Skip to main content

Polars-native factor signal validation toolkit for quantitative finance

Project description

factrix

Tests one factor. Screens a thousand.

Where factrix fits

Does this factor possess predictive edge?

factrix is the first Polars-native Python toolkit that picks the right statistical test for each factor type. Cross-sectional, event, common factor — each gets the tests that fit its data-generating process.

factor construction  →  factrix (verdict)  →  strategy construction  →  backtest  →  live trading
                            ▲ you are here

For each candidate factor factrix answers — is the predictive power real? — and corrects for multiple testing when you screen at scale. Kill fakes before they cost you a backtest.

Why factrix?

  • Type-routed evaluation — Information Coefficient + Fama-MacBeth for cross-sectional factors; Cumulative Average Abnormal Return for events. Each type ships its own multi-metric diagnostic battery.
  • Batch factor screening — screen hundreds of candidate factors with cross-test multiple-testing correction in a single API call.
  • Financial statistics built in — autocorrelation-robust standard errors (Newey-West), overlapping-forward-return correction, persistent-predictor flagging (Stambaugh bias), false-discovery-rate control across batches (Benjamini-Hochberg-Yekutieli). Hand-rolled Information Coefficient loops typically run scipy.stats.ttest_1samp on the IC series and ignore the autocorrelation induced by overlapping forward returns.
  • Polars-native — modern Polars alternative to the pandas-based alphalens.

factrix stops at the verdict — primary test plus diagnostic battery. It does not size positions, model slippage, optimise weights, or compose alphas; those belong to the later stages of the pipeline above.

Is factrix the right tool?

You want to… Use this
Verdict on a factor (cross-sectional / event / common factor) factrix
Screen many factors with multiple-testing correction factrix
Backtest with positions / slippage / margin zipline-reloaded, backtrader, bt, vectorbt, nautilus_trader
Optimise portfolio weights skfolio, riskfolio-lib
Returns-level tear-sheet (P&L diagnostics) pyfolio-reloaded, QuantStats
Familiar cross-sectional tear-sheet alphalens-reloaded
End-to-end machine-learning pipeline qlib
Deflated / probabilistic Sharpe today (commercial) mlfinlab

Where factrix fits — full comparison →

Installation

pip install factrix
# or
uv add factrix

See the installation guide for version pinning and development setup.

Typical usage

Single factor — IC evaluation

import factrix as fx
from factrix.preprocess import compute_forward_return

raw   = fx.datasets.make_cs_panel(n_assets=100, n_dates=500, ic_target=0.08, seed=2024)
panel = compute_forward_return(raw, forward_periods=5)

cfg     = fx.AnalysisConfig.individual_continuous(metric=fx.Metric.IC, forward_periods=5)
profile = fx.evaluate(panel, cfg)

print(profile.verdict(), '| primary_p =', round(profile.primary_p, 4))
print(profile.diagnose())   # WarningCode / InfoCode list

Multi-factor BHY screening

profiles  = [fx.evaluate(p, cfg) for p in [panel_a, panel_b, panel_c, panel_d, panel_e]]
survivors = fx.multi_factor.bhy(profiles, threshold=0.05)

Single-asset (timeseries) fallback

cfg     = fx.AnalysisConfig.individual_continuous(metric=fx.Metric.IC, forward_periods=5)
profile = fx.evaluate(single_asset_panel, cfg)  # mode auto-switches to TIMESERIES
print(profile.stats.get(fx.StatCode.TS_BETA))

Documentation

  • Get Started — install, quickstart, where factrix fits
  • User Guide — concepts (three-axis design, architecture), how-to (PANEL vs TIMESERIES, BHY screening, slice analysis), examples
  • API Reference — entry points, results, lookup tables, per-metric pages
  • Development — contributing, design notes
  • Release Notes — changelog

License

Released under the Apache License 2.0.

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

factrix-0.12.0.tar.gz (269.8 kB view details)

Uploaded Source

Built Distribution

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

factrix-0.12.0-py3-none-any.whl (227.1 kB view details)

Uploaded Python 3

File details

Details for the file factrix-0.12.0.tar.gz.

File metadata

  • Download URL: factrix-0.12.0.tar.gz
  • Upload date:
  • Size: 269.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for factrix-0.12.0.tar.gz
Algorithm Hash digest
SHA256 d3b47926c6b407cc3cc4ae224644b365f885f79da54298b741724fd6f9c3c6ce
MD5 59cc5d00e78669e87d596d4789b741e5
BLAKE2b-256 4d040eda03ad840c216a2524388f5b5cc00aa5f653147cd89a10228314b8ed02

See more details on using hashes here.

Provenance

The following attestation bundles were made for factrix-0.12.0.tar.gz:

Publisher: release.yml on awwesomeman/factrix

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

File details

Details for the file factrix-0.12.0-py3-none-any.whl.

File metadata

  • Download URL: factrix-0.12.0-py3-none-any.whl
  • Upload date:
  • Size: 227.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for factrix-0.12.0-py3-none-any.whl
Algorithm Hash digest
SHA256 978b69941bc2d5ccf3087f40a1d750d62655b6156f9b24104381a77986d9ab08
MD5 545dc80d012b94640c2cd12d2f5ad0a6
BLAKE2b-256 326957d083059981f155f3f9287b8ee4ac68f2397f0577ea327e760b499743d8

See more details on using hashes here.

Provenance

The following attestation bundles were made for factrix-0.12.0-py3-none-any.whl:

Publisher: release.yml on awwesomeman/factrix

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