From 13823c8012c69d02961486f88be66a1d3ce22d42 Mon Sep 17 00:00:00 2001 From: Jan Meis Date: Mon, 25 Mar 2024 08:37:48 +0100 Subject: [PATCH] TestAgreement for p-values --- R/estimators.R | 39 ++++++++++++++++------ R/evaluate_estimator.R | 76 +++++++++++++++++++++++++++++++++++++++++- 2 files changed, 104 insertions(+), 11 deletions(-) diff --git a/R/estimators.R b/R/estimators.R index 57fc129..0bc1f94 100644 --- a/R/estimators.R +++ b/R/estimators.R @@ -1265,8 +1265,8 @@ setMethod("get_stagewise_estimators", signature("MLEOrderingPValue", "Normal"), design, sigma, exact) { - g1 <- Vectorize(\(design, smean1, n1, sigma, two_armed, ...) p1_ml(design, smean1, n1, mu = 0, sigma, two_armed, ...), c("smean1")) - g2 <- Vectorize(\(design, smean1, smean2, n1, n2, sigma, two_armed, ...) p2_ml(design, smean1, smean2, n1, n2, mu = 0, sigma, two_armed, ...), c("smean1", "smean2", "n2")) + g1 <- Vectorize(\(design, smean1, n1, mu, sigma, two_armed, ...) p1_ml(design, smean1, n1, mu = 0, sigma, two_armed, ...), c("smean1")) + g2 <- Vectorize(\(design, smean1, smean2, n1, n2, mu, sigma, two_armed, ...) p2_ml(design, smean1, smean2, n1, n2, mu = 0, sigma, two_armed, ...), c("smean1", "smean2", "n2")) list(g1 = g1, g2 = g2) }) @@ -1282,8 +1282,8 @@ setMethod("get_stagewise_estimators", signature("LikelihoodRatioOrderingPValue", design, sigma, exact) { - g1 <- Vectorize(\(design, smean1, n1, sigma, two_armed, ...) p1_lr(design, smean1, n1, mu = 0, sigma, two_armed, ...), c("smean1")) - g2 <- Vectorize(\(design, smean1, smean2, n1, n2, sigma, two_armed, ...) p2_lr(design, smean1, smean2, n1, n2, mu = 0, sigma, two_armed, ...), c("smean1", "smean2", "n2")) + g1 <- Vectorize(\(design, smean1, n1, mu, sigma, two_armed, ...) p1_lr(design, smean1, n1, mu = 0, sigma, two_armed, ...), c("smean1")) + g2 <- Vectorize(\(design, smean1, smean2, n1, n2, mu, sigma, two_armed, ...) p2_lr(design, smean1, smean2, n1, n2, mu = 0, sigma, two_armed, ...), c("smean1", "smean2", "n2")) list(g1 = g1, g2 = g2) }) @@ -1299,8 +1299,8 @@ setMethod("get_stagewise_estimators", signature("ScoreTestOrderingPValue", "Norm design, sigma, exact) { - g1 <- Vectorize(\(smean1, n1, sigma, two_armed, ...) p1_st(smean1, n1, mu = 0, sigma, two_armed, ...), c("smean1")) - g2 <- Vectorize(\(design, smean1, smean2, n1, n2, sigma, two_armed, ...) p2_st(design, smean1, smean2, n1, n2, mu = 0, sigma, two_armed, ...), c("smean1", "smean2", "n2")) + g1 <- Vectorize(\(smean1, n1, mu, sigma, two_armed, ...) p1_st(smean1, n1, mu = 0, sigma, two_armed, ...), c("smean1")) + g2 <- Vectorize(\(design, smean1, smean2, n1, n2, mu, sigma, two_armed, ...) p2_st(design, smean1, smean2, n1, n2, mu = 0, sigma, two_armed, ...), c("smean1", "smean2", "n2")) list(g1 = g1, g2 = g2) }) @@ -1316,8 +1316,8 @@ setMethod("get_stagewise_estimators", signature("StagewiseCombinationFunctionOrd design, sigma, exact) { - g1 <- Vectorize(\(smean1, n1, sigma, two_armed, ...) p1_sw(smean1, n1, mu = 0, sigma, two_armed, ...), c("smean1")) - g2 <- Vectorize(\(design, smean1, smean2, n1, n2, sigma, two_armed, ...) p2_sw(design, smean1, smean2, n1, n2, mu = 0, sigma, two_armed, ...), c("smean1", "smean2", "n2")) + g1 <- Vectorize(\(smean1, n1, mu, sigma, two_armed, ...) p1_sw(smean1, n1, mu = 0, sigma, two_armed, ...), c("smean1")) + g2 <- Vectorize(\(design, smean1, smean2, n1, n2, mu, sigma, two_armed, ...) p2_sw(design, smean1, smean2, n1, n2, mu = 0, sigma, two_armed, ...), c("smean1", "smean2", "n2")) list(g1 = g1, g2 = g2) }) @@ -1335,8 +1335,27 @@ setMethod("get_stagewise_estimators", signature("NeymanPearsonOrderingPValue", " design, sigma, exact) { - g1 <- Vectorize(\(design, smean1, n1, sigma, two_armed, ...) p1_np(design, smean1, n1, mu = 0, mu0=estimator@mu0, mu1=estimator@mu1, sigma, two_armed, ...), c("smean1")) - g2 <- Vectorize(\(design, smean1, smean2, n1, n2, sigma, two_armed, ...) p2_np(design, smean1, smean2, n1, n2, mu = 0, mu0=estimator@mu0, mu1=estimator@mu1, sigma, two_armed, ...), c("smean1", "smean2", "n2")) + g1 <- Vectorize(\(design, smean1, n1, mu, sigma, two_armed, ...) p1_np(design, smean1, n1, mu = 0, mu0=estimator@mu0, mu1=estimator@mu1, sigma, two_armed, ...), c("smean1")) + g2 <- Vectorize(\(design, smean1, smean2, n1, n2, mu, sigma, two_armed, ...) p2_np(design, smean1, smean2, n1, n2, mu = 0, mu0=estimator@mu0, mu1=estimator@mu1, sigma, two_armed, ...), c("smean1", "smean2", "n2")) + list(g1 = g1, + g2 = g2) + }) +setClass("NaivePValue", contains = "VirtualPValue") +#' @rdname PValue-class +#' @export +NaivePValue <- function() new("NaivePValue", label = "Naive p-value") +#' @rdname get_stagewise_estimators +setMethod("get_stagewise_estimators", signature("NaivePValue", "Normal"), + function(estimator, + data_distribution, + use_full_twoarm_sampling_distribution, + design, + sigma, + exact) { + g1 <- Vectorize(\(smean1, n1, mu, sigma, two_armed, ...) pnorm(smean_to_z(smean1, n1, sigma, two_armed), lower.tail=FALSE), c("smean1")) + g2 <- Vectorize(\(design, smean1, smean2, n1, n2, mu, sigma, two_armed, ...) pnorm(smean_to_z(smeans_to_smean(smean1 = smean1, smean2 = smean2, n1 = n1, n2 = n2), + n = n1 + n2, sigma = sigma, two_armed = two_armed), + lower.tail=FALSE), c("smean1", "smean2", "n2")) list(g1 = g1, g2 = g2) }) diff --git a/R/evaluate_estimator.R b/R/evaluate_estimator.R index 34b6a96..9b01a84 100644 --- a/R/evaluate_estimator.R +++ b/R/evaluate_estimator.R @@ -42,7 +42,7 @@ setClass("EstimatorScore", slots = c(label = "character")) setClass("PointEstimatorScore", contains = "EstimatorScore") setClass("IntervalEstimatorScore", contains = "EstimatorScore") -EstimatorScoreResult <- setClass("EstimatorScoreResult", slots = c(score = "list", estimator = "Estimator", data_distribution = "DataDistribution", +EstimatorScoreResult <- setClass("EstimatorScoreResult", slots = c(score = "list", estimator = "Statistic", data_distribution = "DataDistribution", design = "TwoStageDesign", mu = "ANY", sigma = "numeric", results = "list", integrals = "list")) setClass("EstimatorScoreResultList", contains = "list") @@ -930,6 +930,80 @@ setMethod("evaluate_estimator", signature("TestAgreement", "IntervalEstimator"), conditional_integral) }) +#' @rdname evaluate_estimator-methods +setMethod("evaluate_estimator", signature("TestAgreement", "PValue"), + function(score, + estimator, + data_distribution, + use_full_twoarm_sampling_distribution, + design, + true_parameter, + mu, + sigma, + tol, + maxEval, + absError, + exact, + early_futility_part, + continuation_part, + early_efficacy_part, + conditional_integral) { + if (missing(true_parameter)) + true_parameter <- 0.05 + design <- TwoStageDesignWithCache(design) + stagewise_estimators <- get_stagewise_estimators(estimator = estimator, + data_distribution = data_distribution, + use_full_twoarm_sampling_distribution = use_full_twoarm_sampling_distribution, + design = design, sigma = sigma, exact = exact) + g1 <- stagewise_estimators[[1L]] + g2 <- stagewise_estimators[[2L]] + + if (is(data_distribution, "Student")) { + generate_g1 = \(tp) \(design, smean1, svar1, n1, two_armed, ...) { + t1 <- smean_to_t(smean1, svar1, n1, two_armed) + !xor(design@c1e < t1, g1(design = design, smean1 = smean1, svar1 = svar1, n1 = n1, two_armed = two_armed, ...) < true_parameter) + } + generate_g2 <- \(tp) \(design, smean1, svar1, smean2, svar2, n1, n2, two_armed, ...) { + t1 <- smean_to_t(smean1, svar1, n1, two_armed) + t2 <- smean_to_t(smean2, svar2, n2, two_armed) + c2 <- c2_extrapol(design, t1) + !xor(c2 < t2, g2(design = design, smean1 = smean1, svar1 = svar1, smean2 = smean2, svar2 = svar2, n1 = n1, n2 = n2, two_armed = two_armed, ...) < true_parameter ) + } + } else if (is(data_distribution, "Normal")) { + generate_g1 = \(tp) \(design, smean1, n1, sigma, two_armed, ...) { + z1 <- smean_to_z(smean1, n1, sigma, two_armed) + !xor(design@c1e < z1, g1(design = design, smean1 = smean1, n1 = n1, sigma = sigma, two_armed = two_armed, ...) < true_parameter) + } + generate_g2 <- \(tp) \(design, smean1, smean2, n1, n2, sigma, two_armed, ...) { + z1 <- smean_to_z(smean1, n1, sigma, two_armed) + z2 <- smean_to_z(smean2, n2, sigma, two_armed) + c2 <- c2_extrapol(design, z1) + !xor(c2 < z2, g2(design = design, smean1 = smean1, smean2 = smean2, n1 = n1, n2 = n2, sigma = sigma, two_armed = two_armed, ...) < true_parameter) + } + } else { + stop("This data_distribution class is not supported.") + } + .evaluate_estimator( + score, + estimator, + data_distribution, + use_full_twoarm_sampling_distribution, + design, + generate_g1, + generate_g2, + true_parameter, + mu, + sigma, + tol, + maxEval, + absError, + exact, + early_futility_part, + continuation_part, + early_efficacy_part, + conditional_integral) + }) + setClass("Centrality", contains = "PointEstimatorScore", slots = list(interval = "IntervalEstimator"))