ROADMAP.md
This document outlines the key priorities and upcoming goals for NautilusTrader, charting its path as a production-grade, Rust-native trading engine.
Given the dynamic nature of the project, priorities may evolve to keep pace with the fast-moving development cycle. For real-time updates and detailed task tracking, refer to the NautilusTrader Kanban board.
Note: Bug fixes and roadmap priorities take precedence over feature requests to ensure stability and progress. However, pull requests (PRs) for improvements and new features are always welcome. For more details, see the CONTRIBUTING.md.
To establish NautilusTrader as the default open trading engine for quantitative algorithmic trading, combining production-grade architecture, reliability, and documentation for traders and developers alike.
Port core to Rust
Goal: Leverage Rust's performance and safety features to improve reliability, performance, and scalability.
Improve documentation and tutorials
Goal: Lower the learning curve for new users and empower developers with clear, comprehensive guides:
Improve code ergonomics
Goal: Simplify the development experience for users and contributors:
As we progress on the top priorities, we also plan to focus on the following enhancements:
The NautilusTrader open-source project is purpose-built to empower individual and small team quantitative traders, enabling strategy research and live trading with efficiency and reliability on a single node. By explicitly defining what is in and out of scope, we set clear expectations, focus community efforts, and support a sustainable open-source ecosystem.
New integrations are a major undertaking for the project. They involve more than just the initial code — documentation, tutorials, maintenance, and ongoing user support are all required to make them viable and sustainable. Since contributors are not obligated to complete or maintain an integration, we must carefully weigh the long-term impact and commitment before accepting one into the main project.
At present, the project has limited bandwidth to support new official integrations.
To set clearer expectations:
Step 1 – Open an RFC
Before opening a PR for a new integration, contributors should first open a Request for Comments (RFC) issue. This allows discussion of suitability, alignment with the roadmap, and maintenance considerations before any code is written.
Step 2 – Evaluation
The maintainers will review the RFC in light of factors such as stability, demand, technical fit, and available bandwidth. Integrations must also align with NautilusTrader’s professional, performance-focused, and high-reliability philosophy. Only after agreement at this stage should a PR be considered.
Step 3 – PR submission (if approved)
If the RFC is approved, a contributor may proceed with a PR. Integrations must adhere closely to existing Rust-based adapter implementation patterns to ensure consistency and maintainability. Even then, inclusion in the official distribution depends on long-term sustainability and available resources.
For adapter classification, community listings, and support boundaries, see ADAPTERS.md. For naming rules and disclaimer requirements for independent projects, see TRADEMARK.md.
NautilusTrader is an open-core project. All core trading engine features land in the public repository first, and we are committed to continually widening the feature set and improving documentation so that the community can rely on a modern, production-grade, battle-tested trading engine.
Feedback and contributions from users directly influence the roadmap; as real-world requirements evolve, we will steadily raise the ceiling of what can be achieved with the open-source codebase.
This roadmap builds on NautilusTrader’s strong foundation, driving continuous refinement while expanding its possibilities and capabilities for algorithmic traders and developers.