vignettes_src/hintr-example_district28.R

#' ---
#' title: "Emulate a hintr model run"
#' output: rmarkdown::html_vignette
#' vignette: >
#'   %\VignetteIndexEntry{`hintr` example run}
#'   %\VignetteEngine{knitr::rmarkdown}
#'   %\VignetteEncoding{UTF-8}
#' ---

##+ preamble, include = FALSE
knitr::opts_chunk$set(
                    collapse = TRUE,
                    comment = "#>"
                  )
unlink("outputs", recursive = TRUE)

#'
#'
#' This vignette provides example

##+ setup, message = FALSE

library(naomi)

##+ fit_model
hintr_data <- list(
  pjnz = system.file("extdata/demo_mwi2024_v6.36.PJNZ", package = "naomi"),
  population = system.file("extdata/demo-district28/demo_population_district28.csv", package = "naomi"),
  shape = system.file("extdata/demo-district28/demo_areas_district28.geojson", package = "naomi"),
  survey = system.file("extdata/demo-district28/demo_survey_district28.csv", package = "naomi"),
  art_number = system.file("extdata/demo-district28/demo_art_number_district28.csv", package = "naomi"),
  anc_testing = system.file("extdata/demo-district28/demo_anc_testing_district28.csv", package = "naomi")
)

hintr_options <- list(
  area_scope = "MWI",
  area_level = "3",
  calendar_quarter_t1 = "CY2020Q3",
  calendar_quarter_t2 = "CY2023Q4",
  calendar_quarter_t3 = "CY2025Q3",
  calendar_quarter_t4 = "CY2026Q3",
  survey_prevalence = "DEMO2020PHIA",
  survey_art_coverage = "DEMO2020PHIA",
  survey_recently_infected = "DEMO2020PHIA",
  include_art_t1 = "true",
  include_art_t2 = "true",
  anc_clients_year2 = 2023,
  anc_clients_year2_num_months = "12",
  anc_prevalence_year1 = 2020,
  anc_prevalence_year2 = 2023,
  anc_art_coverage_year1 = 2020,
  anc_art_coverage_year2 = 2023,
  spectrum_population_calibration = "national",
  artattend = "true",
  artattend_t2 = "true",
  artattend_log_gamma_offset = -4L,
  anchor_home_district = TRUE,
  output_aware_plhiv = "true",
  rng_seed = 17,
  no_of_samples = 500,
  max_iter = 250,
  use_kish_prev = "true",
  deff_prev = 1.0,
  use_kish_artcov = "true",
  deff_artcov = 1.0,
  use_kish_recent = "true",
  deff_recent = 1.0,
  use_survey_aggregate = "false",
  psnu_level = NULL
)

calibration_options <- list(
  spectrum_plhiv_calibration_level = "subnational",
  spectrum_plhiv_calibration_strat = "sex_age_group",
  spectrum_artnum_calibration_level = "subnational",
  spectrum_artnum_calibration_strat = "sex_age_group",
  spectrum_aware_calibration_level = "subnational",
  spectrum_aware_calibration_strat = "sex_age_group",
  spectrum_infections_calibration_level = "subnational",
  spectrum_infections_calibration_strat = "sex_age_group",
  calibrate_method = "logistic"
)

hintr_options$outer_verbose <- TRUE

hintr_paths <- hintr_run_model(hintr_data, hintr_options)
calibrated_paths <- hintr_calibrate(hintr_paths, calibration_options)
spectrum_download <- hintr_prepare_spectrum_download(calibrated_paths)

coarse_download <- hintr_prepare_coarse_age_group_download(calibrated_paths)

#' TO DO: add summary report download

#' Read output package and generate datapack export

##+ read_output
naomi_output <- read_output_package(spectrum_download$path)

datapack_path <- tempfile(fileext = ".csv")
write_datapack_csv(naomi_output, datapack_path)

navigator_path <- tempfile(fileext = ".csv")
write_navigator_checklist(naomi_output, navigator_path)
mrc-ide/naomi documentation built on Jan. 6, 2025, 10:20 a.m.