From ad14b55188a06c6c7a4b4c40e4a1629b4c3ded80 Mon Sep 17 00:00:00 2001 From: athowes Date: Wed, 31 Jul 2024 11:12:00 +0100 Subject: [PATCH] Version of delay_samples working with hard coded lognormal --- R/delay-samples.R | 30 +++++++++++++------------- tests/testthat/test-unit-postprocess.R | 20 +++++------------ 2 files changed, 20 insertions(+), 30 deletions(-) diff --git a/R/delay-samples.R b/R/delay-samples.R index 19c5d43c1..b78c7143f 100644 --- a/R/delay-samples.R +++ b/R/delay-samples.R @@ -1,17 +1,17 @@ +#' @export delay_samples <- function(fit) { - dpars <- fit$family$dpars - lp_mu <- brms::posterior_linpred(fit, transform = TRUE, dpar = dpars[1]) - lp_sigma <- brms::posterior_linpred(fit, transform = TRUE, dpar = dpars[2]) - - # lp_mu <- brms::posterior_linpred(fit, transform = TRUE, dpar = "mu") |> - # as.table() |> - # as.data.table() - # names(lp_mu) <- c("draw", "index", "mu") - # lp_sigma <- brms::posterior_linpred(fit, transform = TRUE, dpar = "sigma") |> - # as.table() |> - # as.data.table(value.name = "sigma") - # names(lp_sigma) <- c("draw", "index", "sigma") - # lp <- dplyr::left_join(lp_mu, lp_sigma) - # class(lp) <- c(class(lp), "lognormal_samples") - # x <- add_mean_sd(lp) + # Warning: only works at the moment with lognormal! + pp <- brms::prepare_predictions(fit) + lp_mu <- brms::get_dpar(pp, dpar = "mu", inv_link = TRUE) + lp_sigma <- brms::get_dpar(pp, dpar = "sigma", inv_link = TRUE) + # Assumes lp_mu and lp_sigma have same dimensions + df <- expand.grid("index" = 1:nrow(lp_mu), "draw" = 1:ncol(lp_mu)) + df[["mu"]] <- as.vector(lp_mu) + df[["sigma"]] <- as.vector(lp_sigma) + class(df) <- c(class(df), "lognormal_samples") + dt <- as.data.table(df) + dt <- add_mean_sd(dt) } + +# data <- as_latent_individual(sim_obs) +# fit <- epidist(data) diff --git a/tests/testthat/test-unit-postprocess.R b/tests/testthat/test-unit-postprocess.R index 8ed0b8053..f91eae906 100644 --- a/tests/testthat/test-unit-postprocess.R +++ b/tests/testthat/test-unit-postprocess.R @@ -3,21 +3,11 @@ test_that("add_mean_sd.lognormal_samples works with posterior samples from the l set.seed(1) prep_obs <- as_latent_individual(sim_obs) fit <- epidist(data = prep_obs, seed = 1) - lp_mu <- brms::posterior_linpred(fit, transform = TRUE, dpar = "mu") |> - as.table() |> - as.data.table() - names(lp_mu) <- c("draw", "index", "mu") - lp_sigma <- brms::posterior_linpred(fit, transform = TRUE, dpar = "sigma") |> - as.table() |> - as.data.table(value.name = "sigma") - names(lp_sigma) <- c("draw", "index", "sigma") - lp <- dplyr::left_join(lp_mu, lp_sigma) - class(lp) <- c(class(lp), "lognormal_samples") - x <- add_mean_sd(lp) - expect_s3_class(x, "data.table") - expect_named(x, c("draw", "index", "mu", "sigma", "mean", "sd")) - expect_true(all(x$mean > 0)) - expect_true(all(x$sd > 0)) + delay_samples <- delay_samples(fit) + expect_s3_class(delay_samples, "data.table") + expect_named(delay_samples, c("index", "draw", "mu", "sigma", "mean", "sd")) + expect_true(all(delay_samples$mean > 0)) + expect_true(all(delay_samples$sd > 0)) }) test_that("add_mean_sd.lognormal_samples works with simulated lognormal distribution parameter data", { # nolint: line_length_linter.