forked from BDI-pathogens/OpenABM-Covid19
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathparams.h
331 lines (279 loc) · 20.7 KB
/
params.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
/*
* params.h
*
* Created on: 5 Mar 2020
* Author: hinchr
*/
#ifndef PARAMS_H_
#define PARAMS_H_
#include "constant.h"
#include "structure.h"
/************************************************************************/
/****************************** Structures *****************************/
/************************************************************************/
typedef struct{
long rng_seed; // number used to seed the GSL RNG
char input_param_file[INPUT_CHAR_LEN]; // path to input parameter file
char hospital_input_param_file[INPUT_CHAR_LEN]; // path to input parameter file
char input_household_file[INPUT_CHAR_LEN]; //path to input household demographics file
char output_file_dir[INPUT_CHAR_LEN]; // path to output directory
int param_line_number; // line number to be read from parameter file
int hospital_param_line_number; // line number to be read from parameter file
long param_id; // id of the parameter set
long n_total; // total number of people
int days_of_interactions; // the number of days of interactions to keep
int end_time; // maximum end time
int n_seed_infection; // number of people seeded with the infections
double new_seed_infection_rate; // number of new seed infections added each day (can be fractional)
int rebuild_networks; // should net works be rebuilt every time step or just on parameter changes
double mean_random_interactions[N_AGE_TYPES]; // mean number of random interactions each day
double sd_random_interactions[N_AGE_TYPES]; // sd number of random interactions each day
int random_interaction_distribution; // distribution from which each person random interactions are drawn
double mean_work_interactions[N_DEFAULT_OCCUPATION_NETWORKS];// mean number of regular work interactions
double daily_fraction_work; // fraction of daily work interactions without social-distancing
double child_network_adults; // fraction of adults in the child network
double elderly_network_adults; // fraction of adults in the elderly network
double work_network_rewire; // rewire parameter on the Watts-Strogatz work networks
double mean_infectious_period; // mean period in days that people are infectious
double sd_infectious_period; // sd of period in days that people are infectious
double infectious_rate; // mean total number of people infected for a mean person
double sd_infectiousness_multiplier; // sd of the lognormal used to vary the infectiousness of an individual
double relative_susceptibility[N_AGE_GROUPS]; // relative susceptibility of an age group
double adjusted_susceptibility[N_AGE_GROUPS]; // adjusted susceptibility of an age group (normalising for interactions)
int relative_susceptibility_by_interaction; // is relative susceptibility adjusted per interaction, or per day
double relative_transmission[N_INTERACTION_TYPES]; // relative transmission rate by the type of interactions (e.g. household/workplace/random) w/o social distance
double relative_transmission_used[N_INTERACTION_TYPES]; // relative transmission rate by the type of interactions (e.g. household/workplace/random)
double mean_time_to_symptoms; // mean time from infection to symptoms
double sd_time_to_symptoms; // sd time from infection to symptoms
double hospitalised_fraction[N_AGE_GROUPS]; // fraction of symptomatic patients requiring hospitalisation
double critical_fraction[N_AGE_GROUPS]; // fraction of hospitalised patients who require ICU treatment
double fatality_fraction[N_AGE_GROUPS]; // fraction of ICU patients who die
double mean_time_to_hospital; // mean time from symptoms to hospital
double mean_time_to_critical; // mean time from hospitalised to critical care
double sd_time_to_critical; // sd time from hospitalised to critical care
double mean_time_to_recover; // mean time to recovery if hospitalisation is not required (days)
double sd_time_to_recover; // sd time to recovery if hospitalisation is not required (days)
double mean_time_to_death; // mean time to death after hospital
double sd_time_to_death; // sd time to death after hospital
double mean_time_to_susceptible_after_shift; // mean time to susceptible after recovered (and after a fixed period of time_to_susceptible_shift)
int time_to_susceptible_shift; // Fixed number of days individuals are immune until waning immunity begins
double household_size[N_HOUSEHOLD_MAX];// ONS UK number of households with 1-6 person (in thousands)
double population[N_AGE_GROUPS]; // ONS stratification of population (in millions)
double fraction_asymptomatic[N_AGE_GROUPS]; // faction who are asymptomatic
double asymptomatic_infectious_factor; // relative infectiousness of asymptomatics
double mild_fraction[N_AGE_GROUPS]; // faction who just have mild symptoms
double mild_infectious_factor; // relative infectiousness of people with mild symptoms
double mean_asymptomatic_to_recovery; // mean time to recovery for asymptomatics
double sd_asymptomatic_to_recovery; // sd of time to recovery for asymptomatics
double mean_time_hospitalised_recovery; // mean time to recover if hospitalised
double sd_time_hospitalised_recovery; // sd time to recover if hospitalised
double mean_time_critical_survive; // mean time to survive if critical
double sd_time_critical_survive; // sd time to survive if critical
double location_death_icu[N_AGE_GROUPS];// whether death occurs in the ICU or outside
int quarantined_daily_interactions; // number of interactions a quarantined person has
int hospitalised_daily_interactions; // number of interactions a hopsitalised person has
int quarantine_days; // number of days of previous contacts to quarantine
double self_quarantine_fraction; // fraction of people who self-quarantine when show symptoms
int manual_trace_on; // manual contract trace
int manual_trace_time_on; // time at which manual contact tracing begins
int manual_trace_on_hospitalization; // manual contract trace on hospitalization
int manual_trace_on_positive; // manual contract trace on positive result
int manual_trace_delay; // delay in starting manual trace
int manual_trace_exclude_app_users; // exclude app users from manual contact tracing
int manual_trace_n_workers; // number of workers who can perform manual contact tracing
int manual_trace_interviews_per_worker_day; // number of manual tracing index case interviews that can be made per day
int manual_trace_notifications_per_worker_day; // number of manual tracing trace notifications that can be made per day
double manual_traceable_fraction[N_INTERACTION_TYPES]; // the proportion of interactions which are manually traceable for the interaction types (house/work/random)
int trace_on_symptoms; // contract trace on symptoms
int trace_on_positive; // contract trace on positive result
int retrace_on_positive; // repeat contract tracing on a positive test if already tested on symptoms
int quarantine_length_self; // max length of quarantine if self-quarantine on symptoms
int quarantine_length_traced_symptoms; // max length of quarantine if contact-traced from a index case with only symptoms
int quarantine_length_traced_positive; // max length of quarantine if contact-traced from a index case with a positive test
int quarantine_length_positive; // max length of quarantine if receive positive test result
double quarantine_dropout_self; // daily dropout rate if self-quarantined
double quarantine_dropout_traced_symptoms; // daily dropout rate if contact-traced from a index case with only symptoms
double quarantine_dropout_traced_positive; // daily dropout rate if contact-traced rom a index case with a positive test
double quarantine_dropout_positive; // daily dropout rate if receive positive test result
double quarantine_compliance_traced_symptoms; // probability that someone complies with a amber quarantine message
double quarantine_compliance_traced_positive; // probability that someone complies with a red quarantine message
int quarantine_on_traced; // immediately quarantine those who are contact traced
int quarantine_smart_release_day; // number of days until smart release on no contacts
double traceable_interaction_fraction; // the proportion of interactions which are traceable even if both users have app
int tracing_network_depth; // the number of layers in the interaction network to recursively trace
int allow_clinical_diagnosis; // allow a hospital clinical diagnosis to trigger interventions
int quarantine_household_on_symptoms; // quarantine other household members when someone shows symptoms
int quarantine_household_on_positive; // quarantine other household members when someone tests positive
int quarantine_household_on_traced_symptoms; // quarantine other household members when someone is contact traced and index has symptoms
int quarantine_household_on_traced_positive; // quarantine other household members when someone is contact traced and index is positive
int quarantine_household_contacts_on_positive; // quarantine the contacts of other household members when someone tests positive
int quarantine_household_contacts_on_symptoms; // quarantine the contacts of other household members when someone gets symptoms
int test_on_symptoms; // carry out a test on those with symptoms
int test_on_traced; // carry out a test on those with positive test results
int test_result_wait; // number of days to wait for a test result
int test_order_wait; // minimum number of days to wait for a test to be taken
int test_result_wait_priority; // number of days to wait for a priority test result
int test_order_wait_priority; // minimum number of days to wait for a priority test to be taken
int test_release_on_negative; // release on a negative test result
int priority_test_contacts[N_AGE_GROUPS]; // number of contacts that triggers priority test
int test_insensitive_period; // number of days until a test is sensitive (delay test of recent contacts)
int test_sensitive_period; // number of days post infection in which the test is sensitive
double test_sensitivity; // sensitivity of test
double test_specificity; // specificity of test
double app_users_fraction[N_AGE_GROUPS];// Proportion of the population that use the app by age
int app_turned_on; // is the app turned on
int app_turn_on_time; // time after which the app is usable
double daily_non_cov_symptoms_rate; // Rate of seasonal flu
double lockdown_occupation_multiplier[N_DEFAULT_OCCUPATION_NETWORKS]; // during lockdown distancing this multiplier is applied to the fraction of work network connections made
double lockdown_random_network_multiplier; // during lockdown distancing this multiplier is applied to the fraction of random network connections made
double lockdown_house_interaction_multiplier; // during lockdown this multiplier is applied to the strengin of home connections
int lockdown_time_on; // lockdown turned on at this time
int lockdown_time_off; // lockdown turned off at this time
int lockdown_on; // is lockdown currently on
int lockdown_elderly_time_on; // lockdown elderly turned on at this time
int lockdown_elderly_time_off; // lockdown elderly turned off at this time
int lockdown_elderly_on; // is lockdown elderly currently on
int testing_symptoms_time_on; // testing symptoms turned on at this time
int testing_symptoms_time_off; // testing symptoms turned off at this time
int interventions_on; // should we use interventions
int intervention_start_time; // time at which interventions start
int sys_write_individual; // Should an individual file be written to output?
int sys_write_hospital; // Should a hospital file be written to output?
long N_REFERENCE_HOUSEHOLDS; // Number of households in the household demographics file
int **REFERENCE_HOUSEHOLDS; // Array of reference households
demographic_household_table *demo_house; // Pointer to a table of demographic and house numbers (if user specified)
demographic_occupation_network_table *occupation_network_table;
double ***risk_score; // risk score somebody who has been traced
double **risk_score_household; // risk score for household members of symptomatic person
//Hospital parameters
int hospital_on;
int n_hospitals;
int n_wards[N_HOSPITAL_WARD_TYPES];
int n_ward_beds[N_HOSPITAL_WARD_TYPES];
int n_hcw_per_ward[N_HOSPITAL_WARD_TYPES][N_WORKER_TYPES];
int n_patient_required_interactions[N_HOSPITAL_WARD_TYPES][N_WORKER_TYPES];
int max_hcw_daily_interactions;
//Modifiers for patients not receiving care when transitioning from disease states.
double hospitalised_waiting_mod;
double critical_waiting_mod;
//average amount of interactions healthcare workers have with each other per day
double hcw_mean_work_interactions;
// maximum number of strains allowed
int max_n_strains;
// Replace quarantine with soft quarantine:
// individuals interact with the same people, but transmission rate is lowered
int soft_quarantine_on;
int soft_quarantine_household; // Soft quarantines household of traced contact
int novid_on; // Use NOVID instead of the standard contact tracing app
int novid_quarantine_length; // How long NOVID users quarantine, starting from the time they were traced
// Soft quarantine multiplier for NOVID users notified of nearby positive cases
double novid_soft_multiplier[5]; // TODO: rename soft_quarantine_multiplier
double novid_report_manual_traced; // Probability that a manually traced contact of a positive case will report this info to NOVID
int household_app_adoption; // Force households to either have everybody using the app, or nobody using it
int cluster_app_adoption; // Make app users clustered together
} parameters;
/************************************************************************/
/****************************** Functions *****************************/
/************************************************************************/
int get_model_param_hospital_on(model *pmodel);
double get_model_param_daily_fraction_work_used(model *pmodel, int idx);
int get_model_param_quarantine_days(model *pmodel);
double get_model_param_self_quarantine_fraction(model *pmodel);
int get_model_param_trace_on_symptoms(model *pmodel);
int get_model_param_trace_on_positive(model *pmodel);
int get_model_param_quarantine_on_traced(model *pmodel);
double get_model_param_traceable_interaction_fraction(model *pmodel);
int get_model_param_tracing_network_depth(model *pmodel);
int get_model_param_allow_clinical_diagnosis(model *pmodel);
int get_model_param_quarantine_household_on_symptoms(model *pmodel);
int get_model_param_quarantine_household_on_positive(model *pmodel);
int get_model_param_quarantine_household_on_traced_symptoms(model *pmodel);
int get_model_param_quarantine_household_on_traced_positive(model *pmodel);
int get_model_param_quarantine_household_contacts_on_positive(model *pmodel);
int set_model_param_relative_transmission( model *pmodel, double value, int type );
int get_model_param_quarantine_household_contacts_on_symptoms(model *pmodel);
int get_model_param_test_on_symptoms(model *pmodel);
int get_model_param_test_release_on_negative(model *pmodel);
int get_model_param_test_on_traced(model *pmodel);
int get_model_param_test_result_wait(model *pmodel);
int get_model_param_test_order_wait(model *pmodel);
int get_model_param_test_result_wait_priority(model *pmodel);
int get_model_param_test_order_wait_priority(model *pmodel);
int get_model_param_priority_test_contacts(model *pmodel, int idx);
double get_model_param_app_users_fraction(model *pmodel);
int get_model_param_app_turned_on(model *pmodel);
int get_model_param_lockdown_on(model *pmodel);
double get_model_param_risk_score( model*, int, int, int );
double get_model_param_risk_score_household( model*, int, int );
double get_model_param_lockdown_house_interaction_multiplier(model *pmodel);
double get_model_param_lockdown_random_network_multiplier(model *pmodel);
double get_model_param_lockdown_occupation_multiplier(model *pmodel, int idx);
int get_model_param_manual_trace_on_hospitalization( model *pmodel );
int get_model_param_manual_trace_on_positive( model *pmodel );
int get_model_param_manual_trace_on( model *pmodel );
int get_model_param_manual_trace_delay( model *pmodel );
int get_model_param_manual_trace_exclude_app_users( model *pmodel );
int get_model_param_manual_trace_n_workers( model *pmodel );
int get_model_param_manual_trace_interviews_per_worker_day( model *pmodel );
int get_model_param_manual_trace_notifications_per_worker_day( model *pmodel );
double get_model_param_manual_traceable_fraction( model *pmodel, int );
double get_model_param_fatality_fraction( model *pmodel, int age_group );
int set_model_param_quarantine_days(model *pmodel, int value);
int set_model_param_self_quarantine_fraction(model *pmodel, double value);
int set_model_param_trace_on_symptoms(model *pmodel, int value);
int set_model_param_trace_on_positive(model *pmodel, int value);
int set_model_param_quarantine_on_traced(model *pmodel, int value);
int set_model_param_traceable_interaction_fraction(model *pmodel, double value);
int set_model_param_tracing_network_depth(model *pmodel, int value);
int set_model_param_allow_clinical_diagnosis(model *pmodel, int value);
int set_model_param_quarantine_household_on_symptoms(model *pmodel, int value);
int set_model_param_quarantine_household_on_positive(model *pmodel, int value);
int set_model_param_quarantine_household_on_traced_symptoms(model *pmodel, int value);
int set_model_param_quarantine_household_on_traced_positive(model *pmodel, int value);
int set_model_param_quarantine_household_contacts_on_positive(model *pmodel, int value);
int set_model_param_quarantine_household_contacts_on_symptoms(model *pmodel, int value);
int set_model_param_test_on_symptoms(model *pmodel, int value);
int set_model_param_test_release_on_negative(model *pmodel, int value);
int set_model_param_test_on_traced(model *pmodel, int value);
int set_model_param_test_result_wait(model *pmodel, int value);
int set_model_param_test_order_wait(model *pmodel, int value);
int set_model_param_test_result_wait_priority(model *pmodel, int value);
int set_model_param_test_order_wait_priority(model *pmodel, int value);
int set_model_param_priority_test_contacts(model *pmodel, int value, int idx);
int set_model_param_app_users_fraction(model *pmodel, double value);
int set_model_param_app_turned_on(model *pmodel, int value);
int set_model_param_lockdown_on(model *pmodel, int value);
int set_model_param_lockdown_house_interaction_multiplier(model *pmodel, double value);
int set_model_param_lockdown_random_network_multiplier(model *pmodel, double value);
int set_model_param_lockdown_occupation_multiplier(model *pmodel, double value, int idx);
int set_model_param_lockdown_elderly_on(model *pmodel, int value);
int set_model_param_relative_transmission( model *pmodel, double value, int type );
int set_model_param_manual_trace_on_hospitalization( model *pmodel, int value );
int set_model_param_manual_trace_on_positive( model *pmodel, int value );
int set_model_param_manual_trace_on( model *pmodel, int value );
int set_model_param_manual_trace_delay( model *pmodel, int value );
int set_model_param_manual_trace_exclude_app_users( model *pmodel, int value );
int set_model_param_manual_trace_n_workers( model *pmodel, int value );
int set_model_param_manual_trace_interviews_per_worker_day( model *pmodel, int value );
int set_model_param_manual_trace_notifications_per_worker_day( model *pmodel, int value );
int set_model_param_manual_traceable_fraction( model *pmodel, double value, int type );
int set_model_param_risk_score( model*, int, int, int, double );
int set_model_param_risk_score_household( model*, int, int, double );
int set_model_param_fatality_fraction( model *pmodel, double value, int age_group );
int set_demographic_house_table( parameters*, long, long, long*, long*, long* );
int set_occupation_network_table( parameters* params, long n_total, long n_networks );
int set_indiv_occupation_network_property( parameters* params, long network, int age_type, double mean_interaction, double lockdown_multiplier, long network_id, const char *network_name );
int set_indiv_occupation_network( parameters* params, long n_total, long *people, long *network );
void set_up_default_occupation_network_table( parameters *params );
int set_app_users( model*, long*, long, int );
int get_app_users( model*, long* );
int get_app_user_by_index(model*, int);
long get_individuals( model *, long *, int *, int *, int * , long *, int *, short *);
void update_work_intervention_state(model *pmodel, int value);
void update_household_intervention_state(model *pmodel, int value);
void check_params( parameters* );
void check_hospital_params( parameters *params );
void initialize_params( parameters* );
void destroy_params( parameters* );
void destroy_occupation_network_table(parameters *params);
#endif /* PARAMS_H_ */