This function wraps the functionality of estimate_infections()
in order
to estimate Rt and cases by date of infection and forecast these infections
into the future. In addition to the functionality of
estimate_infections()
it produces additional summary output useful for
reporting results and interpreting them as well as error catching and
reporting, making it particularly useful for production use e.g. running at
set intervals on a dedicated server.
Usage
epinow(
data,
generation_time = gt_opts(),
delays = delay_opts(),
truncation = trunc_opts(),
rt = rt_opts(),
backcalc = backcalc_opts(),
gp = gp_opts(),
obs = obs_opts(),
forecast = forecast_opts(),
stan = stan_opts(),
horizon,
CrIs = c(0.2, 0.5, 0.9),
filter_leading_zeros = TRUE,
zero_threshold = Inf,
return_output = is.null(target_folder),
output = c("samples", "plots", "latest", "fit", "timing"),
plot_args = list(),
target_folder = NULL,
target_date,
logs = tempdir(),
id = "epinow",
verbose = interactive(),
reported_cases
)
Arguments
- data
A
<data.frame>
of confirmed cases (confirm) by date (date).confirm
must be numeric anddate
must be in date format. Optionally this can also have a logicalaccumulate
column which indicates whether data should be added to the next data point. This is useful when modelling e.g. weekly incidence data. See also thefill_missing()
function which helps add theaccumulate
column with the desired properties when dealing with non-daily data. If any accumulation is done this happens after truncation as specified by thetruncation
argument.- generation_time
A call to
gt_opts()
(or its aliasgeneration_time_opts()
) defining the generation time distribution used. For backwards compatibility a list of summary parameters can also be passed.- delays
A call to
delay_opts()
defining delay distributions and options. See the documentation ofdelay_opts()
and the examples below for details.- truncation
A call to
trunc_opts()
defining the truncation of the observed data. Defaults totrunc_opts()
, i.e. no truncation. See theestimate_truncation()
help file for an approach to estimating this from data where thedist
list element returned byestimate_truncation()
is used as thetruncation
argument here, thereby propagating the uncertainty in the estimate.- rt
A list of options as generated by
rt_opts()
defining Rt estimation. Defaults tort_opts()
. To generate new infections using the non-mechanistic model instead of the renewal equation model, usert = NULL
. The non-mechanistic model internally uses the settingrt = rt_opts(use_rt = FALSE, future = "project", gp_on = "R0")
.- backcalc
A list of options as generated by
backcalc_opts()
to define the back calculation. Defaults tobackcalc_opts()
.- gp
A list of options as generated by
gp_opts()
to define the Gaussian process. Defaults togp_opts()
. Set toNULL
to disable the Gaussian process.- obs
A list of options as generated by
obs_opts()
defining the observation model. Defaults toobs_opts()
.- forecast
A list of options as generated by
forecast_opts()
defining the forecast opitions. Defaults toforecast_opts()
. If NULL then no forecasting will be one.- stan
A list of stan options as generated by
stan_opts()
. Defaults tostan_opts()
. Can be used to overridedata
,init
, andverbose
settings if desired.- horizon
Deprecated; use
forecast
instead to specify the predictive horizon- CrIs
Numeric vector of credible intervals to calculate.
- filter_leading_zeros
Logical, defaults to TRUE. Should zeros at the start of the time series be filtered out.
- zero_threshold
Numeric defaults to Inf. Indicates if detected zero cases are meaningful by using a threshold number of cases based on the 7-day average. If the average is above this threshold then the zero is replaced using
fill
.- return_output
Logical, defaults to FALSE. Should output be returned, this automatically updates to TRUE if no directory for saving is specified.
- output
A character vector of optional output to return. Supported options are samples ("samples"), plots ("plots"), the run time ("timing"), copying the dated folder into a latest folder (if
target_folder
is not null, set using "latest"), and the stan fit ("fit"). The default is to return all options.- plot_args
A list of optional arguments passed to
plot.epinow()
.- target_folder
Character string specifying where to save results (will create if not present).
- target_date
Date, defaults to maximum found in the data if not specified.
- logs
Character path indicating the target folder in which to store log information. Defaults to the temporary directory if not specified. Default logging can be disabled if
logs
is set to NULL. If specifying a custom logging setup then the code forsetup_default_logging()
and thesetup_logging()
function are a sensible place to start.- id
A character string used to assign logging information on error. Used by
regional_epinow()
to assign errors to regions. Alter the default to run with error catching.- verbose
Logical, defaults to
TRUE
when used interactively and otherwiseFALSE
. Should verbose debug progress messages be printed. Corresponds to the "DEBUG" level fromfutile.logger
. Seesetup_logging
for more detailed logging options.- reported_cases
Deprecated; use
data
instead.
Value
A list of output from estimate_infections with additional elements summarising results and reporting errors if they have occurred.
Examples
# \donttest{
# set number of cores to use
old_opts <- options()
options(mc.cores = ifelse(interactive(), 4, 1))
# set an example generation time. In practice this should use an estimate
# from the literature or be estimated from data
generation_time <- Gamma(
shape = Normal(1.3, 0.3),
rate = Normal(0.37, 0.09),
max = 14
)
# set an example incubation period. In practice this should use an estimate
# from the literature or be estimated from data
incubation_period <- LogNormal(
meanlog = Normal(1.6, 0.06),
sdlog = Normal(0.4, 0.07),
max = 14
)
# set an example reporting delay. In practice this should use an estimate
# from the literature or be estimated from data
reporting_delay <- LogNormal(mean = 2, sd = 1, max = 10)
# example case data
reported_cases <- example_confirmed[1:40]
# estimate Rt and nowcast/forecast cases by date of infection
out <- epinow(
data = reported_cases,
generation_time = gt_opts(generation_time),
rt = rt_opts(prior = LogNormal(mean = 2, sd = 0.1)),
delays = delay_opts(incubation_period + reporting_delay)
)
#> Logging threshold set at INFO for the name logger
#> Writing EpiNow2 logs to the console and:
#> /tmp/RtmpB3yHY0/regional-epinow/2020-04-01.log.
#> Logging threshold set at INFO for the name logger
#> Writing EpiNow2.epinow logs to the console and:
#> /tmp/RtmpB3yHY0/epinow/2020-04-01.log.
#> WARN [2025-01-13 15:59:07] epinow: The `filter_leading_zeros` argument of `estimate_infections()` is deprecated as of EpiNow2 1.7.0. -
#> WARN [2025-01-13 15:59:07] epinow: The `zero_threshold` argument of `estimate_infections()` is deprecated as of EpiNow2 1.7.0. -
#> WARN [2025-01-13 15:59:53] epinow: There were 1 divergent transitions after warmup. See
#> https://mc-stan.org/misc/warnings.html#divergent-transitions-after-warmup
#> to find out why this is a problem and how to eliminate them. -
#> WARN [2025-01-13 15:59:53] epinow: Examine the pairs() plot to diagnose sampling problems
#> -
# summary of the latest estimates
summary(out)
#> measure estimate
#> <char> <char>
#> 1: New infections per day 3511 (1931 -- 6443)
#> 2: Expected change in daily reports Decreasing
#> 3: Effective reproduction no. 0.8 (0.63 -- 1)
#> 4: Rate of growth -0.065 (-0.13 -- 0.00035)
#> 5: Doubling/halving time (days) -11 (2000 -- -5.3)
# plot estimates
plot(out)
# summary of R estimates
summary(out, type = "parameters", params = "R")
#> date variable strat type median
#> <Date> <char> <char> <char> <num>
#> 1: 2020-02-22 R <NA> estimate 2.0932046
#> 2: 2020-02-23 R <NA> estimate 2.0742469
#> 3: 2020-02-24 R <NA> estimate 2.0524339
#> 4: 2020-02-25 R <NA> estimate 2.0276430
#> 5: 2020-02-26 R <NA> estimate 2.0003527
#> 6: 2020-02-27 R <NA> estimate 1.9715529
#> 7: 2020-02-28 R <NA> estimate 1.9381217
#> 8: 2020-02-29 R <NA> estimate 1.9052145
#> 9: 2020-03-01 R <NA> estimate 1.8693607
#> 10: 2020-03-02 R <NA> estimate 1.8318819
#> 11: 2020-03-03 R <NA> estimate 1.7915851
#> 12: 2020-03-04 R <NA> estimate 1.7496766
#> 13: 2020-03-05 R <NA> estimate 1.7060251
#> 14: 2020-03-06 R <NA> estimate 1.6615403
#> 15: 2020-03-07 R <NA> estimate 1.6161590
#> 16: 2020-03-08 R <NA> estimate 1.5694318
#> 17: 2020-03-09 R <NA> estimate 1.5243524
#> 18: 2020-03-10 R <NA> estimate 1.4774280
#> 19: 2020-03-11 R <NA> estimate 1.4309282
#> 20: 2020-03-12 R <NA> estimate 1.3857576
#> 21: 2020-03-13 R <NA> estimate 1.3410593
#> 22: 2020-03-14 R <NA> estimate 1.2970969
#> 23: 2020-03-15 R <NA> estimate 1.2544436
#> 24: 2020-03-16 R <NA> estimate 1.2126995
#> 25: 2020-03-17 R <NA> estimate 1.1728245
#> 26: 2020-03-18 R <NA> estimate 1.1335612
#> 27: 2020-03-19 R <NA> estimate based on partial data 1.0977546
#> 28: 2020-03-20 R <NA> estimate based on partial data 1.0640896
#> 29: 2020-03-21 R <NA> estimate based on partial data 1.0312702
#> 30: 2020-03-22 R <NA> estimate based on partial data 1.0006406
#> 31: 2020-03-23 R <NA> estimate based on partial data 0.9720692
#> 32: 2020-03-24 R <NA> estimate based on partial data 0.9454812
#> 33: 2020-03-25 R <NA> estimate based on partial data 0.9220330
#> 34: 2020-03-26 R <NA> estimate based on partial data 0.8997998
#> 35: 2020-03-27 R <NA> estimate based on partial data 0.8787748
#> 36: 2020-03-28 R <NA> estimate based on partial data 0.8593860
#> 37: 2020-03-29 R <NA> estimate based on partial data 0.8421474
#> 38: 2020-03-30 R <NA> estimate based on partial data 0.8277967
#> 39: 2020-03-31 R <NA> estimate based on partial data 0.8146756
#> 40: 2020-04-01 R <NA> estimate based on partial data 0.8017988
#> 41: 2020-04-02 R <NA> forecast 0.8017988
#> 42: 2020-04-03 R <NA> forecast 0.8017988
#> 43: 2020-04-04 R <NA> forecast 0.8017988
#> 44: 2020-04-05 R <NA> forecast 0.8017988
#> 45: 2020-04-06 R <NA> forecast 0.8017988
#> 46: 2020-04-07 R <NA> forecast 0.8017988
#> 47: 2020-04-08 R <NA> forecast 0.8017988
#> date variable strat type median
#> mean sd lower_90 lower_50 lower_20 upper_20 upper_50
#> <num> <num> <num> <num> <num> <num> <num>
#> 1: 2.0945625 0.08901705 1.9548799 2.0334941 2.0714957 2.1160576 2.1499519
#> 2: 2.0748765 0.08058514 1.9438332 2.0204392 2.0533346 2.0949202 2.1279557
#> 3: 2.0529249 0.07378758 1.9318637 2.0029019 2.0331795 2.0710515 2.1013251
#> 4: 2.0286208 0.06870206 1.9159098 1.9823109 2.0106083 2.0447974 2.0741500
#> 5: 2.0018988 0.06520549 1.8955967 1.9585175 1.9838721 2.0168027 2.0445623
#> 6: 1.9727278 0.06298436 1.8702554 1.9299983 1.9549044 1.9866160 2.0134250
#> 7: 1.9411214 0.06162241 1.8422521 1.8997694 1.9242037 1.9551234 1.9814716
#> 8: 1.9071447 0.06071914 1.8106001 1.8653036 1.8906865 1.9211946 1.9476406
#> 9: 1.8709147 0.05997073 1.7745959 1.8294756 1.8544915 1.8839082 1.9102825
#> 10: 1.8325969 0.05918591 1.7369503 1.7911713 1.8166046 1.8459930 1.8714254
#> 11: 1.7923962 0.05825714 1.6979061 1.7516934 1.7776536 1.8055869 1.8306156
#> 12: 1.7505465 0.05712321 1.6579294 1.7116668 1.7356306 1.7629568 1.7886233
#> 13: 1.7073004 0.05574775 1.6163437 1.6692719 1.6915114 1.7185309 1.7430837
#> 14: 1.6629203 0.05411724 1.5760667 1.6257498 1.6471379 1.6747146 1.6980556
#> 15: 1.6176719 0.05224669 1.5323160 1.5813595 1.6030405 1.6290035 1.6519437
#> 16: 1.5718195 0.05018049 1.4899432 1.5369604 1.5581180 1.5824387 1.6048652
#> 17: 1.5256240 0.04798446 1.4495697 1.4921916 1.5121503 1.5350181 1.5566504
#> 18: 1.4793418 0.04573582 1.4071962 1.4475386 1.4667496 1.4883164 1.5084771
#> 19: 1.4332254 0.04352079 1.3639701 1.4027475 1.4206782 1.4423372 1.4614286
#> 20: 1.3875238 0.04144367 1.3209208 1.3592894 1.3751140 1.3958226 1.4134379
#> 21: 1.3424826 0.03964088 1.2789950 1.3150228 1.3314345 1.3500544 1.3675758
#> 22: 1.2983422 0.03828602 1.2378867 1.2722229 1.2877641 1.3058325 1.3226100
#> 23: 1.2553342 0.03757317 1.1962623 1.2296814 1.2446136 1.2630494 1.2795070
#> 24: 1.2136768 0.03767792 1.1542531 1.1886515 1.2031514 1.2211869 1.2381921
#> 25: 1.1735690 0.03871393 1.1106765 1.1482362 1.1631402 1.1808792 1.1987477
#> 26: 1.1351855 0.04071126 1.0683523 1.1097246 1.1243331 1.1439237 1.1606195
#> 27: 1.0986723 0.04362724 1.0284051 1.0704970 1.0874858 1.1089543 1.1261966
#> 28: 1.0641435 0.04737428 0.9874307 1.0333749 1.0529505 1.0748867 1.0942011
#> 29: 1.0316801 0.05184322 0.9484161 0.9970779 1.0191819 1.0428855 1.0643284
#> 30: 1.0013298 0.05691441 0.9105962 0.9629343 0.9871068 1.0144158 1.0374658
#> 31: 0.9731087 0.06246237 0.8742135 0.9309030 0.9574909 0.9877380 1.0126598
#> 32: 0.9470038 0.06836084 0.8377123 0.9004440 0.9291677 0.9634994 0.9914206
#> 33: 0.9229782 0.07448996 0.8075112 0.8715226 0.9030506 0.9401880 0.9713972
#> 34: 0.9009762 0.08074307 0.7751755 0.8457614 0.8783746 0.9201709 0.9527718
#> 35: 0.8809285 0.08702999 0.7450461 0.8220318 0.8562202 0.9022719 0.9374154
#> 36: 0.8627578 0.09327579 0.7167127 0.7991922 0.8367292 0.8856209 0.9222232
#> 37: 0.8463825 0.09941665 0.6899655 0.7784044 0.8179970 0.8697235 0.9100497
#> 38: 0.8317194 0.10539574 0.6660794 0.7599482 0.8004872 0.8570784 0.8979053
#> 39: 0.8186865 0.11116122 0.6451005 0.7421734 0.7866082 0.8440091 0.8892889
#> 40: 0.8072046 0.11666634 0.6261711 0.7277443 0.7729046 0.8342125 0.8808662
#> 41: 0.8072046 0.11666634 0.6261711 0.7277443 0.7729046 0.8342125 0.8808662
#> 42: 0.8072046 0.11666634 0.6261711 0.7277443 0.7729046 0.8342125 0.8808662
#> 43: 0.8072046 0.11666634 0.6261711 0.7277443 0.7729046 0.8342125 0.8808662
#> 44: 0.8072046 0.11666634 0.6261711 0.7277443 0.7729046 0.8342125 0.8808662
#> 45: 0.8072046 0.11666634 0.6261711 0.7277443 0.7729046 0.8342125 0.8808662
#> 46: 0.8072046 0.11666634 0.6261711 0.7277443 0.7729046 0.8342125 0.8808662
#> 47: 0.8072046 0.11666634 0.6261711 0.7277443 0.7729046 0.8342125 0.8808662
#> mean sd lower_90 lower_50 lower_20 upper_20 upper_50
#> upper_90
#> <num>
#> 1: 2.243170
#> 2: 2.208863
#> 3: 2.174446
#> 4: 2.141464
#> 5: 2.108813
#> 6: 2.079107
#> 7: 2.043436
#> 8: 2.006627
#> 9: 1.968274
#> 10: 1.928766
#> 11: 1.890492
#> 12: 1.846040
#> 13: 1.802045
#> 14: 1.755480
#> 15: 1.708346
#> 16: 1.659481
#> 17: 1.608886
#> 18: 1.558046
#> 19: 1.507602
#> 20: 1.457419
#> 21: 1.410738
#> 22: 1.363585
#> 23: 1.318635
#> 24: 1.275829
#> 25: 1.237554
#> 26: 1.202786
#> 27: 1.172269
#> 28: 1.146748
#> 29: 1.121984
#> 30: 1.099485
#> 31: 1.080932
#> 32: 1.063831
#> 33: 1.050872
#> 34: 1.038722
#> 35: 1.028432
#> 36: 1.019793
#> 37: 1.013788
#> 38: 1.010136
#> 39: 1.004981
#> 40: 1.004391
#> 41: 1.004391
#> 42: 1.004391
#> 43: 1.004391
#> 44: 1.004391
#> 45: 1.004391
#> 46: 1.004391
#> 47: 1.004391
#> upper_90
options(old_opts)
# }