
이 전략은 부린 띠의 이중 표준 격차 모형에 기반한 거래 전략이다. 부린 띠의 상하 궤도와 1과 2 표준 격차를 거래 신호로 사용한다. 가격이 부린 띠의 궤도를 돌파할 때 더 많이 하고, 가격이 부린 띠의 궤도를 돌파할 때 공백한다. 이 전략은 동시에 1과 2 표준 격차를 중단 지점으로 사용한다.
이 전략은 먼저 브린 띠의 중간 궤도, 상단 궤도 및 하단 궤도를 계산한다. 중간 궤도는 CLOSE의 SMA이며 상단 궤도는 중간 궤도 +2이다.*표준이 떨어지고, 하단 트랙은 중도-2이다.*표준 격차. 가격이 상회할 때 더 많은 구매 신호를 생성하고, 가격이 하락할 때 더 많은 판매 신호를 생성한다. 또한, 전략은 중간 경로 + 1 표준 격차와 중간 경로 -1 표준 격차의 선을 그리기도 한다. 그들은 중단 지점으로 사용됩니다. 구체적인 논리는 다음과 같습니다.
이 전략은 전체적으로 전형적인 브린 벨트 돌파 전략이다. 이 전략은 이중 표준 차이를 사용하여 신호 판단의 엄격성을 높이고, 두 개의 스톱 라인을 사용하여 적극적으로 위험을 제어한다. 이 전략에는 특정 변수 최적화 공간이 있으며, 중간 궤도 주기, 표준 차이의 배수 등과 같은 변수를 조정하여 더 나은 전략 성능을 얻을 수 있다. 이 전략은 또한 브린 벨트 전략에서 일반적으로 직면하는 가짜 돌파 문제가 있다.
/*backtest
start: 2022-12-11 00:00:00
end: 2023-12-17 00:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=5
// Bollinger Bands: Madrid : 14/SEP/2014 11:07 : 2.0
// This displays the traditional Bollinger Bands, the difference is
// that the 1st and 2nd StdDev are outlined with two colors and two
// different levels, one for each Standard Deviation
strategy(shorttitle='MBB', title='Bollinger Bands', overlay=true)
src = input(close)
length = input.int(34, minval=1)
mult = input.float(2.0, minval=0.001, maxval=50)
basis = ta.sma(src, length)
dev = ta.stdev(src, length)
dev2 = mult * dev
upper1 = basis + dev
lower1 = basis - dev
upper2 = basis + dev2
lower2 = basis - dev2
colorBasis = src >= basis ? color.blue : color.orange
pBasis = plot(basis, linewidth=2, color=colorBasis)
pUpper1 = plot(upper1, color=color.new(color.blue, 0), style=plot.style_circles)
pUpper2 = plot(upper2, color=color.new(color.blue, 0))
pLower1 = plot(lower1, color=color.new(color.orange, 0), style=plot.style_circles)
pLower2 = plot(lower2, color=color.new(color.orange, 0))
fill(pBasis, pUpper2, color=color.new(color.blue, 80))
fill(pUpper1, pUpper2, color=color.new(color.blue, 80))
fill(pBasis, pLower2, color=color.new(color.orange, 80))
fill(pLower1, pLower2, color=color.new(color.orange, 80))
// Entry conditions
longCondition = ta.crossover(close, upper1)
shortCondition = ta.crossunder(close, lower1)
// Entry and exit strategy
strategy.entry("Buy", strategy.long, when=longCondition)
strategy.entry("Sell", strategy.short, when=shortCondition)
strategy.close("Buy", when=shortCondition)
strategy.close("Sell", when=longCondition)