| ezdm_summary_stats | R Documentation |
Computes robust summary statistics for the EZ-Diffusion Model by fitting mixture models to raw trial-level RT data, separating contaminant responses from true responses.
ezdm_summary_stats(
rt,
response,
version = c("3par", "4par"),
distribution = c("exgaussian", "lognormal", "invgaussian"),
method = c("mixture", "simple", "robust"),
robust_scale = c("iqr", "mad"),
contaminant_bound = c("min", "max"),
min_trials = 10,
init_contaminant = 0.05,
max_contaminant = 0.5,
maxit = 100,
tol = 1e-06
)
rt |
Numeric vector of reaction times in seconds. |
response |
Vector of response indicators. Accepts multiple formats:
|
version |
Character. Either "3par" (default) for pooled RTs or "4par" for separate upper/lower boundary RTs. Controls the output columns. |
distribution |
Character. The parametric distribution for the RT component. One of "exgaussian" (default), "lognormal", or "invgaussian" |
method |
Character. One of "mixture" (default) for robust estimation via mixture modeling, "robust" for non-parametric robust estimation using median and IQR/MAD-based variance, or "simple" for standard moment calculation. The "robust" method is faster and requires no distributional assumptions, but note that the EZ equations were derived for mean and variance, so using median may introduce some bias for skewed distributions. |
robust_scale |
Character. Scale estimator for robust method. Either "iqr" (default) for IQR-based variance estimation (variance = (IQR/1.349)^2) or "mad" for MAD-based estimation (variance = MAD^2, where MAD is scaled to be consistent with SD for normal data). Only used when method = "robust". |
contaminant_bound |
Vector of length 2 specifying the bounds (in seconds) for the uniform contaminant distribution. Can be numeric values or the special strings "min" and "max" to use data-driven bounds (default):
The buffer extends data-driven bounds to ensure conservative estimates. Examples: c(0.1, 3.0), c("min", "max"), c(0.1, "max"), c("min", 3.0) |
min_trials |
Integer. Minimum number of trials required for fitting. Returns NA if fewer trials are available. Default is 10 |
init_contaminant |
Numeric. Initial proportion of contaminants for EM algorithm. Default is 0.05 |
max_contaminant |
Numeric. Maximum allowed contaminant proportion (0 < max <= 1). Estimates are clipped to this value to prevent inflated contaminant proportions. Default is 0.5 |
maxit |
Integer. Maximum number of EM iterations. Default is 100 |
tol |
Numeric. Convergence tolerance for EM algorithm. Default is 1e-6 |
RT outliers and contaminant responses (fast guesses, lapses of attention) can distort the mean and variance estimates used as input to the EZ-Diffusion equations. This function addresses this by fitting a mixture model with two components: a uniform distribution for contaminants and a parametric RT distribution for true responses. Robust moments are then extracted from the fitted parametric component.
This function is designed to work with dplyr::group_by() and
dplyr::reframe() for grouped operations. Use adjust_ezdm_accuracy()
as a separate step if you need to adjust accuracy counts for
contamination.
A 1-row data.frame. For version = "3par": mean_rt, var_rt,
n_upper, n_trials, contaminant_prop. For version = "4par":
mean_rt_upper, mean_rt_lower, var_rt_upper, var_rt_lower,
n_upper, n_trials, contaminant_prop_upper, contaminant_prop_lower.
adjust_ezdm_accuracy() for adjusting accuracy counts,
flag_contaminant_rts() for trial-level contamination probabilities,
ezdm() for fitting the EZ-Diffusion Model
# Generate example data
set.seed(123)
rt <- rgamma(100, shape = 5, rate = 10) + 0.3
response <- rbinom(100, 1, 0.8)
# 3par summary stats
ezdm_summary_stats(rt, response)
# With dplyr for grouped operations
# library(dplyr)
# mydata |>
# group_by(subject) |>
# reframe(ezdm_summary_stats(rt, response))
# 4par version with separate upper/lower moments
ezdm_summary_stats(rt, response, version = "4par")
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.