Trading strategies builder, backtester, and real-time trader.
algo-trader is an implementation of an algorithmic trading strategy executor and backtester. Capable of backtesting strategies locally and trading them in real-time via your broker API.
Please be aware that this is a work in progress and the trader is missing external market data and trade providers. If you'd like to use the trader for real-world trading, you'll have to implement your broker API. Although real-time trading is not finished, backtesting is fully functional, so implemented strategies can be backtested and used in real trading when it will be ready.
algo-trader is written in Python, and its current stack composes of:
- MongoDB as a backend data store for backtesting strategies
- tulipy - Python bindings for Tulip Indicators. Used to provide technical indicators calculations.
- ib_client (Optional) - Python library to communicate with Interactive Brokers gateway. Only needed if you plan on doing real trading via IB.
A Source is an implementation of a Candle Iterator. This is the starting point of the pipeline and the "source" for the incoming candles processed.
Processor is the primary processing unit in the pipeline. Processors can be constructed in any order while Candles are flowing from the source, forward through all processors. Each processor is responsible for sending the candles it processes to the next processor (unless it has a reason not to).
The process()
function gets with each candle also an object called SharedContext
.
The context is an instance of an in-memory KV store to share context and information between processors.
Another way to share data between processors is to make use of the attachments
field on the Candle itself.
This field is intended for metadata on the candle, like calculations and state relevant to that candle point in time. Candle attachments are persistent throughout the pipeline.
Reprocessing is a feature that enables a processor to re-send an already processed candle to the next processor. Reprocessing is useful for processors that do some logic outside the main flow of the pipeline. for example, upon events, external triggers, market/trade provider's events/issues, etc... An example of reprocessing can be found in the AssetCorrelationProcessor
An Event as its name suggests, defines an event that occurred in the system. It follows the same flow as the Candles, passing between processors. Each processor is responsible for propagating the event to the next processor (if needed).
Because pipelines are data-driven and not time-driven, events can be used as checkpoints to indicate something that happened in the data stream. For example, running the same pipeline from a DB source and a real-time market data source can have different effects if the processor were to rely on time.
It is crucial to have the same behavior when fast-running from DB and real-time for backtesting to be useful.
Strategies are executed per candle by the StrategyProcessor. A strategy is responsible for executing the trading logic and dispatching Signals (StrategySignal). In the event a strategy is raising a trading signal, the StrategyProcessor will catch and pass it to the SignalsExecutor for execution.
A Terminator is an optional final piece of the pipeline. It's executed at the very end of a pipeline when the Source iterator has been fully consumed. Terminators are useful for unit testing, backtesting, and environment cleanups.
algo-trader is using MongoDB for data storage. To run Mongo locally use docker-compose
.
docker-compose -f docker-compose.yml up -d
It is best to use a virtual environment to run algo-trader.
python3 -m venv run
source run/bin/activate
pip3 install -r requirements.txt
- Unit:
./scripts/test-unit.sh
- Integration (needs IB gateway running):
./scripts/test-integration.sh
- All:
./scripts/test-all.sh
Contributions are welcome and much needed. Please refer to the guidelines.