Overall Statistics
Total Trades
1
Average Win
0%
Average Loss
0%
Compounding Annual Return
11.485%
Drawdown
25.800%
Expectancy
0
Net Profit
4.630%
Sharpe Ratio
0.542
Probabilistic Sharpe Ratio
37.415%
Loss Rate
0%
Win Rate
0%
Profit-Loss Ratio
0
Alpha
-0.021
Beta
0.882
Annual Standard Deviation
0.323
Annual Variance
0.104
Information Ratio
-1.002
Tracking Error
0.047
Treynor Ratio
0.198
Total Fees
$49.52
class ResistanceTransdimensionalSplitter(QCAlgorithm):

    def Initialize(self):
        self.SetStartDate(2009, 1, 1)
        self.SetEndDate(2009, 6, 1)
        self.SetCash(1000000)
        spy = self.AddEquity("SPY", Resolution.Minute)
        spy.SetDataNormalizationMode(DataNormalizationMode.Raw)
        self.spy = spy.Symbol
        self.contract = None
        self.SetWarmUp(200)
    
    def OnData(self, data):
        if self.IsWarmingUp:
            return

        if not self.Portfolio[self.spy].Invested:
            self.SetHoldings(self.spy, 0.9)
            self.Debug(str(self.Portfolio[self.spy].HoldingsValue))
            
        if self.contract is None:
            self.contract = self.GetContract()
            self.SetHoldings(self.contract, 0.1)
            return
        
    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]