| Overall Statistics |
|
Total Trades 174 Average Win 170.59% Average Loss -0.12% Compounding Annual Return 20.581% Drawdown 9.700% Expectancy 33.512 Net Profit 591.651% Sharpe Ratio 0.603 Probabilistic Sharpe Ratio 0.000% Loss Rate 98% Win Rate 2% Profit-Loss Ratio 1483.00 Alpha 0.131 Beta 0.35 Annual Standard Deviation 0.279 Annual Variance 0.078 Information Ratio 0.212 Tracking Error 0.289 Treynor Ratio 0.481 Total Fees $30162.50 Estimated Strategy Capacity $1000.00 Lowest Capacity Asset SPY 31WE5G5T8KZ5Y|SPY R735QTJ8XC9X |
class UncoupledTransdimensionalPrism(QCAlgorithm):
def Initialize(self):
self.SetStartDate(2012, 1, 1) # Set Start Date
self.SetEndDate(2022, 5, 1)
self.SetCash(1000000) # Set Strategy Cash
spy = self.AddEquity("SPY", Resolution.Minute)
spy.SetDataNormalizationMode(DataNormalizationMode.Raw)
self.tlt = self.AddEquity('TLT', Resolution.Minute).Symbol
self.spy = spy.Symbol
self.contract = None
self.alpha = 0.01/12 # the weight of options position
self.strike = 0.725 # the ratio of strike to market
def OnData(self, data):
if (self.Time.hour,self.Time.minute) != (15, 30): return
if not self.Portfolio[self.spy].Invested:
self.SetHoldings(self.spy, 1.00*(1-self.alpha))
self.SetHoldings(self.tlt, 0.00*(1-self.alpha))
# DO HEDGE
if self.contract is None:
self.contract = self.GetContract()
return
if (self.contract.ID.Date - self.Time).days < 1:
# self.Liquidate(self.contract)
self.RemoveSecurity(self.contract)
self.contract = None
return
# ES Added: Ensure bar data contains the contract
if not data.ContainsKey(self.contract): return
if not self.Portfolio[self.contract].Invested:
self.SetHoldings(self.contract, self.alpha)
self.Debug(self.contract)
if self.Securities[self.spy].Price < self.contract.ID.StrikePrice * 1.0:
self.Liquidate(self.contract)
self.RemoveSecurity(self.contract)
def GetContract(self):
targetStrike = self.Securities[self.spy].Price * self.strike
targetStrike = (targetStrike) - (targetStrike)%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 30 < (x.ID.Date - self.Time).days <= 45]
if len(puts) == 0:
return None
self.AddOptionContract(puts[0], Resolution.Minute)
return puts[0]