A purely functional, immutable trading simulator implemented in OCaml. This project models a limit order book, trading agents, and risk metrics using functional programming techniques.
The simulator demonstrates several key concepts:
- Immutable Data Structures: Every update to the order book creates a new immutable instance.
- Pure Functions: The matching engine uses pure functions without side effects.
- Functional Reactive Programming: The simulation loop processes streams of orders reactively.
- Property-Based Testing: Tests verify core properties like no crossed market.
- Order Book: A matching engine that pairs buy and sell orders based on price-time priority.
- Trading Agents: Different agent strategies including market makers, arbitrageurs, and random traders.
- Risk Module: Tracks inventory, cash positions, PnL, and risk metrics.
- Simulation Loop: Processes ticks and generates a history of state snapshots.
The order book maintains two sorted collections:
- Bids (Buy orders): Sorted in descending price order
- Asks (Sell orders): Sorted in ascending price order
When a new order arrives:
- For a buy order, we check if there are any asks with a price <= the buy price
- For a sell order, we check if there are any bids with a price >= the sell price
- If a match is found, we execute a trade at the resting order's price
- Unmatched quantity remains in the book
The engine ensures price-time priority, meaning:
- Orders at better prices execute first
- For equal prices, earlier orders execute first
- 
Market Maker: - Places buy and sell orders around the mid-price
- Aims to profit from the bid-ask spread
 
- 
Arbitrage Bot: - Detects crossed markets (best bid >= best ask)
- Immediately trades to capture the arbitrage opportunity
 
- 
Random Trader: - Generates random orders with varying prices and quantities
- Simulates noise traders in the market
 
- OCaml 4.12.0 or higher
- Dune 2.9.0 or higher
- Alcotest (for unit testing)
- QCheck (for property-based testing)
- QCheck-Alcotest (for integrating QCheck with Alcotest)
Install dependencies:
opam install dune alcotest qcheck qcheck-alcotest# Install dependencies
make setup
# Build the project
make build# Run with default settings (50 ticks)
make run
# Run with custom ticks
dune exec bin/main.exe -- --ticks 200
# Output to JSON
dune exec bin/main.exe -- --ticks 100 --output simulation.json# Run all tests with the comprehensive test runner
./run_tests.sh
# Or use dune directly
dune runtest
# Run specific test files
dune test test/test_order_book.ml
dune test test/test_agents.ml
dune test test/test_integration.mlWe have several types of tests:
- Unit Tests: Verify individual components
- Integration Tests: Verify component interactions
- Property-Based Tests: Verify invariants with random inputs (partially disabled)
See the Testing Guide for more details.
Tick: 42
Top of Book: Bid=100.50 Ask=100.60
Last Trade: Buy#123 vs Sell#99 @ 100.55 (50 qty)
Agent PnL:
  MarketMaker: +12.30
  ArbitrageBot: -3.20
  RandomTrader: +0.05
Order Book Depth:
  Bids: [100.50 x 20, 100.45 x 10, ...]
  Asks: [100.60 x 15, 100.65 x 25, ...]
---------------------------------------
src/
  types.ml        # Core data structures
  order_book.ml   # Matching engine
  agents.ml       # Trading agent strategies
  simulation.ml   # Simulation loop
  risk.ml         # Risk metrics
bin/
  main.ml         # Entry point
test/
  test_order_book.ml  # Unit and property tests for order book
  test_agents.ml      # Unit tests for trading agents
  test_integration.ml # Integration tests
docs/
  TESTING_GUIDE.md       # Comprehensive testing overview
  INTEGRATION_TESTING.md # Guide for integration tests
  STRESS_TESTING.md      # Guide for stress tests
  SCENARIO_TESTING.md    # Guide for scenario tests
  BENCHMARK_TESTING.md   # Guide for performance benchmarks
run_tests.sh           # Test runner script
DEBUGGING_JOURNEY.md   # Documentation of debugging process
MIT License
This project includes a detailed debugging journey that documents the issues faced during development and how they were resolved. This can be useful for learning about OCaml type systems, functional programming patterns, and testing strategies.
See DEBUGGING_JOURNEY.md for the full story.
For more information on testing approaches and best practices, see the documentation in the docs/ directory:
- Testing Guide: Overview of all testing approaches
- Integration Testing: Testing component interactions
- Stress Testing: Testing under high load
- Scenario Testing: Testing realistic market scenarios
- Benchmark Testing: Performance measurement