Market Making RL - simulation, experiments, and CLI
Project description
Market Making RL Agent
Why this is useful
- End-to-end, deployable research stack: config-driven envs, MLflow tracking, CLI, REST API with async jobs, and DuckDB persistence
- Microstructure features that matter: OU price dynamics with regime switching, probabilistic fills, fees/slippage, multi-asset correlation, depth-aware quoting, size decisions
- Baselines and RL: Naive, Inventory-aware, Avellaneda–Stoikov, PPO; hyperparameter search with Optuna
At a glance
Benchmarks (best-of grid)
60s Quickstart
pip install mmrl
mmrl backtest
mmrl evaluate # Naive vs Rule-Based vs A–S vs PPO
mmrl analyze strategy_comparison.csv --plot # analyze your returns file
Programmatic API (Python)
from mmrl import run_backtest
cfg = {
"run_tag": "demo", "seed": 42, "steps": 500, "output_dir": "results",
"agent": {"spread": 0.1, "inventory_sensitivity": 0.05},
"market": {"ou_enabled": True, "ou": {"mu": 100, "kappa": 0.05, "sigma": 0.5, "dt": 1.0},
"vol_regime": {"enabled": True, "high_sigma_scale": 3.0, "switch_prob": 0.02}},
"execution": {"base_arrival_rate": 1.0, "alpha": 1.5},
"fees": {"fee_bps": 1.0, "slippage_bps": 2.0, "maker_bps": -0.5, "taker_bps": 1.0}
}
run_dir, metrics = run_backtest(cfg)
print(run_dir, metrics)
From source:
pip install -r requirements.txt
Colab Notebooks
Multi-asset
- Configure under
multi_assetinconfigs/inventory.yaml - Run:
python3 experiments/evaluate_multi_asset.py
python3 analysis/plot_multi_asset.py results/.../multi_asset_history.csv
API
- Start stack:
docker compose up -d redis worker api mlflow
curl http://localhost:8000/health
curl http://localhost:8000/config/schema # config JSON schema
- Submit jobs:
curl -X POST http://localhost:8000/backtest -H 'Content-Type: application/json' -d '{"steps": 200}'
curl -X POST http://localhost:8000/grid -H 'Content-Type: application/json' -d '{"execution": {"alpha_grid": [1.0, 1.5]}}'
curl http://localhost:8000/trades/<run_id>?limit=100
curl http://localhost:8000/runs/<run_dir_name>/artifacts
curl -L -o run.zip http://localhost:8000/runs/<run_dir_name>/download
Hyperparameter Optimization
python3 experiments/hyperopt.py
Notable features
- Multi-asset Gym wrapper with per-asset, per-level actions (offsets + sizes)
- Depth-aware agent placing quotes at multiple levels with regime-conditioned parameters
- DuckDB persistence of runs/metrics/trades and a
/trades/{run_id}endpoint - MLflow logging of params, metrics, artifacts with run IDs written per run
- CLI extras:
mmrl fetch-data(CCXT sample),mmrl config-validate,mmrl config-schema
Roadmap
- Postgres-backed storage and public demo deployment
- Size-aware RL policy across multi-asset Gym env
- Notebooks + Colab badges for quick experimentation
Packaging
- Install from source or build wheel with
python -m build(requiresbuild). - Optional extras:
mmrl[api]for FastAPI stackmmrl[rl]for Gymnasium/SB3
Data utilities
- Fetch sample trades to Parquet:
python3 -m mmrl.cli fetch-data --exchange binance --symbol BTC/USDT --limit 1000 --out data/btcusdt.parquet
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
mmrl-0.1.2.tar.gz
(37.1 kB
view details)
Built Distribution
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
mmrl-0.1.2-py3-none-any.whl
(44.2 kB
view details)
File details
Details for the file mmrl-0.1.2.tar.gz.
File metadata
- Download URL: mmrl-0.1.2.tar.gz
- Upload date:
- Size: 37.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
059afbbc8dcecb70ca030e524cb53910e1544b179825ecf730490d7a2ba8955e
|
|
| MD5 |
36330edec13c3fc0744242b4baf14d8c
|
|
| BLAKE2b-256 |
04eb1f8efa211d6aa540b9ff17b35bc426ba9172e46125c88f0ad3dfc3bacd0f
|
File details
Details for the file mmrl-0.1.2-py3-none-any.whl.
File metadata
- Download URL: mmrl-0.1.2-py3-none-any.whl
- Upload date:
- Size: 44.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b5b164cd975f58e826e28340b989717e105455bff1abe6ce47979964d78e4c14
|
|
| MD5 |
c5e9665da1e0461029efc7d914614742
|
|
| BLAKE2b-256 |
66db70e1fb159c22e3e08bb3f2f5389a490588fddc31bde91f999585ba3d9287
|