Skip to content

Commit

Permalink
Merge branch 'develop' into joannakennedyharvard-documentation-oak
Browse files Browse the repository at this point in the history
  • Loading branch information
clementzach authored Nov 4, 2023
2 parents 1d91329 + fcc49a7 commit e24ec1e
Show file tree
Hide file tree
Showing 11 changed files with 133 additions and 145 deletions.
4 changes: 0 additions & 4 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,7 @@
name: 'Build and test'

on:
pull_request:
push:
paths-ignore:
- 'docs/**'
- 'CITATION.cff'
workflow_dispatch:

jobs:
Expand Down
3 changes: 0 additions & 3 deletions .github/workflows/docs.yml
Original file line number Diff line number Diff line change
@@ -1,10 +1,7 @@
name: Sphinx documentation

on:
pull_request:
push:
paths:
- 'docs/**'
workflow_dispatch:

jobs:
Expand Down
115 changes: 55 additions & 60 deletions forest/bonsai/tests/test_simulate_gps_data.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@
ActionType, Attributes, Person, gen_basic_traj, gen_basic_pause,
gen_route_traj, gen_all_traj, remove_data, prepare_data,
process_switches, load_attributes, sim_gps_data
)
)
from forest.jasmine.data2mobmat import great_circle_dist


Expand Down Expand Up @@ -282,7 +282,7 @@ def test_get_path_close_locations(coords1, coords3):
== 2)


@pytest.fixture
@pytest.fixture()
def random_path(directions1, coords1, coords2):
lat1, lon1 = coords1
lat2, lon2 = coords2
Expand Down Expand Up @@ -352,7 +352,8 @@ def test_bounding_box_simple_case(sample_coordinates):

def test_zero_meters_bounding_box(sample_coordinates):
bbox = bounding_box(sample_coordinates, 0)
assert bbox[0] == bbox[2] and bbox[1] == bbox[3]
assert bbox[0] == bbox[2]
assert bbox[1] == bbox[3]


@pytest.fixture(scope="session")
Expand Down Expand Up @@ -423,32 +424,27 @@ def sample_locations():
def sample_attributes():
"""Sample attributes"""
return {
"User 1":
{
"main_employment": "none",
"vehicle": "car",
"travelling_status": 10,
"active_status": 0
},

"Users 2-4":
{
"main_employment": "university",
"vehicle": "bicycle",
"travelling_status": 8,
"active_status": 8,
"active_status-16": 2
},

"User 5":
{
"main_employment": "office",
"vehicle": "foot",
"travelling_status": 9,
"travelling_status-20": 1,
"preferred_places": ["cafe", "bar", "cinema"]
}
"User 1": {
"main_employment": "none",
"vehicle": "car",
"travelling_status": 10,
"active_status": 0
},
"Users 2-4": {
"main_employment": "university",
"vehicle": "bicycle",
"travelling_status": 8,
"active_status": 8,
"active_status-16": 2
},
"User 5": {
"main_employment": "office",
"vehicle": "foot",
"travelling_status": 9,
"travelling_status-20": 1,
"preferred_places": ["cafe", "bar", "cinema"]
}
}


def test_attributes_user_missing_args(sample_attributes):
Expand All @@ -462,12 +458,10 @@ def test_process_attributes_arguments_correct(sample_attributes):
"""Test that given arguments are processed correctly"""
user_attrs = sample_attributes["User 5"]
attrs = Attributes(**user_attrs)
assert (
attrs.travelling_status == 9
and attrs.preferred_places == [
PossibleExits.CAFE, PossibleExits.BAR, PossibleExits.CINEMA
]
)
assert attrs.travelling_status == 9
assert attrs.preferred_places == [
PossibleExits.CAFE, PossibleExits.BAR, PossibleExits.CINEMA
]


def test_person_main_employment(sample_coordinates, sample_locations,
Expand Down Expand Up @@ -535,7 +529,7 @@ def test_update_preferred_places_case_first_option(sample_person):
sample_person.update_preferred_places(PossibleExits.CAFE)
assert sample_person.preferred_places_today == [
PossibleExits.BAR, PossibleExits.CAFE, PossibleExits.CINEMA
]
]


def test_update_preferred_places_case_last_option(sample_person):
Expand All @@ -547,17 +541,17 @@ def test_update_preferred_places_case_last_option(sample_person):
def test_choose_preferred_exit_morning_home(sample_person):
"""Test choosing preferred exit early in the morning"""
preferred_exit, location = sample_person.choose_preferred_exit(0)
assert (preferred_exit == "home"
and location == sample_person.home_coordinates)
assert preferred_exit == "home"
assert location == sample_person.home_coordinates


def test_choose_preferred_exit_night_home(sample_person):
"""Test choosing preferred exit late in the night"""
preferred_exit, location = sample_person.choose_preferred_exit(
24 * 3600 - 1
)
assert (preferred_exit == "home_night"
and location == sample_person.home_coordinates)
assert preferred_exit == "home_night"
assert location == sample_person.home_coordinates


def test_choose_preferred_exit_random_exit(sample_person):
Expand Down Expand Up @@ -669,7 +663,7 @@ def test_gen_basic_traj_distance(random_path):
"""Test basic trajectory generation distance"""
_, dist = gen_basic_traj(
random_path[0], random_path[-1], Vehicle.FOOT, 100
)
)
assert dist == great_circle_dist(*random_path[0], *random_path[-1])[0]


Expand Down Expand Up @@ -705,7 +699,8 @@ def test_gen_basic_pause_t_diff_range(random_path):
def test_gen_route_traj_shape(random_path):
"""Test route generation shape is correct"""
traj, _ = gen_route_traj(random_path, Vehicle.CAR, 0)
assert traj.shape[1] == 3 and traj.shape[0] >= len(random_path)
assert traj.shape[1] == 3
assert traj.shape[0] >= len(random_path)


def test_gen_route_traj_distance(random_path):
Expand Down Expand Up @@ -735,7 +730,7 @@ def test_gen_all_traj_len(sample_person, mocker):
start_date=datetime.date(2021, 10, 1),
end_date=datetime.date(2021, 10, 5),
api_key="mock_api_key",
)
)
assert traj.shape[0] == 4 * 24 * 3600


Expand All @@ -749,7 +744,7 @@ def test_gen_all_traj_time(sample_person, mocker):
start_date=datetime.date(2021, 10, 1),
end_date=datetime.date(2021, 10, 5),
api_key="mock_api_key",
)
)
assert np.all(np.diff(traj[:, 0]) > 0)


Expand All @@ -764,7 +759,7 @@ def test_gen_all_traj_consistent_values(sample_person, mocker):
start_date=datetime.date(2021, 10, 1),
end_date=datetime.date(2021, 10, 5),
api_key="mock_api_key",
)
)

distances = []
for i in range(len(traj) - 1):
Expand All @@ -786,10 +781,11 @@ def test_gen_all_traj_time_at_home(sample_person, mocker):
start_date=datetime.date(2021, 10, 1),
end_date=datetime.date(2021, 10, 5),
api_key="mock_api_key",
)
)

home_time_list = np.array(home_time_list)
assert np.all(home_time_list >= 0) and np.all(home_time_list <= 24 * 3600)
assert np.all(home_time_list >= 0)
assert np.all(home_time_list <= 24 * 3600)


def test_gen_all_traj_dist_travelled(sample_person, mocker):
Expand All @@ -803,7 +799,7 @@ def test_gen_all_traj_dist_travelled(sample_person, mocker):
start_date=datetime.date(2021, 10, 1),
end_date=datetime.date(2021, 10, 5),
api_key="mock_api_key",
)
)
total_d_list = np.array(total_d_list)
assert np.all(total_d_list >= 0)

Expand All @@ -819,7 +815,7 @@ def generated_trajectory(sample_person, mocker):
start_date=datetime.date(2021, 10, 1),
end_date=datetime.date(2021, 10, 5),
api_key="mock_api_key",
)
)
return traj


Expand All @@ -833,7 +829,8 @@ def test_prepare_data_shape(generated_trajectory):
"""Test shape of prepared dataset"""
obs_data = remove_data(generated_trajectory, 15, .8, 4)
final_data = prepare_data(obs_data, 0, "UTC")
assert final_data.shape[0] == len(obs_data) and final_data.shape[1] == 6
assert final_data.shape[0] == len(obs_data)
assert final_data.shape[1] == 6


def test_prepare_data_timezones(generated_trajectory):
Expand All @@ -842,18 +839,16 @@ def test_prepare_data_timezones(generated_trajectory):
final_data = prepare_data(obs_data, 0, "Etc/GMT+1")
boolean_series = (
final_data['timestamp'] == final_data['UTC time'] + 3600000
)
)
assert sum(boolean_series) == len(boolean_series)


def test_process_switches(sample_attributes):
"""Test processing attributes with switch of behavior"""
key = "User 5"
switches = process_switches(sample_attributes, key)
assert (
list(switches.keys())[0] == "travelling_status-20"
and list(switches.values())[0] == 1
)
assert list(switches.keys())[0] == "travelling_status-20"
assert list(switches.values())[0] == 1


def test_load_attributes_nusers(sample_attributes):
Expand Down Expand Up @@ -912,13 +907,13 @@ def sample_addresses():
'addr:street': 'Cambridge Crescent'
}
},
],
],
dtype=object
)


def test_sim_gps_data_times(
sample_addresses, sample_locations, sample_attributes, mocker
sample_addresses, sample_locations, sample_attributes, mocker
):
"""Test timestamp of simulated trajectories"""
mocker.patch("forest.bonsai.simulate_gps_data.get_path",
Expand All @@ -936,17 +931,17 @@ def test_sim_gps_data_times(
cycle=15,
percentage=.8,
attributes_dict=sample_attributes,
)
)
list_of_time_differences = []
for i in range(1, data.shape[0]):
list_of_time_differences.append(
data.timestamp[i] - data.timestamp[i-1]
data.timestamp[i] - data.timestamp[i - 1]
)
assert np.all(np.array(list_of_time_differences) > 0)


def test_sim_gps_data_multiple_people(
sample_addresses, sample_locations, sample_attributes, mocker
sample_addresses, sample_locations, sample_attributes, mocker
):
"""Test timestamp of simulated trajectories"""
mocker.patch("forest.bonsai.simulate_gps_data.get_path",
Expand All @@ -964,5 +959,5 @@ def test_sim_gps_data_multiple_people(
cycle=15,
percentage=.8,
attributes_dict=sample_attributes,
)
)
assert len(np.unique(data.user)) == 3
8 changes: 5 additions & 3 deletions forest/oak/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
import logging
import math
import os
from typing import Optional

from dateutil import tz
import numpy as np
Expand Down Expand Up @@ -418,9 +419,10 @@ def find_continuous_dominant_peaks(valid_peaks: np.ndarray, min_t: int,
return cont_peaks[:, :-1]


def run(study_folder: str, output_folder: str, tz_str: str = None,
frequency: Frequency = Frequency.DAILY, time_start: str = None,
time_end: str = None, users: list = None) -> None:
def run(study_folder: str, output_folder: str, tz_str: Optional[str] = None,
frequency: Frequency = Frequency.DAILY,
time_start: Optional[str] = None, time_end: Optional[str] = None,
users: Optional[list] = None) -> None:
"""Runs walking recognition and step counting algorithm over dataset.
Determine paths to input and output folders, set analysis time frames,
Expand Down
28 changes: 14 additions & 14 deletions forest/poplar/tests/test_poplar_functions.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,31 +29,31 @@ def test_datetime2stamp():


def test_datetime2stamp_bad_seconds():
with pytest.raises(ValueError):
with pytest.raises(ValueError, match="second must be in 0..59"):
datetime2stamp(time_list=[2020, 11, 1, 12, 9, 150],
tz_str="America/New_York")


def test_datetime2stamp_bad_minutes():
with pytest.raises(ValueError):
with pytest.raises(ValueError, match="minute must be in 0..59"):
datetime2stamp(time_list=[2020, 11, 1, 12, 209, 50],
tz_str="America/New_York")


def test_datetime2stamp_bad_hours():
with pytest.raises(ValueError):
with pytest.raises(ValueError, match="hour must be in 0..23"):
datetime2stamp(time_list=[2020, 11, 1, 35, 20, 50],
tz_str="America/New_York")


def test_datetime2stamp_bad_days():
with pytest.raises(ValueError):
with pytest.raises(ValueError, match="day is out of range for month"):
datetime2stamp(time_list=[2020, 11, 35, 5, 20, 50],
tz_str="America/New_York")


def test_datetime2stamp_bad_months():
with pytest.raises(ValueError):
with pytest.raises(ValueError, match="month must be in 1..12"):
datetime2stamp(time_list=[2020, 15, 20, 5, 20, 50],
tz_str="America/New_York")

Expand Down Expand Up @@ -119,19 +119,19 @@ def test_get_files_timestamps():
file_list, timestamp_list = get_files_timestamps(
os.path.join(TEST_DATA_DIR, "idr8gqdh", "gps")
)

assert np.array_equal(file_list, np.array(
['2021-12-15 01_00_00+00_00.csv', '2021-12-16 21_00_00+00_00.csv',
'2021-12-17 00_00_00+00_00.csv']
))
assert np.array_equal(timestamp_list, np.array(
[1639530000, 1639688400, 1639699200]
))
assert np.array_equal(
file_list, np.array(['2021-12-15 01_00_00+00_00.csv',
'2021-12-16 21_00_00+00_00.csv',
'2021-12-17 00_00_00+00_00.csv'])
)
assert np.array_equal(
timestamp_list, np.array([1639530000, 1639688400, 1639699200])
)

# Testing functions in forest.poplar.functions.helpers


@pytest.fixture
@pytest.fixture()
def gps_df():
return read_data("idr8gqdh", TEST_DATA_DIR, "gps", "America/New_York",
time_start=[2021, 12, 15, 20, 9, 50],
Expand Down
Loading

0 comments on commit e24ec1e

Please sign in to comment.