一目均衡表トレンドフォロー戦略


作成日: 2023-12-26 16:13:42 最終変更日: 2023-12-26 16:13:42
コピー: 1 クリック数: 678
1
フォロー
1621
フォロワー

一目均衡表トレンドフォロー戦略

概要

一目平衡戦略は,平均線を計算し,イチモク・キンコ・ヒョ指数と組み合わせてトレンドの方向を判断し,低リスクのトレンドを追跡する戦略である.

戦略原則

この戦略は,主に Ichimoku Kinko Hyo指標に基づいてトレンドの方向を判断する.Ichimoku Kinko Hyoは,初見均衡表である,変換線 ((Tenkan-sen),基準線 ((Kijun-sen),先行線 ((Senkou Span A) と確認線 ((Senkou Span B) で構成され,前と後ろの間の均衡区域を形成し,雲帯と呼ばれます.価格が多頭トレンドであるとき,価格の下の雲帯は空頭信号である.

この策略は,価格と平均線との関係を組み合わせてトレンドの方向を判断する.価格がベースラインと変換ラインを上方から突破すると買入シグナルが生じ,価格が下方から雲帯を突破すると売出シグナルが生じます.このような組み合わせの判断によって,偽の突破を効果的にフィルターしてトレンドの方向をロックすることができます.

優位分析

  • イチモク・キンコ・ヒョの指数でトレンドを判断し,揺れ動いている市場の偽の突破に惑わされないために
  • 平均線パラメータは調整可能で,異なる周期に対して最適化できます.
  • 均線関係判断を組み合わせて,トレンドの方向を有効に固定します.
  • クラウドバンド判断により,低リスクのトレンド追跡取引が可能

リスク分析

  • 震災は誤った信号を発する
  • パラメータの不適切な設定は,取引シグナルが頻繁にまたは不時に発生する可能性があります.
  • 人工的なトレンドの方向とパラメータの調整が必要

最適化の方向

この戦略は以下の点で最適化できます.

  1. Ichimokuのパラメータを最適化して,より多くの時間周期に対応する
  2. 単一損失を抑えるためのストップ・ロース戦略を強化する
  3. 他の指標と組み合わせて,強弱なトレンドを判断し,揺れ動向に誤って導かれないようにする
  4. 極限条件の追加で,極限条件を回避する

要約する

全体として,一目平衡戦略は,イチモク・キンコ・ヒョ指数によってトレンドの方向を判断し,トレンドを効果的にロックし,均線関係判断と連携して取引信号を生成し,低リスクのトレンド追跡取引を実現する.この戦略は,パラメータを調整して最適化することで,異なる市場環境に適応し,投資家がさらなる研究と使用に値する.

ストラテジーソースコード
/*backtest
start: 2022-12-19 00:00:00
end: 2023-12-25 00:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//@version=3
// Credit for the initial code to nathanhoffer - I simply added the ability to select a time period
//
strategy("Cloud Breakout", overlay=true, initial_capital=10000, default_qty_type=strategy.percent_of_equity, default_qty_value=100, commission_type=strategy.commission.percent, commission_value=0.0)

/////////////// Component Code Start ///////////////
testStartYear = input(2016, "Backtest Start Year") 
testStartMonth = input(1, "Backtest Start Month")
testStartDay = input(1, "Backtest Start Day")
testPeriodStart = timestamp(testStartYear,testStartMonth,testStartDay, 0, 0)

testStopYear = input(2019, "Backtest Stop Year")
testStopMonth = input(12, "Backtest Stop Month")
testStopDay = input(31, "Backtest Stop Day")
testPeriodStop = timestamp(testStopYear,testStopMonth,testStopDay, 0, 0)

testPeriod() => true

Ten = input(18, minval=1, title="Tenkan")
Kij = input(60, minval=1, title="Kijun")
LeadSpan = input(30, minval=1, title="Senkou B")
Displace = input(52, minval=1, title="Senkou A")
SpanOffset = input(52, minval=1, title="Span Offset")

sts = input(true, title="Show Tenkan")
sks = input(true, title="Show Kijun")
ssa = input(true, title="Show Span A")
ssb = input(true, title="Show Span B")
sc = input(true, title="Show Chikou")

source = close

//Script for Ichimoku Indicator
donchian(len) => avg(lowest(len), highest(len))
TS = donchian(Ten)
KS = donchian(Kij)
SpanA = avg(TS, KS)
SpanB = donchian(LeadSpan)

CloudTop = max(TS, KS)

Chikou = source[Displace]
SpanAA = avg(TS, KS)[SpanOffset]
SpanBB = donchian(LeadSpan)[SpanOffset]

//Kumo Breakout (Long)
SpanA_Top = SpanAA >= SpanBB ? 1 : 0
SpanB_Top = SpanBB >= SpanAA ? 1 : 0

SpanA_Top2 = SpanA >= SpanB ? 1 : 0
SpanB_Top2 = SpanB >= SpanA ? 1 : 0

SpanA1 = SpanA_Top2 ? SpanA : na
SpanA2 = SpanA_Top2 ? SpanB : na

SpanB1 = SpanB_Top2 ? SpanA : na
SpanB2 = SpanB_Top2 ? SpanB : na

//plot for Tenkan and Kijun (Current Timeframe)
p1= plot(sts and TS ? TS : na, title="Tenkan", linewidth = 2, color = gray)
p2 = plot(sks and KS ? KS : na, title="Kijun", linewidth = 2, color = black)
//p5 = plot(sc and KS ? KS : na, title="Chikou", linewidth = 2, color = orange)
p5 = plot(sc and Displace ? close: na, title="Chikou", linewidth = 2, offset=-Displace, color = orange)

//Plot for Kumo Cloud (Dynamic Color)
p3 = plot(ssa and SpanA ? SpanA : na, title="SpanA", linewidth=2, offset=Displace, color=green)
p4 = plot(ssb and SpanB ? SpanB : na, title="SpanB", linewidth=2, offset=Displace, color=red)

p8 = plot(ssa and SpanA1 ? SpanA1 : na, title="Span A1 above", style=linebr, linewidth=1, offset=Displace, color=green)
p9 = plot(ssa and SpanA2 ? SpanA2 : na, title="Span A2 above", style=linebr, linewidth=1, offset=Displace, color=green)
p10 = plot(ssb and SpanB1 ? SpanB1 : na, title="Span B1 above", style=linebr, linewidth=1, offset=Displace, color=red)
p11 = plot(ssb and SpanB2 ? SpanB2 : na, title="Span B2 above", style=linebr, linewidth=1, offset=Displace, color=red)

fill(p8, p9, color = lime, transp=70, title="Kumo Cloud Up")
fill (p10, p11, color=red, transp=70, title="Kumo Cloud Down")

LongSpan = (SpanA_Top and source[1] < SpanAA[1] and source > SpanAA) or (SpanB_Top and source[1] < SpanBB[1] and source > SpanBB) ? 1 : 0
cupSpan = LongSpan  == 1 ? LongSpan : 0

Long_Breakout = (SpanA_Top ==1 and crossover(source, SpanAA)) or (SpanB_Top ==1 and crossover(source, SpanBB))

ShortSpan = (SpanB_Top and source[1] > SpanAA[1] and source < SpanAA) or (SpanA_Top and source[1] > SpanBB[1] and source < SpanBB) ? 1 : 0
cdnSpan = ShortSpan == 1 ? ShortSpan : 0

Short_Breakout = (SpanA_Top ==1 and crossunder(source, SpanBB)) or (SpanB_Top ==1 and crossunder(source, SpanAA))

//Kumo Twist
Kumo_Twist_Long = SpanA[1] < SpanB[1] and SpanA > SpanB ? 1 : 0
Kumo_Twist_Short = SpanA[1] > SpanB[1] and SpanA < SpanB ? 1 : 0

cupD = Kumo_Twist_Long == 1 ? Kumo_Twist_Long : 0
cdnD = Kumo_Twist_Short == 1 ? Kumo_Twist_Short : 0

Chikou_Above = close > Chikou
Chikou_Below = close < Chikou

long = (cross(TS, SpanA) or cross(TS, SpanB)) and TS>SpanA and TS>SpanB and TS>=KS
short = cross(TS, KS) and KS >= TS

if testPeriod()
    strategy.entry("long", strategy.long, when=Long_Breakout)
    strategy.entry("short", strategy.short, when=Short_Breakout)