この戦略は,MACD指標と複数のEMAラインを組み合わせて,週間の2つの時間枠から強い市場傾向を把握します.週間のチャート上のMACD指標を使用して,全体的なトレンド方向を決定し,日中のチャート上の3つのEMA線 (5日,15日,30日) を使用して,トレンドを確認し,ブレイクポイントで取引を行う.主なアイデアは,強いトレンドに従い,大きな波に乗って,短期EMAが長期EMAを超えると取引に入り,EMAが引き戻しまたはストップロスの条件が引き起こすときに離脱することです.
毎週MACDは全体的な傾向を決定する.毎週MACD指標を計算し,現在の週と前週のMACDヒストグラム値の違いを比較する.ポジティブな差は上昇傾向を示し,マイナス差は下落傾向を示します.市場が開いている毎週月曜日にトレンド方向を更新します.
複数のEMA線がトレンドを確認する.日内グラフに5日,15日,30日間のEMA線をグラフ化する.短期EMAが長期EMAを上回り離れる時,トレンドは上昇し,逆にトレンドは低下する.
EMAの交差点での取引:
ポジション追加: 現時点では追加入場条件は設定されていません.
2つのタイムフレームを組み合わせることで,トレンド決定はより信頼性が高まります.週間のMACDはレンジ・バインド市場に引っかかることを避け,イントラデイEMAクロスオーバーはトレンド内の各波を捕捉します.
日中チャート上の5/15/30日 EMAの選択は,ノイズを効果的にフィルタリングし,明確なトレンドを把握します.
ストップ・ロスの設定は合理的で,個々の取引におけるリスクを制御する.固定ポイントストップ・ロスをEMAストップ・ロスと組み合わせることで,損失制御とトレンドフォローの両方を可能にします.
MACDとEMAの計算のような重要なコンポーネントを持つモジュール式コードデザインは,高度に再利用可能で拡張可能である.
MACDヒストグラム差値の誤った選択は,傾向基準が過度に緩やかまたは厳格になり,誤判を引き起こす可能性があります.バックテストとパラメータ最適化は最適な値値を選択するのに役立ちます.
日中のEMAパラメータの不正な選択 - 短すぎると過剰取引になり,長すぎると機会を逃す可能性があります.バックテストとパラメータ最適化は最適なパラメータ組み合わせを選択するのに役立ちます.
不適切な固定ストップ・ロストポイント - 狭すぎると頻繁にストップアウトになり,幅が広い場合,取引ごとに過度の損失を引き起こす可能性があります.各ツールの変動特性に基づいてカスタマイズされたストップ・ロスは役立ちます.
EMA は,トレンドターニングポイントに遅れをとり,最良のエントリー/エグジットポイントを見逃す可能性があります.しかし,長期的には,リスクを効果的に制御し,全体的な良いパフォーマンスを生み出すことができます.
傾向強さを確認し,正確性を向上させるために,RSIのような他の指標を毎週MACDの上に追加することを検討してください.
取引頻度とリスクを減らすため,CCIのような他の指標を日中EMAクロスオーバー信号の追加フィルターとして追加することを検討する.
ストップ・ロスのポイントを設定します ストップ・ロスのポイントは ストップ・ロスのポイントを設定します
ポジションの拡大と減少のための戦略ルールを追加することを検討する - 資本効率を改善するために,徐々に強い傾向を追加し,弱まる傾向を削減する.
MACD+EMAマルチタイムフレームブレイクストラテジーは,トレンド決定と確認の両方の科学的根拠を持つトレンドフォロー戦略である.主要市場トレンドを効果的に把握し,安定した収益を生むことができる.一方,戦略はリスク管理においてかなり完全であり,合理的なストップロストと退出規則を通じて引き下げを効果的に制限する.しかし,トレンド信号の遅れやスケーリング規則の欠如などのいくつかの欠点もあります.さらに最適化および改善することができます.全体として,これは学び,活用する非常に価値のある定量的な取引戦略です.
/*backtest start: 2023-03-16 00:00:00 end: 2024-03-21 00:00:00 period: 1d basePeriod: 1h exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ // 1) 전주와 전전주의 히스토그램의 차이를 계산하여, 매주 월요일에 매매 방향을 표시하고, // 2) 5일, 15일, 30일 선을 호출하여 평행하게 그리고, 매매 방향에 따라 // 3) 분봉기준의 이동평균선 매매전략 // 4) 수익 실현은 미설정 해둠 //@version=5 strategy('Last week MACD+ 15day, 30day break through, by Ho.J', overlay=true, initial_capital=30000, commission_value = 7.5, commission_type=strategy.commission.cash_per_order, slippage = 0) // 백테스팅 기간 설정 start_time = input(timestamp("Jan 19 2024 00:00:01"), confirm = true) end_time = input(timestamp("MAR 19 2024 23:59:59"), confirm = true) is_in_time = true stopLoss = input.int(100, title="손절 수준") // 지난주 값 불러오기 입력 매개변수, 1은 5일, 3은 15일, 6은 30일 이동평균선을 구하는 변수임 emaLength1 = input(1, title="EMA Length") emaLength2 = input(3, title="EMA Length") emaLength3 = input(6, title="EMA Length") timeframePeriod = "W" // 'D'는 일간 데이터를 의미 // 분봉기준 EMA 계산 shortEMA = ta.ema(close, 50) mediumEMA = ta.ema(close, 60) longEMA = ta.ema(close, 150) // 분봉기준 EMA 그리기 plot(shortEMA, color=color.blue, title="5일 EMA") plot(mediumEMA, color=color.orange, title="15일 EMA") plot(longEMA, color=color.red, title="30일 EMA") // 주간 MACD 계산, 전주와 전전주 히스토그램을 계산하여 상대적인 상승, 하락을 계산 [macdLine, signalLine, _] = ta.macd(close, 12, 26, 9) histogram = macdLine - signalLine histLastWeek = request.security(syminfo.tickerid, timeframePeriod, histogram[1], lookahead=barmerge.lookahead_on) histWeekBeforeLast = request.security(syminfo.tickerid, timeframePeriod, histogram[2], lookahead=barmerge.lookahead_on) histDiff = histLastWeek - histWeekBeforeLast // 현재 주의 월요일 첫 봉인지 확인 isMondayFirstBar = (dayofweek == dayofweek.monday) and (hour == 09) and (minute == 00) // 여기서 시간은 시장 개장 시간에 따라 조정해야 함 // 월요일 첫봉에, 주간 MACD 히스토그램이 상승하면 '매수', 하락하면 '매도' 표시 var label myLabel = na if (isMondayFirstBar) if (histDiff > 0) myLabel := label.new(bar_index, high, "이번주는 매수만", color=color.green, textcolor=color.white, style=label.style_label_down, size=size.large) else if (histDiff < 0) myLabel := label.new(bar_index, low, "이번주는 매도만", color=color.red, textcolor=color.white, style=label.style_label_up, size=size.large) // 지난주 EMA 값 요청 // 'lookahead'를 사용하여 지난 데이터를 기준으로 계산 lastWeekEMA1 = request.security(syminfo.tickerid, timeframePeriod, ta.ema(close[1], emaLength1), lookahead=barmerge.lookahead_on) lastWeekEMA2 = request.security(syminfo.tickerid, timeframePeriod, ta.ema(close[1], emaLength2), lookahead=barmerge.lookahead_on) lastWeekEMA3 = request.security(syminfo.tickerid, timeframePeriod, ta.ema(close[1], emaLength3), lookahead=barmerge.lookahead_on) // 지난주 EMA 그리기 plot(lastWeekEMA1, color=color.red, title="Last Week EMA1") plot(lastWeekEMA2, color=color.rgb(157, 126, 126), title="Last Week EMA2") plot(lastWeekEMA3, color=color.rgb(199, 192, 192), title="Last Week EMA3") // 매수/매도 조건 buySignal = ta.crossover(close, lastWeekEMA2) and histDiff > 0 // addbuySignal = ta.crossover(close, lastWeekEMA3) and histDiff > 0 sellSignal = ta.crossunder(shortEMA, longEMA) and histDiff < 0 // addSellSignal = ta.crossunder(close, lastWeekEMA3) and histDiff < 0 // 매수 조건 if (buySignal) strategy.entry('Buy', strategy.long) alert('Buy Signal', alert.freq_once_per_bar_close) // if (addbuySignal) // strategy.entry('Buy', strategy.long) // alert('add Buy Signal', alert.freq_once_per_bar_close) if (strategy.position_size > 0 and ((strategy.position_avg_price - close) >= stopLoss) or ta.crossunder(close, mediumEMA)) strategy.close('Buy') alert('Close Buy Signal', alert.freq_once_per_bar_close) // 매도 조건 if (sellSignal) strategy.entry('Sell', strategy.short) alert('Sell Signal', alert.freq_once_per_bar_close) //if (addSellSignal) // strategy.entry('Sell', strategy.short) // alert('add Sell Signal', alert.freq_once_per_bar_close) if (strategy.position_size < 0 and ((close - strategy.position_avg_price) >= stopLoss) or ta.crossover(shortEMA, mediumEMA)) strategy.close('Sell') alert('Close Sell Signal', alert.freq_once_per_bar_close)