# region imports
from AlgorithmImports import *
import pandas as pd
import numpy as np
from datetime import time, datetime, timedelta
# endregion
class CombinedAlgorithm(QCAlgorithm):
def Initialize(self):
# INITIALIZE
self.SetStartDate(2021, 3, 1) # Set Start Date
self.SetEndDate(2021, 4, 1)
self.SetCash(10000) # Set Strategy Cash
self.spy = self.AddEquity('SPY', Resolution.Minute)
self.spy.SetDataNormalizationMode(DataNormalizationMode.Raw)
# SCHEDULED EVENTS
self.Schedule.On(self.DateRules.WeekStart("SPY"), self.TimeRules.AfterMarketOpen("SPY"), self.WeekStart)
self.Schedule.On(self.DateRules.WeekEnd("SPY"), self.TimeRules.BeforeMarketClose("SPY"), self.WeekEnd)
self.Schedule.On(self.DateRules.EveryDay("SPY"), self.TimeRules.AfterMarketOpen("SPY"), self.DailyCheck)
# TOGGLES
# self.short_ema_trail = True
self.invest = False
self.weekly_trigger = False
self.buy = False
# VARIABLES
self.trigger_week_high = 0
self.trigger_week_low = 0
self.previous_week_high = 0
self.previous_week_low = 0
self.SetWarmUp(timedelta(days = 20))
weeklyConsolidator = TradeBarConsolidator(Calendar.Weekly)
self.SubscriptionManager.AddConsolidator(self.spy.Symbol, weeklyConsolidator)
weeklyConsolidator.DataConsolidated += self.OnTwoWeekBar
self.weekBarWindow = RollingWindow[TradeBar](2) # 2
# CUSTOM CHART
log_plot = Chart('Custom Chart')
log_plot.AddSeries(Series('Orders',SeriesType.Scatter,0))
log_plot.AddSeries(Series('Spy Price', SeriesType.Line,0))
self.AddChart(log_plot)
def Rebalance(self):
if self.IsWarmingUp:
return
def OnData(self, data):
# VARIABLES
spy_price = self.Securities[self.spy.Symbol].Price
held_stocks = self.Portfolio[self.spy.Symbol].Quantity
shares_to_buy = int(self.Portfolio.Cash / spy_price)
profit = self.Portfolio[self.spy.Symbol].UnrealizedProfitPercent
if (spy_price > self.trigger_week_high) and self.weekly_trigger and self.invest:
self.MarketOrder(self.spy.Symbol, (shares_to_buy*0.1))
self.invest = False
self.weekly_trigger = False
self.Log(f'{self.trigger_week_high} previous weeks high ORDER')
def OnTwoWeekBar(self, sender, bar):
self.weekBarWindow.Add(bar)
if not self.weekBarWindow.IsReady:
return
trigger_week = self.weekBarWindow[0]
previous_week = self.weekBarWindow[1]
self.trigger_week_high = trigger_week.High
self.trigger_week_low = trigger_week.Low
self.previous_week_high = previous_week.High
self.previous_week_low = previous_week.Low
self.Log(f'{self.trigger_week_high} previous weeks high CORRECT')
def WeekStart(self):
# Inside Bar
if (self.trigger_week_high < self.previous_week_high) and (self.trigger_week_low > self.previous_week_low):
self.weekly_trigger = True
self.invest = True
# 2Down
if (self.trigger_week_high < self.previous_week_high) and (self.trigger_week_low < self.previous_week_low):
self.weekly_trigger = True
self.invest = True
def WeekEnd(self):
if self.weekly_trigger:
self.weekly_trigger = False
self.invest = False
def DailyCheck(self):
self.Log(f'{self.trigger_week_high} Daily one')
def OnOrderEvent(self, orderEvent):
if orderEvent.FillQuantity == 0:
return
fetched = self.Transactions.GetOrderById(orderEvent.OrderId)
symbol = orderEvent.Symbol
fill_price = orderEvent.FillPrice
self.Plot('Custom Chart', 'Orders', fill_price)