This package estimates heterogeneous effects in factorial and conjoint experiments. Its details are fully described in Goplerud, Imai, and Pashley (2025): “Estimating Heterogeneous Causal Effects of High-Dimensional Treatments: Application to Conjoint Analysis”.
The core method is a Bayesian regularized finite mixture-of-experts where moderators can affect an individual’s probability of cluster membership and a sparsity-inducing prior fuses together levels of each factor in each cluster while respecting ANOVA-style sum-to-zero constraints described in Egami and Imai (2019). The posterior mode is found using an AECM algorithm with a number of techniques to accelerate convergence. Approximate quantification of uncertainty is provided by examining the Hessian of the log-posterior. Additional details are explained in the paper and (briefly) in the package documentation.
It can be installed from CRAN or the most-to-update version can be
installed using devtools
. Note, macOS users may need to
ensure that XQuartz is installed; please see information from CRAN (here) for more
details.
# CRAN
install.packages("FactorHet")
# Up-to-Date GitHub Version
library(devtools)
devtools::install_github('mgoplerud/FactorHet')
There are two key functions for estimating the model: In most cases,
one will prefer to use the FactorHet_mbo
function to
jointly (i) estimate the amount of regularization by minimizing a
criterion such as the BIC using model-based optimization and (ii)
estimate the final model. However, if one has a specific value of
lambda
of interest, one can fit the model for a fixed
amount of regularization using FactorHet
. A simple example
is shown below:
fit_FH <- FactorHet_mbo(
formula = y ~ factor_1 + factor_2 + factor_1 : factor_2,
design = design,
moderator = ~ moderator_1 + moderator_2)
In the case of repeated observations, the individual is specified via
group
and the task identifier is specified via
task
. In the case of a conjoint experiment, the profile
identifier (i.e. “left” or “right”) is specified via
choice_order
. An example is shown below:
fit_FH <- FactorHet_mbo(
formula = y ~ factor_1 + factor_2 + factor_1 : factor_2,
design = design, moderator = ~ moderator_1 + moderator_2,
group = ~ id, task = ~ task, choice_order = ~ choice_left)
Finally, after fitting the model, there are functions to calculate the Average Marginal Effect (AME) and related concepts (e.g. ACE, AMIE). A simple example is shown below:
AME(fit_FH)
The effects of moderators on cluster membership can be analyzed using
two key functions; first, posterior_by_moderators
shows the
estimated distribution of (posterior) cluster membership probabilities
by covariates. Second, margeff_moderators
shows the change
in the prior cluster membership as one moderator changes, averaging
across all other moderators. This is similar to a marginal effect in a
multinomial logistic regression. Example code is shown below:
posterior_by_moderators(fit_FH)
margeff_moderators(fit_FH)
Some function names (e.g., AME
and
margeff_moderators
) have been changed for clarity from an
older verison of those package. Those functions should still run but
will throw a warning and should be updated in existing code.