# 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 *
###
### Regression algorithm demonstrating use of map files with custom data
###
###
###
###
###
###
###
###
class CustomDataUsingMapFileRegressionAlgorithm(QCAlgorithm):
def initialize(self):
# Initialise the data and resolution required, as well as the cash and start-end dates for your algorithm. All algorithms must initialized.
self.set_start_date(2013, 6, 27)
self.set_end_date(2013, 7, 2)
self.initial_mapping = False
self.execution_mapping = False
self.foxa = Symbol.create("FOXA", SecurityType.EQUITY, Market.USA)
self._symbol = self.add_data(CustomDataUsingMapping, self.foxa).symbol
for config in self.subscription_manager.subscription_data_config_service.get_subscription_data_configs(self._symbol):
if config.resolution != Resolution.MINUTE:
raise ValueError("Expected resolution to be set to Minute")
def on_data(self, slice):
date = self.time.date()
if slice.symbol_changed_events.contains_key(self._symbol):
mapping_event = slice.symbol_changed_events[self._symbol]
self.log("{0} - Ticker changed from: {1} to {2}".format(str(self.time), mapping_event.old_symbol, mapping_event.new_symbol))
if date == datetime(2013, 6, 27).date():
# we should Not receive the initial mapping event
if mapping_event.new_symbol != "NWSA" or mapping_event.old_symbol != "FOXA":
raise AssertionError("Unexpected mapping event mapping_event")
self.initial_mapping = True
if date == datetime(2013, 6, 29).date():
if mapping_event.new_symbol != "FOXA" or mapping_event.old_symbol != "NWSA":
raise AssertionError("Unexpected mapping event mapping_event")
self.set_holdings(self._symbol, 1)
self.execution_mapping = True
def on_end_of_algorithm(self):
if self.initial_mapping:
raise AssertionError("The ticker generated the initial rename event")
if not self.execution_mapping:
raise AssertionError("The ticker did not rename throughout the course of its life even though it should have")
class CustomDataUsingMapping(PythonData):
'''Test example custom data showing how to enable the use of mapping.
Implemented as a wrapper of existing NWSA->FOXA equity'''
def get_source(self, config, date, is_live_mode):
return TradeBar().get_source(SubscriptionDataConfig(config, CustomDataUsingMapping,
# create a new symbol as equity so we find the existing data files
Symbol.create(config.mapped_symbol, SecurityType.EQUITY, config.market)),
date,
is_live_mode)
def reader(self, config, line, date, is_live_mode):
return TradeBar.parse_equity(config, line, date)
def requires_mapping(self):
'''True indicates mapping should be done'''
return True
def is_sparse_data(self):
'''Indicates that the data set is expected to be sparse'''
return True
def default_resolution(self):
'''Gets the default resolution for this data and security type'''
return Resolution.MINUTE
def supported_resolutions(self):
'''Gets the supported resolution for this data and security type'''
return [ Resolution.MINUTE ]