Metadata-Version: 2.4
Name: linearmodels
Version: 7.0
Summary: Linear Panel, Instrumental Variable, Asset Pricing, and System Regression models for Python
Keywords: linear models,regression,instrumental variables,IV,panel,fixed effects,clustered,heteroskedasticity,endogeneity,instruments,statistics,statistical inference,econometrics
Author-Email: Kevin Sheppard <kevin.k.sheppard@gmail.com>
Maintainer-Email: Kevin Sheppard <kevin.k.sheppard@gmail.com>
License-Expression: NCSA
License-File: LICENSE.md
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: End Users/Desktop
Classifier: Intended Audience :: Financial and Insurance Industry
Classifier: Intended Audience :: Science/Research
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Classifier: Operating System :: MacOS :: MacOS X
Classifier: Operating System :: Microsoft :: Windows
Classifier: Operating System :: POSIX
Classifier: Programming Language :: Python
Classifier: Programming Language :: Cython
Classifier: Topic :: Scientific/Engineering
Project-URL: homepage, https://github.com/bashtage/linearmodels
Project-URL: documentation, https://bashtage.github.io/linearmodels/
Project-URL: repository, https://github.com/bashtage/linearmodels
Project-URL: changelog, https://bashtage.github.io/linearmodels/changes.html
Requires-Python: >=3.10
Requires-Dist: numpy<3,>=1.22.3
Requires-Dist: pandas>=1.4.0
Requires-Dist: scipy>=1.8.0
Requires-Dist: statsmodels>=0.13.0
Requires-Dist: mypy_extensions>=0.4
Requires-Dist: pyhdfe>=0.1
Requires-Dist: formulaic>=1.2.1
Provides-Extra: test
Requires-Dist: pytest<9,>=8.4.1; extra == "test"
Requires-Dist: pytest-randomly; extra == "test"
Requires-Dist: pytest-xdist; extra == "test"
Requires-Dist: pytest-cov; extra == "test"
Requires-Dist: coverage[toml]; extra == "test"
Requires-Dist: meson; extra == "test"
Requires-Dist: ninja; extra == "test"
Provides-Extra: doc
Requires-Dist: setuptools>=61; extra == "doc"
Requires-Dist: wheel; extra == "doc"
Requires-Dist: setuptools_scm[toml]<9,>=8.0.3; extra == "doc"
Requires-Dist: oldest-supported-numpy; extra == "doc"
Requires-Dist: cython<4,>=3.0.13; extra == "doc"
Requires-Dist: numpy>=1.22; extra == "doc"
Requires-Dist: scipy>=1.5.0; extra == "doc"
Requires-Dist: ipython>=8.0.1; extra == "doc"
Requires-Dist: matplotlib>=3.0; extra == "doc"
Requires-Dist: patsy>=0.5.3; extra == "doc"
Requires-Dist: statsmodels>=0.13.5; extra == "doc"
Requires-Dist: jinja2; extra == "doc"
Requires-Dist: sphinx>=7; extra == "doc"
Requires-Dist: seaborn; extra == "doc"
Requires-Dist: numpydoc>=1.0.0; extra == "doc"
Requires-Dist: nbsphinx; extra == "doc"
Requires-Dist: sphinx-immaterial; extra == "doc"
Requires-Dist: jupyter; extra == "doc"
Requires-Dist: notebook; extra == "doc"
Requires-Dist: sphinx-autodoc-typehints; extra == "doc"
Requires-Dist: fonttools>=4.43.0; extra == "doc"
Requires-Dist: jupyterlab>=4.4.8; extra == "doc"
Requires-Dist: ipython>=7; extra == "doc"
Requires-Dist: sphinx_immaterial; extra == "doc"
Requires-Dist: nbconvert; extra == "doc"
Requires-Dist: pickleshare; extra == "doc"
Requires-Dist: pandas~=2.3.3; extra == "doc"
Requires-Dist: sphinxcontrib-spelling; extra == "doc"
Requires-Dist: sphinx_autodoc_typehints; extra == "doc"
Provides-Extra: dev
Requires-Dist: xarray>=0.16; extra == "dev"
Requires-Dist: pandas-stubsl; extra == "dev"
Requires-Dist: wheel; extra == "dev"
Requires-Dist: setuptools_scm[toml]<10,>=9.2.0; extra == "dev"
Requires-Dist: packaging; extra == "dev"
Requires-Dist: cython>=3.0.10; extra == "dev"
Requires-Dist: numba>=0.55; extra == "dev"
Requires-Dist: matplotlib>=3; extra == "dev"
Requires-Dist: seaborn; extra == "dev"
Requires-Dist: pytest<9,>=8.4.1; extra == "dev"
Requires-Dist: pytest-randomly; extra == "dev"
Requires-Dist: pytest-xdist; extra == "dev"
Requires-Dist: pytest-cov; extra == "dev"
Requires-Dist: black[jupyter]~=25.9.0; extra == "dev"
Requires-Dist: isort~=6.0; extra == "dev"
Requires-Dist: colorama; extra == "dev"
Requires-Dist: flake8; extra == "dev"
Requires-Dist: flake8-bugbear; extra == "dev"
Requires-Dist: mypy>=1.3; extra == "dev"
Requires-Dist: ruff>=0.8.6; extra == "dev"
Requires-Dist: pyupgrade>=3.4.0; extra == "dev"
Requires-Dist: jupyterlab-code-formatter; extra == "dev"
Requires-Dist: jupyterlab>=4.4.8; extra == "dev"
Requires-Dist: zipp>=3.19.1; extra == "dev"
Description-Content-Type: text/markdown

# Linear Models

| Metric                     |                                                                                                                                                                                                                                                          |
| :------------------------- | :------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| **Latest Release**         | [![PyPI version](https://badge.fury.io/py/linearmodels.svg)](https://badge.fury.io/py/linearmodels)                                                                                                                                                      |
| **Continuous Integration** | [![Build Status](https://dev.azure.com/kevinksheppard/kevinksheppard/_apis/build/status/bashtage.linearmodels?branchName=main)](https://dev.azure.com/kevinksheppard/kevinksheppard/_build/latest?definitionId=2&branchName=main)                        |
| **Coverage**               | [![codecov](https://codecov.io/gh/bashtage/linearmodels/branch/main/graph/badge.svg)](https://codecov.io/gh/bashtage/linearmodels)                                                                                                                       |
| **Code Quality**           | [![Codacy Badge](https://api.codacy.com/project/badge/Grade/745a24a69cb2466b95df6a53c83892de)](https://www.codacy.com/manual/bashtage/linearmodels?utm_source=github.com&utm_medium=referral&utm_content=bashtage/linearmodels&utm_campaign=Badge_Grade) |
| **Citation**               | [![DOI](https://zenodo.org/badge/82291672.svg)](https://zenodo.org/badge/latestdoi/82291672)                                                                                                                                                             |

Linear (regression) models for Python. Extends
[statsmodels](http://www.statsmodels.org) with Panel regression,
instrumental variable estimators, system estimators and models for
estimating asset prices:

-   **Panel models**:
    -   Fixed effects (maximum two-way)
    -   First difference regression
    -   Between estimator for panel data
    -   Pooled regression for panel data
    -   Fama-MacBeth estimation of panel models

-   **High-dimensional Regresssion**:
    -   Absorbing Least Squares

-   **Instrumental Variable estimators**
    -   Two-stage Least Squares
    -   Limited Information Maximum Likelihood
    -   k-class Estimators
    -   Generalized Method of Moments, also with continuously updating

-   **Factor Asset Pricing Models**:
    -   2- and 3-step estimation
    -   Time-series estimation
    -   GMM estimation

-   **System Regression**:
    -   Seemingly Unrelated Regression (SUR/SURE)
    -   Three-Stage Least Squares (3SLS)
    -   Generalized Method of Moments (GMM) System Estimation

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

## Panel models

Like [statsmodels](http://www.statsmodels.org) to include, supports
formulas for specifying models. For example, the classic Grunfeld regression can be
specified

```python
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.

```python
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 values
`EntityEffects` and `TimeEffects` which add entity (fixed) and time
effects, respectively.

Formula support comes from the [formulaic](https://github.com/matthewwardrop/formulaic/)
package which is a replacement for [patsy](https://patsy.readthedocs.io/en/latest/).

## Instrumental Variable Models

IV regression models can be similarly specified.

```python
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

```bash
pip install linearmodels
```

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

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

## Documentation

[Stable Documentation](https://bashtage.github.io/linearmodels/) is
built on every tagged version using
[doctr](https://github.com/drdoctr/doctr).
[Development Documentation](https://bashtage.github.io/linearmodels/devel)
is 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.

-   Linear Instrumental variable estimation - **complete**
-   Linear Panel model estimation - **complete**
-   Fama-MacBeth regression - **complete**
-   Linear Factor Asset Pricing - **complete**
-   System regression - **complete**
-   Linear IV Panel model estimation - _not started_
-   Dynamic Panel model estimation - _not started_

## Requirements

### Running

-   Python 3.10+
-   NumPy (1.22+)
-   SciPy (1.8+)
-   pandas (1.4+)
-   statsmodels (0.13.1+)
-   formulaic (1.0.0+)
-   xarray (0.16+, optional)
-   Cython (3.0.10+, optional)


### Testing

-   py.test

### Documentation

-   sphinx
-   sphinx-immaterial
-   nbsphinx
-   nbconvert
-   nbformat
-   ipython
-   jupyter
