Skip to main content

Python bindings for the Ensmallen library.

Project description

pyensmallen: python bindings for the ensmallen library for numerical optimization

Lightweight python bindings for ensmallen library. Currently supports

  • L-BFGS, with intended use for optimisation of smooth objectives for m-estimation
  • ADAM (and variants with different step-size routines) - makes use of ensmallen's templatization.
  • Frank-Wolfe, with intended use for constrained optimization of smooth losses
    • constraints are either lp-ball (lasso, ridge, elastic-net) or simplex
  • (Generalized) Method of Moments estimation with ensmallen optimizers.
    • this uses ensmallen for optimization [and relies on jax for automatic differentiation to get gradients and jacobians]. This is the main use case for pyensmallen and is the reason for the bindings.
  • Estimator classes for linear, logistic, and Poisson regression with classical and robust inference for unregularized fits

See ensmallen docs for details. The notebooks/ directory walks through several statistical examples.

speed

pyensmallen is very fast. A comprehensive set of benchmarks is available in the benchmarks directory. The benchmarks are run on an intel 12th gen framework laptop. Benchmarks vary data size (sample size and number of covariates) and parametric family (linear, logistic, poisson) and compare pyensmallen with scipy and statsmodels (I initially also tried to keep cvxpy in the comparison set but it was far too slow to be in the running). At large data sizes, pyensmallen is roughly an order of magnitude faster than scipy, which in turn is an order of magnitude faster than statsmodels. So, a single statsmodels run takes around as long as a pyensmallen run that naively uses the nonparametric bootstrap for inference. This makes the bootstrap a viable option for inference in large data settings.

Installation:

Make sure your system has blas installed. On macos, this can be done via brew. Linux systems should have it installed by default. If you are using conda, you can install blas via conda-forge.

Then,

from pypi

uv pip install pyensmallen

from source

  1. Install armadillo and ensmallen for your system (build from source, or via conda-forge; I went with the latter)
  2. git clone this repository
  3. If you are using uv:
    • uv pip install --python .venv/bin/python meson meson-python ninja pybind11
    • uv pip install --python .venv/bin/python --no-build-isolation -e .
  4. If you are using vanilla pip in an activated environment:
    • python -m pip install meson meson-python ninja pybind11
    • python -m pip install --no-build-isolation -e .
  5. Profit? Or at least minimize loss?

full development environment

To install everything required to run tests and notebooks:

uv pip install --python .venv/bin/python meson meson-python ninja pybind11
uv pip install --python .venv/bin/python --no-build-isolation -e ".[full]"

Vanilla pip equivalent:

python -m pip install meson meson-python ninja pybind11
python -m pip install --no-build-isolation -e ".[full]"

The full extra includes the Python dependencies used by:

  • the test suite
  • GMM and autodiff examples
  • benchmark notebooks
  • plotting and notebook tooling

documentation

doc-generation

The repository includes a Quarto documentation site in docs/. The docs are built from three sources:

  • hand-written Quarto pages in docs/*.qmd
  • generated API reference pages in docs/reference/*.qmd, built from Python and pybind11 docstrings with quartodoc
  • executed notebook pages in docs/notebooks/*.ipynb

Use the render script instead of calling quarto render directly:

scripts/render_docs.sh

The script does the following:

  • uses the repository .venv as the Quarto Python runtime
  • forces JAX onto CPU so notebook execution is stable during docs builds
  • copies the tracked notebooks from notebooks/ into docs/notebooks/
  • runs quartodoc to regenerate the API reference pages from docstrings
  • runs quarto render docs to execute the notebooks and build the site

If you need the full docs toolchain first:

uv pip install --python .venv/bin/python meson meson-python ninja pybind11
uv pip install --python .venv/bin/python --no-build-isolation -e ".[full]"

The rendered site lands in docs/_site/. The generated API source pages land in docs/reference/.

from wheel

  • download the appropriate .whl for your system from the more recent release listed in Releases and run uv pip install ./pyensmallen... OR
  • copy the download url and run uv pip install https://github.com/apoorvalal/pyensmallen/releases/download/<version>/pyensmallen-<version>-<pyversion>-linux_x86_64.whl

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyensmallen-0.4.2.tar.gz (4.6 MB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

pyensmallen-0.4.2-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (17.2 MB view details)

Uploaded CPython 3.12manylinux: glibc 2.17+ x86-64

pyensmallen-0.4.2-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (17.2 MB view details)

Uploaded CPython 3.11manylinux: glibc 2.17+ x86-64

pyensmallen-0.4.2-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (17.2 MB view details)

Uploaded CPython 3.10manylinux: glibc 2.17+ x86-64

File details

Details for the file pyensmallen-0.4.2.tar.gz.

File metadata

  • Download URL: pyensmallen-0.4.2.tar.gz
  • Upload date:
  • Size: 4.6 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pyensmallen-0.4.2.tar.gz
Algorithm Hash digest
SHA256 b75f07c39a5a4fe37080950b078b3ff76ec0cff95089f58148e505eab62ab758
MD5 3ee3b00c51efd824b78d42470bf54bf0
BLAKE2b-256 0c63f5e91033b0160526a044c81445facc30e6450df371904784a8e5ba53d6a7

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyensmallen-0.4.2.tar.gz:

Publisher: build.yml on apoorvalal/pyensmallen

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pyensmallen-0.4.2-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for pyensmallen-0.4.2-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 839ebb161e6a15b65cbf4cff2cd18014f5be5c196835190cfe728c429a7251c6
MD5 0cd142a832e7bf9697efca5a2cd98715
BLAKE2b-256 0c825cb43a5bca21f59cc1134ad41c87b941fc7fec46a8bd926c3449873f6e0d

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyensmallen-0.4.2-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl:

Publisher: build.yml on apoorvalal/pyensmallen

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pyensmallen-0.4.2-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for pyensmallen-0.4.2-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 eaa347cf7eae0d24cbb6e057dbfb87cd439073f0c46b240c6bf4fb7ec5d600fb
MD5 5ff1bb468149df65c1e990ba0585519f
BLAKE2b-256 c687f8bb2101ce575310739fd02df861af83da979baffcd3b8d63f81365739b1

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyensmallen-0.4.2-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl:

Publisher: build.yml on apoorvalal/pyensmallen

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pyensmallen-0.4.2-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for pyensmallen-0.4.2-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 b2d9bfbd14b33c8f65ea3728bd38f276ba4191e69b392e30cfc12323811305d4
MD5 205fe5490772fd49f88c96a266c095a3
BLAKE2b-256 500d45165c269f775a0b7d68d1d2145ddf1929209e63401a0bb5cab1a802dda7

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyensmallen-0.4.2-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl:

Publisher: build.yml on apoorvalal/pyensmallen

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page