| Overall Statistics |
|
Total Trades 7 Average Win 1.21% Average Loss -0.26% Compounding Annual Return 29.657% Drawdown 30.000% Expectancy 2.746 Net Profit 93.538% Sharpe Ratio 1.301 Probabilistic Sharpe Ratio 60.283% Loss Rate 33% Win Rate 67% Profit-Loss Ratio 4.62 Alpha 0.041 Beta 0.944 Annual Standard Deviation 0.203 Annual Variance 0.041 Information Ratio 0.625 Tracking Error 0.045 Treynor Ratio 0.28 Total Fees $7.00 Estimated Strategy Capacity $69000000.00 Lowest Capacity Asset QQQ RIWIV7K5Z9LX |
class FocusedSkyBlueGalago(QCAlgorithm):
def Initialize(self):
self.SetStartDate(2019, 1, 1)
#self.SetEndDate(2018, 1, 3)
self.InitCash = 10000
self.SetCash(self.InitCash)
self.AddEquity("SPY", Resolution.Minute)
# ETF's we're going to trade===================================
spy = self.AddEquity("SPY", Resolution.Minute)
QQQ = self.AddEquity("QQQ", Resolution.Minute)
tqqq = self.AddEquity("TQQQ", Resolution.Minute)
spy.SetDataNormalizationMode(DataNormalizationMode.Raw)
tqqq.SetDataNormalizationMode(DataNormalizationMode.Raw)
self.spy = spy.Symbol
self.qqq = QQQ.Symbol
self.tqqq = tqqq.Symbol
#Option Contract =================================================
self.contract = None
# Rebalance beginning of every month =======================
self.Schedule.On(self.DateRules.MonthStart("SPY"),
self.TimeRules.AfterMarketOpen("SPY"), self.MonthlyRebalance)
# Graphing SPY Benchmark =================
self.MKT = self.AddEquity("SPY", Resolution.Daily).Symbol
self.mkt = []
#Stoploss
self.priceSPY = 0
self.Count = 0
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
'''
#Start of day
if not self.Portfolio[self.spy].Invested:
self.SetHoldings(self.spy, .6)
self.SetHoldings(self.qqq, .36)
#do at start of day
if self.Count == 0:
if data.ContainsKey("SPY"):
self.priceSPY = data.Bars["SPY"].High
#do at start of day
self.Count = 1
#Stoploss
else:
if data.ContainsKey("SPY"):
if ( (data.Bars["SPY"].High - self.priceSPY) / self.priceSPY ) < -.05:
#self.Debug(self.Time)
#self.Debug((data.Bars["SPY"].High - self.priceSPY) / self.priceSPY )
self.SetHoldings(self.spy, 0)
self.SetHoldings(self.qqq, 0)
return
#Reset trailing stoploss parameter
self.Count = 0
# DO HEDGE
if self.contract is None:
self.contract = self.GetContract()
return
if (self.contract.ID.Date - self.Time).days < 180:
self.Liquidate(self.contract)
self.RemoveSecurity(self.contract)
self.contract = None
return
if not self.Portfolio[self.contract].Invested:
self.SetHoldings(self.contract, 0.05)
if self.Securities[self.spy].Price < self.contract.ID.StrikePrice * 1.2:
self.Liquidate(self.contract)
self.RemoveSecurity(self.contract)
def GetContract(self):
targetStrike = (self.Securities[self.spy].Price * 0.6) - (self.Securities[self.spy].Price * 0.6)%5
contracts = self.OptionChainProvider.GetOptionContractList(self.spy, self.Time)
puts = [x for x in contracts if x.ID.OptionRight == OptionRight.Put]
puts = sorted( sorted(puts, key = lambda x: x.ID.Date, reverse = True),
key = lambda x: x.ID.StrikePrice)
puts = [x for x in puts if x.ID.StrikePrice == targetStrike]
puts = [x for x in puts if 270 < (x.ID.Date - self.Time).days <= 420]
if len(puts) == 0:
self.Log("No Puts")
return None
self.AddOptionContract(puts[0], Resolution.Minute)
puts[0]
def MonthlyRebalance(self):
#Now I need to rebalance portfolio on a monthly basis
self.SetHoldings(self.spy, 0.5)
self.SetHoldings(self.qqq, 0.45)
return
def OnEndOfDay(self):
mkt_price = self.History(self.MKT, 2, Resolution.Daily)['close'].unstack(level= 0).iloc[-1]
self.mkt.append(mkt_price)
mkt_perf = self.InitCash * self.mkt[-1] / self.mkt[0]
self.Plot('Strategy Equity', self.MKT, mkt_perf)