# 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 *
###
### This algorithm demonstrates how to submit orders to a Financial Advisor account group, allocation profile or a single managed account.
###
###
###
###
###
class FinancialAdvisorDemoAlgorithm(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 be initialized.
self.set_start_date(2013,10,7) #Set Start Date
self.set_end_date(2013,10,11) #Set End Date
self.set_cash(100000) #Set Strategy Cash
self._symbol = self.add_equity("SPY", Resolution.SECOND).symbol
# The default order properties can be set here to choose the FA settings
# to be automatically used in any order submission method (such as SetHoldings, Buy, Sell and Order)
# Use a default FA Account Group with an Allocation Method
self.default_order_properties = InteractiveBrokersOrderProperties()
# account group created manually in IB/TWS
self.default_order_properties.fa_group = "TestGroupEQ"
# supported allocation methods are: EqualQuantity, NetLiq, AvailableEquity, PctChange
self.default_order_properties.fa_method = "EqualQuantity"
# set a default FA Allocation Profile
# DefaultOrderProperties = InteractiveBrokersOrderProperties()
# allocation profile created manually in IB/TWS
# self.default_order_properties.fa_profile = "TestProfileP"
# send all orders to a single managed account
# DefaultOrderProperties = InteractiveBrokersOrderProperties()
# a sub-account linked to the Financial Advisor master account
# self.default_order_properties.account = "DU123456"
def on_data(self, data):
# on_data event is the primary entry point for your algorithm. Each new data point will be pumped in here.
if not self.portfolio.invested:
# when logged into IB as a Financial Advisor, this call will use order properties
# set in the DefaultOrderProperties property of QCAlgorithm
self.set_holdings("SPY", 1)