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

53,517

Version

0.8.2

License

GPL-3

Issues

Pull Requests

Stars

Forks

Maintainer

Laurent Berge

Last Published

February 11th, 2021

Functions in fixest (0.8.2)

coeftable

Obtain various statistics from an estimation
as.list.fixest_multi

Transforms a fixest_multi object into a list
bread.fixest

Extracts the bread matrix from fixest objects
coef.fixest

Extracts the coefficients from a fixest estimation
coefplot

Plots confidence intervals and point estimates
base_did

Sample data for difference in difference
AIC.fixest

Aikake's an information criterion
$.fixest_multi

Extracts the root of a fixest_multi object
aggregate.fixest

Aggregates the values of DiD coefficients a la Sun and Abraham
BIC.fixest

Bayesian information criterion
did_means

Treated and control sample descriptives
confint.fixest

Confidence interval for parameters estimated with fixest
deviance.fixest

Extracts the deviance of a fixest estimation
collinearity

Collinearity diagnostics for fixest objects
demean

Centers a set of variables around a set of factors
etable

Estimations table (export the results of multiples estimations to a DF or to Latex)
estfun.fixest

Extracts the scores from a fixest estimation
dof

Type of degree of freedom in fixest summary
feglm

Fixed-effects GLM estimations
feNmlm

Fixed effects nonlinear maximum likelihood models
femlm

Fixed-effects maximum likelihood model
_index_

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

Extract the formula of a fixest fit
fitstat_register

Register custom fit statistics
feols

Fixed-effects OLS estimation
fitstat

Computes fit statistics of fixest objects
fixef.fixest

Extract the Fixed-Effects from a fixest estimation.
fitted.fixest

Extracts fitted values from a fixest fit
fixest-deprecated

Deprecated functions in package fixest.
nobs.fixest

Extracts the number of observations form a fixest object
fixef_reexported

Functions exported from nlme to implement fixest methods
logLik.fixest

Extracts the log-likelihood
obs2remove

Finds observations to be removed from ML estimation with fixed-effects
model.matrix.fixest

Design matrix of a femlm model
sandwich_reexported

Functions exported from sandwich to implement fixest methods
resid.fixest

Extracts residuals from a fixest object
i

Create, or interact variables with, factors
setFixest_coefplot

Sets the defaults of coefplot
hatvalues.fixest

Hat values for fixest objects
setFixest_dict

Sets/gets the dictionary relabeling the variables
lag.formula

Lags a variable using a formula
print.fixest_fitstat

Print method for fit statistics of fixest estimations
f

Lags a variable in a fixest estimation
print.fixest_multi

Print method for fixest_multi objects
plot.fixest.fixef

Displaying the most notable fixed-effects
panel

Constructs a fixest panel data base
predict.fixest

Predict method for fixest fits
setFixest_fml

Sets/gets formula macros
setFixest_estimation

Default arguments for fixest estimations
style.tex

Style definitions for Latex tables
[.fixest_multi

Subset a fixest_multi object
setFixest_se

Sets the default type of standard errors to be used
sigma.fixest

Residual standard deviation of fixest estimations
print.fixest

A print facility for fixest objects.
setFixest_notes

Sets/gets whether to display notes in fixest estimation functions
terms.fixest

Extract the terms
to_integer

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

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

Sets/gets the number of threads to use in fixest functions
summary.fixest.fixef

Summary method for fixed-effects coefficients
wald

Wald test of nullity of coefficients
summary.fixest_multi

Summary for fixest_multi objects
summary.fixest.obs2remove

Summary method for fixest.obs2remove objects
r2

R2s of fixest models
rep.fixest

Replicates fixest objects
[[.fixest_multi

Extracts one element from a fixest_multi object
stepwise

Stepwise estimation tools
weights.fixest

Extracts the weights from a fixest object
vcov.fixest

Computes the variance/covariance of a fixest object
update.fixest

Updates a fixest estimation
style.df

Style of data.frames created by etable
[.fixest_panel

Method to subselect from a fixest_panel
unpanel

Dissolves a fixest panel
xpd

Expands formula macros
trade

Trade data sample