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.3.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.3-py3-none-any.whl (112.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: midastrader-1.0.3.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.3.tar.gz
Algorithm Hash digest
SHA256 0436d2b7960d4b742d9b6a102d263ce0e23eddf8127cbbdb88a4e4be52f9d74e
MD5 0458750de5b6851925c6e71e43b65e2b
BLAKE2b-256 48392c1c74026e5005524824eeed45087a5f4ef1d18dadf2a8ff6f73f5586928

See more details on using hashes here.

File details

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

File metadata

  • Download URL: midastrader-1.0.3-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.3-py3-none-any.whl
Algorithm Hash digest
SHA256 8ee5a0205507b914d118115e3a6c8742f90f088245e9371cade71a436867419d
MD5 21af5bb02eaf8cf58d97c4d1c7d768e9
BLAKE2b-256 2dd9dc51e484404bc4b0e0fddf3bd142419570f934cb0325b2b29d8b526f446a

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