Is anyone having supertrend code?

i need supertrend crossover code…

1 Like

Check this below amibroker AFL code for supertrend

function GetSecondNum()
{
Time = Now( 4 );
Seconds = int( Time % 100 );
Minutes = int( Time / 100 % 100 );
Hours = int( Time / 10000 % 100 );
SecondNum = int( Hours * 60 * 60 + Minutes * 60 + Seconds );
return SecondNum;
}

function PopupWindowEx( popupID, bodytext, captiontext, timeout, left, top )
{
displayText = bodytext + captiontext;
if ( ( StaticVarGetText( “prevPopup” + popupID ) != displayText) OR ( StaticVarGet( “prevPopupTime” + popupID ) < GetSecondNum() ) )
{
StaticVarSetText( “prevPopup” + popupID, displayText);
StaticVarSet( “prevPopupTime” + popupID, GetSecondNum() + timeout );
PopupWindow( bodytext, Captiontext + popupID, timeout, Left, top );
PlaySound(“c:\windows\media\ding.wav”);
}
}

_SECTION_BEGIN(“SuperTrend Ver 3.0 with Sound and Popup Alert”);
SetBarsRequired(100000,0);
GraphXSpace = 15;
SetChartOptions(0,chartShowArrows|chartShowDates);
SetChartBkColor(colorBlack);
GfxSetBkMode(0);
GfxSetOverlayMode(1);
SetBarFillColor(IIf(C>O,colorGreen,IIf(C<=O,colorRed,colorLightGrey)));
Plot(C,“\nPrice”,IIf(C>O,colorDarkGreen,IIf(C<=O,colorDarkRed,colorLightGrey)),64,0,0,0,0);

// Initial Values overrides you backtesting settings

SetOption( “InitialEquity”, 100000);
SetOption(“FuturesMode” ,False);
SetOption(“MinShares”,1);
SetOption(“CommissionMode”,2);
SetOption(“CommissionAmount”,0);
SetOption(“AccountMargin”,100);
SetOption(“RefreshWhenCompleted”,True);
SetTradeDelays(0,0,0,0);
SetPositionSize(1,spsShares);

_N(Title = StrFormat(“{{NAME}} - {{INTERVAL}} {{DATE}} Open %g, Hi %g, Lo %g, Close %g (%.1f%%) {{VALUES}}”, O, H, L, C, SelectedValue( ROC( C, 1 ) ) ));

Factor=Param(“Factor”,4,1,10,0.1);

Pd=Param(“ATR Periods”,10,1,100,1);

Up=(H+L)/2+(Factor*ATR(Pd));

Dn=(H+L)/2-(Factor*ATR(Pd));

iATR=ATR(Pd);

TrendUp=TrendDown=Null;

trend[0]=1;

changeOfTrend=0;

flag=flagh=0;

for (i = 1; i <BarCount-1; i++) {

  TrendUp[i] = Null;
  TrendDown[i] = Null;
  trend[i]=1;
  if (Close[i]>Up[i-1]) {
     trend[i]=1;
     if (trend[i-1] == -1) changeOfTrend = 1;
    }
  else if (Close[i]<Dn[i-1]) {
     trend[i]=-1;
     if (trend[i-1] == 1) changeOfTrend = 1;
  }
  else if (trend[i-1]==1) {
     trend[i]=1;
     changeOfTrend = 0;       
  }
  else if (trend[i-1]==-1) {
     trend[i]=-1;
     changeOfTrend = 0;
  }
  if (trend[i]<0 && trend[i-1]>0) {
     flag=1;
  }
  else {
     flag=0;
  }
  if (trend[i]>0 && trend[i-1]<0) {
     flagh=1;
  }
  else {
     flagh=0;
  }
  if (trend[i]>0 && Dn[i]<Dn[i-1]){
     Dn[i]=Dn[i-1];
  }
  if (trend[i]<0 && Up[i]>Up[i-1])
    { Up[i]=Up[i-1];
  }
  if (flag==1)
   {  Up[i]=(H[i]+L[i])/2+(Factor*iATR[i]);;
    } 
  if (flagh==1)
    { Dn[i]=(H[i]+L[i])/2-(Factor*iATR[i]);;
     }
  if (trend[i]==1) {
     TrendUp[i]=Dn[i];
     if (changeOfTrend == 1) {
        TrendUp[i-1] = TrendDown[i-1];
        changeOfTrend = 0;
     }
  }
  else if (trend[i]==-1) {
     TrendDown[i]=Up[i];
     if (changeOfTrend == 1) {
        TrendDown[i-1] = TrendUp[i-1];
        changeOfTrend = 0;
     }
  }

}

Plot(TrendUp,“Trend”,colorGreen);

Plot(TrendDown,“Down”,colorRed);

Buy = trend==1;

Sell=trend==-1;

Buy = Ref(Buy,-1);
Sell = Ref(Sell,-1);

GfxTextOut("Trend: "+WriteVal(Trend,1.2),500,500);

Buy=ExRem(Buy,Sell);

Sell=ExRem(Sell,Buy);

Short=Sell;

Cover=Buy;

BuyPrice=ValueWhen(Buy,C);

SellPrice=ValueWhen(Sell,C);

ShortPrice=ValueWhen(Short,C);

CoverPrice=ValueWhen(Cover,C);

Title = EncodeColor(colorWhite)+ “Super Trend AFL code from www.marketcalls.in” + " - " + Name() + " - " + EncodeColor(colorRed)+ Interval(2) + EncodeColor(colorWhite) +

" - " + Date() +" - “+”\n" +EncodeColor(colorRed) +“Op-”+O+" “+“Hi-”+H+” “+“Lo-”+L+” "+

“Cl-”+C+" "+ “Vol= “+ WriteVal(V)+”\n”+

EncodeColor(colorLime)+

WriteIf (Buy , " GO LONG / Reverse Signal at “+C+” “,”")+

WriteIf (Sell , " EXIT LONG / Reverse Signal at “+C+” “,”“)+”\n"+EncodeColor(colorYellow)+

WriteIf(Sell , “Total Profit/Loss for the Last Trade Rs.”+(C-BuyPrice)+“”,“”)+

WriteIf(Buy , “Total Profit/Loss for the Last trade Rs.”+(SellPrice-C)+“”,“”);

PlotShapes(IIf(Buy, shapeSquare, shapeNone),colorGreen, 0, L, Offset=-40);

PlotShapes(IIf(Buy, shapeSquare, shapeNone),colorLime, 0,L, Offset=-50);
PlotShapes(IIf(Buy, shapeUpArrow, shapeNone),colorWhite, 0,L, Offset=-45);
PlotShapes(IIf(Short, shapeSquare, shapeNone),colorRed, 0, H, Offset=40);
PlotShapes(IIf(Short, shapeSquare, shapeNone),colorOrange, 0,H, Offset=50);
PlotShapes(IIf(Short, shapeDownArrow, shapeNone),colorWhite, 0,H, Offset=-45);

duration = 10000000;

LastClose= Ref(C,-1); // if you like to add this popup will show you

if (Buy[BarCount-2]==True)
{
//PopupWindowEx( “ID:1”, “Get Ready to BUY \n”+Name() + " “+ Interval(2)+” : “+ " Last =”+LastClose , “Buy Alert -”, 1000, 100, 1 ) ;
}
if (Short[BarCount-2]==True)
{
//PopupWindowEx( “ID:2”, “Get Ready to SHORT \n”+Name() + " "+ Interval(2) + " : “+ " Last =”+LastClose , "Short Alert ", 1000, 1, 150 ) ;
}

TrendSL=IIf(trend==1,TrendUp,TrendDown);

for(i=BarCount-1;i>1;i–)

{

if(Buy[i] == 1)

{

entry = C[i];

sig = “BUY”;

sl = TrendSL[i];

tar1 = entry + (entry * .0050);

tar2 = entry + (entry * .0092);

tar3 = entry + (entry * .0179);

bars = i;

i = 0;

}

if(Sell[i] == 1)

{

sig = “SELL”;

entry = C[i];

sl = TrendSL[i];

tar1 = entry - (entry * .0050);

tar2 = entry - (entry * .0112);

tar3 = entry - (entry * .0212);

bars = i;

i = 0;

}

}

Offset = 20;

Clr = IIf(sig == “BUY”, colorLime, colorRed);

ssl = IIf(bars == BarCount-1, TrendSL[BarCount-1], Ref(TrendSL, -1));

sl = ssl[BarCount-1];

Plot(LineArray(bars-Offset, tar1, BarCount, tar1,1), “”, Clr, styleLine|styleDots, Null, Null, Offset);

Plot(LineArray(bars-Offset, tar2, BarCount, tar2,1), “”, Clr, styleLine|styleDots, Null, Null, Offset);

Plot(LineArray(bars-Offset, tar3, BarCount, tar3,1), “”, Clr, styleLine|styleDots, Null, Null, Offset);

//Plot(LineArray(bars-Offset, sl, BarCount, sl,1), “”, colorDarkRed, styleLine|styleLine, Null, Null, Offset);

//Plot(LineArray(bars-Offset, entry, BarCount, entry,1), “”, colorGreen, styleLine|styleLine, Null, Null, Offset);

/*

for (i=bars; i <BarCount;i++)

{

PlotText(“”+sig+“@”+entry, BarCount-5,entry,Null,colorBlue);

PlotText(“T1@”+tar1,BarCount-5,tar1,Null,Clr);PlotText(“T2@”+tar2,BarCount-5,tar2,Null,Clr);PlotText (“T3@”+tar3,BarCount-5,tar3,Null,Clr);

}*/

messageboard = ParamToggle(“Message Board”,“Show|Hide”,1);

if (messageboard == 1 )

{

GfxSelectFont( “Tahoma”, 13, 100 );

GfxSetBkMode( 1 );

GfxSetTextColor( colorWhite );

if ( sig ==“BUY”)

{

GfxSelectSolidBrush( colorBlue ); // this is the box background color

}

else

{

GfxSelectSolidBrush( colorRed ); // this is the box background color

}

pxHeight = Status( “pxchartheight” ) ;

xx = Status( “pxchartwidth”);

Left = 1100;

width = 310;

x = 5;

x2 = 290;

y = pxHeight;

GfxSelectPen( colorGreen, 1); // broader color

GfxRoundRect( x, y - 98, x2, y , 7, 7 ) ;

GfxTextOut( ( “Marketcalls - Supertrend”),13,y-100);

GfxTextOut( (" "),27,y-100);

GfxTextOut( (“Last " + sig + " Signal came " + (BarCount-bars-1) * Interval()/60 + " mins ago”), 13, y-80) ; // The text format location

GfxTextOut( (“” + WriteIf(sig ==“BUY”,sig + " @ “,sig + " @”) + " : " + entry), 13, y-60);

GfxTextOut( (“Trailing SL : " + Ref(TrendSL,-1) + " (” + WriteVal(IIf(sig == “SELL”,entry-sl,sl-entry), 2.2) + “)”), 13, y-40);

/*GfxTextOut( ("TGT:1 : " + tar1), 13, y -80);

GfxTextOut( ("TGT:2 : " + tar2), 13,y-60);

GfxTextOut( ("TGT:3 : " + tar3), 13,y-40);*/

GfxTextOut( ("Current P/L : " + WriteVal(IIf(sig == “BUY”,(C-entry),(entry-C)),2.2)), 13, y-22);;

}

// Calculate Equity Curve

eq = Equity( 1, 0 );

//////////////////////////////////////////////////
// Calculate the Last Five Trades Profit/Losses //
//////////////////////////////////////////////////

tradesback = 5;
Signum = Cum( Buy ) + Cum( Short );
Signumstart1 = LastValue( SigNum ) - ( tradesback - 1 );
Signumstart2 = LastValue( SigNum ) - ( tradesback - 2 );
Signumstart3 = LastValue( SigNum ) - ( tradesback - 3 );
Signumstart4 = LastValue( SigNum ) - ( tradesback - 4 );
Signumstart5 = LastValue( SigNum ) - ( tradesback - 5 );

bi = BarIndex();
bistart = ValueWhen( signum == signumstart1, bi );
bicond = bi >= bistart AND bi <= LastValue( bi );

SellPL = IIf( Sell AND bicond, C-BuyPrice, 0 );
CovPL = IIf( Cover AND bicond, ShortPrice - C,0 );

cumPL = SellPL + CovPL;

//Plot (SellPL,“Sell”,colorGreen,styleHistogram,maskhistogram);
///Plot (CovPL,“Cover”, colorRed,styleHistogram,maskhistogram);

lsince = LowestSince(Sell OR Cover, cumPL, 0);
hsince = HighestSince(Sell OR Cover, CumPL, 0);

vs= IIf(lsince==0,hsince,lsince);

PL1 = ValueWhen( signum == signumstart1 , vs,1 );
PL2 = ValueWhen( signum == signumstart2 , vs,1 );
PL3 = ValueWhen( signum == signumstart3 , vs,1 );
PL4 = ValueWhen( signum == signumstart4 , vs,1 );
PL5 = ValueWhen( signum == signumstart5, vs ,1 );

//////////////////////////////////////////////////
// Plot the Last Five Trades Profit/Losses //
//////////////////////////////////////////////////

Title = EncodeColor(colorWhite)+ “Backtest Results from www.marketcalls.in” + " - " + Name() + " - " + EncodeColor(colorRed)+ Interval(2) + EncodeColor(colorWhite) +

" - " + Date() +" - “+”\n" +EncodeColor(colorRed) +“Op-”+O+" “+“Hi-”+H+” “+“Lo-”+L+” "+

“Cl-”+C+" “+ “Vol= “+ WriteVal(V)+”\n”+ EncodeColor(colorYellow)+ “\n\n\nLast 5 Trade Results\n” +
“\nTrade1= " + PL1
+”\n”+ “Trade2= " + PL2
+”\n"+ “Trade3= " + PL3
+”\n"+ “Trade4= " + PL4
+”\n"+ "Trade5= " + PL5;

//Magfied Market Price

FS=30;

GfxSelectFont(“Times New Roman”, FS, 700, True );

GfxSetBkMode( colorWhite );

GfxSetTextColor(colorGreen);

Hor=940;

Ver=12;

GfxTextOut(“”+C, Hor , Ver );

YC=TimeFrameGetPrice(“C”,inDaily,-1);

DD=Prec(C-YC,2);

xx=Prec((DD/YC)*100,2);

GfxSelectFont(“Times New Roman”, 11, 700, True );

GfxSetBkMode( colorBlack );

GfxSetTextColor(colorYellow);

GfxTextOut(“”+DD+" (“+xx+”%)", Hor , Ver+45 );

_SECTION_END();

_SECTION_BEGIN(“Time Left”);

RequestTimedRefresh( 1 );

TimeFrame = Interval();

SecNumber = GetSecondNum();

Newperiod = SecNumber % TimeFrame == 0;

SecsLeft = SecNumber - int( SecNumber / TimeFrame ) * TimeFrame;

SecsToGo = TimeFrame - SecsLeft;

x=50;//Param(“xposn”,50,0,1000,1);

y=380;//Param(“yposn”,380,0,1000,1);

GfxSelectSolidBrush( ColorRGB( 230, 230, 230 ) );

GfxSelectPen( ColorRGB( 230, 230, 230 ), 2 );

if ( NewPeriod )

{

GfxSelectSolidBrush( colorYellow );

GfxSelectPen( colorYellow, 2 );

Say( “New period” );

}

//GfxRoundRect( x+45, y+40, x-3, y-2, 0, 0 );

//GfxSetBkMode(1);

GfxSelectFont( “Arial”, 14, 700, False );

GfxSetTextColor( colorRed );

GfxTextOut( “Time Left :”+SecsToGo+“”, x, y );

_SECTION_END();

_SECTION_BEGIN(“PiBridge_Choks”);
EnableScript(“vbscript”);AmiPath = fdir( “C:\Program Files (x86)\Amibroker\Broker.exe”, 1 );
if (AmiPath==“”){Path = “C:\Program Files\Amibroker\”;Sys = “Bit32”; }else {Path = “C:\Program Files (x86)\Amibroker\”;Sys = “Bit64”;}
GfxSetBkMode(0);GfxSetTextColor( colorWhite );pxw = Status(“pxwidth”);pxh = Status(“pxheight”);Tikr = StrToUpper(Name());Val = StrToUpper(“DAY”);
BarB = BeginValue(BarIndex());BarE = EndValue(BarIndex());BarC = BarIndex();BarL = LastValue(BarC,1);BarT1 = ValueWhen(DateNum()!= Ref(DateNum(),-1) ,BarIndex());
BarT = IIf(IsEmpty(BarT1),BarIndex(),BarIndex()-BarT1);sym=TrdSym=Exch=ClientId=ORdType=ProdType=“”;Qty=0;
if (IsNull(fgetstatus(“SymbolList.txt”,1,4))){SymbolList = fopen( “SymbolList.txt”, “w”);if (SymbolList){fputs( “AmibrokerSymbol,TradeSymbol,Exchange,Qty,ClientID,OrderType,ProductType,Validity”+ “\n” +“EXAMPLE-I,EXAMPLE15MAYFUT,NFO,1,ABCD01,L,MIS,DAY” + “\n” , SymbolList );fclose(SymbolList);}}
Input = fopen( “SymbolList.txt”, “r”);if(Input){ while( ! feof(Input)){LineIn = fgets(Input);if (LineIN !=“”){ if (StrToUpper(StrExtract(LineIn,0)) == Tikr){ Sym = StrToUpper(StrExtract(LineIn,0));TrdSym = StrToUpper(StrExtract(LineIn,1));Exch = StrToUpper(StrExtract(LineIn,2));Qty = StrToNum(StrExtract(LineIn,3));ClientId = StrToUpper(StrExtract(LineIn,4));OrdType = StrToUpper(StrExtract(LineIn,5));ProdType = StrToUpper(StrExtract(LineIn,6));}}}fclose( Input );}
DT = LastValue(DateNum(),1);TT = LastValue(TimeNum(),1);if (ORdType == “L”)TrdPrice = LastValue(C,1);else TrdPrice = 0;
BuyVar = StaticVarGetText(Name()+“-Buy”);BuyVar1 = Name()+“-Buy-”+NumToStr(BarT,1.0)+“-”+NumToStr(GetChartID(),1.0);BuyL = LastValue(Buy);
SellVar = StaticVarGetText(Name()+“-Sell”);SellVar1 = Name()+“-Sell-”+NumToStr(BarT,1.0)+“-”+NumToStr(GetChartID(),1.0);SellL = LastValue(Sell);
ShortVar = StaticVarGetText(Name()+“-Short”);ShortVar1 = Name()+“-Short-”+NumToStr(BarT,1.0)+“-”+NumToStr(GetChartID(),1.0);ShortL = LastValue(Short);
CoverVar = StaticVarGetText(Name()+“-Cover”);CoverVar1 = Name()+“-Cover-”+NumToStr(BarT,1.0)+“-”+NumToStr(GetChartID(),1.0);CoverL = LastValue(Cover);
if (BuyL AND BuyVar != BuyVar1 AND Sym != “”){brd = CreateStaticObject(“pibridge.Bridge”);brd.PlaceOrder (Exch,TrdSym,StrLeft(Sym,10),“LONG”,1,Qty,0,TrdPrice,0,ORdType,ProdType,ClientId,Val);StaticVarSetText(Name()+“-Buy”,BuyVar1);}
if (CoverL AND CoverVar != CoverVar1 AND Sym != “”){brd = CreateStaticObject(“pibridge.Bridge”);brd.PlaceOrder (Exch,TrdSym,StrLeft(Sym,10),“EXIT SHORT”,1,Qty,0,TrdPrice,0,ORdType,ProdType,ClientId,Val);StaticVarSetText(Name()+“-Cover”,CoverVar1);}
if (SellL AND SellVar != SellVar1 AND Sym != “”){brd = CreateStaticObject(“pibridge.Bridge”);brd.PlaceOrder (Exch,TrdSym,StrLeft(Sym,10),“EXIT LONG”,2,Qty,0,TrdPrice,0,ORdType,ProdType,ClientId,Val);StaticVarSetText(Name()+“-Sell”,SellVar1);}
if (ShortL AND ShortVar != ShortVar1 AND Sym != “”){brd = CreateStaticObject(“pibridge.Bridge”);brd.PlaceOrder (Exch,TrdSym,StrLeft(Sym,10),“SHORT”,2,Qty,0,TrdPrice,0,ORdType,ProdType,ClientId,Val);StaticVarSetText(Name()+“-Short”,ShortVar1);}
GfxSelectFont( “Lucida Fax”, 8.5, 700, False );GfxSetTextColor( colorGold );GfxTextOut(“Coded by Choks”,(pxw/2)-50,pxh-40);GfxTextOut(“Mail Ur Feedback to [email protected]”,(pxw/2)-130,pxh-30);
display = ParamToggle(“Display Symbol Details”,“Yes|No”,1);if(display==1){GfxTextOut("SYMBOL: " + sym,5,50);GfxTextOut("TRADE SYMBOL: " + Trdsym,5,70);GfxTextOut("EXCH: " + Exch,5,90);GfxTextOut("CLIENT ID: " + Clientid,5,110);GfxTextOut("PROD TYPE: " + prodtype,5,130);GfxTextOut(“ORDER TYPE: " + ORdtype,5,150);GfxTextOut(“QTY: " + WriteVal(Qty,1.0),5,170);}
if (sym == “”){GfxSelectFont( “Lucida Fax”, 24, 700, False );GfxTextOut(“Symbol Details Not Found in Text File”,(pxw/2)-330,pxh/2);}
if ((sym != “” AND Exch == “NFO” AND StrRight(TrdSym,3)!= “FUT”) OR (sym != “” AND Exch == “NSE” AND StrRight(TrdSym,2)!= “EQ”) OR (sym != “” AND Exch == “MCX” AND StrRight(TrdSym,3)!= “FUT”))
{GfxSelectFont( “Lucida Fax”, 24, 700, False );GfxTextOut(“Trade Symbol MisMatch Check Symbol List File”,(pxw/2)-370,pxh/2);}
Bridge = ParamTrigger(“To Check Pi Bridge Connectivity !”,“Press Here”);if (Bridge){brd = CreateStaticObject(“pibridge.Bridge”);}
Resetvar = ParamTrigger(“To Reset Static Variables !”,“Press Here”);if (ResetVar){StaticVarRemove(”*”);}DelSymbol = ParamTrigger(“To Delete SymbolList File !”,“Press Here”);if (DelSymbol){SymbolList = fopen( “SymbolList.txt”, “w”);
if (SymbolList){fputs( “AmibrokerSymbol,TradeSymbol,Exchange,Qty,ClientID,OrderType,ProductType,Validity”+ “\n” +“EXAMPLE-I,EXAMPLE15MAYFUT,NFO,1,ABCD01,L,MIS,DAY” + “\n” , SymbolList );fclose(SymbolList);}}
OpFolder = ParamTrigger(“To Open Amibroker Directory!”,“Press Here”);
<%
On Error Resume Next
OpFolder = AFL(“OpFolder”)
sys = AFL(“Sys”)
if OpFolder = 1 AND sys = “Bit32” then
CreateObject(“Shell.Application”).Open("C:\Program Files\Amibroker")
elseif OpFolder = 1 AND sys = “Bit64” then
CreateObject(“Shell.Application”).Open("C:\Program Files (x86)\Amibroker")
else
end if
%>
OpFile = ParamTrigger(“To Open Symbol List File!”,“Press Here”);
<%
On Error Resume Next
OpFile = AFL(“OpFile”)
sys = AFL(“Sys”)
if OpFile = 1 AND sys = “Bit32” then
CreateObject(“Shell.Application”).Open(“C:\Program Files\Amibroker\SymbolList.txt”)
elseif OpFile = 1 AND sys = “Bit64” then
CreateObject(“Shell.Application”).Open(“C:\Program Files (x86)\Amibroker\SymbolList.txt”)
else
end if
%>

_SECTION_END();

First off, what does super trend crossover mean?