Note: This project is deprecated and has been replaced by the new project available at furnace-examples, which is based on Mojo and Rust.
A high-performance trading library, written in Mojo and C++, designed to simplify quantitative trading.
-
Concise and Efficient Syntax
- Mojo Programming Language: Inspired by the ease of use of Python, the Mojo programming language has been designed with a concise and efficient syntax aimed at delivering performance comparable to that of C/C++/Rust, while maintaining code readability and ease of use.
-
Integration with Multiple Exchanges
- Broad Support: Easily integrate with mainstream exchanges, such as OKX, Bybit, Binance, etc.
-
Extensive Support for Technical Indicators
- TulipIndicators: Integrates over 104 technical indicators, offering powerful tools for market analysis and strategy development.
-
Support for Multiple Strategies
- Flexible Application: Run and manage multiple trading strategies simultaneously, improving resource utilization and investment efficiency.
-
Event-Driven Model
- Efficient Response: Optimize strategy execution and signal processing to ensure timely responses to market changes.
-
Integration with Photon High-Performance Coroutine Library
- Concurrent Processing: Enhance the program's concurrency capabilities and optimize execution efficiency and resource utilization with the efficient Photon coroutine library.
-
Low-Latency HTTP Client Component
- Rapid Communication: Ensure real-time and accurate data transmission and strategy execution with the low-latency HTTP client component.
-
High-Performance WebSocket Module
- Real-Time Data Stream: Achieve real-time data exchange with exchanges and ensure immediate information updates and rapid strategy execution with the high-performance WebSocket module.
-
Integration with simdjson Parsing Library
- Efficient Parsing: Utilize the simdjson parsing library for rapid JSON processing capabilities, ensuring efficient and accurate data parsing.
To ensure optimal performance and compatibility, please make sure your system meets the following requirements:
- Operating System: Ubuntu 20.04+ (amd64)
- Python Environment: Python 3.9+ is required. It is recommended to manage it using Miniconda.
- Mojo Programming Language Version: 24.3.0
For information on how to install Mojo, please refer to the Mojo Official Installation Guide. Make sure you are using the supported version of the operating system to avoid compatibility issues.
Before starting, make sure you have installed the Mojo programming language and all necessary dependencies according to the system requirements. Next, you can install and configure this quantitative trading library by following the steps below:
- Clone the Project
Clone this project into your local environment:
git clone https://github.com/f0cii/moxt.git
cd moxt
- Use Docker (Optional)
If you prefer to use Docker to run the Mojo environment, you can use our provided Dockerfile by following these steps:
docker build -t moxt -f mojo.Dockerfile .
docker run -it moxt
This step is optional and is provided for those who wish to simplify their environment setup using Docker. If you are not familiar with Docker, we recommend checking the Docker Official Documentation for more information.
Before running the application, you need to download the compiled libmoxt.so library file. You can use either curl or wget command to download it directly into your project directory:
# Install jq
sudo apt install jq
# Make the download script executable
chmod +x download_libmoxt.sh
# Run the download script
./download_libmoxt.sh
Note: These commands download the latest version of libmoxt.so from the moxt-cpp GitHub releases. Ensure you have curl or wget installed on your system to use these commands.
Alternatively, if you prefer to compile libmoxt.so yourself or need a specific version, please visit moxt-cpp for compilation instructions.
Some of the core functionalities of this project are implemented in C++ and compiled into the libmoxt.so shared library. This means that in order for the MOXT library to function correctly and take full advantage of these high-performance features, you need to download this shared library to your project directory. The C++ code for the project is located in the moxt-cpp repository.
# Set script execution permissions
chmod +x ./scripts/ld
chmod +x ./scripts/mojoc
chmod +x ./build.sh
# Compile
magic shell
./build.sh main.mojo -o moxt
# Set environment variables
source setup.sh
# Install Python dependencies
pip install tomli
# Running ./moxt initiates the quantitative trading process.
# Please note that the specific strategies to be run must be specified in the configuration file (config.toml). Ensure that the strategy settings in this file have been correctly configured according to your requirements before executing ./moxt.
./moxt
Note: The trading_strategies
directory is used to store trading strategies.
Join our community to get help, share ideas, and collaborate!
- Discord: Join our Discord server to chat with the MOXT community.
Feel free to add me on WeChat for further discussions and sharing!
This project is licensed under the MIT License - see the [LICENSE] file for more details.
**Disclaimer: ** This project is for learning and research purposes only and does not constitute any trading or investment advice. Please use this project cautiously for actual trading.