-
Notifications
You must be signed in to change notification settings - Fork 2.7k
Expand file tree
/
Copy pathdatabento_cme_quoter.py
More file actions
116 lines (98 loc) · 3.88 KB
/
databento_cme_quoter.py
File metadata and controls
116 lines (98 loc) · 3.88 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
#!/usr/bin/env python3
# -------------------------------------------------------------------------------------------------
# Copyright (C) 2015-2026 Nautech Systems Pty Ltd. All rights reserved.
# https://nautechsystems.io
#
# Licensed under the GNU Lesser General Public License Version 3.0 (the "License");
# You may not use this file except in compliance with the License.
# You may obtain a copy of the License at https://www.gnu.org/licenses/lgpl-3.0.en.html
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# -------------------------------------------------------------------------------------------------
import time
from pathlib import Path
import pandas as pd
from nautilus_trader.adapters.databento import DatabentoDataLoader
from nautilus_trader.backtest.config import BacktestEngineConfig
from nautilus_trader.backtest.engine import BacktestEngine
from nautilus_trader.config import LoggingConfig
from nautilus_trader.config import RiskEngineConfig
from nautilus_trader.examples.strategies.simpler_quoter import SimpleQuoterStrategy
from nautilus_trader.examples.strategies.simpler_quoter import SimpleQuoterStrategyConfig
from nautilus_trader.model.currencies import USD
from nautilus_trader.model.enums import AccountType
from nautilus_trader.model.enums import OmsType
from nautilus_trader.model.identifiers import TraderId
from nautilus_trader.model.identifiers import Venue
from nautilus_trader.model.objects import Money
from nautilus_trader.test_kit.providers import TestInstrumentProvider
if __name__ == "__main__":
# Configure backtest engine
config = BacktestEngineConfig(
trader_id=TraderId("BACKTESTER-001"),
logging=LoggingConfig(log_level="INFO"),
risk_engine=RiskEngineConfig(bypass=True),
)
# Build the backtest engine
engine = BacktestEngine(config=config)
# Add a trading venue (multiple venues possible)
XCME = Venue("XCME") # <-- ISO 10383 MIC
engine.add_venue(
venue=XCME,
oms_type=OmsType.NETTING,
account_type=AccountType.MARGIN,
base_currency=USD,
starting_balances=[Money(1_000_000.0, USD)],
)
# Add instruments
ESZ5 = TestInstrumentProvider.es_future(
expiry_year=2025,
expiry_month=12,
venue=XCME,
)
engine.add_instrument(ESZ5)
# Add data
loader = DatabentoDataLoader()
paths = [
"~/Downloads/GLBX-20251023-C8KMULLDMW/glbx-mdp3-20251012.mbp-1.dbn.zst",
# "/Downloads/GLBX-20251023-C8KMULLDMW/glbx-mdp3-20251013.mbp-1.dbn.zst",
]
for path in paths:
quotes = loader.from_dbn_file(
path=Path(path).expanduser(),
instrument_id=ESZ5.id,
)
engine.add_data(quotes)
# Configure your strategy
config_strategy = SimpleQuoterStrategyConfig(
instrument_id=ESZ5.id,
tob_offset_ticks=0,
log_data=False,
)
# Instantiate and add your strategy
strategy = SimpleQuoterStrategy(config=config_strategy)
engine.add_strategy(strategy=strategy)
time.sleep(0.1)
input("Press Enter to continue...")
# Run the engine (from start to end of data)
engine.run()
# Optionally view reports
with pd.option_context(
"display.max_rows",
100,
"display.max_columns",
None,
"display.width",
300,
):
print(engine.trader.generate_account_report(XCME))
print(engine.trader.generate_order_fills_report())
print(engine.trader.generate_positions_report())
# For repeated backtest runs make sure to reset the engine
engine.reset()
# Good practice to dispose of the object
engine.dispose()