2019-10-24 18:11:24 +02:00
# Participants to include in the analysis
2020-06-23 17:33:34 +02:00
# You must create a file for each participant named pXXX containing their device_id. This can be done manually or automatically
2020-09-03 20:18:01 +02:00
PIDS : [ test01]
2019-10-24 22:27:43 +02:00
# Global var with common day segments
DAY_SEGMENTS : &day_segments
2020-09-14 20:21:36 +02:00
TYPE : PERIODIC # FREQUENCY, PERIODIC, EVENT
FILE : "data/external/daysegments_periodic.csv"
2020-09-16 20:54:20 +02:00
INCLUDE_PAST_PERIODIC_SEGMENTS : FALSE # Only relevant if TYPE=PERIODIC, if set to TRUE we consider day segments back enough in the past as to include the first day of data
2020-07-23 03:54:19 +02:00
2019-11-05 21:17:20 +01:00
# Global timezone
2019-11-06 23:12:06 +01:00
# Use codes from https://en.wikipedia.org/wiki/List_of_tz_database_time_zones
# Double check your code, for example EST is not US Eastern Time.
2019-11-05 21:17:20 +01:00
TIMEZONE : &timezone
2019-11-06 23:12:06 +01:00
America/New_York
2019-11-05 21:17:20 +01:00
2020-02-10 22:45:34 +01:00
DATABASE_GROUP : &database_group
2020-03-09 17:55:43 +01:00
MY_GROUP
2020-02-10 22:45:34 +01:00
DOWNLOAD_PARTICIPANTS :
IGNORED_DEVICE_IDS : [ ] # for example "5a1dd68c-6cd1-48fe-ae1e-14344ac5215f"
GROUP : *database_group
2019-10-24 23:27:00 +02:00
# Download data config
DOWNLOAD_DATASET :
2020-02-10 22:45:34 +01:00
GROUP : *database_group
2019-10-24 23:27:00 +02:00
# Readable datetime config
READABLE_DATETIME :
2019-11-05 21:17:20 +01:00
FIXED_TIMEZONE : *timezone
2019-10-24 23:27:00 +02:00
2020-07-09 19:01:50 +02:00
PHONE_VALID_SENSED_BINS :
COMPUTE : False # This flag is automatically ignored (set to True) if you are extracting PHONE_VALID_SENSED_DAYS or screen or Barnett's location features
2020-07-22 22:47:32 +02:00
BIN_SIZE : &bin_size 5 # (in minutes)
2020-10-19 21:07:12 +02:00
# Add as many PHONE sensors as you have, they all improve the computation of PHONE_VALID_SENSED_BINS and PHONE_VALID_SENSED_DAYS.
# If you are extracting screen or Barnett/Doryab location features, PHONE_SCREEN and PHONE_LOCATIONS tables are mandatory.
# You can choose any of the keys shown below, just make sure its DB_TABLE exists in your database!
# PHONE_MESSAGES, PHONE_CALLS, PHONE_LOCATIONS, PHONE_BLUETOOTH, PHONE_ACTIVITY_RECOGNITION, PHONE_BATTERY, PHONE_SCREEN, PHONE_LIGHT,
# PHONE_ACCELEROMETER, PHONE_APPLICATIONS_FOREGROUND, PHONE_WIFI_VISIBLE, PHONE_WIFI_CONNECTED, PHONE_CONVERSATION
PHONE_SENSORS : [ ]
2020-07-09 19:01:50 +02:00
PHONE_VALID_SENSED_DAYS :
COMPUTE : False
2020-07-22 22:47:32 +02:00
MIN_VALID_HOURS_PER_DAY : &min_valid_hours_per_day [ 16 ] # (out of 24) MIN_HOURS_PER_DAY
2020-07-24 18:58:48 +02:00
MIN_VALID_BINS_PER_HOUR : &min_valid_bins_per_hour [ 6 ] # (out of 60min/BIN_SIZE bins)
2020-07-09 19:01:50 +02:00
2020-04-08 22:02:58 +02:00
# Communication SMS features config, TYPES and FEATURES keys need to match
2020-10-19 21:07:12 +02:00
PHONE_MESSAGES :
2020-06-23 17:33:34 +02:00
DB_TABLE : messages
2020-08-31 19:34:15 +02:00
PROVIDERS :
RAPIDS :
COMPUTE : False
MESSAGES_TYPES : [ received, sent]
FEATURES :
received : [ count, distinctcontacts, timefirstmessage, timelastmessage, countmostfrequentcontact]
sent : [ count, distinctcontacts, timefirstmessage, timelastmessage, countmostfrequentcontact]
SRC_LANGUAGE : "r"
2020-10-19 21:07:12 +02:00
SRC_FOLDER : "rapids" # inside src/features/phone_messages
2019-11-06 21:38:08 +01:00
2020-04-08 17:51:18 +02:00
# Communication call features config, TYPES and FEATURES keys need to match
2020-10-19 21:07:12 +02:00
PHONE_CALLS :
2020-06-23 17:33:34 +02:00
DB_TABLE : calls
2020-08-28 23:50:49 +02:00
PROVIDERS :
RAPIDS :
2020-08-31 19:34:15 +02:00
COMPUTE : False
2020-08-28 23:50:49 +02:00
CALL_TYPES : [ missed, incoming, outgoing]
FEATURES :
missed : [ count, distinctcontacts, timefirstcall, timelastcall, countmostfrequentcontact]
incoming : [ count, distinctcontacts, meanduration, sumduration, minduration, maxduration, stdduration, modeduration, entropyduration, timefirstcall, timelastcall, countmostfrequentcontact]
outgoing : [ count, distinctcontacts, meanduration, sumduration, minduration, maxduration, stdduration, modeduration, entropyduration, timefirstcall, timelastcall, countmostfrequentcontact]
SRC_LANGUAGE : "r"
2020-10-19 21:07:12 +02:00
SRC_FOLDER : "rapids" # inside src/features/phone_calls
2019-11-05 18:34:22 +01:00
2020-10-19 21:07:12 +02:00
PHONE_LOCATIONS :
2020-06-23 17:33:34 +02:00
DB_TABLE : locations
2020-08-28 19:53:00 +02:00
LOCATIONS_TO_USE : FUSED_RESAMPLED # ALL, GPS OR FUSED_RESAMPLED
FUSED_RESAMPLED_CONSECUTIVE_THRESHOLD : 30 # minutes, only replicate location samples to the next sensed bin if the phone did not stop collecting data for more than this threshold
FUSED_RESAMPLED_TIME_SINCE_VALID_LOCATION : 720 # minutes, only replicate location samples to consecutive sensed bins if they were logged within this threshold after a valid location row
PROVIDERS :
DORYAB :
2020-08-28 23:50:49 +02:00
COMPUTE : False
2020-08-28 19:53:00 +02:00
FEATURES : [ "locationvariance" , "loglocationvariance" , "totaldistance" , "averagespeed" , "varspeed" , "circadianmovement" , "numberofsignificantplaces" , "numberlocationtransitions" , "radiusgyration" , "timeattop1location" , "timeattop2location" , "timeattop3location" , "movingtostaticratio" , "outlierstimepercent" , "maxlengthstayatclusters" , "minlengthstayatclusters" , "meanlengthstayatclusters" , "stdlengthstayatclusters" , "locationentropy" , "normalizedlocationentropy" ]
DBSCAN_EPS : 10 # meters
DBSCAN_MINSAMPLES : 5
THRESHOLD_STATIC : 1 # km/h
MAXIMUM_GAP_ALLOWED : 300
2020-08-28 23:50:49 +02:00
MINUTES_DATA_USED : False
2020-08-28 19:53:00 +02:00
SAMPLING_FREQUENCY : 0
2020-10-19 21:07:12 +02:00
SRC_FOLDER : "doryab" # inside src/features/phone_locations
2020-08-28 19:53:00 +02:00
SRC_LANGUAGE : "python"
BARNETT :
2020-08-28 23:50:49 +02:00
COMPUTE : False
2020-08-28 19:53:00 +02:00
FEATURES : [ "hometime" , "disttravelled" , "rog" , "maxdiam" , "maxhomedist" , "siglocsvisited" , "avgflightlen" , "stdflightlen" , "avgflightdur" , "stdflightdur" , "probpause" , "siglocentropy" , "circdnrtn" , "wkenddayrtn" ]
ACCURACY_LIMIT : 51 # meters, drops location coordinates with an accuracy higher than this. This number means there's a 68% probability the true location is within this radius
TIMEZONE : *timezone
2020-08-28 23:50:49 +02:00
MINUTES_DATA_USED : False # Use this for quality control purposes, how many minutes of data (location coordinates gruped by minute) were used to compute features
2020-10-19 21:07:12 +02:00
SRC_FOLDER : "barnett" # inside src/features/phone_locations
2020-08-28 19:53:00 +02:00
SRC_LANGUAGE : "r"
2020-07-16 20:26:43 +02:00
2020-10-19 21:07:12 +02:00
PHONE_BLUETOOTH :
2020-06-23 17:33:34 +02:00
DB_TABLE : bluetooth
2020-08-31 23:08:26 +02:00
PROVIDERS :
RAPIDS :
COMPUTE : False
FEATURES : [ "countscans" , "uniquedevices" , "countscansmostuniquedevice" ]
2020-10-19 21:07:12 +02:00
SRC_FOLDER : "rapids" # inside src/features/phone_bluetooth
2020-08-31 23:08:26 +02:00
SRC_LANGUAGE : "r"
2019-11-18 20:22:08 +01:00
2020-10-19 21:07:12 +02:00
PHONE_ACTIVITY_RECOGNITION :
2020-06-23 17:33:34 +02:00
DB_TABLE :
ANDROID : plugin_google_activity_recognition
IOS : plugin_ios_activity_recognition
2020-10-08 00:11:06 +02:00
PROVIDERS :
RAPIDS :
COMPUTE : False
FEATURES : [ "count" , "mostcommonactivity" , "countuniqueactivities" , "durationstationary" , "durationmobile" , "durationvehicle" ]
ACTIVITY_CLASSES :
STATIONARY : [ "still" , "tilting" ]
MOBILE : [ "on_foot" , "walking" , "running" , "on_bicycle" ]
VEHICLE : [ "in_vehicle" ]
2020-10-19 21:07:12 +02:00
SRC_FOLDER : "rapids" # inside src/features/phone_activity_recognition
2020-10-08 00:11:06 +02:00
SRC_LANGUAGE : "python"
2019-11-25 18:53:32 +01:00
2020-10-19 21:07:12 +02:00
PHONE_BATTERY :
2020-06-23 17:33:34 +02:00
DB_TABLE : battery
2020-09-29 23:13:34 +02:00
PROVIDERS :
RAPIDS :
COMPUTE : False
FEATURES : [ "countdischarge" , "sumdurationdischarge" , "countcharge" , "sumdurationcharge" , "avgconsumptionrate" , "maxconsumptionrate" ]
2020-10-19 21:07:12 +02:00
SRC_FOLDER : "rapids" # inside src/features/phone_battery
2020-09-29 23:13:34 +02:00
SRC_LANGUAGE : "python"
2019-11-27 20:25:17 +01:00
2020-10-19 21:07:12 +02:00
PHONE_SCREEN :
2020-06-23 17:33:34 +02:00
DB_TABLE : screen
2020-09-19 02:25:29 +02:00
PROVIDERS :
RAPIDS :
COMPUTE : False
REFERENCE_HOUR_FIRST_USE : 0
IGNORE_EPISODES_SHORTER_THAN : 0 # in minutes, set to 0 to disable
IGNORE_EPISODES_LONGER_THAN : 0 # in minutes, set to 0 to disable
FEATURES : [ "countepisode" , "sumduration" , "maxduration" , "minduration" , "avgduration" , "stdduration" , "firstuseafter" ] # "episodepersensedminutes" needs to be added later
EPISODE_TYPES : [ "unlock" ]
2020-10-19 21:07:12 +02:00
SRC_FOLDER : "rapids" # inside src/features/phone_screen
2020-09-19 02:25:29 +02:00
SRC_LANGUAGE : "python"
2020-01-14 15:51:39 +01:00
2020-10-19 21:07:12 +02:00
PHONE_LIGHT :
2020-06-23 17:33:34 +02:00
DB_TABLE : light
2020-09-01 18:01:24 +02:00
PROVIDERS :
RAPIDS :
2020-09-03 20:36:42 +02:00
COMPUTE : False
2020-09-01 18:01:24 +02:00
FEATURES : [ "count" , "maxlux" , "minlux" , "avglux" , "medianlux" , "stdlux" ]
2020-10-19 21:07:12 +02:00
SRC_FOLDER : "rapids" # inside src/features/phone_light
2020-09-01 18:01:24 +02:00
SRC_LANGUAGE : "python"
2020-10-19 21:07:12 +02:00
PHONE_ACCELEROMETER :
2020-06-23 17:33:34 +02:00
DB_TABLE : accelerometer
2020-10-13 17:42:36 +02:00
PROVIDERS :
RAPIDS :
COMPUTE : False
FEATURES : [ "maxmagnitude" , "minmagnitude" , "avgmagnitude" , "medianmagnitude" , "stdmagnitude" ]
2020-10-19 21:07:12 +02:00
SRC_FOLDER : "rapids" # inside src/features/phone_accelerometer
2020-10-13 17:42:36 +02:00
SRC_LANGUAGE : "python"
2020-10-13 23:54:53 +02:00
PANDA :
COMPUTE : False
VALID_SENSED_MINUTES : False
FEATURES :
exertional_activity_episode : [ "sumduration" , "maxduration" , "minduration" , "avgduration" , "medianduration" , "stdduration" ]
nonexertional_activity_episode : [ "sumduration" , "maxduration" , "minduration" , "avgduration" , "medianduration" , "stdduration" ]
2020-10-19 21:07:12 +02:00
SRC_FOLDER : "panda" # inside src/features/phone_accelerometer
2020-10-13 23:54:53 +02:00
SRC_LANGUAGE : "python"
2020-01-29 22:22:53 +01:00
2020-10-19 21:07:12 +02:00
PHONE_APPLICATIONS_FOREGROUND :
2020-06-23 17:33:34 +02:00
DB_TABLE : applications_foreground
2020-10-19 21:07:12 +02:00
APPLICATION_CATEGORIES :
CATALOGUE_SOURCE : FILE # FILE (genres are read from CATALOGUE_FILE) or GOOGLE (genres are scrapped from the Play Store)
CATALOGUE_FILE : "data/external/stachl_application_genre_catalogue.csv"
UPDATE_CATALOGUE_FILE : False # if CATALOGUE_SOURCE is equal to FILE, whether or not to update CATALOGUE_FILE, if CATALOGUE_SOURCE is equal to GOOGLE all scraped genres will be saved to CATALOGUE_FILE
SCRAPE_MISSING_CATEGORIES : False # whether or not to scrape missing genres, only effective if CATALOGUE_SOURCE is equal to FILE. If CATALOGUE_SOURCE is equal to GOOGLE, all genres are scraped anyway
2020-09-01 21:25:35 +02:00
PROVIDERS :
RAPIDS :
2020-09-03 20:36:42 +02:00
COMPUTE : False
2020-09-01 21:25:35 +02:00
SINGLE_CATEGORIES : [ "all" , "email" ]
MULTIPLE_CATEGORIES :
social : [ "socialnetworks" , "socialmediatools" ]
entertainment : [ "entertainment" , "gamingknowledge" , "gamingcasual" , "gamingadventure" , "gamingstrategy" , "gamingtoolscommunity" , "gamingroleplaying" , "gamingaction" , "gaminglogic" , "gamingsports" , "gamingsimulation" ]
SINGLE_APPS : [ "top1global" , "com.facebook.moments" , "com.google.android.youtube" , "com.twitter.android" ] # There's no entropy for single apps
EXCLUDED_CATEGORIES : [ ]
EXCLUDED_APPS : [ "com.fitbit.FitbitMobile" , "com.aware.plugin.upmc.cancer" ]
FEATURES : [ "count" , "timeoffirstuse" , "timeoflastuse" , "frequencyentropy" ]
2020-10-19 21:07:12 +02:00
SRC_FOLDER : "rapids" # inside src/features/phone_applications_foreground
2020-09-01 21:25:35 +02:00
SRC_LANGUAGE : "python"
2020-02-07 17:52:55 +01:00
2020-10-19 21:07:12 +02:00
PHONE_WIFI_VISIBLE :
DB_TABLE : "wifi"
PROVIDERS :
RAPIDS :
COMPUTE : False
FEATURES : [ "countscans" , "uniquedevices" , "countscansmostuniquedevice" ]
SRC_FOLDER : "rapids" # inside src/features/phone_wifi_visible
SRC_LANGUAGE : "r"
PHONE_WIFI_CONNECTED :
DB_TABLE : "sensor_wifi"
PROVIDERS :
RAPIDS :
COMPUTE : False
FEATURES : [ "countscans" , "uniquedevices" , "countscansmostuniquedevice" ]
SRC_FOLDER : "rapids" # inside src/features/phone_wifi_connected
SRC_LANGUAGE : "r"
PHONE_CONVERSATION :
DB_TABLE :
ANDROID : plugin_studentlife_audio_android
IOS : plugin_studentlife_audio
PROVIDERS :
RAPIDS :
COMPUTE : False
FEATURES : [ "minutessilence" , "minutesnoise" , "minutesvoice" , "minutesunknown" , "sumconversationduration" , "avgconversationduration" ,
"sdconversationduration" , "minconversationduration" , "maxconversationduration" , "timefirstconversation" , "timelastconversation" , "sumenergy" ,
"avgenergy" , "sdenergy" , "minenergy" , "maxenergy" , "silencesensedfraction" , "noisesensedfraction" ,
"voicesensedfraction" , "unknownsensedfraction" , "silenceexpectedfraction" , "noiseexpectedfraction" , "voiceexpectedfraction" ,
"unknownexpectedfraction" , "countconversation" ]
RECORDING_MINUTES : 1
PAUSED_MINUTES : 3
SRC_FOLDER : "rapids" # inside src/features/phone_conversation
SRC_LANGUAGE : "python"
2020-02-07 17:35:15 +01:00
HEARTRATE :
2020-06-23 17:33:34 +02:00
COMPUTE : False
DB_TABLE : fitbit_data
2020-02-07 17:35:15 +01:00
DAY_SEGMENTS : *day_segments
2020-06-23 17:33:34 +02:00
SUMMARY_FEATURES : [ "restinghr" ] # calories features' accuracy depend on the accuracy of the participants fitbit profile (e.g. heigh, weight) use with care : [ "caloriesoutofrange" , "caloriesfatburn" , "caloriescardio" , "caloriespeak" ]
2020-06-22 20:15:56 +02:00
INTRADAY_FEATURES : [ "maxhr" , "minhr" , "avghr" , "medianhr" , "modehr" , "stdhr" , "diffmaxmodehr" , "diffminmodehr" , "entropyhr" , "minutesonoutofrangezone" , "minutesonfatburnzone" , "minutesoncardiozone" , "minutesonpeakzone" ]
2020-02-07 17:35:15 +01:00
2020-01-29 22:22:53 +01:00
STEP :
2020-06-23 17:33:34 +02:00
COMPUTE : False
DB_TABLE : fitbit_data
2020-01-29 22:22:53 +01:00
DAY_SEGMENTS : *day_segments
2020-06-24 19:33:58 +02:00
EXCLUDE_SLEEP :
2020-06-24 19:40:15 +02:00
EXCLUDE : False
2020-06-24 19:33:58 +02:00
TYPE : FIXED # FIXED OR FITBIT_BASED (CONFIGURE FITBIT's SLEEP DB_TABLE)
FIXED :
START : "23:00"
END : "07:00"
2020-04-03 23:03:45 +02:00
FEATURES :
2020-01-29 22:22:53 +01:00
ALL_STEPS : [ "sumallsteps" , "maxallsteps" , "minallsteps" , "avgallsteps" , "stdallsteps" ]
2020-06-26 23:33:30 +02:00
SEDENTARY_BOUT : [ "countepisode" , "sumduration" , "maxduration" , "minduration" , "avgduration" , "stdduration" ]
ACTIVE_BOUT : [ "countepisode" , "sumduration" , "maxduration" , "minduration" , "avgduration" , "stdduration" ]
2020-02-10 22:45:34 +01:00
THRESHOLD_ACTIVE_BOUT : 10 # steps
2020-06-26 23:33:30 +02:00
INCLUDE_ZERO_STEP_ROWS : False
2020-03-09 18:32:14 +01:00
2020-05-15 23:51:00 +02:00
SLEEP :
2020-06-23 17:33:34 +02:00
COMPUTE : False
DB_TABLE : fitbit_data
2020-05-15 23:51:00 +02:00
DAY_SEGMENTS : *day_segments
SLEEP_TYPES : [ "main" , "nap" , "all" ]
2020-06-13 00:44:05 +02:00
SUMMARY_FEATURES : [ "sumdurationafterwakeup" , "sumdurationasleep" , "sumdurationawake" , "sumdurationtofallasleep" , "sumdurationinbed" , "avgefficiency" , "countepisode" ]
2020-05-15 23:51:00 +02:00
2020-07-22 22:47:32 +02:00
### Visualizations ################################################################
HEATMAP_FEATURES_CORRELATIONS :
PLOT : False
MIN_ROWS_RATIO : 0.5
MIN_VALID_HOURS_PER_DAY : *min_valid_hours_per_day
2020-07-27 02:11:25 +02:00
MIN_VALID_BINS_PER_HOUR : *min_valid_bins_per_hour
2020-07-22 22:47:32 +02:00
PHONE_FEATURES : [ accelerometer, activity_recognition, applications_foreground, battery, calls_incoming, calls_missed, calls_outgoing, conversation, light, location_doryab, messages_received, messages_sent, screen]
FITBIT_FEATURES : [ fitbit_heartrate, fitbit_step, fitbit_sleep]
CORR_THRESHOLD : 0.1
2020-07-23 02:00:14 +02:00
CORR_METHOD : "pearson" # choose from {"pearson", "kendall", "spearman"}
2020-07-22 22:47:32 +02:00
HISTOGRAM_VALID_SENSED_HOURS :
PLOT : False
MIN_VALID_HOURS_PER_DAY : *min_valid_hours_per_day
2020-07-27 02:11:25 +02:00
MIN_VALID_BINS_PER_HOUR : *min_valid_bins_per_hour
2020-07-22 22:47:32 +02:00
HEATMAP_DAYS_BY_SENSORS :
PLOT : False
MIN_VALID_HOURS_PER_DAY : *min_valid_hours_per_day
2020-07-27 02:11:25 +02:00
MIN_VALID_BINS_PER_HOUR : *min_valid_bins_per_hour
2020-07-22 22:47:32 +02:00
EXPECTED_NUM_OF_DAYS : -1
2020-08-03 21:19:45 +02:00
DB_TABLES : [ accelerometer, applications_foreground, battery, bluetooth, calls, light, locations, messages, screen, wifi, sensor_wifi, plugin_google_activity_recognition, plugin_ios_activity_recognition, plugin_studentlife_audio_android, plugin_studentlife_audio]
2020-07-22 22:47:32 +02:00
HEATMAP_SENSED_BINS :
PLOT : False
BIN_SIZE : *bin_size
OVERALL_COMPLIANCE_HEATMAP :
PLOT : False
2020-07-24 18:58:48 +02:00
ONLY_SHOW_VALID_DAYS : False
EXPECTED_NUM_OF_DAYS : -1
2020-07-22 22:47:32 +02:00
BIN_SIZE : *bin_size
MIN_VALID_HOURS_PER_DAY : *min_valid_hours_per_day
2020-07-27 02:11:25 +02:00
MIN_VALID_BINS_PER_HOUR : *min_valid_bins_per_hour
2020-07-22 22:47:32 +02:00