Overall Statistics
Total Orders
5
Average Win
0%
Average Loss
-0.34%
Compounding Annual Return
-0.822%
Drawdown
0.900%
Expectancy
-0.5
Start Equity
100000
End Equity
99867.5
Net Profit
-0.132%
Sharpe Ratio
-0.854
Sortino Ratio
-0.753
Probabilistic Sharpe Ratio
25.191%
Loss Rate
50%
Win Rate
50%
Profit-Loss Ratio
0
Alpha
-0.01
Beta
0.096
Annual Standard Deviation
0.015
Annual Variance
0
Information Ratio
0.138
Tracking Error
0.123
Treynor Ratio
-0.137
Total Fees
$4.00
Estimated Strategy Capacity
$130000000.00
Lowest Capacity Asset
IBM 2ZN0UI19JRV52|IBM R735QTJ8XC9X
Portfolio Turnover
0.95%
#region imports
from AlgorithmImports import *
#endregion

class ProtectivePutAlgorithm(QCAlgorithm):

    def Initialize(self):
        self.SetStartDate(2014, 1, 1)
        self.SetEndDate(2014, 3, 1)
        self.SetCash(100000)

        option = self.AddOption("IBM")
        self.symbol = option.Symbol
        option.set_filter(lambda universe: universe.include_weeklys().naked_put(30, 0))

        self.put = None

        # use the underlying equity as the benchmark
        self.SetBenchmark(self.symbol.Underlying)

    def OnData(self, slice):

        if self.put and self.Portfolio[self.put].Invested:
            return

        chain = slice.OptionChains.get(self.symbol)
        if not chain:
            return

        # Find ATM put with the farthest expiry
        expiry = max([x.Expiry for x in chain])
        put_contracts = sorted([x for x in chain
            if x.Right == OptionRight.Put and x.Expiry == expiry],
            key=lambda x: abs(chain.Underlying.Price - x.Strike))

        if not put_contracts:
            return

        atm_put = put_contracts[0]

        protective_put = OptionStrategies.ProtectivePut(self.symbol, atm_put.Strike, expiry)
        self.Buy(protective_put, 1)

        self.put = atm_put.Symbol