Skip to main content

A cryptocurrency trading toolkit centered on the standard_bot backtesting, paper signal, and execution workflow

Project description

cyqnt-trd

cyqnt-trd is a cryptocurrency trading toolkit centered on the standard_bot workflow for:

  • historical data download to local parquet
  • local resample from 1m into higher timeframes
  • Numba-accelerated backtesting
  • paper signal generation
  • monitor / run-manager driven execution flows

The current recommended path is:

historical parquet -> local resample -> standard_bot signal -> NumbaBacktestRunner

Install

From PyPI

pip install cyqnt-trd

The package supports Python >=3.8,<3.12, which includes Binance AI's Python 3.11.2.

For HTTPS requests, cyqnt-trd resolves the CA bundle in this order:

  1. REQUESTS_CA_BUNDLE
  2. SSL_CERT_FILE
  3. CURL_CA_BUNDLE
  4. Linux system CA bundle: /etc/ssl/certs/ca-certificates.crt
  5. certifi
  6. requests default verification behavior

For special Linux deployments where Binance endpoints are signed by an internal CA that exists only in the system trust store, set the deployment CA bundle via environment variables, for example:

export REQUESTS_CA_BUNDLE=/etc/ssl/certs/ca-certificates.crt
export SSL_CERT_FILE=/etc/ssl/certs/ca-certificates.crt

For development

git clone https://github.com/nthu-chung/crypto_trading
cd crypto_trading
python3 -m venv .venv-standard-bot
source .venv-standard-bot/bin/activate
python -m pip install -U pip
python -m pip install -r requirements.txt -r requirements-standard-bot-mvp.txt

Recommended Standard Bot Entry Points

Backtest

python -m cyqnt_trd.standard_bot.entrypoints.mvp_backtest \
  --engine numba \
  --market-type futures \
  --strategy multi_timeframe_ma_spread \
  --symbol BTCUSDT \
  --interval 5m \
  --secondary-interval 1h \
  --primary-ma-period 20 \
  --reference-ma-period 20 \
  --spread-threshold-bps 0 \
  --historical-dir data/mtf_90d \
  --start-ts 1768003200000 \
  --end-ts 1775779200000 \
  --download-missing \
  --output-json docs/backtests/btc_mtf_ma_cross_5m_1h_20_20_90d.json

Paper Signal

python -m cyqnt_trd.standard_bot.entrypoints.mvp_paper \
  --market-type futures \
  --strategy multi_timeframe_ma_spread \
  --symbol BTCUSDT \
  --interval 5m \
  --secondary-interval 1h \
  --primary-ma-period 20 \
  --reference-ma-period 20 \
  --spread-threshold-bps 0 \
  --historical-dir data/mtf_90d \
  --dry-run

Monitor / Background Session

python -m cyqnt_trd.standard_bot.entrypoints.mvp_monitor_http \
  --broker paper \
  --host 127.0.0.1 \
  --port 8787

Data Workflow

The preferred data workflow is:

  1. Download Binance K bars into local parquet
  2. Store the finest useful granularity, usually 1m
  3. Resample locally into 5m, 15m, 1h, etc.
  4. Run standard_bot on local parquet instead of using raw API responses as final backtest input

This keeps:

  • point-in-time alignment clearer
  • local backtests repeatable
  • paper signal and backtest logic consistent

Current Strategy Families On The Mainline

The standard_bot mainline currently includes Numba-backed support for:

  • moving_average_cross
  • price_moving_average
  • rsi_reversion
  • multi_timeframe_ma_spread
  • donchian_breakout

Package Notes

  • The preferred historical backtest engine is NumbaBacktestRunner
  • The preferred CLI entrypoint is cyqnt_trd.standard_bot.entrypoints.mvp_backtest
  • Legacy cyqnt_trd/backtesting/* still exists for compatibility, but is not the recommended path for new work

Requirements

Key dependencies include:

  • pandas==2.3.3
  • polars==1.0.0
  • numba==0.60.0
  • pyarrow==21.0.0
  • requests==2.32.5

Binance SDK dependencies:

  • binance-sdk-spot==8.2.1
  • binance-sdk-derivatives-trading-usds-futures==10.0.1
  • binance-sdk-algo==2.6.0
  • binance-common==3.8.0
  • binance-common

License

MIT License

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

cyqnt_trd-0.1.9.dev2.tar.gz (996.8 kB view details)

Uploaded Source

Built Distribution

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

cyqnt_trd-0.1.9.dev2-py3-none-any.whl (1.2 MB view details)

Uploaded Python 3

File details

Details for the file cyqnt_trd-0.1.9.dev2.tar.gz.

File metadata

  • Download URL: cyqnt_trd-0.1.9.dev2.tar.gz
  • Upload date:
  • Size: 996.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for cyqnt_trd-0.1.9.dev2.tar.gz
Algorithm Hash digest
SHA256 68e7ed4530027f61fb45231921dda6da3e8943467943778e5de9dcf9b53c961f
MD5 f0539ca6fd73d1702ab81b0cdc1c221e
BLAKE2b-256 e3a910fb7500a16e7ab7ad57028f3b6e1f21dafa591afc6d4e0bc1e9fcb07c66

See more details on using hashes here.

File details

Details for the file cyqnt_trd-0.1.9.dev2-py3-none-any.whl.

File metadata

  • Download URL: cyqnt_trd-0.1.9.dev2-py3-none-any.whl
  • Upload date:
  • Size: 1.2 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for cyqnt_trd-0.1.9.dev2-py3-none-any.whl
Algorithm Hash digest
SHA256 0f356e1c2592a49a37373ad6f491d00bd883d63ae1d1ed5e4f431616e39ad0e7
MD5 3e26ad58fb477ec3970a3968a91029e3
BLAKE2b-256 a51ba06fe7b5fdeee2e607d3d06581ae20b70fd65b49e6712b57d13347c31e24

See more details on using hashes here.

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