Chiến lược này là một hệ thống giao dịch đột phá động lực dựa trên Bollinger Bands, chủ yếu nắm bắt các cơ hội xu hướng thông qua mối quan hệ giữa giá và Bollinger Band trên. Chiến lược sử dụng cơ chế lựa chọn loại trung bình động thích nghi, kết hợp với các kênh lệch chuẩn để xác định các đặc điểm biến động của thị trường, đặc biệt phù hợp với các thị trường có biến động cao.
Logic cốt lõi của chiến lược dựa trên các yếu tố chính sau: 1. Sử dụng các đường trung bình động có thể tùy chỉnh (bao gồm SMA, EMA, SMMA, WMA, VWMA) để tính dải giữa của Bollinger Bands. 2. Định vị ban nhạc trên và dưới một cách năng động thông qua trình nhân độ lệch chuẩn (bên mặc định 2.0). 3. Tham gia các vị trí dài khi giá vượt qua dải trên, cho thấy sự hình thành của xu hướng phá vỡ mạnh. 4. Ra khỏi vị trí khi giá giảm xuống dưới dải dưới, gợi ý khả năng kết thúc xu hướng tăng. 5. Bao gồm chi phí giao dịch (0,1%) và trượt (3 điểm), phản ánh tốt hơn điều kiện giao dịch thực tế.
Đây là một xu hướng được thiết kế tốt theo chiến lược với logic rõ ràng. Nó nắm bắt được đà thị trường thông qua bản chất năng động của Bollinger Bands và bao gồm các cơ chế kiểm soát rủi ro tốt. Chiến lược có thể tùy chỉnh cao và có thể thích nghi với các môi trường thị trường khác nhau thông qua điều chỉnh tham số.
/*backtest start: 2019-12-23 08:00:00 end: 2024-12-11 08:00:00 period: 1d basePeriod: 1d exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=5 strategy("Demo GPT - Bollinger Bands", overlay=true, initial_capital=10000, commission_type=strategy.commission.percent, commission_value=0.1, slippage=3, default_qty_type=strategy.percent_of_equity, default_qty_value=100) // Inputs length = input.int(20, minval=1, title="Length") maType = input.string("SMA", "Basis MA Type", options = ["SMA", "EMA", "SMMA (RMA)", "WMA", "VWMA"]) src = input(close, title="Source") mult = input.float(2.0, minval=0.001, maxval=50, title="StdDev") offset = input.int(0, "Offset", minval=-500, maxval=500) // Date range inputs startYear = input.int(2018, "Start Year", minval=1970, maxval=2100) startMonth = input.int(1, "Start Month", minval=1, maxval=12) startDay = input.int(1, "Start Day", minval=1, maxval=31) endYear = input.int(2069, "End Year", minval=1970, maxval=2100) endMonth = input.int(12, "End Month", minval=1, maxval=12) endDay = input.int(31, "End Day", minval=1, maxval=31) // Time range startTime = timestamp("GMT+0", startYear, startMonth, startDay, 0, 0) endTime = timestamp("GMT+0", endYear, endMonth, endDay, 23, 59) // Moving average function ma(source, length, _type) => switch _type "SMA" => ta.sma(source, length) "EMA" => ta.ema(source, length) "SMMA (RMA)" => ta.rma(source, length) "WMA" => ta.wma(source, length) "VWMA" => ta.vwma(source, length) // Calculate Bollinger Bands basis = ma(src, length, maType) dev = mult * ta.stdev(src, length) upper = basis + dev lower = basis - dev // Plot plot(basis, "Basis", color=#2962FF, offset=offset) p1 = plot(upper, "Upper", color=#F23645, offset=offset) p2 = plot(lower, "Lower", color=#089981, offset=offset) fill(p1, p2, title="Background", color=color.rgb(33, 150, 243, 95)) // Strategy logic: Only go long and flat inDateRange = time >= startTime and time <= endTime noPosition = strategy.position_size == 0 longPosition = strategy.position_size > 0 // Buy if close is above upper band if inDateRange and noPosition and close > upper strategy.entry("Long", strategy.long) // Sell/Exit if close is below lower band if inDateRange and longPosition and close < lower strategy.close("Long")