Skip to main content

A robust backtesting and live trading engine designed for seamless strategy development and deployment. It supports user-defined strategies, multi-threaded execution, and integrations with brokers and data sources.

Project description

MidasTrader

License pypi-version

MidasTrader is a robust trading system designed for seamless transitions between backtesting and live trading without requiring changes to user code. It integrates a flexible architecture combining a data engine, execution engine, and core components that streamline the strategy development process. The system is built with a multi-threaded design where each component communicates via a shared message bus.

Key Components

  1. Core Engine:

    • Central to the system, the Core Engine includes:
      • Order Book: Tracks market depth and price movements.
      • Portfolio Server: Manages and tracks portfolio allocations and positions.
      • Performance Tracking: Calculates and monitors key trading metrics.
      • Order Management System: Handles order placement, modifications, and cancellations.
      • Base Strategy: A foundation for user-defined strategies.
  2. Data Engine:

    • Connects to user-defined data sources:
      • Midas Server: Access historical data via the Midas ecosystem.
      • Binary Data Files: Handles local files encoded with the Midas Binary Encoding Library.
      • External Sources: Currently supports Databento, with more integrations planned.
  3. Execution Engine:

    • Facilitates live trading by connecting to brokers:
      • Currently supports Interactive Brokers.
      • Users can configure broker details in the config.toml file.

Installation

You can install midastrader directly from PyPI:

pip install midastrader

Configuration

Configuration File (config.toml)

Define system parameters, including data sources, execution settings, and strategy configuration.

Strategy File (logic.py)

Strategies are implemented by extending the BaseStrategy class. Define your custom logic in Python.

Usage

CLI Mode

Run the system using the following commands:

# Backtest Mode
midas path/to/config.toml backtest

# Live Mode
midas path/to/config.toml live

Application Mode

Alternatively, you can use the system programmatically in your application:

from midas.cli import run

# Backtest Mode
run("path/to/config.toml", "backtest")

# Live Mode
run("path/to/config.toml", "live")

Supported Features

Data Vendors
Databento
Brokers
Interactive Brokers

Future Plans

  • Add more data sources.
  • Integrate additional brokers.

Contributing

Contributions are welcome! Feel free to open an issue or submit a pull request with suggestions or improvements.

License

This project is licensed under the Apache 2.0 License. See the LICENSE file for details.

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

midastrader-1.0.2.tar.gz (88.5 kB view details)

Uploaded Source

Built Distribution

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

midastrader-1.0.2-py3-none-any.whl (112.6 kB view details)

Uploaded Python 3

File details

Details for the file midastrader-1.0.2.tar.gz.

File metadata

  • Download URL: midastrader-1.0.2.tar.gz
  • Upload date:
  • Size: 88.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.10.16

File hashes

Hashes for midastrader-1.0.2.tar.gz
Algorithm Hash digest
SHA256 57d7d47cc786c3c441d78c50fc8e980ff26b16b837d4d1c860555a01f4d1e708
MD5 6be32e9430a9cded2341d02b4399b811
BLAKE2b-256 50c898bcdc19a66f3699feba75d9e67592697f5da753c54322bb1a4b25afbe11

See more details on using hashes here.

File details

Details for the file midastrader-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: midastrader-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 112.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.10.16

File hashes

Hashes for midastrader-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 071472989e81c364cca1483431f4e5d73c3e857130b671b8886765096b08dce0
MD5 e6c30d0a1b9a16c53172488b96cb841c
BLAKE2b-256 76b65c7ea385afae4c4325fffc1e65de138932dd3c29fbf92fc8a9100e926cf1

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