# QUANTCONNECT.COM - Democratizing Finance, Empowering Individuals.
# Lean Algorithmic Trading Engine v2.0. Copyright 2014 QuantConnect Corporation.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
#
# 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.
from AlgorithmImports import *
###
### Futures framework algorithm that uses open interest to select the active contract.
###
###
###
###
###
class OpenInterestFuturesRegressionAlgorithm(QCAlgorithm):
expected_expiry_dates = {datetime(2013, 12, 27), datetime(2014,2,26)}
def initialize(self):
self.universe_settings.resolution = Resolution.TICK
self.set_start_date(2013,10,8)
self.set_end_date(2013,10,11)
self.set_cash(10000000)
# set framework models
universe = OpenInterestFutureUniverseSelectionModel(self, lambda date_time: [Symbol.create(Futures.Metals.GOLD, SecurityType.FUTURE, Market.COMEX)], None, len(self.expected_expiry_dates))
self.set_universe_selection(universe)
def on_data(self,data):
if self.transactions.orders_count == 0 and data.has_data:
matched = list(filter(lambda s: not (s.id.date in self.expected_expiry_dates) and not s.is_canonical(), data.keys()))
if len(matched) != 0:
raise AssertionError(f"{len(matched)}/{len(slice.keys())} were unexpected expiry date(s): " + ", ".join(list(map(lambda x: x.id.date, matched))))
for symbol in data.keys():
self.market_order(symbol, 1)
elif any(p.value.invested for p in self.portfolio):
self.liquidate()