GitHub - bashtage/linearmodels: Additional linear models including instrumental variable and panel data models that are missing from statsmodels. (original) (raw)

Linear Models

Metric
Latest Release PyPI version
Continuous Integration Build Status
Coverage codecov
Code Quality Codacy Badge
codebeat badge
Citation DOI

Linear (regression) models for Python. Extendsstatsmodels with Panel regression, instrumental variable estimators, system estimators and models for estimating asset prices:

Designed to work equally well with NumPy, Pandas or xarray data.

Panel models

Like statsmodels to include, supports formulas for specifying models. For example, the classic Grunfeld regression can be specified

import numpy as np from statsmodels.datasets import grunfeld data = grunfeld.load_pandas().data data.year = data.year.astype(np.int64)

MultiIndex, entity - time

data = data.set_index(['firm','year']) from linearmodels import PanelOLS mod = PanelOLS(data.invest, data[['value','capital']], entity_effects=True) res = mod.fit(cov_type='clustered', cluster_entity=True)

Models can also be specified using the formula interface.

from linearmodels import PanelOLS mod = PanelOLS.from_formula('invest ~ value + capital + EntityEffects', data) res = mod.fit(cov_type='clustered', cluster_entity=True)

The formula interface for PanelOLS supports the special valuesEntityEffects and TimeEffects which add entity (fixed) and time effects, respectively.

Formula support comes from the formulaicpackage which is a replacement for patsy.

Instrumental Variable Models

IV regression models can be similarly specified.

import numpy as np from linearmodels.iv import IV2SLS from linearmodels.datasets import mroz data = mroz.load() mod = IV2SLS.from_formula('np.log(wage) ~ 1 + exper + exper ** 2 + [educ ~ motheduc + fatheduc]', data)

The expressions in the [ ] indicate endogenous regressors (before ~) and the instruments.

Installing

The latest release can be installed using pip

The main branch can be installed by cloning the repo and running setup

git clone https://github.com/bashtage/linearmodels cd linearmodels pip install .

Documentation

Stable Documentation is built on every tagged version usingdoctr.Development Documentationis automatically built on every successful build of main.

Plan and status

Should eventually add some useful linear model estimators such as panel regression. Currently only the single variable IV estimators are polished.

Requirements

Running

Testing

Documentation