Time is of the essence: effectiveness of dairy farm control strategies for H5N1 are limited by fast spread
This repository hosts the code, data and supporting analysis for “Time is of the essence: effectiveness of dairy farm control for H5N1 is limited by fast spread.” The analysis was structured in the form of an R package to facilitate reproducibility.
Installation
You can install the development version of rRsurveillance from GitHub with:
# install.packages("remotes")
remotes::install_github("wf-id/h5n1speed")
Running the analysis
The primary analysis scripts are available as:
- manuscript/intervention-effectiveness.R contains the code to generate the figures shown in Figure 2 panels A-C which shows the effectiveness of each surveillance strategy and detection threshold at prevent infections.
- manuscript/time-to-effective-strategy.R contains the code to generate the time required to realize an effective strategy. These values are used to generate Figure 2 panels D-E.
- manuscript/delay_strategy.qmd contains the code to generate Figure 1, panel A and assembles the figures to make Figure 2.
Please note that the R scripts were run across 38 threads on a single node of the Wake Forest University HPC which took ~5-6hrs. Running these scripts on a single machine may take a significantly long time.
Underlying functions
We have parameterized our analysis into an R package to faciliate ease of use and allow us to explore scenarios of speed on surveillance and intervention strategies.
-
run_det_ode
contains the code used to run a deterministic compartmental model as described in our manuscript. This code use the deSolve package to solve the differential equations. Additionally, this code adds in the milk production. -
detect_infections_ode
processes the outputs from therun_det_ode
and find when some particular detection threshold has been met (e.g., number of cows infected cumulatively, number of symptomatic cows with clinical signs, some proportion drop in milk production). This function returns a list object with the timepoint at which the detection threshold is met. -
run_intervention_ode
allows a given intervention to be applied given some detection and surveillance approach (e.g., the number symptomatic detected) at that time with some delay with varying intensity.