Overall Statistics |
Total Orders
256
Average Win
0.47%
Average Loss
-0.38%
Compounding Annual Return
1.005%
Drawdown
11.400%
Expectancy
0.326
Start Equity
100000
End Equity
115818.02
Net Profit
15.818%
Sharpe Ratio
-0.3
Sortino Ratio
-0.094
Probabilistic Sharpe Ratio
0.033%
Loss Rate
40%
Win Rate
60%
Profit-Loss Ratio
1.22
Alpha
-0.013
Beta
0.05
Annual Standard Deviation
0.03
Annual Variance
0.001
Information Ratio
-0.691
Tracking Error
0.139
Treynor Ratio
-0.18
Total Fees
$603.89
Estimated Strategy Capacity
$6000.00
Lowest Capacity Asset
QAT VQ6KGBSR66AT
Portfolio Turnover
0.44%
|
# https://quantpedia.com/strategies/ramadan-effect/ # # The investment universe consists of countries for which stock market index data are available and in which the proportion of population the professing Muslim faith # exceeded 50%. Most of the countries could be easily tracked via index ETFs. The research paper we use as an example uses 14 Muslim countries. # Ramadan is the ninth month in the Islamic calendar, which is based on the motion of the moon. The Ramadan month could be calculated by using information on the # lunar phases and sunset times from astronomical calendar or information about Ramadan dates from various public sources. # The trading strategy is simple. The investor holds an equally weighted portfolio of ETFs during Ramadan month. He/she is otherwise invested in cash. from AlgorithmImports import * from pandas.tseries.offsets import BDay class RamadanEffect(QCAlgorithm): def initialize(self): self.set_start_date(2010, 1, 1) self.set_cash(100000) self.symbols: List[Symbol] = [ self.add_equity(x, Resolution.DAILY).symbol for x in [ 'TUR', 'GULF', 'GAF', 'PAK', 'UAE', 'QAT', 'EGPT', 'EWM', 'EIDO', 'KSA' ] ] # Source: https://www.infoplease.com/calendars/holidays/islamic-holidays csv_string_file: str = self.download('data.quantpedia.com/backtesting_data/calendar/ramadan_dates.csv') date_pairs_str: List[str] = csv_string_file.split('\r\n') self.date_ranges: List[List] = [] for pair in date_pairs_str: split: List[str] = pair.split(';') self.date_ranges.append( pd.date_range(start=datetime.strptime(split[0], "%d.%m.%Y").date(), end=datetime.strptime(split[1], "%d.%m.%Y").date()) ) def on_data(self, slice: Slice) -> None: if any(str(self.time.date()) in self.date_ranges[i] for i in range(len(self.date_ranges))): # open trades if not self.portfolio.invested: portfolio: List[PortfolioTarget] = [ PortfolioTarget(symbol, 1. / len(self.symbols)) for symbol in self.symbols if symbol in slice and slice[symbol] ] self.set_holdings(portfolio, True) else: # close trades if self.portfolio.invested: self.liquidate()