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.
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4