Cette stratégie utilise l'oscillateur de momentum de Chande (CMO) pour déterminer les niveaux de surachat et de survente pour les signaux de trading.
La logique clé est la suivante:
L'OMC reflète l'élan des changements de prix. Les valeurs absolues élevées représentent la divergence de prix entrant dans les zones de surachat / survente. La stratégie utilise cette caractéristique de l'OMC, en utilisant une moyenne multipériodique pour lisser la courbe pour identifier les extrêmes.
Les mesures d'atténuation
La stratégie peut être renforcée par:
Cette stratégie utilise CMO pour identifier les surachats / survente pour la négociation de la réversion moyenne. La moyenne à plusieurs périodes aide à éviter les faux signaux. CMO lui-même a une base théorique solide pour mesurer la divergence. Des améliorations grâce à de meilleurs paramètres, arrêts et filtres peuvent en faire une stratégie de trading d'oscillateur stable.
/*backtest start: 2023-09-11 00:00:00 end: 2023-09-14 07:00:00 period: 30m basePeriod: 15m exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=2 ////////////////////////////////////////////////7//////////// // Copyright by HPotter v1.0 21/02/2017 // This indicator plots the absolute value of CMO averaged over three // different lengths. This indicator plots a classical-looking oscillator, // which is really an averaged value based on three different periods. // // You can change long to short in the Input Settings // Please, use it only for learning or paper trading. Do not for real trading. //////////////////////////////////////////////////////////// strategy(title="CMOabsav", shorttitle="CMOabsav") Length1 = input(5, minval=1) Length2 = input(10, minval=1) Length3 = input(20, minval=1) TopBand = input(58, minval=1) LowBand = input(5, minval=0) reverse = input(false, title="Trade reverse") hline(0, color=green, linestyle=hline.style_dashed) hline(TopBand, color=purple, linestyle=hline.style_solid) hline(LowBand, color=red, linestyle=hline.style_solid) xMom = close - close[1] xMomabs = abs(close - close[1]) nSum1 = sum(xMom, Length1) nSumAbs1 = sum(xMomabs, Length1) nSum2 = sum(xMom, Length2) nSumAbs2 = sum(xMomabs, Length2) nSum3 = sum(xMom, Length3) nSumAbs3 = sum(xMomabs, Length3) nRes = abs(100 * (nSum1 / nSumAbs1 + nSum2 / nSumAbs2 + nSum3 / nSumAbs3 ) / 3) pos = iff(nRes > TopBand, 1, iff(nRes < LowBand, -1, nz(pos[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) barcolor(possig == -1 ? red: possig == 1 ? green : blue ) plot(nRes, color=blue, title="CMOabsav")