Skip to main content

Python library for building, backtesting, and operationalizing quantitative Bitcoin accumulation strategies with dollar-cost averaging (DCA).

Project description

StackSats

Python library for quantitative Bitcoin accumulation via DCA strategies.

Not a general crypto trading bot or brokerage wrapper—see What StackSats is.

StackSats Logo

PyPI version Python versions Package Check License: MIT

StackSats is a Python library for building, backtesting, and operationalizing quantitative dollar-cost averaging (DCA) strategies for Bitcoin accumulation. It helps you turn research signals and feature pipelines into validated BTC weight schedules and daily allocation decisions.

Use StackSats when you want to:

  • build custom Bitcoin accumulation strategies in Python
  • backtest DCA rules against BRK-derived canonical Bitcoin datasets
  • validate causal constraints before shipping a strategy
  • emit daily BTC allocation decisions for agents or external execution systems

StackSats is library-first: the CLI, demo flows, and hosted agent API all sit on top of the same Python package surface.

Learn more at www.stackingsats.org.

Hosted documentation: https://hypertrial.github.io/stacksats/ — start from docs/index.md.

What StackSats is

StackSats is not a general crypto trading bot or brokerage wrapper. It is a research and decision engine for Bitcoin accumulation strategies:

  • Python library: define strategies with BaseStrategy, run them with stable configs, and consume results from Python.
  • Quantitative DCA toolkit: model how much BTC to accumulate over time instead of placing exchange-specific orders directly.
  • Backtesting framework: compare strategies, validate constraints, and export artifact sets from repeatable runs.
  • Execution boundary: StackSats computes decisions; brokerage execution stays outside the package unless you wire in an adapter intentionally.

Documentation map

BRK compatibility

StackSats is a Python library with explicit compatibility for the Bitcoin Research Kit (BRK) project and BRK-derived canonical data workflows. We document BRK as the upstream project and link to the official BRK surfaces: bitcoinresearchkit/brk, brk on crates.io, and brk on docs.rs.

This is a project and data compatibility statement, not a promise that StackSats embeds BRK, re-exports Rust crates, or version-locks BRK crate APIs. StackSats remains a Python package with its own stable 1.x support boundary.

Framework principles

The framework owns budget math, iteration, feasibility clipping, and lock semantics; you own features, signals, hyperparameters, and daily intent (propose_weight or build_target_profile). The same sealed allocation kernel runs in local runs, backtests, and production. See docs/framework.md.

Primary production flow

  1. StackSats computes a validated BTC accumulation decision.
  2. An external agent or automation reads the decision payload.
  3. Brokerage execution stays outside StackSats.

Use stacksats strategy decide-daily (or strategy.decide_daily(...)) for the agent-facing interface; docs/run/decide-daily.md covers payloads and sensitivity. Use stacksats serve agent-api for a hosted /v1 HTTP service (docs/run/agent-api.md, including token policy). Use stacksats strategy run-daily when StackSats should submit through a configured adapter (docs/run/run-daily.md).

Security: follow SECURITY.md for reporting; treat decision and API tokens as secrets.

Installation

Use case Command
Use StackSats from PyPI pip install stacksats
Editable install from a checkout python -m pip install -c requirements/constraints-maintainer.txt -e ".[dev,all]"

Optional extras: pip install "stacksats[viz]" (animation/plots), [network] (HTTP BTC price helpers), [service] (agent API), [deploy] (Postgres/export helpers). The stacksats-plot-weights helper needs both [viz] and [deploy] plus a configured DATABASE_URL (it reads stored weight windows, then renders). Helper scripts are documented convenience tools, not part of the frozen stable 1.x CLI subset.

Development venv (from repo root):

python -m venv venv
source venv/bin/activate
python -m pip install --upgrade pip
pip install -c requirements/constraints-maintainer.txt -e ".[dev,all]"
pip install pre-commit
venv/bin/python -m pre_commit install -t pre-commit

Quick start

Install, import the stable 1.x surface, then run the packaged demo:

pip install stacksats
from stacksats import BaseStrategy, StrategyRunner, list_strategies
stacksats demo backtest

Artifacts: output/<strategy_id>/<version>/<run_id>/

If you want to build strategies in Python next, start with docs/start/first-strategy-run.md and docs/start/minimal-strategy-examples.md. For the full CLI, use docs/commands.md. For BRK data setup (stacksats data fetch|prepare|doctor), use docs/start/full-data-setup.md. For the support boundary, use docs/stability.md. stacksats strategy validate is strict by default; use --no-strict only when you intend the lighter path.

Public API

The stable 1.x contract covers top-level exports, documented artifacts, and the documented CLI/agent API subset. See docs/reference/public-api.md and docs/stability.md. load_data() uses strict BRK validation; for long-format merged metrics exploration, see docs/start/eda-quickstart.md.

Development

See CONTRIBUTING.md for the full local quality matrix (tests, docs gates, coverage, release checks). Typical fast loop:

venv/bin/python -m pytest -q
venv/bin/python -m ruff check .
bash scripts/check_docs_refs.sh
venv/bin/python scripts/check_docs_ux.py
venv/bin/python -m mkdocs build --strict

If the repo path changes locally, rerun bash scripts/install_hooks.sh to refresh git hook paths.

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

stacksats-1.3.0.tar.gz (1.9 MB view details)

Uploaded Source

Built Distribution

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

stacksats-1.3.0-py3-none-any.whl (882.2 kB view details)

Uploaded Python 3

File details

Details for the file stacksats-1.3.0.tar.gz.

File metadata

  • Download URL: stacksats-1.3.0.tar.gz
  • Upload date:
  • Size: 1.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.12

File hashes

Hashes for stacksats-1.3.0.tar.gz
Algorithm Hash digest
SHA256 c2854949c5fba0329b830eb7b8ddbfa1da9879739274d84efae5c350ca04bcfb
MD5 785df646895840c1e5c27dce3fcd623b
BLAKE2b-256 8f376d861078156106cac5ed0344c46afcc0096930b9971977a9a91da15229b4

See more details on using hashes here.

File details

Details for the file stacksats-1.3.0-py3-none-any.whl.

File metadata

  • Download URL: stacksats-1.3.0-py3-none-any.whl
  • Upload date:
  • Size: 882.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.12

File hashes

Hashes for stacksats-1.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 374783bc617ecae44e9d617d5011565beaaf35d989db21810b88b87a7e472839
MD5 0c35d8cb29a1e6d36954554faaf6c552
BLAKE2b-256 f350927c02d91a2261831d57b6c0b7bc04b34c712884c1f76a3d18321d0e3d6a

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