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.6.tar.gz (89.0 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.6-py3-none-any.whl (112.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: midastrader-1.0.6.tar.gz
  • Upload date:
  • Size: 89.0 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.6.tar.gz
Algorithm Hash digest
SHA256 6fb93e970c8350bce30ca271c6bc1d9f70b49cff37067e8e482a91d05b4a7210
MD5 38010ee399da682c96e021af100ee350
BLAKE2b-256 40dc9cbe70f8a4e4dba48e9c16dea55ac2ae728fcf8d7da20ef24d19863ed7ef

See more details on using hashes here.

File details

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

File metadata

  • Download URL: midastrader-1.0.6-py3-none-any.whl
  • Upload date:
  • Size: 112.8 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.6-py3-none-any.whl
Algorithm Hash digest
SHA256 809f89d5a96644e9bc474ae3cc286259b8a5d07f30d49fd1f21011f7f2f65f12
MD5 1b3fb182182100a076e6394e10bb3693
BLAKE2b-256 b99a5788a6496b5dd844e9588d40ed11c027a99d5b7714e6e9bf9d6c67b9a602

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