Skip to content

Commit

Permalink
Extend grid to all statistics:
Browse files Browse the repository at this point in the history
 * parameterise grid outputs with string vector
 * fix incidence grid rendering for p_ stats
  • Loading branch information
giovannic committed Jan 24, 2024
1 parent 3a76ba3 commit 4d2b3ae
Show file tree
Hide file tree
Showing 3 changed files with 69 additions and 12 deletions.
4 changes: 2 additions & 2 deletions R/parameters.R
Original file line number Diff line number Diff line change
Expand Up @@ -207,7 +207,7 @@
#' * severe_incidence_rendering_min_ages - the minimum ages for severe incidence
#' outputs; default = turned off
#' * severe_incidence_rendering_max_ages - the corresponding max ages; default = turned off
#' * render_grid - whether to render prevalence and incidence values for a grid of year wide age groups between 0 and 100; default = turned off
#' * render_grid - which statistics to render values for in a grid of year wide age groups between 0 and 100; e.g. 'p_detect_' ; default = turned off
#'
#' miscellaneous:
#'
Expand Down Expand Up @@ -395,7 +395,7 @@ get_parameters <- function(overrides = list()) {
severe_incidence_rendering_max_ages = numeric(0),
age_group_rendering_min_ages = numeric(0),
age_group_rendering_max_ages = numeric(0),
render_grid = FALSE,
render_grid = NULL,
# misc
custom_demography = FALSE,
human_population = 100,
Expand Down
58 changes: 48 additions & 10 deletions R/render.R
Original file line number Diff line number Diff line change
Expand Up @@ -56,22 +56,39 @@ create_prevelance_renderer <- function(
)
}

if (parameters$render_grid) {
if (!is.null(parameters$render_grid)) {
grid_renderer(
birth,
renderer,
NULL,
'n',
'n_',
timestep
)
}

if ('n_detect_' %in% parameters$render_grid) {
grid_renderer(
birth,
renderer,
detected,
'n_detect',
'n_detect_',
timestep
)
}
if ('p_detect_' %in% parameters$render_grid) {
weights <- rep(0, parameters$human_population)
weights[clinically_detected$to_vector()] <- 1
weights[asymptomatic$to_vector()] <- prob
weights <- weights[detected$to_vector()]
grid_renderer(
birth,
renderer,
detected,
'p_detect_',
timestep,
weights
)
}
}
}

Expand Down Expand Up @@ -120,15 +137,27 @@ incidence_renderer <- function(
)
}

if (render_grid) {
n_prefix = paste0('n_', prefix)
if (n_prefix %in% render_grid) {
grid_renderer(
birth,
renderer,
target,
'n_inc',
n_prefix,
timestep
)
}
p_prefix = paste0('p_', prefix)
if (p_prefix %in% render_grid) {
grid_renderer(
birth,
renderer,
source_pop,
p_prefix,
timestep,
prob
)
}
}

create_variable_mean_renderer_process <- function(
Expand Down Expand Up @@ -217,19 +246,20 @@ grid_renderer <- function(
renderer,
target,
prefix,
timestep
timestep,
weights = NULL
) {
counts <- grid_count(birth, target, timestep)
counts <- grid_count(birth, target, timestep, weights)
for (i in seq_along(counts)) {
renderer$render(
paste0('grid_', prefix, '_', i),
paste0('grid_', prefix, i),
counts[[i]],
timestep
)
}
}

grid_count <- function(birth, selected, timestep) {
grid_count <- function(birth, selected, timestep, weights = NULL) {
if (is.null(selected)) {
selected_births <- birth$get_values()
} else {
Expand All @@ -238,8 +268,16 @@ grid_count <- function(birth, selected, timestep) {
age <- floor(get_age(selected_births, timestep) / 365)
age[age < 0] <- NA
age[age > 100] <- NA
non_zero <- table(age)
counts <- rep(0, 101)
if (!is.null(weights)) {
if (length(weights) == 0) {
return(counts)
}
non_zero <- aggregate(x = weights, by = list(age = age), FUN = sum)
counts[non_zero$age + 1] <- non_zero$x
return(counts)
}
non_zero <- table(age)
counts[as.numeric(names(non_zero)) + 1] <- non_zero
counts
}
19 changes: 19 additions & 0 deletions tests/testthat/test-grid-render.R
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,25 @@ test_that('grid_count counts internally correctly', {
expect_equal(grid_count(birth, selected, timestep), expected)
})

test_that('grid_count does weighted counts correctly', {
timestep <- 5 * 365
birth <- individual::IntegerVariable$new(timestep - c(1, 1, 3, 4) * 365 - 1)
expected <- rep(0, 101)
weights <- c(.1, .2, .3, .4)
expected[c(1, 3, 4) + 1] <- c(.3, .3, .4)
expect_equal(grid_count(birth, NULL, timestep, weights), expected)
})

test_that('grid_count works for empty case', {
timestep <- 5 * 365
birth <- individual::IntegerVariable$new(timestep - c(1, 1, 3, 4) * 365 - 1)
expected <- rep(0, 101)
weights <- numeric(0)
selected <- individual::Bitset$new(4)
expect_equal(grid_count(birth, selected, timestep, weights), rep(0, 101))
})


test_that('grid_count counts at the boundaries correctly', {
timestep <- 5 * 365
birth <- individual::IntegerVariable$new(timestep - c(1, 2, 3, 4) * 365)
Expand Down

0 comments on commit 4d2b3ae

Please sign in to comment.