
この戦略は,ランダムな振動指標であるストキャスティック・オシレータ (Stochastic Oscillator) を使用して,市場の過剰買いと過剰売り状態を識別し,事前に定義されたリスクとリターンパラメータの下で取引を誘発し,波動的な取引区間内で利益を得ることを期待する.この戦略の主な構想は,取引区間の低点で買い,取引区間の高点で売り,リスクを厳密に制御することです.
ランダムな振動指数に基づく波動区間取引戦略は,事前に定義された取引区間内で,ランダムな指数のオーバーバイとオーバーセール信号を利用して取引を誘発しようとする.この戦略は,厳格なリスク管理と取引間隔によってリスクを制御する.この戦略には一定の利点があるにもかかわらず,その成功は,取引区間を正しく識別することに大きく依存する.将来の最適化の方向は,他の技術指標のダイナミックな止損枠の導入,より高度な区間識別技術の使用,およびトレンドフィルターの追加を含む.実用的には,個人の好みとリスク承受能力に応じて戦略のパラメータとリスク管理ルールを調整することが不可欠である.
/*backtest
start: 2023-06-11 00:00:00
end: 2024-06-16 00:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=5
strategy("Range Trading with Stochastic", overlay=true)
// Input Parameters
overboughtLevel = input.int(80, title="Overbought Level", minval=1, maxval=100)
oversoldLevel = input.int(20, title="Oversold Level", minval=1, maxval=100)
stochLength = input.int(14, title="Stochastic Length", minval=1)
riskPerTrade = input.float(0.01, title="Risk per Trade (%)", minval=0.01, maxval=100, step=0.01)
barsBetweenTrades = input.int(20, title="Bars Between Trades", minval=1)
// Calculate Stochastic Oscillator
k = ta.sma(ta.stoch(close, high, low, stochLength), 3)
d = ta.sma(k, 3)
// Variables to Track Time Since Last Trade
var lastTradeBar = 0
barsSinceLastTrade = bar_index - lastTradeBar
// Risk Management
atr = ta.atr(14)
stopLoss = 2 * atr
takeProfit = 2 * atr
riskAmount = strategy.equity * riskPerTrade / 100
positionSize = 1
// Entry Conditions
longCondition = k < oversoldLevel and strategy.position_size == 0 and barsSinceLastTrade >= barsBetweenTrades
shortCondition = k > overboughtLevel and strategy.position_size == 0 and barsSinceLastTrade >= barsBetweenTrades
// Entry/Exit Orders
if longCondition
strategy.entry("Long", strategy.long, qty=positionSize)
strategy.exit("Long Exit", "Long", stop=close - stopLoss, limit=close + takeProfit)
lastTradeBar := bar_index // Update last trade bar
if shortCondition
strategy.entry("Short", strategy.short, qty=positionSize)
strategy.exit("Short Exit", "Short", stop=close + stopLoss, limit=close - takeProfit)
lastTradeBar := bar_index // Update last trade bar
// Plot Stochastic
plot(k, color=color.blue, title="%K")
plot(d, color=color.orange, title="%D")
hline(overboughtLevel, color=color.red, title="Overbought")
hline(oversoldLevel, color=color.green, title="Oversold")