Overall Statistics |
Total Trades 6 Average Win 0% Average Loss -0.95% Compounding Annual Return 24.046% Drawdown 26.400% Expectancy -1 Net Profit 24.022% Sharpe Ratio 1.117 Probabilistic Sharpe Ratio 49.412% Loss Rate 100% Win Rate 0% Profit-Loss Ratio 0 Alpha -0.006 Beta 0.925 Annual Standard Deviation 0.25 Annual Variance 0.063 Information Ratio -0.689 Tracking Error 0.043 Treynor Ratio 0.302 Total Fees $156.72 |
class UncoupledTransdimensionalPrism(QCAlgorithm): def Initialize(self): self.SetStartDate(2009, 1, 1) # Set Start Date self.SetEndDate(2009, 12, 31) self.SetCash(1000000) # Set Strategy Cash spy = self.AddEquity("SPY", Resolution.Minute) spy.SetDataNormalizationMode(DataNormalizationMode.Raw) self.spy = spy.Symbol self.contract = None def OnData(self, data): if not self.Portfolio[self.spy].Invested: self.SetHoldings(self.spy, 0.99) # 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.01) if self.Securities[self.spy].Price < self.contract.ID.StrikePrice * 1.3: 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: return None self.AddOptionContract(puts[0], Resolution.Minute) return puts[0]