forked from lopmanlab/covid_campus_model
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path99_parm_init_control.R
141 lines (112 loc) · 6.72 KB
/
99_parm_init_control.R
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
parameter_table <- read.csv("99_ParameterTable_f21.csv") # Parameter table manuscript
#parameter_table <-read.csv("ParameterTable_EmoryFall2021.csv") # Parameter table Fall 2021
p_tab <- parameter_table[,1:9]
p_tab$Value <-gsub(",","",p_tab$Value)
p_tab$Value <- as.numeric(as.character(p_tab$Value))
p_tab$Lower <- as.numeric(as.character(p_tab$Lower))
p_tab$Upper <- as.numeric(as.character(p_tab$Upper))
#Epi parameters
R0_student_to_student <- p_tab$Value[which(p_tab$Var=="R0_student_to_student")] # number of other students that a student infects, on average
R0_on_to_on <- p_tab$Value[which(p_tab$Var == "R0_on_to_on")] # number of additional students that a student living off campus infects, on average
R0_saf <- p_tab$Value[which(p_tab$Var == "R0_saf")] # number of staff and faculty that an average student infects
latent <- p_tab$Value[which(p_tab$Var == "latent")] # latent period duration in days. This is shorter than incubation period, which is more like 5 days
infectious <- p_tab$Value[which(p_tab$Var == "infectious")]
N_on <- p_tab$Value[which(p_tab$Var == "N_on")]
N_off<-p_tab$Value[which(p_tab$Var == "N")]-N_on #Based on number on campus
N_saf <- p_tab$Value[which(p_tab$Var == "N_saf")]
N = N_on + N_off + N_saf
beta_student_to_student <- as.numeric(R0_student_to_student/infectious/(N_on+N_off)) # daily effective contact rates
beta_on_to_on <- as.numeric((R0_student_to_student + R0_on_to_on) / infectious / N_on)
beta_saf <- as.numeric(R0_saf/infectious/(N_on+N_off+N_saf))
# infectious period in days.This is longer than symptomatic period, which is more like 6 days.
# Effectively this assumes that infectiousness starts 1 day before symptoms
# daily effective contact rate -- symptomatic period
eff_npi <- p_tab$Value[which(p_tab$Var == "eff_npi")] # efficacy of masking and other NPIs
daily_new_case <- p_tab$Value[which(p_tab$Var == "daily_new_case")] # daily new case/population in surrounding area
under_report <- p_tab$Value[which(p_tab$Var == "under_report")] # under-report factor
community <- daily_new_case*under_report # daily probability of community infection - not acquired on campus
p_asympt_stu <- 1-p_tab$Value[which(p_tab$Var == "p_sympt_stu")] # proportion asymptomatic -- students
p_hosp_stu <- p_tab$Value[which(p_tab$Var == "p_hosp_stu")] # probability of hospitalization -- students
p_death_stu <- p_tab$Value[which(p_tab$Var == "p_death_stu")] # probability of death -- students
p_asympt_saf <- 1-p_tab$Value[which(p_tab$Var == "p_sympt_saf")] # proportion asymptomatic -- staff and faculty
p_hosp_saf <- p_tab$Value[which(p_tab$Var == "p_hosp_saf")] # probability of hospitalization -- staff and faculty
p_death_saf <- p_tab$Value[which(p_tab$Var == "p_death_saf")] # probability of death -- staff and faculty
contacts <- p_tab$Value[which(p_tab$Var == "contacts")] # contacts per case
p_contacts_reached <- p_tab$Value[which(p_tab$Var == "p_contacts_reached")] # proportion of contacts reached
ili <- p_tab$Value[which(p_tab$Var == "ili")] # daily ili
p_ili_flu <- p_tab$Value[which(p_tab$Var == "p_ili_flu")] # Proportion ILI flu positive
sensitivity <- p_tab$Value[which(p_tab$Var == "sensitivity")] # PCR sensitivity on day 4
sensitivity_2 <- p_tab$Value[which(p_tab$Var == "sensitivity_2")] # PCR sensitivity on day 2
sensitivity_7 <- p_tab$Value[which(p_tab$Var == "sensitivity_7")] # PCR sensitivity on day 7
isolation <- p_tab$Value[which(p_tab$Var == "isolation")] # isolation or quarantine period in days
p_vacc <- p_tab$Value[which(p_tab$Var == "p_vacc")] # proportion vaccinated at baseline
p_imm <- p_tab$Value[which(p_tab$Var == "p_imm")] # proportion natural infected at baseline
ve <- p_tab$Value[which(p_tab$Var == "ve")] # vaccine or natural protection
# Emory population
E_on=0 #students living on campus
I_on=0
P_on = 0
R_on = N_on*(p_vacc+p_imm-p_vacc*p_imm)*ve
Q_on = 0
E_off=0 #students living off campus
I_off=0
P_off = 0
R_off = N_off*(p_vacc+p_imm-p_vacc*p_imm)*ve
Q_off = 0
E_saf=0
I_saf=0
P_saf = 0
R_saf = N_saf*(p_vacc+p_imm-p_vacc*p_imm)*ve
Q_saf = 0
testing=0
screening_on=0 #screening interval for oncampus students
screening =0 #screening intervals for off campus students and staff
## Initial conditions to model
init <- init.dcm(S_on=N_on-(E_on+I_on+R_on), # number initially susceptible
E_on=E_on, # number initially incubating
I_on=I_on, # number initially infectious
Isym_on = 0,
P_on=P_on, # number initially isolated
R_on=R_on, # initially immune
Icum_on = 0, # cumulative cases -- for counting incidence
Pcum_on = 0,
Q_on = Q_on,
Qcum_on = 0,
Hcum_on =0,
Dcum_on=0,
Icum_on_camp=0,
#Icum_on_com=0,
S_off=N_off-(E_off+I_off+R_off),
E_off=E_off,
I_off=I_off,
Isym_off = 0,
P_off=P_off,
R_off=R_off,
Icum_off = 0,
Pcum_off = 0,
Q_off = Q_off,
Qcum_off = 0,
Hcum_off = 0,
Dcum_off =0,
Icum_off_camp=0,
#Icum_off_com=0,
S_saf=N_saf-(E_saf+I_saf+R_saf),
E_saf=E_saf,
I_saf=I_saf,
Isym_saf = 0,
P_saf=P_saf,
R_saf=R_saf,
Icum_saf = 0,
Pcum_saf = 0,
Q_saf = 0,
Hcum_saf =0,
Dcum_saf =0,
Icum_saf_camp=0,
#Icum_saf_com=0,
Test = 0,
lam_on = 0,
lam_off = 0,
lam_saf = 0
)
# Control features
control <- control.dcm(nsteps = 116, new.mod = model) #Time steps for manuscript