Learn R Programming

simglm (version 0.8.0)

sim_pow: Master power simulation function.

Description

Input simulation conditions, returns power for term.

Usage

sim_pow(
  fixed,
  random = NULL,
  random3 = NULL,
  fixed_param,
  random_param = list(NULL),
  random_param3 = list(NULL),
  cov_param,
  k = NULL,
  n,
  p = NULL,
  error_var,
  with_err_gen,
  arima = FALSE,
  data_str,
  cor_vars = NULL,
  fact_vars = list(NULL),
  unbal = list(level2 = FALSE, level3 = FALSE),
  unbal_design = list(level2 = NULL, level3 = NULL),
  lvl1_err_params = NULL,
  arima_mod = list(NULL),
  contrasts = NULL,
  homogeneity = TRUE,
  heterogeneity_var = NULL,
  cross_class_params = NULL,
  knot_args = list(NULL),
  missing = FALSE,
  missing_args = list(NULL),
  pow_param,
  alpha,
  pow_dist = c("z", "t"),
  pow_tail = c(1, 2),
  replicates,
  terms_vary = NULL,
  raw_power = TRUE,
  lm_fit_mod = NULL,
  lme4_fit_mod = NULL,
  nlme_fit_mod = NULL,
  arima_fit_mod = NULL,
  general_mod = NULL,
  general_extract = NULL,
  ...
)

Arguments

fixed

One sided formula for fixed effects in the simulation. To suppress intercept add -1 to formula.

random

One sided formula for random effects in the simulation. Must be a subset of fixed.

random3

One sided formula for random effects at third level in the simulation. Must be a subset of fixed (and likely of random).

fixed_param

Fixed effect parameter values (i.e. beta weights). Must be same length as fixed.

random_param

A list of named elements that must contain:

  • random_var: variance of random parameters,

  • rand_gen: Name of simulation function for random effects.

Optional elements are:

  • ther: Theorectial mean and variance from rand_gen,

  • ther_sim: Simulate mean/variance for standardization purposes,

  • cor_vars: Correlation between random effects,

  • ...: Additional parameters needed for rand_gen function.

random_param3

A list of named elements that must contain:

  • random_var: variance of random parameters,

  • rand_gen: Name of simulation function for random effects.

Optional elements are:

  • ther: Theorectial mean and variance from rand_gen,

  • ther_sim: Simulate mean/variance for standardization purposes,

  • cor_vars: Correlation between random effects,

  • ...: Additional parameters needed for rand_gen function.

cov_param

List of arguments to pass to the continuous generating function, must be the same order as the variables specified in fixed. This list does not include intercept, time, factors, or interactions. Required arguments include:

  • dist_fun: This is a quoted R distribution function.

  • var_type: This is the level of variable to generate. Must be either 'single', 'level1', 'level2', or 'level3'. Must be same order as fixed formula above.

Optional arguments to the distribution functions are in a nested list, see the examples or vignettes for example code.

k

Number of third level clusters.

n

Cluster sample size.

p

Within cluster sample size.

error_var

Scalar of error variance.

with_err_gen

Distribution function to pass on to the level one simulation of errors.

arima

TRUE/FALSE flag indicating whether residuals should be correlated. If TRUE, must specify a valid model to pass to arima.sim via the arima_mod argument. See arima.sim for examples.

data_str

Type of data. Must be "cross", "long", or "single".

cor_vars

A vector of correlations between variables.

fact_vars

A nested list of factor, categorical, or ordinal variable specification, each list must include:

  • numlevels = Number of levels for ordinal or factor variables.

  • var_type = Must be 'single', 'level1', 'level2', or 'level3'.

Optional arguments include:

  • replace

  • prob

  • value.labels

See also sample for use of these optional arguments.

unbal

A named TRUE/FALSE list specifying whether unbalanced simulation design is desired. The named elements must be: "level2" or "level3" representing unbalanced simulation for level two and three respectively. Default is FALSE, indicating balanced sample sizes at both levels.

unbal_design

When unbal = TRUE, this specifies the design for unbalanced simulation in one of two ways. It can represent the minimum and maximum sample size within a cluster via a named list. This will be drawn from a random uniform distribution with min and max specified. Secondly, the actual sample sizes within each cluster can be specified. This takes the form of a vector that must have the same length as the level two or three sample size. These are specified as a named list in which level two sample size is controlled via "level2" and level three sample size is controlled via "level3".

lvl1_err_params

Additional parameters passed as a list on to the level one error generating function

arima_mod

A list indicating the ARIMA model to pass to arima.sim. See arima.sim for examples.

contrasts

An optional list that specifies the contrasts to be used for factor variables (i.e. those variables with .f or .c). See contrasts for more detail.

homogeneity

Either TRUE (default) indicating homogeneity of variance assumption is assumed or FALSE to indicate desire to generate heterogeneity of variance.

heterogeneity_var

Variable name as a character string to use for heterogeneity of variance simulation.

cross_class_params

A list of named parameters when cross classified data structures are desired. Must include the following arguments:

  • num_ids: The number of cross classified clusters. These are in addition to the typical cluster ids

  • random_param: This argument is a list of arguments passed to sim_rand_eff. These must include:

    • random_var: The variance of the cross classified random effect

    • rand_gen: The random generating function used to generate the cross classified random effect.

    Optional elements are:

    • ther: Theorectial mean and variance from rand_gen,

    • ther_sim: Simulate mean/variance for standardization purposes,

    • cor_vars: Correlation between random effects,

    • ...: Additional parameters needed for rand_gen function.

knot_args

A nested list of named knot arguments. See sim_knot for more details. Arguments must include:

  • var

  • knot_locations

missing

TRUE/FALSE flag indicating whether missing data should be simulated.

missing_args

Additional missing arguments to pass to the missing_data function. See missing_data for examples.

pow_param

Number of parameter to calculate power includes intercept where applicable.

alpha

What should the per test alpha rate be used for the hypothesis testing.

pow_dist

Which distribution should be used when testing hypothesis test, z or t?

pow_tail

One-tailed or two-tailed test?

replicates

How many replications should be done (i.e. the denominator in power calculation).

terms_vary

A named list of terms that should vary as a function for the power simulation. The names must match arguments to the simulation function, see sim_reg for examples. Values specified here should not be included as arguments in the function call.

raw_power

TRUE/FALSE indicating whether raw power output should be returned. Default is TRUE, which will create a new nested column with raw data by variable(s) manipulated in power analysis.

lm_fit_mod

Valid lm syntax to be used for model fitting.

lme4_fit_mod

Valid lme4 syntax to be used for model fitting.

nlme_fit_mod

Valid nlme syntax to be used for model fitting. This should be specified as a named list with fixed and random components.

arima_fit_mod

Valid nlme syntax for fitting serial correlation structures. See corStruct for help. This must be specified to include serial correlation.

general_mod

Valid model syntax. This syntax can be from any R package. By default, broom is used to extract model result information. Note, package must be defined or loaded prior to running the sim_pow function.

general_extract

A valid function to extract model results if general_mod argument is used. This argument is primarily used if extracting model results is not possibly using the broom package. If this is left NULL (default), broom is used to collect model results.

...

Currently not used.

Details

This function is a wrapper that replicates the simulation functions for simple regression and the linear mixed model power functions. This function replicates the power call a specified number of times and prints outs a matrix with the results.