Weight-based backtesting engine for quantitative trading
Project description
wbt Python Package
Python API for the wbt Rust backtesting engine.
Development Objectives
This Python subproject aims to provide a practical research-facing interface for weight-based backtesting while keeping the heavy computation in Rust.
Design priorities:
- Keep data input flexible for common research formats.
- Return analysis-friendly outputs as pandas objects.
- Preserve one consistent metric schema across stats outputs.
- Provide plotting utilities that work directly on backtest outputs.
Project Layout
This directory is an independent Python subproject.
python/
|-- pyproject.toml
|-- README.md
|-- scripts/
|-- tests/
`-- wbt/
The Rust crate remains one level up at ../Cargo.toml. maturin builds the extension module from there.
Installation And Local Setup
Requirements:
- Rust toolchain
- Python 3.10+
- uv
Setup:
cd python
uv sync --extra dev
uv run maturin develop --release
Quick Start
import pandas as pd
from wbt import WeightBacktest
df = pd.DataFrame(
{
"dt": [
"2024-01-02 09:01:00",
"2024-01-02 09:02:00",
"2024-01-02 09:03:00",
"2024-01-02 09:04:00",
],
"symbol": ["AAPL", "AAPL", "AAPL", "AAPL"],
"weight": [0.5, 0.2, 0.0, -0.3],
"price": [185.0, 186.0, 186.5, 184.5],
}
)
wb = WeightBacktest(
df,
digits=2,
fee_rate=0.0002,
n_jobs=4,
weight_type="ts", # "ts" or "cs"
yearly_days=252,
)
print("all:", wb.stats)
print("long:", wb.long_stats)
print("short:", wb.short_stats)
print(wb.daily_return.head())
print(wb.dailys.head())
print(wb.pairs.head())
print(wb.segment_stats("2024-01-01", "2024-12-31", kind="多空"))
print(wb.long_alpha_stats)
Accepted Inputs
The data argument accepts:
- pandas.DataFrame
- polars.DataFrame
- polars.LazyFrame
- file path as str or Path
Supported file formats from path input:
- csv
- parquet
- feather
- arrow
Required columns:
| Column | Type | Meaning |
|---|---|---|
| dt | datetime-like | Bar end time |
| symbol | str | Instrument code |
| weight | float | Target position weight |
| price | float | Price used for return calculation |
Notes:
- Null values are not allowed.
- weight is rounded by digits before backtest.
Main API Surface
Top-level imports (all reachable from import wbt):
from wbt import (
# Backtest engine
WeightBacktest, backtest,
# Performance metrics (Rust-backed)
daily_performance,
top_drawdowns,
rolling_daily_performance,
cal_yearly_days,
# Strategy utilities (pure Python)
weights_simple_ensemble,
cal_trade_price,
log_strategy_info,
# Reporting
generate_backtest_report,
# Test data
mock_symbol_kline, mock_weights,
)
Primary class and helpers:
WeightBacktest(...): main backtest engine entry.backtest(...): convenience wrapper returning aWeightBacktest.daily_performance(returns, yearly_days=252): standalone metric utility on a daily-return array.top_drawdowns(returns, top=10): top-N drawdown windows.rolling_daily_performance(df, ret_col, window=252, min_periods=100, yearly_days=None): rolling-window daily performance.cal_yearly_days(dts): infer yearly trading-day count from a date series.weights_simple_ensemble(df, weight_cols, method="mean", only_long=False, **kwargs): ensemble multiple strategy weights (mean/vote/sum_clip).cal_trade_price(df, digits=None, windows=(5, 10, 15, 20, 30, 60)): TWAP / VWAP and next-bar trade-price table grouped by symbol.log_strategy_info(strategy, df): pretty-print per-symbol weight summaries via loguru.generate_backtest_report(wb, output_path): render a self-contained HTML report.mock_symbol_kline(...)/mock_weights(...): generators for quick experiments.
Core WeightBacktest properties and methods:
stats,long_stats,short_statsdaily_return,long_daily_return,short_daily_returndailys,pairsalpha,alpha_stats,bench_statssegment_stats(sdt, edt, kind)long_alpha_statsget_symbol_daily(symbol),get_symbol_pairs(symbol)
Logging Note
cal_yearly_days and rolling_daily_performance emit warnings from Rust (e.g. short-span fallback) via the log crate. The package initializes pyo3-log at module load, so those warnings show up through Python's standard logging. If you use loguru, install an InterceptHandler once to route them into your loguru sinks.
Plotting Utilities
Two plotting surfaces are provided:
wbt.plotting — single-purpose figures
from wbt.plotting import (
plot_backtest_overview,
plot_colored_table,
plot_cumulative_returns,
plot_daily_return_dist,
plot_drawdown,
plot_long_short_comparison,
plot_monthly_heatmap,
plot_pairs_analysis,
plot_symbol_returns,
)
wbt.report — report-grade composite charts
from wbt.report import (
HtmlReportBuilder,
LongShortComparisonChart,
generate_backtest_report,
get_performance_metrics_cards,
plot_backtest_stats,
plot_colored_table,
plot_cumulative_returns,
plot_daily_return_distribution,
plot_drawdown_analysis,
plot_long_short_comparison,
plot_monthly_heatmap,
)
Typical usage:
fig1 = plot_cumulative_returns(wb.daily_return)
fig2 = plot_drawdown(wb.daily_return)
fig3 = plot_pairs_analysis(wb.pairs)
# Composite stats overview (3-in-1 layout)
fig4 = plot_backtest_stats(wb.daily_return, ret_col="total")
# Optional HTML export
html = plot_backtest_overview(wb.daily_return, to_html=True)
# Full HTML report file
generate_backtest_report(wb, "report.html")
Quality And Testing
Run checks from python/:
uv run pytest -v
uv run ruff format --check .
uv run ruff check . --no-fix
uv run basedpyright
Architecture Snapshot
repo-root/
|-- Cargo.toml
|-- src/
| |-- lib.rs # PyO3 bindings (pyfunctions, _wbt pymodule)
| `-- core/
| |-- cal_yearly_days.rs # Rust core for cal_yearly_days
| |-- daily_performance.rs
| |-- rolling_daily_performance.rs
| |-- top_drawdowns.rs
| `-- ... # backtest engine internals
`-- python/
`-- wbt/
|-- __init__.py # top-level exports
|-- _df_convert.py # pandas <-> Arrow IPC helpers
|-- _wbt.pyi # Rust extension stubs
|-- backtest.py # WeightBacktest class
|-- mock.py # mock_symbol_kline / mock_weights
|-- top_drawdowns.py # adapter for _wbt.top_drawdowns
|-- utils/ # adapters + pure-Python utilities
| |-- __init__.py
| |-- cal_yearly_days.py
| |-- rolling_daily_performance.py
| |-- weights_simple_ensemble.py
| |-- cal_trade_price.py
| `-- log_strategy_info.py
|-- plotting/ # single-purpose plotly charts
| |-- __init__.py
| |-- _common.py
| |-- returns.py
| |-- risk.py
| |-- trades.py
| `-- overview.py
`-- report/ # HTML report + composite charts
|-- __init__.py
|-- _generator.py
|-- _plot_backtest.py
`-- html_builder.py
License
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distributions
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file wbt-0.2.0.tar.gz.
File metadata
- Download URL: wbt-0.2.0.tar.gz
- Upload date:
- Size: 389.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5911c8b0e817bcfa69209e94232c22c5b82a5a01b2ac9cd6d07fef541897a26f
|
|
| MD5 |
436141c60afb03168082dd47f8d7e9e3
|
|
| BLAKE2b-256 |
678168c06abaa1378982d2185a0bd2439d41531cdec21a3658dc58ad3f1c1009
|
Provenance
The following attestation bundles were made for wbt-0.2.0.tar.gz:
Publisher:
release.yml on zengbin93/wbt
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
wbt-0.2.0.tar.gz -
Subject digest:
5911c8b0e817bcfa69209e94232c22c5b82a5a01b2ac9cd6d07fef541897a26f - Sigstore transparency entry: 1560093886
- Sigstore integration time:
-
Permalink:
zengbin93/wbt@cd34ebe206c970ce9a023beae4a90c6d55f6be2b -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/zengbin93
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@cd34ebe206c970ce9a023beae4a90c6d55f6be2b -
Trigger Event:
push
-
Statement type:
File details
Details for the file wbt-0.2.0-cp310-abi3-win_amd64.whl.
File metadata
- Download URL: wbt-0.2.0-cp310-abi3-win_amd64.whl
- Upload date:
- Size: 21.3 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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b3438ff519dce4bdc5c4560bf75c513d8549dfe9c0fa57d7dd84d538c4f38f80
|
|
| MD5 |
ddefa0c032a07aaa34c3153e29ad9d14
|
|
| BLAKE2b-256 |
fb4408852d5008919d84b532ea1ac5321915d14779bd5f62ddb435216847166e
|
Provenance
The following attestation bundles were made for wbt-0.2.0-cp310-abi3-win_amd64.whl:
Publisher:
release.yml on zengbin93/wbt
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
wbt-0.2.0-cp310-abi3-win_amd64.whl -
Subject digest:
b3438ff519dce4bdc5c4560bf75c513d8549dfe9c0fa57d7dd84d538c4f38f80 - Sigstore transparency entry: 1560094371
- Sigstore integration time:
-
Permalink:
zengbin93/wbt@cd34ebe206c970ce9a023beae4a90c6d55f6be2b -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/zengbin93
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@cd34ebe206c970ce9a023beae4a90c6d55f6be2b -
Trigger Event:
push
-
Statement type:
File details
Details for the file wbt-0.2.0-cp310-abi3-manylinux_2_28_x86_64.whl.
File metadata
- Download URL: wbt-0.2.0-cp310-abi3-manylinux_2_28_x86_64.whl
- Upload date:
- Size: 19.6 MB
- Tags: CPython 3.10+, manylinux: glibc 2.28+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2d6d3da8260f4b8d85d376fafaf3432d1838eeadaa9c795037562136faf5eecc
|
|
| MD5 |
8ececc5a01b420fb25b9fa29d32a619b
|
|
| BLAKE2b-256 |
dde9a5a73f3d4894688b913cd0ac3def0018eea93f214ee69ba12f3c6a48391f
|
Provenance
The following attestation bundles were made for wbt-0.2.0-cp310-abi3-manylinux_2_28_x86_64.whl:
Publisher:
release.yml on zengbin93/wbt
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
wbt-0.2.0-cp310-abi3-manylinux_2_28_x86_64.whl -
Subject digest:
2d6d3da8260f4b8d85d376fafaf3432d1838eeadaa9c795037562136faf5eecc - Sigstore transparency entry: 1560094128
- Sigstore integration time:
-
Permalink:
zengbin93/wbt@cd34ebe206c970ce9a023beae4a90c6d55f6be2b -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/zengbin93
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@cd34ebe206c970ce9a023beae4a90c6d55f6be2b -
Trigger Event:
push
-
Statement type:
File details
Details for the file wbt-0.2.0-cp310-abi3-manylinux_2_28_aarch64.whl.
File metadata
- Download URL: wbt-0.2.0-cp310-abi3-manylinux_2_28_aarch64.whl
- Upload date:
- Size: 18.0 MB
- Tags: CPython 3.10+, manylinux: glibc 2.28+ ARM64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
87a957d9c3ec594fc08c6848d2d663314852d88ada62f3f648fac3145a5185a4
|
|
| MD5 |
19cdca5f8210d704cafe1468ba9b7a7d
|
|
| BLAKE2b-256 |
72271c3dbaf4f393c6813b03db8c67b63b2ab8af7084bab19fac30d0db3e9911
|
Provenance
The following attestation bundles were made for wbt-0.2.0-cp310-abi3-manylinux_2_28_aarch64.whl:
Publisher:
release.yml on zengbin93/wbt
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
wbt-0.2.0-cp310-abi3-manylinux_2_28_aarch64.whl -
Subject digest:
87a957d9c3ec594fc08c6848d2d663314852d88ada62f3f648fac3145a5185a4 - Sigstore transparency entry: 1560094652
- Sigstore integration time:
-
Permalink:
zengbin93/wbt@cd34ebe206c970ce9a023beae4a90c6d55f6be2b -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/zengbin93
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@cd34ebe206c970ce9a023beae4a90c6d55f6be2b -
Trigger Event:
push
-
Statement type:
File details
Details for the file wbt-0.2.0-cp310-abi3-macosx_11_0_arm64.whl.
File metadata
- Download URL: wbt-0.2.0-cp310-abi3-macosx_11_0_arm64.whl
- Upload date:
- Size: 17.3 MB
- Tags: CPython 3.10+, macOS 11.0+ ARM64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0d71e0c2d6e22e59b9ae74de5f5c02686bd70eb1d894889d3c376556f2993ebb
|
|
| MD5 |
f8fc24486da3d06070d33e240655a623
|
|
| BLAKE2b-256 |
a5955fb69f5bfe2221b52e8e25b9c8f9d383793e91ae0a0c851f26a5b5209806
|
Provenance
The following attestation bundles were made for wbt-0.2.0-cp310-abi3-macosx_11_0_arm64.whl:
Publisher:
release.yml on zengbin93/wbt
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
wbt-0.2.0-cp310-abi3-macosx_11_0_arm64.whl -
Subject digest:
0d71e0c2d6e22e59b9ae74de5f5c02686bd70eb1d894889d3c376556f2993ebb - Sigstore transparency entry: 1560094514
- Sigstore integration time:
-
Permalink:
zengbin93/wbt@cd34ebe206c970ce9a023beae4a90c6d55f6be2b -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/zengbin93
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@cd34ebe206c970ce9a023beae4a90c6d55f6be2b -
Trigger Event:
push
-
Statement type:
File details
Details for the file wbt-0.2.0-cp310-abi3-macosx_10_12_x86_64.whl.
File metadata
- Download URL: wbt-0.2.0-cp310-abi3-macosx_10_12_x86_64.whl
- Upload date:
- Size: 19.0 MB
- Tags: CPython 3.10+, macOS 10.12+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5fab78900c6e03a916bebfdfc7d8bfdf2d9084c0febfe84e010736156ca4168e
|
|
| MD5 |
04433876a4249e47db0f470491d1526d
|
|
| BLAKE2b-256 |
d6c52451ad814fd837b44d1511024e65d3e6f33a27cf2440f42d213c602c007f
|
Provenance
The following attestation bundles were made for wbt-0.2.0-cp310-abi3-macosx_10_12_x86_64.whl:
Publisher:
release.yml on zengbin93/wbt
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
wbt-0.2.0-cp310-abi3-macosx_10_12_x86_64.whl -
Subject digest:
5fab78900c6e03a916bebfdfc7d8bfdf2d9084c0febfe84e010736156ca4168e - Sigstore transparency entry: 1560094253
- Sigstore integration time:
-
Permalink:
zengbin93/wbt@cd34ebe206c970ce9a023beae4a90c6d55f6be2b -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/zengbin93
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@cd34ebe206c970ce9a023beae4a90c6d55f6be2b -
Trigger Event:
push
-
Statement type: