Spaces:
Sleeping
Sleeping
| # tickers is a list of stock tickers | |
| import tickers | |
| # prices is a dict; the key is a ticker and the value is a list of historic prices, today first | |
| import prices | |
| # Trade represents a decision to buy or sell a quantity of a ticker | |
| import Trade | |
| import random | |
| import numpy as np | |
| def trade2(): | |
| # Buy the stock with the highest price today | |
| ticker = max(prices, key=lambda t: prices[t][0]) # Find ticker with highest price | |
| return [Trade(ticker, random.randrange(1, 10))] # Buy a small quantity | |
| def trade3(): | |
| # Sell the stock with the lowest price today | |
| ticker = min(prices, key=lambda t: prices[t][0]) | |
| return [Trade(ticker, random.randrange(-10, -1))] | |
| def trade4(): | |
| # Buy the stock with the largest percent increase today | |
| changes = {t: (prices[t][0] - prices[t][1]) / prices[t][1] for t in prices} | |
| ticker = max(changes, key=changes.get) | |
| return [Trade(ticker, random.randrange(1, 10))] | |
| def trade5(): | |
| # Sell the stock with the largest percent decrease today | |
| changes = {t: (prices[t][0] - prices[t][1]) / prices[t][1] for t in prices} | |
| ticker = min(changes, key=changes.get) | |
| return [Trade(ticker, random.randrange(-10, -1))] | |
| def trade6(): | |
| # Buy the 3 stocks with the highest moving average over the last 5 days | |
| mvgs = {t: np.mean(prices[t][:5]) for t in prices} | |
| top_tickers = sorted(mvgs, key=mvgs.get, reverse=True)[:3] | |
| return [Trade(t, random.randrange(1, 5)) for t in top_tickers] | |
| def trade7(): | |
| # Sell the 3 stocks with the lowest moving average over the last 5 days | |
| mvgs = {t: np.mean(prices[t][:5]) for t in prices} | |
| bottom_tickers = sorted(mvgs, key=mvgs.get)[:3] | |
| return [Trade(t, random.randrange(-5, -1)) for t in bottom_tickers] | |
| def trade8(): | |
| # Randomly buy or sell a single stock based on a coin flip | |
| ticker = random.choice(tickers) | |
| action = random.choice([-1, 1]) # -1 for sell, 1 for buy | |
| return [Trade(ticker, action * random.randrange(1, 10))] | |
| def trade9(): | |
| # Diversify: Buy a small amount of 5 random stocks | |
| chosen_tickers = random.sample(tickers, 5) | |
| return [Trade(t, random.randrange(1, 3)) for t in chosen_tickers] | |
| def trade10(): | |
| # Follow the trend: If the market is up today, buy, else sell | |
| market_change = (prices[tickers[0]][0] - prices[tickers[0]][1]) / prices[tickers[0]][1] | |
| action = 1 if market_change > 0 else -1 | |
| ticker = random.choice(tickers) | |
| return [Trade(ticker, action * random.randrange(1, 10))] | |
| def trade11(): | |
| # Mean Reversion: Buy the 2 stocks that fell the most yesterday, hoping they rebound | |
| yesterday_changes = {t: (prices[t][1] - prices[t][2]) / prices[t][2] for t in prices} | |
| bottom_tickers = sorted(yesterday_changes, key=yesterday_changes.get)[:2] | |
| return [Trade(t, random.randrange(1, 5)) for t in bottom_tickers] | |
| def trade12(): | |
| # Momentum: Short the 2 stocks that rose the most yesterday, expecting a pullback | |
| yesterday_changes = {t: (prices[t][1] - prices[t][2]) / prices[t][2] for t in prices} | |
| top_tickers = sorted(yesterday_changes, key=yesterday_changes.get, reverse=True)[:2] | |
| return [Trade(t, random.randrange(-5, -1)) for t in top_tickers] | |
| def trade13(): | |
| # Pairs Trading: Long one stock, short another with a similar price history | |
| correlations = np.corrcoef([prices[t] for t in tickers]) | |
| i, j = np.unravel_index(np.argmax(correlations), correlations.shape) | |
| return [Trade(tickers[i], 1), Trade(tickers[j], -1)] | |
| def trade14(): | |
| # Relative Strength: Go long on the strongest stock, short the weakest | |
| performances = {t: (prices[t][0] - prices[t][-1]) / prices[t][-1] for t in prices} | |
| strongest = max(performances, key=performances.get) | |
| weakest = min(performances, key=performances.get) | |
| return [Trade(strongest, 1), Trade(weakest, -1)] | |
| def trade15(): | |
| # Calendar Spread: Buy this month's option, sell next month's (same strike | |
| # This is a simplified representation, as actual option trading is more complex | |
| ticker = random.choice(tickers) | |
| return [Trade(f"{ticker}_OPT_THIS_MONTH", 1), Trade(f"{ticker}_OPT_NEXT_MONTH", -1)] | |
| def trade16(): | |
| # Straddle: Buy both a call and put option on the same stock (same strike | |
| ticker = random.choice(tickers) | |
| strike = prices[ticker][0] # Use the current price as a simple strike price | |
| return [Trade(f"{ticker}_CALL_{strike}", 1), Trade(f"{ticker}_PUT_{strike}", 1)] | |
| def trade17(): | |
| # Breakout: Buy if a stock breaks above its 52-week high | |
| ticker = random.choice(tickers) | |
| if prices[ticker][0] > max(prices[ticker]): | |
| return [Trade(ticker, random.randrange(1, 10))] | |
| else: | |
| return [] | |
| def trade18(): | |
| # Volatility: If market volatility is high, sell (expecting it to decrease | |
| market_volatility = np.std([prices[t][0] / prices[t][1] for t in tickers]) | |
| if market_volatility > 0.05: # You'd adjust this threshold based on your risk tolerance | |
| ticker = random.choice(tickers) | |
| return [Trade(ticker, random.randrange(-10, -1))] | |
| else: | |
| return [] | |
| def trade19(): | |
| # Golden Cross: Buy if the short-term moving average crosses above the long-term | |
| ticker = random.choice(tickers) | |
| short_ma = np.mean(prices[ticker][:5]) | |
| long_ma = np.mean(prices[ticker][:20]) | |
| if short_ma > long_ma and short_ma - long_ma < 0.01: # Small margin to avoid false signals | |
| return [Trade(ticker, random.randrange(1, 10))] | |
| else: | |
| return [] | |
| def trade20(): | |
| # Death Cross: Sell if the short-term moving average crosses below the long-term | |
| ticker = random.choice(tickers) | |
| short_ma = np.mean(prices[ticker][:5]) | |
| long_ma = np.mean(prices[ticker][:20]) | |
| if short_ma < long_ma and long_ma - short_ma < 0.01: | |
| return [Trade(ticker, random.randrange(-10, -1))] | |
| else: | |
| return [] | |
| def trade21(): | |
| # Correlated Pairs Buy: Buy a pair of stocks that have historically moved together | |
| correlations = np.corrcoef([prices[t] for t in tickers]) | |
| i, j = np.unravel_index(np.argmax(correlations), correlations.shape) | |
| return [Trade(tickers[i], 1), Trade(tickers[j], 1)] | |
| def trade22(): | |
| # Correlated Pairs Sell: Sell a pair of stocks that have historically moved together | |
| correlations = np.corrcoef([prices[t] for t in tickers]) | |
| i, j = np.unravel_index(np.argmax(correlations), correlations.shape) | |
| return [Trade(tickers[i], -1), Trade(tickers[j], -1)] | |
| def trade23(): | |
| # Contrarian Pairs Buy: Buy a stock that's down while its correlated pair is up | |
| correlations = np.corrcoef([prices[t] for t in tickers]) | |
| i, j = np.unravel_index(np.argmax(correlations), correlations.shape) | |
| if prices[tickers[i]][0] < prices[tickers[i]][1] and prices[tickers[j]][0] > prices[tickers[j]][1]: | |
| return [Trade(tickers[i], 1)] | |
| else: | |
| return [] | |
| def trade24(): | |
| # Contrarian Pairs Sell: Sell a stock that's up while its correlated pair is down | |
| correlations = np.corrcoef([prices[t] for t in tickers]) | |
| i, j = np.unravel_index(np.argmax(correlations), correlations.shape) | |
| if prices[tickers[i]][0] > prices[tickers[i]][1] and prices[tickers[j]][0] < prices[tickers[j]][1]: | |
| return [Trade(tickers[i], -1)] | |
| else: | |
| return [] | |
| def trade25(): | |
| # Correlation Reversal: Buy a stock that's recently become less correlated with the market | |
| # This is a simplified version, you'd likely use a rolling correlation window | |
| market_prices = [prices[t] for t in tickers] | |
| correlations_today = np.corrcoef(market_prices) | |
| correlations_yesterday = np.corrcoef([p[1:] for p in market_prices]) | |
| diffs = correlations_today - correlations_yesterday | |
| i, j = np.unravel_index(np.argmin(diffs), diffs.shape) | |
| if i != j: # Ensure we're not comparing a stock to itself | |
| return [Trade(tickers[i], 1)] | |
| else: | |
| return [] | |
| def trade26(): | |
| # Sector Rotation: Buy the top 2 stocks from the sector that's most correlated with the market | |
| # Assuming you have sector data (e.g., 'sector_map' dict: ticker -> sector) | |
| sector_returns = {s: np.mean([(prices[t][0] - prices[t][1]) / prices[t][1] for t in tickers if sector_map[t] == s]) for s in set(sector_map.values())} | |
| top_sector = max(sector_returns, key=sector_returns.get) | |
| top_tickers_in_sector = sorted([(t, prices[t][0]) for t in tickers if sector_map[t] == top_sector], key=lambda x: x[1], reverse=True)[:2] | |
| return [Trade(t, 1) for t, _ in top_tickers_in_sector] | |
| def trade27(): | |
| # Beta-Weighted Portfolio: Allocate more to stocks with higher betas (more volatile | |
| # You'd need historical market data to calculate betas | |
| betas = {t: random.uniform(0.5, 2) for t in tickers} # Placeholder for actual betas | |
| total_beta = sum(betas.values()) | |
| allocations = {t: betas[t] / total_beta * 100 for t in tickers} | |
| return [Trade(t, int(allocations[t])) for t in tickers] | |
| def trade28(): | |
| # Diversified Portfolio: Buy a mix of stocks with low correlations to each other | |
| correlations = np.corrcoef([prices[t] for t in tickers]) | |
| chosen_tickers = [] | |
| while len(chosen_tickers) < 5 and len(tickers) > 0: | |
| t = random.choice(tickers) | |
| if all(correlations[tickers.index(t)][tickers.index(c)] < 0.5 for c in chosen_tickers): | |
| chosen_tickers.append(t) | |
| tickers.remove(t) | |
| return [Trade(t, random.randrange(1, 3)) for t in chosen_tickers] | |
| def trade29(): | |
| # Cointegration: Find a pair of stocks that are cointegrated and trade their spread | |
| # This requires more complex analysis (e.g., using the Johansen test) | |
| # For simplicity, we'll just pick a random pair and assume cointegration | |
| i, j = random.sample(range(len(tickers)), 2) | |
| spread = prices[tickers[i]][0] - prices[tickers[j]][0] | |
| if spread > 0: | |
| return [Trade(tickers[i], -1), Trade(tickers[j], 1)] | |
| else: | |
| return [Trade(tickers[i], 1), Trade(tickers[j], -1)] | |
| def trade30(): | |
| # Basket Trading: Buy or sell a basket of stocks based on their correlation to a benchmark | |
| # You'd need a benchmark ticker and its historical prices | |
| benchmark = "SPY" | |
| correlations = np.corrcoef([prices[t] for t in tickers + [benchmark]])[:-1, -1] # Correlate each stock with the benchmark | |
| if np.mean(correlations) > 0.5: | |
| return [Trade(t, 1) for t in tickers] | |
| else: | |
| return [Trade(t, -1) for t in tickers] | |
| def trade31(): | |
| # Double Bottom: Buy when a stock forms a double bottom pattern | |
| ticker = random.choice(tickers) | |
| if prices[ticker][0] < prices[ticker][2] < prices[ticker][4] and prices[ticker][1] > prices[ticker][3]: | |
| return [Trade(ticker, 1)] | |
| else: | |
| return [] | |
| def trade32(): | |
| # Double Top: Sell when a stock forms a double top pattern | |
| ticker = random.choice(tickers) | |
| if prices[ticker][0] > prices[ticker][2] > prices[ticker][4] and prices[ticker][1] < prices[ticker][3]: | |
| return [Trade(ticker, -1)] | |
| else: | |
| return [] | |
| def trade33(): | |
| # Head and Shoulders: Sell when a stock forms a head and shoulders pattern | |
| ticker = random.choice(tickers) | |
| if prices[ticker][0] < prices[ticker][2] < prices[ticker][4] and prices[ticker][1] > prices[ticker][3] > prices[ticker][5]: | |
| return [Trade(ticker, -1)] | |
| else: | |
| return [] | |
| def trade34 | |
| # Inverse Head and Shoulders: Buy when a stock forms an inverse head and shoulders pattern | |
| ticker = random.choice(tickers) | |
| if prices[ticker][0] > prices[ticker][2] > prices[ticker][4] and prices[ticker][1] < prices[ticker][3] < prices[ticker][5]: | |
| return [Trade(ticker, 1)] | |
| else: | |
| return [] | |
| def trade35(): | |
| # Ascending Triangle: Buy when a stock forms an ascending triangle pattern | |
| ticker = random.choice(tickers) | |
| # Simplified logic: check for higher lows and flat highs | |
| if prices[ticker][0] > prices[ticker][2] > prices[ticker][4] and prices[ticker][1] == prices[ticker][3] == prices[ticker][5]: | |
| return [Trade(ticker, 1)] | |
| else: | |
| return [] | |
| def trade36(): | |
| # Descending Triangle: Sell when a stock forms a descending triangle pattern | |
| ticker = random.choice(tickers) | |
| # Simplified logic: check for lower highs and flat lows | |
| if prices[ticker][0] < prices[ticker][2] < prices[ticker][4] and prices[ticker][1] == prices[ticker][3] == prices[ticker][5]: | |
| return [Trade(ticker, -1)] | |
| else: | |
| return [] | |
| def trade37(): | |
| # Flag/Pennant: Buy or sell based on the direction of the flag/pennant pattern | |
| ticker = random.choice(tickers) | |
| # Simplified logic: check for a consolidation period after a strong move | |
| if abs(prices[ticker][0] - np.mean(prices[ticker][1:5])) < 0.05 and abs(prices[ticker][5] - prices[ticker][6]) > 0.1: | |
| # Buy if the prior move was up, sell if down | |
| return [Trade(ticker, 1 if prices[ticker][5] > prices[ticker][6] else -1)] | |
| else: | |
| return [] | |
| def trade38(): | |
| # Gap Up: Buy when a stock opens significantly higher than its previous close | |
| ticker = random.choice(tickers) | |
| if prices[ticker][0] > prices[ticker][1] * 1.05: # 5% gap up | |
| return [Trade(ticker, 1)] | |
| else: | |
| return [] | |
| def trade39(): | |
| # Gap Down: Sell when a stock opens significantly lower than its previous close | |
| ticker = random.choice(tickers) | |
| if prices[ticker][0] < prices[ticker][1] * 0.95: # 5% gap down | |
| return [Trade(ticker, -1)] | |
| else: | |
| return [] | |
| def trade40(): | |
| # Rounding Bottom: Buy when a stock forms a rounding bottom pattern | |
| ticker = random.choice(tickers) | |
| # Simplified logic: check for a gradual price increase after a period of decline | |
| if prices[ticker][0] > prices[ticker][2] > prices[ticker][4] and prices[ticker][1] < prices[ticker][3] < prices[ticker][5]: | |
| return [Trade(ticker, 1)] | |
| else: | |
| return [] | |
| def trade41(): | |
| # Overbought/Oversold (RSI): Sell if RSI is above 70, buy if below 30 | |
| ticker = random.choice(tickers) | |
| rsi = calculate_rsi(prices[ticker], 14) # Assuming you have an RSI calculation function | |
| if rsi > 70: | |
| return [Trade(ticker, -1)] | |
| elif rsi < 30: | |
| return [Trade(ticker, 1)] | |
| else: | |
| return [] | |
| def trade42(): | |
| # Bollinger Bands Breakout: Buy if price breaks above the upper band, sell if below lower | |
| ticker = random.choice(tickers) | |
| upper, middle, lower = calculate_bollinger_bands(prices[ticker], 20, 2) # Assuming you have a Bollinger Band calculation function | |
| if prices[ticker][0] > upper: | |
| return [Trade(ticker, 1)] | |
| elif prices[ticker][0] < lower: | |
| return [Trade(ticker, -1)] | |
| else: | |
| return [] | |
| def trade43(): | |
| # Channel Breakout: Buy or sell when price breaks out of a recent price channel | |
| ticker = random.choice(tickers) | |
| highs = [max(prices[ticker][i:i+5]) for i in range(len(prices[ticker]) - 5)] | |
| lows = [min(prices[ticker][i:i+5]) for i in range(len(prices[ticker]) - 5)] | |
| if prices[ticker][0] > highs[-1]: | |
| return [Trade(ticker, 1)] | |
| elif prices[ticker][0] < lows[-1]: | |
| return [Trade(ticker, -1)] | |
| else: | |
| return [] | |
| def trade44(): | |
| # Trend Following: Buy if the 20-day moving average is rising, sell if falling | |
| ticker = random.choice(tickers) | |
| ma20_today = np.mean(prices[ticker][:20]) | |
| ma20_yesterday = np.mean(prices[ticker][1:21]) | |
| if ma20_today > ma20_yesterday: | |
| return [Trade(ticker, 1)] | |
| elif ma20_today < ma20_yesterday: | |
| return [Trade(ticker, -1)] | |
| else: | |
| return [] | |
| def trade45(): | |
| # MACD Crossover: Buy when MACD line crosses above signal line, sell when below | |
| ticker = random.choice(tickers) | |
| macd_line, signal_line = calculate_macd(prices[ticker]) # Assuming you have a MACD calculation function | |
| if macd_line[-1] > signal_line[-1] and macd_line[-2] <= signal_line[-2]: | |
| return [Trade(ticker, 1)] | |
| elif macd_line[-1] < signal_line[-1] and macd_line[-2] >= signal_line[-2]: | |
| return [Trade(ticker, -1)] | |
| else: | |
| return [] | |
| def trade46(): | |
| # Stochastic Oscillator: Buy if %K crosses above %D in oversold zone, sell if opposite | |
| ticker = random.choice(tickers) | |
| k_line, d_line = calculate_stochastic(prices[ticker]) # Assuming you have a Stochastic calculation function | |
| if k_line[-1] > d_line[-1] and k_line[-1] < 20: | |
| return [Trade(ticker, 1)] | |
| elif k_line[-1] < d_line[-1] and k_line[-1] > 80: | |
| return [Trade(ticker, -1)] | |
| else: | |
| return [] | |
| def trade47(): | |
| # Volume Spike: Buy if today's volume is much higher than the average | |
| # You'd need volume data for this strategy | |
| ticker = random.choice(tickers) | |
| avg_volume = np.mean(volumes[ticker][1:]) # Assuming you have 'volumes' data | |
| if volumes[ticker][0] > avg_volume * 2: | |
| return [Trade(ticker, 1)] | |
| else: | |
| return [] | |
| def trade48(): | |
| # Price Spike: Buy if today's price increase is much higher than average daily change | |
| ticker = random.choice(tickers) | |
| daily_changes = [(prices[ticker][i] - prices[ticker][i + 1]) / prices[ticker][i + 1] for i in range(len(prices[ticker]) - 1)] | |
| avg_change = np.mean(daily_changes) | |
| today_change = (prices[ticker][0] - prices[ticker][1]) / prices[ticker][1] | |
| if today_change > avg_change * 2: | |
| return [Trade(ticker, 1)] | |
| else: | |
| return [] | |
| def trade49(): | |
| # Mean Reversion (Long-term): Buy if the price is below its 200-day moving average | |
| ticker = random.choice(tickers) | |
| ma200 = np.mean(prices[ticker]) | |
| if prices[ticker][0] < ma200: | |
| return [Trade(ticker, 1)] | |
| else: | |
| return [] | |
| def trade50(): | |
| # Trend Reversal (Parabolic SAR): Buy or sell based on the Parabolic SAR indicator | |
| # Assuming you have a Parabolic SAR calculation function | |
| ticker = random.choice(tickers) | |
| sar = calculate_parabolic_sar(prices[ticker]) | |
| if prices[ticker][0] > sar[-1]: | |
| return [Trade(ticker, 1)] | |
| elif prices[ticker][0] < sar[-1]: | |
| return [Trade(ticker, -1)] | |
| else: | |
| return [] | |
| def trade51(): | |
| # Market Outperformance: Buy stocks whose daily returns beat the market | |
| total_market_values = [sum(prices[t][i] for t in tickers) for i in range(len(prices[tickers[0]]))] | |
| market_return = (total_market_values[0] - total_market_values[1]) / total_market_values[1] | |
| outperformers = [t for t in tickers if (prices[t][0] - prices[t][1]) / prices[t][1] > market_return] | |
| if outperformers: | |
| ticker = random.choice(outperformers) | |
| return [Trade(ticker, 1)] | |
| else: | |
| return [] | |
| def trade52(): | |
| # Market Underperformance: Short stocks whose daily returns lag the market | |
| total_market_values = [sum(prices[t][i] for t in tickers) for i in range(len(prices[tickers[0]]))] | |
| market_return = (total_market_values[0] - total_market_values[1]) / total_market_values[1] | |
| underperformers = [t for t in tickers if (prices[t][0] - prices[t][1]) / prices[t][1] < market_return] | |
| if underperformers: | |
| ticker = random.choice(underperformers) | |
| return [Trade(ticker, -1)] | |
| else: | |
| return [] | |
| def trade53(): | |
| # Relative Strength to Market: Buy the stock with the highest relative strength to the market | |
| total_market_values = [sum(prices[t][i] for t in tickers) for i in range(len(prices[tickers[0]]))] | |
| market_return = (total_market_values[0] - total_market_values[1]) / total_market_values[1] | |
| relative_strengths = {t: ((prices[t][0] - prices[t][1]) / prices[t][1]) - market_return for t in tickers} | |
| ticker = max(relative_strengths, key=relative_strengths.get) | |
| return [Trade(ticker, 1)] | |
| def trade54(): | |
| # Relative Weakness to Market: Short the stock with the lowest relative strength to the market | |
| total_market_values = [sum(prices[t][i] for t in tickers) for i in range(len(prices[tickers[0]]))] | |
| market_return = (total_market_values[0] - total_market_values[1]) / total_market_values[1] | |
| relative_strengths = {t: ((prices[t][0] - prices[t][1]) / prices[t][1]) - market_return for t in tickers} | |
| ticker = min(relative_strengths, key=relative_strengths.get) | |
| return [Trade(ticker, -1)] | |
| def trade55(): | |
| # Sector vs. Market: Buy top stock from sector outperforming the market, short from underperforming | |
| # Assuming you have sector data (e.g., 'sector_map' dict: ticker -> sector) | |
| total_market_values = [sum(prices[t][i] for t in tickers) for i in range(len(prices[tickers[0]]))] | |
| market_return = (total_market_values[0] - total_market_values[1]) / total_market_values[1] | |
| sector_returns = {s: np.mean([(prices[t][0] - prices[t][1]) / prices[t][1] for t in tickers if sector_map[t] == s]) for s in set(sector_map.values())} | |
| outperforming_sectors = [s for s in sector_returns if sector_returns[s] > market_return] | |
| underperforming_sectors = [s for s in sector_returns if sector_returns[s] < market_return] | |
| trades = [] | |
| if outperforming_sectors: | |
| top_ticker = max([(t, prices[t][0]) for t in tickers if sector_map[t] == random.choice(outperforming_sectors)], key=lambda x: x[1])[0] | |
| trades.append(Trade(top_ticker, 1)) | |
| if underperforming_sectors: | |
| bottom_ticker = min([(t, prices[t][0]) for t in tickers if sector_map[t] == random.choice(underperforming_sectors)], key=lambda x: x[1])[0] | |
| trades.append(Trade(bottom_ticker, -1)) | |
| return trades | |
| def trade56(): | |
| # Market-Neutral Pairs: Long/short pairs of stocks with similar market betas | |
| betas = {t: random.uniform(0.8, 1.2) for t in tickers} # Placeholder, calculate actual betas | |
| pairs = [(t1, t2) for t1 in tickers for t2 in tickers if abs(betas[t1] - betas[t2]) < 0.1 and t1 != t2] | |
| if pairs: | |
| t1, t2 = random.choice(pairs) | |
| return [Trade(t1, 1), Trade(t2, -1)] | |
| else: | |
| return [] | |
| def trade57(): | |
| # Beta Rotation: Buy high-beta stocks if the market is rising, low-beta if falling | |
| total_market_values = [sum(prices[t][i] for t in tickers) for i in range(len(prices[tickers[0]]))] | |
| market_return = (total_market_values[0] - total_market_values[1]) / total_market_values[1] | |
| betas = {t: random.uniform(0.5, 2) for t in tickers} # Placeholder, calculate actual betas | |
| if market_return > 0: # Market is rising | |
| target_beta = 1.5 # Example target for high-beta | |
| else: | |
| target_beta = 0.8 # Example target for low-beta | |
| closest_ticker = min(tickers, key=lambda t: abs(betas[t] - target_beta)) | |
| return [Trade(closest_ticker, 1 if market_return > 0 else -1)] # Buy if rising, short if falling | |
| def trade58(): | |
| # Market Timing with Relative Strength: Buy strong stocks in up markets, sell in down markets | |
| total_market_values = [sum(prices[t][i] for t in tickers) for i in range(len(prices[tickers[0]]))] | |
| market_return = (total_market_values[0] - total_market_values[1]) / total_market_values[1] | |
| relative_strengths = {t: ((prices[t][0] - prices[t][-1]) / prices[t][-1]) for t in tickers} # Calculate over a longer period (e.g., 20 days) | |
| if market_return > 0: | |
| strongest = max(relative_strengths, key=relative_strengths.get) | |
| return [Trade(strongest, 1)] | |
| else: | |
| weakest = min(relative_strengths, key=relative_strengths.get) | |
| return [Trade(weakest, -1)] | |
| def trade59(): | |
| # Relative Value to Market: Buy stocks trading below their historical average relative to the market | |
| # Requires historical data to calculate averages | |
| total_market_values = [sum(prices[t][i] for t in tickers) for i in range(len(prices[tickers[0]]))] | |
| relative_values = {t: prices[t][0] / total_market_values[0] for t in tickers} # Current relative value | |
| historical_averages = {t: 0.05 for t in tickers} # Placeholder, calculate actual averages | |
| undervalued = [t for t in tickers if relative_values[t] < historical_averages[t] * 0.95] # Allow some buffer | |
| if undervalued: | |
| ticker = random.choice(undervalued) | |
| return [Trade(ticker, 1)] | |
| else: | |
| return [] | |
| def trade60(): | |
| # Market-Cap Weighted: Allocate trade amounts proportional to each stock's market cap relative to total market | |
| total_market_value = sum(prices[t][0] for t in tickers) | |
| market_caps = {t: prices[t][0] * 1000 for t in tickers} # Assuming 1000 shares outstanding for each stock | |
| weights = {t: market_caps[t] / total_market_value for t in tickers} | |
| total_trade_amount = 100 # Example | |
| trades = [Trade(t, int(weights[t] * total_trade_amount)) for t in tickers] | |
| return trades |