Name
渔夫指标移动止损策略Fisher-Yurik-Trailing-Stop-Strategy
Author
ChaoZhang
Strategy Description
渔夫指标移动止损策略是一种融合了渔夫指标和移动止损机制的量化交易策略。该策略利用渔夫指标产生买入和卖出信号,同时设置追踪止损来锁定利润,在保护利润的同时争取更大收益。
- 输入日期范围,限定回测或实盘的时间段
- 输入渔夫指标的参数,默认为2周期
- 输入止盈止损比例,默认为5%止盈,2%止损
- 计算渔夫指标的主线和信号线
- 当主线上穿信号线时产生买入信号
- 设置追踪止损,进入长仓后价格下跌2%时止损
- 价格上涨超过5%时止盈
- 渔夫指标容易判断趋势,买入信号准确
- 追踪止损机制可以锁定大部分利润,同时避免超过设置的止损点
- 可自定义参数,适应不同市场环境
- 简单易用,容易理解实现
- 参数设置不当可能导致过于激进交易,应谨慎测试
- 止损点过大可能导致 Outiliers的影响,导致超出预期的损失
- 止盈点过小可能导致利润太早切出,影响盈利能力
- 应根据不同品种确定合适的参数
可以通过调整止损止盈比例,测试不同参数组合来优化参数;结合其他指标过滤信号;设置仓位管理规则来控制单笔风险。
- 优化渔夫指标的参数,测试不同参数对策略的影响
- 结合其他指标,如MACD,KD等过滤信号,提高信号质量
- 增加开仓前的条件判断,例如突破布林带上轨等
- 增加仓位管理模块,控制单笔仓位带来的风险
- 优化移动止损的方式,如平滑移动止损,Chandelier Exit等
渔夫指标移动止损策略整合了趋势判断和止损管理,通过参数优化,指标组合以及止损方式的改进,可以适应大部分品种,在防止超出可承受损失的前提下获得较好收益,值得探索和实践。
||
The Fisher Yurik trailing stop strategy is a quantitative trading strategy that integrates the Fisher Yurik indicator and trailing stop mechanisms. It uses the Fisher Yurik indicator to generate buy and sell signals while setting trailing stops to lock in profits, maximizing gains while protecting profits.
- Input date ranges to define backtest/live trading timeframe
- Input parameters for Fisher Yurik indicator, default to 2 periods
- Input profit taking and stop loss ratios, default to 5% profit and 2% loss
- Calculate main and signal lines of Fisher Yurik indicator
- Generate buy signal when main line crosses above signal line
- Set trailing stop, exit long position when price drops 2% after entry
- Take profit when price rises above 5%
- Fisher Yurik indicator easily identifies trends, accurate buy signals
- Trailing stop locks in most profits while avoiding stops beyond threshold
- Customizable parameters suit different market environments
- Simple and easy to understand implementation
- Improper parameter tuning may cause over-aggressive trading, require cautious testing
- Stop loss too wide may lead to losses fromoutliers beyond expectations
- Take profit too tight may cut wins short, limiting profitability
- Appropriate parameters should be determined for different products
Risks can be addressed by adjusting stop/profit ratios, testing parameters, using signal filters, position sizing rules.
- Optimize Fisher Yurik parameters for impact on strategy
- Add signal filters like MACD, KD to improve signal quality
- Add entry conditions like breakouts from Bollinger Bands
- Incorporate position sizing rules to control per trade risk
- Enhance trailing stop methods, e.g. smoothed, Chandelier Exits
The Fisher Yurik trailing stop strategy combines trend identification and risk management. With parameter tuning, indicator combinations, and stop loss enhancements, it can suit most instruments for good profits within acceptable risk tolerances.
[/trans]
Strategy Arguments
Argument | Default | Description |
---|---|---|
v_input_1 | true | From Month |
v_input_2 | true | From Day |
v_input_3 | 2021 | From Year |
v_input_4 | true | To Month |
v_input_5 | true | To Day |
v_input_6 | 9999 | To Year |
v_input_7 | 2 | Period |
v_input_float_1 | 1.05 | profit level |
v_input_float_2 | 1.02 | after the signal |
Source (PineScript)
/*backtest
start: 2023-01-26 00:00:00
end: 2024-02-01 00:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=5
strategy("Fisher_Yurik Strategy with Trailing Stop", shorttitle="FY Strategy", overlay=true)
// Date Ranges
from_month = input(defval = 1, title = "From Month")
from_day = input(defval = 1, title = "From Day")
from_year = input(defval = 2021, title = "From Year")
to_month = input(defval = 1, title = "To Month")
to_day = input(defval = 1, title = "To Day")
to_year = input(defval = 9999, title = "To Year")
start = timestamp(from_year, from_month, from_day, 00, 00) // backtest start window
finish = timestamp(to_year, to_month, to_day, 23, 59) // backtest finish window
window = true
period = input(2, title='Period')
cost = input.float(1.05, title='profit level ', step=0.01)
dusus = input.float(1.02, title='after the signal', step=0.01)
var float Value = na
var float Fish = na
var float ExtBuffer1 = na
var float ExtBuffer2 = na
price = (high + low) / 2
MaxH = ta.highest(high, period)
MinL = ta.lowest(low, period)
Value := 0.33 * 2 * ((price - MinL) / (MaxH - MinL) - 0.5) + 0.67 * nz(Value[1])
Value := math.max(math.min(Value, 0.999), -0.999)
Fish := 0.5 * math.log((1 + Value) / (1 - Value)) + 0.5 * nz(Fish[1])
up = Fish >= 0
ExtBuffer1 := up ? Fish : na
ExtBuffer2 := up ? na : Fish
var float entryPrice = na
var float stopPrice = na
if (ExtBuffer1 > ExtBuffer1[1])
entryPrice := close*dusus
stopPrice := close * cost
if (ExtBuffer2 < ExtBuffer2[1])
entryPrice := close
stopPrice := close * cost
// Sadece seçilen test döneminde işlem yapma koşulu eklenmiştir
strategy.entry("Buy", strategy.long, when=ExtBuffer1 > ExtBuffer1[1] and window)
strategy.exit("Take Profit/Trailing Stop", from_entry="Buy", when=(close >= entryPrice * cost) or (close < stopPrice), trail_offset=0.08, trail_price=entryPrice * cost)
Detail
https://www.fmz.com/strategy/440833
Last Modified
2024-02-02 14:57:33