Learn R Programming

⚠️There's a newer version (0.12.1) of this package.Take me there.

fixest: Fast and user-friendly fixed-effects estimation

The fixest package offers a family of functions to perform estimations with multiple fixed-effects in both an OLS and a GLM context. Please refer to the introduction for a walk-through.

At the time of writing of this page (February 2020), fixest is the fastest existing method to perform fixed-effects estimations, often by orders of magnitude. See below for a benchmarking with the fastest alternative software.

Benchmarking

Here is a comparison of the performance of fixest functions to other state of the art methods to perform estimations with multiple fixed-effects. The results are reported in the five figures below. Package fixest (black lines) is consistently faster in all situations.

Setup

The benchmarking was performed as follows: In the OLS context, we estimate the following equation:

The same functional form (one variable, three fixed-effects) is estimated for the Poisson, the Negative Binomial and the Logit cases (with ad hoc modifications to fit each model). See Berge (2018) for more details on the setup.

For the "difficult" benchmark (OLS only), the data is generated in a way that makes the convergence of the fixed-effects slow. The phenomenon of slow convergence is frequent for real micro-level data sets involving employee and firm fixed-effects for instance.

Each estimation is replicated 10 times and the average computing time is reported in the figures.

The alternative methods used for comparison are:

  • OLS: felm (R: package lfe), reghdfe (Stata) and FixedEffectModels (Julia)
  • Poisson: glmmboot (R: package glmmML), feglm (R: package alpaca) and ppmlhdfe (Stata)
  • Negative Binomial: glm.nb (R: package MASS) and nbreg (Stata)
  • Logit: glmmboot (R: package glmmML), feglm (R: package alpaca) and logit (Stata)

All the aforementioned packages were updated at the benchmarking date: February 2020.

The code and data for the benchmarking can be found in this folder.

Acknowledgements

Of course the development of fixest has been inspired and pushed forward by (almost all) these (great) packages used in the benchmarking and I am deeply indebted to their authors. Although fixest contains many features, some are still uncovered and you should definitely have a look at these packages.

Copy Link

Version

Install

install.packages('fixest')

Monthly Downloads

28,663

Version

0.8.0

License

GPL-3

Maintainer

Laurent Berge

Last Published

December 14th, 2020

Functions in fixest (0.8.0)

$.fixest_multi

Extracts the root of a fixest_multi object
BIC.fixest

Bayesian information criterion
base_did

Sample data for difference in difference
bread.fixest

Extracts the bread matrix from fixest objects
collinearity

Collinearity diagnostics for fixest objects
AIC.fixest

Aikake's an information criterion
as.list.fixest_multi

Transforms a fixest_multi object into a list
coef.fixest

Extracts the coefficients from a fixest estimation
coefplot

Plots confidence intervals and point estimates
coeftable

Obtain various statistics from an estimation
deviance.fixest

Extracts the deviance of a fixest estimation
dof

Type of degree of freedom in fixest summary
estfun.fixest

Extracts the scores from a fixest estimation
etable

Estimations table (export the results of multiples estimations to a DF or to Latex)
feNmlm

Fixed effects nonlinear maximum likelihood models
did_means

Treated and control sample descriptives
fitted.fixest

Extracts fitted values from a fixest fit
demean

Centers a set of variables around a set of factors
confint.fixest

Confidence interval for parameters estimated with fixest
fitstat_register

Register custom fit statistics
fixef.fixest

Extract the Fixed-Effects from a fixest estimation.
feglm

Fixed-effects GLM estimations
femlm

Fixed-effects maximum likelihood model
fixest-deprecated

Deprecated functions in package fixest.
fixef_reexported

Functions exported from nlme to implement fixest methods
lag.formula

Lags a variable using a formula
formula.fixest

Extract the formula of a fixest fit
plot.fixest.fixef

Displaying the most notable fixed-effects
_index_

Fast and User-Friendly Fixed-Effects Estimations
predict.fixest

Predict method for fixest fits
hatvalues.fixest

Hat values for fixest objects
resid.fixest

Extracts residuals from a fixest object
rep.fixest

Replicates fixest objects
print.fixest_multi

Print method for fixest_multi objects
r2

R2s of fixest models
style.tex

Style definitions for Latex tables
style.df

Style of data.frames created by etable
[.fixest_panel

Method to subselect from a fixest_panel
[.fixest_multi

Subset a fixest_multi object
i

Create, or interact variables with, factors
f

Lags a variable in a fixest estimation
model.matrix.fixest

Design matrix of a femlm model
nobs.fixest

Extracts the number of observations form a fixest object
logLik.fixest

Extracts the log-likelihood
sandwich_reexported

Functions exported from sandwich to implement fixest methods
feols

Fixed-effects OLS estimation
setFixest_nthreads

Sets/gets the number of threads to use in fixest functions
[[.fixest_multi

Extracts one element from a fixest_multi object
xpd

Expands formula macros
summary.fixest

Summary of a fixest object. Computes different types of standard errors.
weights.fixest

Extracts the weights from a fixest object
summary.fixest.fixef

Summary method for fixed-effects coefficients
summary.fixest.obs2remove

Summary method for fixest.obs2remove objects
print.fixest_fitstat

Print method for fit statistics of fixest estimations
setFixest_fml

Sets/gets formula macros
print.fixest

A print facility for fixest objects.
setFixest_notes

Sets/gets whether to display notes in fixest estimation functions
fitstat

Computes fit statistics of fixest objects
panel

Constructs a fixest panel data base
obs2remove

Finds observations to be removed from ML estimation with fixed-effects
setFixest_estimation

Default arguments for fixest estimations
setFixest_se

Sets the default type of standard errors to be used
unpanel

Dissolves a fixest panel
setFixest_dict

Sets/gets the dictionary relabeling the variables
setFixest_coefplot

Sets the defaults of coefplot
to_integer

Fast transform of any type of vector(s) into an integer vector
update.fixest

Updates a fixest estimation
sigma.fixest

Residual standard deviation of fixest estimations
vcov.fixest

Extracts the variance/covariance of a femlm fit
trade

Trade data sample
wald

Wald test of nullity of coefficients
summary.fixest_multi

Summary for fixest_multi objects
stepwise

Stepwise estimation tools
terms.fixest

Extract the terms