Skip to main content

Ferrum is a statistical visualization library for Python: a grammar-first charting system that unifies exploratory plots, statistical graphics, interactive views, and model diagnostics, backed by a Rust engine.

Project description

Ferrum

Grammar-of-graphics statistical visualization for Python, with a Rust core.

Ferrum builds every chart — scatter plot, faceted histogram, ROC curve, SHAP beeswarm — from the same grammar of data, encodings, marks, scales, and statistical transforms. The declaration layer is Python; the computation engine is Rust compiled via PyO3.

Install

pip install ferrum-viz

Install with all optional extras (scikit-learn, SHAP, Jupyter interactive rendering):

pip install ferrum-viz[all]

Quickstart

import ferrum as fm
import polars as pl

df = pl.DataFrame({"x": [1, 2, 3, 4], "y": [2, 4, 3, 5], "group": ["a", "a", "b", "b"]})

chart = fm.Chart(df).mark_point().encode(x="x", y="y", color="group:N")
chart.save("scatter.svg")
chart.show_png()  # raster output, no display server needed

Key features

  • One chart model — scatter plots, statistical graphics, and ML diagnostics share the same grammar and compose with +, |, &.
  • Stat transforms in the pipeline — KDE, LOESS, bootstrap CIs, binning, and aggregations are declared in the chart spec and computed in Rust.
  • Model diagnostics as chartsfm.roc_chart(model, X, y), fm.confusion_matrix_chart(...), fm.shap_chart(...) return regular Chart objects.
  • Zero system dependencies — no Cairo, no X11, no display server. Renders anywhere pip install works.
  • DataFrame pluralism — polars, pandas, modin, cuDF, dask, ibis, and pyarrow all work through Chart(data).
  • Interactive renderingchart.interactive() switches to a GPU-backed WASM renderer with selections, zoom/pan, linked views, and tooltips. Backed by anywidget for Jupyter.
  • 12 built-in themes — from Paper Ink (warm cream default) to dark, publication, and editorial styles.

Examples

# Layer a LOESS trend on a scatter plot
points = fm.Chart(df).mark_point(opacity=0.6).encode(x="x", y="y", color="group:N")
trend = fm.Chart(df).mark_smooth(method="loess").encode(x="x", y="y", color="group:N")
chart = points + trend

# Compose diagnostics into a model report
source = fm.ModelSource(model, X_test, y_test)
report = (fm.roc_chart(source) | fm.confusion_matrix_chart(source)) & fm.importance_chart(source)
report.save("model_report.svg")

# Figure-level helpers
fm.displot(df, x="value", hue="group", kind="kde")
fm.catplot(df, x="species", y="measurement", kind="violin")
fm.pairplot(df, vars=["a", "b", "c"], hue="label")

Architecture

Layer Role
src/ferrum/ Python declaration API — Chart, encodings, marks, themes, plots
crates/ferrum-core/ Rust computation engine — transforms, scales, rendering
Arrow CDI Zero-copy data transport between Python and Rust via pyo3-arrow

Development

Requires Python 3.10+, Rust toolchain, and maturin.

uv sync
unset CONDA_PREFIX && uv run --no-sync maturin develop   # build Rust extension
uv run pytest                                            # run tests

Documentation

Full docs at ferrumviz.com.

License

See LICENSE for details.

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

ferrum_viz-0.8.3.tar.gz (3.8 MB view details)

Uploaded Source

Built Distributions

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

ferrum_viz-0.8.3-cp310-abi3-win_amd64.whl (7.7 MB view details)

Uploaded CPython 3.10+Windows x86-64

ferrum_viz-0.8.3-cp310-abi3-manylinux_2_39_x86_64.whl (7.6 MB view details)

Uploaded CPython 3.10+manylinux: glibc 2.39+ x86-64

ferrum_viz-0.8.3-cp310-abi3-macosx_11_0_arm64.whl (6.4 MB view details)

Uploaded CPython 3.10+macOS 11.0+ ARM64

File details

Details for the file ferrum_viz-0.8.3.tar.gz.

File metadata

  • Download URL: ferrum_viz-0.8.3.tar.gz
  • Upload date:
  • Size: 3.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for ferrum_viz-0.8.3.tar.gz
Algorithm Hash digest
SHA256 077c808e01f1853881f297a8c1513e513322d8da673508113b90bf1976e441a6
MD5 5d0c743d042bb2f0c3fa218c3f560465
BLAKE2b-256 a02e2cb62fe1e343cacf7ab6c7c471c81f9d6410a9a959a36f541725f560ebca

See more details on using hashes here.

Provenance

The following attestation bundles were made for ferrum_viz-0.8.3.tar.gz:

Publisher: publish.yaml on chris-santiago/ferrum

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

File details

Details for the file ferrum_viz-0.8.3-cp310-abi3-win_amd64.whl.

File metadata

  • Download URL: ferrum_viz-0.8.3-cp310-abi3-win_amd64.whl
  • Upload date:
  • Size: 7.7 MB
  • Tags: CPython 3.10+, Windows x86-64
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for ferrum_viz-0.8.3-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 397dc67c8b691017eeda65bcb28e217d752b2ae5ece3142ab377f17b7cb7e5e7
MD5 812f9dd99ddadeec7c0e5e69332f6fb9
BLAKE2b-256 94f7c0e516c96953d9bef804a8d5e9ca2d21e3527a38ca052aed8ff0106b418d

See more details on using hashes here.

Provenance

The following attestation bundles were made for ferrum_viz-0.8.3-cp310-abi3-win_amd64.whl:

Publisher: publish.yaml on chris-santiago/ferrum

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

File details

Details for the file ferrum_viz-0.8.3-cp310-abi3-manylinux_2_39_x86_64.whl.

File metadata

File hashes

Hashes for ferrum_viz-0.8.3-cp310-abi3-manylinux_2_39_x86_64.whl
Algorithm Hash digest
SHA256 5fbbe7508c32472923844c4818539057303f49584ca40405e2c7683a40785e4b
MD5 0f0daf324c19ed63736d85066d873024
BLAKE2b-256 99986d441800eed3b8010826bc26262ef6f90a7f4f9c231090568e24a4dcd29e

See more details on using hashes here.

Provenance

The following attestation bundles were made for ferrum_viz-0.8.3-cp310-abi3-manylinux_2_39_x86_64.whl:

Publisher: publish.yaml on chris-santiago/ferrum

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

File details

Details for the file ferrum_viz-0.8.3-cp310-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for ferrum_viz-0.8.3-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 0e70dd7916f97311d87d1ad8b588c59b9c2f7e66fe57733eb11685647ed58543
MD5 8f5d5f5bbc90152d18b39a6ca0e6a0f1
BLAKE2b-256 9fccfc7cd3d558da8b93e68ee2f57c2590d42f5927cff56e50954ced3219fe18

See more details on using hashes here.

Provenance

The following attestation bundles were made for ferrum_viz-0.8.3-cp310-abi3-macosx_11_0_arm64.whl:

Publisher: publish.yaml on chris-santiago/ferrum

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