双管齐下量化反转追踪策略通过组合使用简单移动平均线指标和随机指标,实现了一个既可以抓住市场快速反转的同时又可以减少因错过信号带来的机会成本的高效稳定的短线交易策略。
该策略由两部分组成:123形态反转部分和自适应移动平均线部分。123形态反转部分通过计算前两个交易日的收盘价关系来判断是否出现反转机会。如果前一日收盘价低于前二日而当前交易日收盘价高于前一日,且随机慢线低于50,则产生买入信号。如果前一日收盘价高于前二日而当前交易日收盘价低于前一日,且随机快线高于50,则产生卖出信号。这可以抓住快速的短线反转机会。另一部分是自适应移动平均线,它在市场不活跃时响应缓慢,活跃时响应迅速,可以有效过滤噪音躲避震荡,判断主要趋势方向。两者信号同向时产生入场信号,同向平仓。
双管齐下量化反转追踪策略最大的优势是组合使用反转形态和趋势过滤,使得它既可以捕捉快速反转又可以避免在震荡市中被套牢。收益来源主要有两个:第一,123形态的识别可以及时追踪价格快速调头的机会,这是许多稳重策略所无法做到的。第二,自适应移动平均线的应用确保了交易方向和主趋势一致,有效过滤了噪音,减少了不必要的损失。
该策略的主要风险在于参数设置的不当可能导致交易频率过高或信号识别能力不足。如果123形态的参数设置过于灵敏,可能导致在震荡行情中交易频繁,产生较多平仓亏损。如果自适应移动平均线参数设置过于缓慢,则可能错过反转机会。此外,趋势行情中追高杀跌也会带来更大的资金波动。
该策略可以从以下几个方面进行优化:第一,调整123形态的参数,使其既能识别明确反转,又不至于过于灵敏产生错误信号。第二,优化自适应移动平均线的参数,在平稳和敏感间找到最佳平衡。第三,可以引入止损策略,以控制单笔亏损。第四,可以结合市场情绪指标增强决策质量。
双管齐下量化反转追踪策略成功地集成了反转交易和趋势过滤两个缺一不可的部分,组合优势显著。通过不断优化参数设定,持续完善止损和风控机制,该策略有望成为一个易于实现收益,可控风险的高效量化交易策略。
/*backtest start: 2024-01-18 00:00:00 end: 2024-02-17 00:00:00 period: 1h basePeriod: 15m exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=4 //////////////////////////////////////////////////////////// // Copyright by HPotter v1.0 08/12/2020 // This is combo strategies for get a cumulative signal. // // First strategy // This System was created from the Book "How I Tripled My Money In The // Futures Market" by Ulf Jensen, Page 183. This is reverse type of strategies. // The strategy buys at market, if close price is higher than the previous close // during 2 days and the meaning of 9-days Stochastic Slow Oscillator is lower than 50. // The strategy sells at market, if close price is lower than the previous close price // during 2 days and the meaning of 9-days Stochastic Fast Oscillator is higher than 50. // // Second strategy // Everyone wants a short-term, fast trading trend that works without large // losses. That combination does not exist. But it is possible to have fast // trading trends in which one must get in or out of the market quickly, but // these have the distinct disadvantage of being whipsawed by market noise // when the market is volatile in a sideways trending market. During these // periods, the trader is jumping in and out of positions with no profit-making // trend in sight. In an attempt to overcome the problem of noise and still be // able to get closer to the actual change of the trend, Kaufman developed an // indicator that adapts to market movement. This indicator, an adaptive moving // average (AMA), moves very slowly when markets are moving sideways but moves // swiftly when the markets also move swiftly, change directions or break out of // a trading range. // // WARNING: // - For purpose educate only // - This script to change bars colors. //////////////////////////////////////////////////////////// Reversal123(Length, KSmoothing, DLength, Level) => vFast = sma(stoch(close, high, low, Length), KSmoothing) vSlow = sma(vFast, DLength) pos = 0.0 pos := iff(close[2] < close[1] and close > close[1] and vFast < vSlow and vFast > Level, 1, iff(close[2] > close[1] and close < close[1] and vFast > vSlow and vFast < Level, -1, nz(pos[1], 0))) pos KAMA(Length) => pos = 0.0 nAMA = 0.0 xPrice = close xvnoise = abs(xPrice - xPrice[1]) nfastend = 0.666 nslowend = 0.0645 reverse = input(false, title="Trade reverse") nsignal = abs(xPrice - xPrice[Length]) nnoise = sum(xvnoise, Length) nefratio = iff(nnoise != 0, nsignal / nnoise, 0) nsmooth = pow(nefratio * (nfastend - nslowend) + nslowend, 2) nAMA := nz(nAMA[1]) + nsmooth * (xPrice - nz(nAMA[1])) pos := iff(close[1] > nAMA, 1, iff(close[1] < nAMA, -1, nz(pos[1], 0))) pos strategy(title="Combo Backtest 123 Reversal & Kaufman Moving Average Adaptive", shorttitle="Combo", overlay = true) Length = input(14, minval=1) KSmoothing = input(1, minval=1) DLength = input(3, minval=1) Level = input(50, minval=1) //------------------------- LengthKAMA = input(21, minval=2) reverse = input(false, title="Trade reverse") posReversal123 = Reversal123(Length, KSmoothing, DLength, Level) posKAMA = KAMA(LengthKAMA) pos = iff(posReversal123 == 1 and posKAMA == 1 , 1, iff(posReversal123 == -1 and posKAMA == -1, -1, 0)) possig = iff(reverse and pos == 1, -1, iff(reverse and pos == -1 , 1, pos)) if (possig == 1) strategy.entry("Long", strategy.long) if (possig == -1) strategy.entry("Short", strategy.short) if (possig == 0) strategy.close_all() barcolor(possig == -1 ? #b50404: possig == 1 ? #079605 : #0536b3 )