Overall Statistics
Total Trades
110
Average Win
11.03%
Average Loss
-6.54%
Compounding Annual Return
6.322%
Drawdown
55.700%
Expectancy
0.572
Net Profit
305.780%
Sharpe Ratio
0.352
Probabilistic Sharpe Ratio
0.008%
Loss Rate
42%
Win Rate
58%
Profit-Loss Ratio
1.69
Alpha
0.002
Beta
0.972
Annual Standard Deviation
0.162
Annual Variance
0.026
Information Ratio
0.012
Tracking Error
0.038
Treynor Ratio
0.059
Total Fees
$701.21
Estimated Strategy Capacity
$1300000000.00
Lowest Capacity Asset
SPY R735QTJ8XC9X
# https://quantpedia.com/strategies/january-effect-in-stocks/
#
# Invest in small-cap stocks at the beginning of each January. Stay invested in large-cap stocks for the rest of the year.
#
# QC implementation changes:
#   - Small cap etf (IWM) and large cap etf (SPY) are used as investment assets.

from AlgorithmImports import *

class JanuaryEffectInStocks(QCAlgorithm):

    def Initialize(self):
        self.SetStartDate(2000, 1, 1)  
        self.SetCash(100000) 

        data = self.AddEquity("SPY", Resolution.Daily)
        data.SetLeverage(10)
        self.large_cap = data.Symbol
        
        data = self.AddEquity("IWM", Resolution.Daily)
        data.SetLeverage(10)
        self.small_cap = data.Symbol

        self.start_price = None
        self.recent_month = -1
        
    def OnData(self, data):
        if self.recent_month == self.Time.month:
            return
        self.recent_month = self.Time.month

        if self.Securities[self.large_cap].GetLastData() and self.Securities[self.small_cap].GetLastData():
            if (self.Time.date() - self.Securities[self.large_cap].GetLastData().Time.date()).days < 5 and (self.Time.date() - self.Securities[self.small_cap].GetLastData().Time.date()).days < 5:
                if self.Time.month == 1:
                    if self.Portfolio[self.large_cap].Invested:
                        self.Liquidate(self.large_cap)
                    self.SetHoldings(self.small_cap, 1)
                else:
                    if self.Portfolio[self.small_cap].Invested:
                        self.Liquidate(self.small_cap)
                    self.SetHoldings(self.large_cap, 1)
            else:
                self.Liquidate()
        else:
            self.Liquidate()