// Downloaded From https://www.WiseStockTrader.com /* #337 Trailing Staircase Stop Uses H/L Hysteresis to reduce buy/sell whipsaw here: Buy = iif( trends < L , 1,0); Sell = IIf( trends > H , 1,0); Code: GeorgeRai 3 Aug 2016 Background http://www.wisestocktrader.com/indicators/1692-sve-trends-trail AFL code by E.M.Pottasch, 12/28/2010, idea from: http://stocata.org/metastock/stop_trail_trends.html */ // INIT ===== SetChartBkColor( colorlavender ); SetChartOptions(0, chartShowDates); GraphXSpace = 5; // PARAMS ===== atrfact = Param("Atr factor",1.5, 1.0, 10.0, 0.1); period = Param("Period",17, 1, 100, 1); // MAIN ===== function trends_func(resistance) { trends = (H+L)/2; // initialize support = (H+L)/2; // initialize for( i = 4; i < BarCount; i++ ) { // support prev = support[ i - 1 ]; if (L[ i ] >= L[ i - 2 ] AND L[ i - 1 ] >= L[ i - 2 ] AND L[ i - 3 ] >= L[ i - 2 ] AND L[ i - 4 ] >= L[ i - 2 ]) { support[ i ] = L[ i - 2 ]; } else if (L[ i ] > H[ i - 1]*1.0013) { support[ i ] = H[ i - 1 ]*0.9945; } else if (L[ i ] > prev*1.1) { support[ i ] = prev*1.05; } else { support[ i ] = prev; } // trends prev = trends[ i - 1 ]; if (H[ i ] > prev AND H[ i - 1 ] > prev) { trends[ i ] = Max(prev,support[ i ]); } else if (H[ i ] < prev AND H[ i - 1 ] < prev) { trends[ i ] = Min(prev,resistance[ i ]); } else if (H[ i ] > prev) { trends[ i ] = support[ i ]; } else { trends[ i ] = resistance[ i ]; } } return trends; } HiLo = IIf(H-L<1.5*MA(H-L,period),H-L,1.5*MA(H-L,period)); Href = IIf(L<=Ref(H,-1),H-Ref(C,-1),(H-Ref(C,-1))-(L-Ref(H,-1))/2); Lref = IIf(H>=Ref(L,-1),Ref(C,-1)-L,(Ref(C,-1)-L)-(Ref(L,-1)-H)/2); diff1 = Max(HiLo,Href); diff2 = Max(diff1,Lref); ATRmod = Wilders(diff2,period); loss = atrfact*ATRmod; resistance = C + loss; trends = trends_func(resistance); // calculate trends // TRADE SIGNALS ===== Buy = iif( trends < L , 1,0); Sell = IIf( trends > H , 1,0); Buy = ExRem(Buy,Sell); Sell = ExRem(Sell,Buy); // P/L Calcs ===== BuyPrice = ValueWhen(Buy, Close); SellPrice = ValueWhen(Sell, Close); // Calculate Profit for each sale Profit = 0.0; for (i=5; i C,trends,Null),"\ntrailShort",Colorred,styleStaircase); Plot(IIf(trends < C,trends,Null),"\ntrailLong",Colorgreen, styleStaircase); Plot(C, "", colorBlack, styleCandle); PlotShapes( shapeUpArrow*Buy, colorGreen, 0, L, -20); PlotShapes( shapeHollowUpArrow*Buy, colorBlack,0, L, -20) ; PlotShapes( shapeDownArrow*Sell, colorRed,0,H, -20) ; PlotShapes( shapeHollowDownArrow*Sell, colorBlack,0,H, -20) ; Title = "#337 Trailing Staircase Stop " + " {{NAME}} " + "\n\nAve $ Traded / day $M = " + WriteVal((MA(C,20) * MA(V,20))/1E6, (format=0.2)) + "\n" + EncodeColor(colorIndigo) +"Total Profit = " + WriteVal(TotalProfit, (format=0.2)) + "\n";