forked from QuantConnect/Lean
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathBasicTemplateIndiaIndexAlgorithm.py
More file actions
71 lines (54 loc) · 2.87 KB
/
BasicTemplateIndiaIndexAlgorithm.py
File metadata and controls
71 lines (54 loc) · 2.87 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
# 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 *
### <summary>
### Basic Template India Index Algorithm uses framework components to define the algorithm.
### </summary>
### <meta name="tag" content="using data" />
### <meta name="tag" content="using quantconnect" />
### <meta name="tag" content="trading and orders" />
class BasicTemplateIndiaIndexAlgorithm(QCAlgorithm):
'''Basic template framework algorithm uses framework components to define the algorithm.'''
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.SetAccountCurrency("INR") #Set Account Currency
self.SetStartDate(2019, 1, 1) #Set Start Date
self.SetEndDate(2019, 1, 5) #Set End Date
self.SetCash(1000000) #Set Strategy Cash
# Use indicator for signal; but it cannot be traded
self.Nifty = self.AddIndex("NIFTY50", Resolution.Minute, Market.India).Symbol
# Trade Index based ETF
self.NiftyETF = self.AddEquity("JUNIORBEES", Resolution.Minute, Market.India).Symbol
# Set Order Properties as per the requirements for order placement
self.DefaultOrderProperties = IndiaOrderProperties(Exchange.NSE)
# Define indicator
self._emaSlow = self.EMA(self.Nifty, 80)
self._emaFast = self.EMA(self.Nifty, 200)
self.Debug("numpy test >>> print numpy.pi: " + str(np.pi))
def OnData(self, data):
'''OnData event is the primary entry point for your algorithm. Each new data point will be pumped in here.
Arguments:
data: Slice object keyed by symbol containing the stock data
'''
if not data.Bars.ContainsKey(self.Nifty) or not data.Bars.ContainsKey(self.NiftyETF):
return
if not self._emaSlow.IsReady:
return
if self._emaFast > self._emaSlow:
if not self.Portfolio.Invested:
self.marketTicket = self.MarketOrder(self.NiftyETF, 1)
else:
self.Liquidate()
def OnEndOfAlgorithm(self):
if self.Portfolio[self.Nifty].TotalSaleVolume > 0:
raise Exception("Index is not tradable.")