Run Prepost bounds
Usage
prepost_bounds(
formula,
data,
moderator,
prepost,
sims = 1000,
conf_level = 0.95,
moderator_mono = NULL,
outcome_mono = NULL,
stable_mod = FALSE,
tau = 0.25,
progress = TRUE,
solver = "Rglpk"
)
Arguments
- formula
A formula with syntax
y ~ t
, wherey
is the (unquoted) name of the outcome andt
is the (unquoted) name of the treatment.- data
A data.frame containing variables in the formula, moderator, and covariates arguments.
- moderator
A one-sided formuala with syntax
~ d
, whered
is the (unquoted) name of the moderator variable for the CATE.- prepost
A one-sided formula with syntax ~ z, where z is the indicator variable for whether the moderator was measured pre- or post-treatment.
- sims
An integer specifying the number of bootstrap replications for the confidence intervals.
- conf_level
A numeric specifying level for the confidence intervals.
- moderator_mono
A integer or vector of length 2 indicating if the bounds should assume monotonicity of the effect of the post-test on the moderator with
1
indicating that the post-test effect is positive and-1
indicating that it is negative. The vector of length 2 allows the monotonicity assumption to vary by treatment status with the first entry being for control and the second for treated.- outcome_mono
A integer or vector of length 2 indicating if the bounds should assume monotonicity of the effect of the post-test on the outcome with
1
indicating that the post-test effect is positive and-1
indicating that it is negative. The vector of length 2 allows the monotonicity assumption to vary by treatment status with the first entry being for control and the second for treated.- stable_mod
A logical value indicating if the bounds should assume that the moderator is unaffected by pre-vs-post measurement under the control condition.
- tau
A numeric indicating how close the the moment conditions of the estimated bounds have to be from the minimum values in the sample. This allows us to obtain bounds and confidence intevals even when the assumptions are slightly violated due to sampling.
- progress
A logical indicating if progress bars should be displayed. Defaults to TRUE.
- solver
A character indicating what linear programming solver to use: "Rglpk" (the default) or "lpSolve".
Examples
data(land_experiment)
prepost_bounds(
support ~ treat_comb,
data = land_experiment,
moderator = ~ land_insecure,
prepost = ~ prepost,
sims = 50
)
#> Bootstrap running...
#> 0% |== | 100%
#> 0% |==== | 100%
#> 0% |====== | 100%
#> 0% |======== | 100%
#> 0% |========== | 100%
#> 0% |============ | 100%
#> 0% |============== | 100%
#> 0% |================ | 100%
#> 0% |================== | 100%
#> 0% |====================| 100%
#> $Q
#> [1] 0.07446809
#>
#> $upper
#> [1] 1.078787
#>
#> $lower
#> [1] -1.082133
#>
#> $solution_L
#> [1] 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000 0.777777778
#> [7] 0.000000000 0.222222222 0.400000000 0.000000000 0.249769585 0.000000000
#> [13] 0.000000000 0.000000000 0.350230415 0.000000000 0.121011494 0.008643678
#> [19] 0.000000000 0.000000000 0.630260870 0.118344828 0.121739130 0.000000000
#> [25] 0.000000000 0.052280311 0.000000000 0.000000000 0.672234686 0.156840934
#> [31] 0.118644068 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000
#> [37] 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000
#> [43] 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000
#> [49] 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000
#> [55] 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000
#> [61] 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000
#> [67] 0.000000000 0.000000000 0.805531915 0.925531915 0.000000000 0.000000000
#> [73] 0.751272364 0.672234686 0.000000000 0.000000000 0.000000000 0.000000000
#> [79] 0.222222222 0.400000000 0.000000000 0.000000000
#>
#> $solution_U
#> [1] 0.777777778 0.000000000 0.222222222 0.000000000 0.000000000 0.000000000
#> [7] 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000
#> [13] 0.000000000 0.400000000 0.000000000 0.600000000 0.040551724 0.008643678
#> [19] 0.000000000 0.000000000 0.630260870 0.198804598 0.121739130 0.000000000
#> [25] 0.052280311 0.052280311 0.000000000 0.000000000 0.700414145 0.076381164
#> [31] 0.118644068 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000
#> [37] 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000
#> [43] 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000
#> [49] 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000
#> [55] 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000
#> [61] 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000 0.000000000
#> [67] 0.000000000 0.000000000 0.954468085 0.828757721 0.000000000 0.000000000
#> [73] 0.670812594 0.752694456 0.000000000 0.000000000 0.000000000 0.000000000
#> [79] 0.777777778 0.600000000 0.000000000 0.000000000
#>
#> $deviation
#> [1] 0
#>
#> $ci_lower
#> [1] -1.202693
#>
#> $ci_upper
#> [1] 1.182806
#>
#> $pre_est
#> [1] 0.3808728
#>
#> $post_est
#> [1] 0.48171
#>