Jump to content

Welcome to the new Traders Laboratory! Please bear with us as we finish the migration over the next few days. If you find any issues, want to leave feedback, get in touch with us, or offer suggestions please post to the Support forum here.

  • Welcome Guests

    Welcome. You are currently viewing the forum as a guest which does not give you access to all the great features at Traders Laboratory such as interacting with members, access to all forums, downloading attachments, and eligibility to win free giveaways. Registration is fast, simple and absolutely free. Create a FREE Traders Laboratory account here.

spyro

Zig zag pivot indicator

Recommended Posts

inputs:

 

ATRPeriod(9), //Number of ATR Periods

 

ATRMulti(2.0), // ATR Multiplier

 

 

 

StrengthSensitivity(2), //Pivot Strength

 

 

 

ShowZigZagLines(True),

 

ShowZigZagCount(True),

 

ShowZigZagTime(True),

 

ZigZagLineColorUp(BLUE),

 

ZigZagLineColorDN(CYAN),

 

ZigZagLineWidth(1),

 

ZigZagLineStyle(Tool_Solid),

 

ZigZagTextColor(CYAN),

 

VertOffset1(1),

 

VertOffset2(2), // Second String on Swing Hi/Lows

 

DecimalPlaces(2);

 

 

 

vars:

 

NewSwingPrice(0),

 

LastSwingPrice(0),

 

SwingPrice(High),

 

SwingDate(Date),

 

SwingTime(Time),

 

TLDir(0), { TLDir = -1 implies prev TL dn, +1 implies prev TL up }

 

SaveSwing(false),

 

AddTL(false),

 

UpdateTL(false),

 

TLRef(0),

 

TLSwing(0),

 

PeakTextRef(0),PeakTextRef2(0),

 

PeakStr(""), PeakStr2(""),

 

Diff(0),

 

ArrayMax (17),

 

ATRPoints(0),

 

BarDiff(0), TimeDiff(0),

 

ZigZagCount(0),

 

ZZCountStr(""),

 

x(0),

 

showDebug(FALSE);

 

 

 

 

 

Arrays:

 

TrendLine[17] (0), DayValue[17] (0), ZigZag[1000,3](0);

 

 

 

if CurrentBar = 1 then

 

begin

 

for x=0 to ArrayMax { Draw Fib Lines }

 

begin

 

if x <= ArrayMax then

 

begin

 

TrendLine[x] = TL_New (Date[1], Time[1], Low, Date, Time, Low);

 

 

 

TL_SetExtLeft (TrendLine[x], false);

 

TL_SetExtRight (TrendLine[x], True);

 

end; // if

 

end; // for

 

end; //if currentbar

 

 

 

{ Candidate swings are just-confirmed, 3-bar (Str=1), SwingHi's and SwingLo's }

 

NewSwingPrice = SwingHigh( 1, High, StrengthSensitivity, StrengthSensitivity+1);

 

 

 

 

 

ATRPoints = ATRMulti*AvgTrueRange(ATRPeriod) ;

 

 

 

if NewSwingPrice <> -1 then

 

begin

 

if (TLDir <= 0 and NewSwingPrice >= SwingPrice + ATRPoints) then

 

{ prepare to add new up TL }

 

begin

 

SaveSwing = true;

 

AddTL = true;

 

TLDir = 1;

 

end

 

else

 

if TLDir = 1 and NewSwingPrice >= SwingPrice then { prepare to update prev up TL }

 

begin

 

SaveSwing = true;

 

UpdateTL = true;

 

end;

 

end

 

else

 

begin

 

{ NewSwingPrice = SwingLow( 1, Low, 1, 2 ); }

 

NewSwingPrice = SwingLow( 1, Low, StrengthSensitivity, StrengthSensitivity+1);

 

 

 

if NewSwingPrice <> -1 then

 

begin { prepare to add new dn TL }

 

if TLDir >= 0 and NewSwingPrice <= SwingPrice - ATRPoints then

 

begin

 

SaveSwing = true;

 

AddTL = true;

 

TLDir = -1;

 

end

 

else

 

if TLDir = -1 and NewSwingPrice <= SwingPrice then { prepare to update prev dn TL }

 

begin

 

SaveSwing = true;

 

UpdateTL = true ;

 

end;

 

end;

 

end;

 

 

 

if SaveSwing then { save new swing and reset SaveSwing }

 

begin

 

SwingPrice = NewSwingPrice ;

 

SwingDate = Date[strengthSensitivity];

 

SwingTime = Time[strengthSensitivity];

 

// SaveSwing = false ;

 

end ;

 

if (showDebug) then

 

print(" AddTL === ", AddTL, " UpdateTL == ", UpdateTL, "SaveSwing == ", SaveSwing, " TL Dir = ", TLDir);

 

 

 

{ add new TL and reset AddTL }

 

if AddTL then

 

begin

 

PeakTextRef = Text_New(Date, Time, Close, " ");

 

Text_SetColor(PeakTextRef, ZigZagTextColor);

 

 

 

if (ShowZigZagTime) then

 

begin

 

PeakTextRef2 = Text_New(Date, Time, Close, " ");

 

Text_SetColor(PeakTextRef2, ZigZagTextColor);

 

end;

 

 

 

if ShowZigZagLines then

 

begin

 

TLRef = TL_New(SwingDate, SwingTime, SwingPrice, SwingDate[1], SwingTime[1],SwingPrice[1]);

 

Text_SetStyle(PeakTextRef, 2, 2);

 

Text_SetStyle(PeakTextRef2, 2, 3);

 

TL_SetExtLeft( TLRef, false);

 

TL_SetExtRight( TLRef, false);

 

TL_SetSize( TLRef, ZigZagLineWidth);

 

if TLDir = -1 then

 

TL_SetColor( TLRef, ZigZagLineColorDN)

 

else

 

TL_SetColor( TLRef, ZigZagLineColorUp);

 

 

 

LastSwingPrice = SwingPrice[1];

 

end;

 

 

 

if (TLDir[1] <> TLDir[2]) then BarDiff = 0

 

else BarDiff = BarDiff +1;

 

 

 

ZigZagCount = ZigZagCount + 1;

 

 

 

ZigZag[ZigZagCount,1] = SwingPrice; // Current Swing Price

 

ZigZag[ZigZagCount,2] = BarNumber; // BarNum

 

ZigZag[ZigZagCount,3] = TimetoMinutes(Time); // Time Var

 

 

 

BarDiff = ZigZag[ZigZagCount,2] - ZigZag[ZigZagCount-1,2];

 

 

 

if (showZigZagCount) then

 

ZZCountStr = "[" + NumToStr(ZigZagCount,0) +"] "

 

else

 

ZZCountStr = "";

 

 

 

if TLDir = -1 then

 

Diff = LastSwingPrice - SwingPrice

 

else

 

Diff = SwingPrice - LastSwingPrice;

 

 

 

TimeDiff = Zigzag[ZigZagcount,3] - Zigzag[ZigZagcount-1,3];

 

{jmh}

 

{ PeakStr = ZZCountStr + " " + NumToStr(SwingPrice,DecimalPlaces) + " / " + NumToStr(Diff, DecimalPlaces);

 

PeakStr2 = ELTimetoString(MinutestoTime(ZigZag[ZigZagCount,3])) + " / " + NumtoStr(BarDiff,0)+ " / " + NumtoStr(TimeDiff,0);}

 

PeakStr = NumToStr(SwingPrice,DecimalPlaces) + " / " + NumToStr(Diff, DecimalPlaces) ;

 

PeakStr2 = " ";

 

 

 

 

 

Text_SetString(PeakTextRef, PeakStr);

 

if TLDir = -1 then

 

Text_SetLocation(PeakTextRef, SwingDate, SwingTime, SwingPrice - VertOffset1)

 

else

 

Text_SetLocation(PeakTextRef, SwingDate, SwingTime, SwingPrice + VertOffset2);

 

 

 

 

 

if (ShowZigZagTime) then

 

begin

 

Text_SetString(PeakTextRef2, PeakStr2);

 

if TLDir = -1 then

 

Text_SetLocation(PeakTextRef2, SwingDate, SwingTime, SwingPrice - VertOffset2)

 

else

 

Text_SetLocation(PeakTextRef2, SwingDate, SwingTime, SwingPrice + VertOffset1);

 

end;

 

 

 

 

 

AddTL = false;

 

end

 

else if UpdateTL then { update prev TL and reset UpdateTL }

 

begin

 

if ShowZigZagLines then

 

TL_SetEnd( TLRef, SwingDate, SwingTime, SwingPrice);

 

 

 

if (TLDir[1] <> TLDir[2]) then BarDiff = 0

 

else BarDiff = BarDiff +1;

 

 

 

ZigZag[ZigZagCount,1] = SwingPrice; // Current Swing Price

 

ZigZag[ZigZagCount,2] = BarNumber[1]; // BarNum

 

ZigZag[ZigZagCount,3] = TimetoMinutes(Time); // Time Var

 

 

 

 

 

BarDiff = ZigZag[ZigZagCount,2] - ZigZag[ZigZagCount-1,2];

 

 

 

if (showZigZagCount) then

 

ZZCountStr = "[" + NumToStr(ZigZagCount,0) +"] "

 

else

 

ZZCountStr = "";

 

 

 

if TLDir = -1 then

 

Diff = LastSwingPrice - SwingPrice

 

else

 

Diff = SwingPrice - LastSwingPrice;

 

 

 

TimeDiff = Zigzag[ZigZagcount,3] - Zigzag[ZigZagcount-1,3];

 

 

 

{ PeakStr = ZZCountStr + "" + NumToStr(SwingPrice,DecimalPlaces) + " / " + NumToStr(Diff, DecimalPlaces);}

 

PeakStr = NumToStr(SwingPrice,DecimalPlaces) + " / " + NumToStr(Diff, DecimalPlaces);

 

PeakStr2 = " ";

 

{ PeakStr2 = ELTimetoString(MinutestoTime(ZigZag[ZigZagCount,3])) + " / " + NumtoStr(BarDiff,0)+ " / " + NumtoStr(TimeDiff,0);}

 

 

 

Text_SetString( PeakTextRef, PeakStr);

 

 

 

if TLDir = -1 then

 

Text_SetLocation(PeakTextRef, SwingDate, SwingTime, SwingPrice - VertOffset1)

 

else

 

Text_SetLocation(PeakTextRef, SwingDate, SwingTime, SwingPrice + VertOffset2);

 

 

 

if (ShowZigZagTime) then

 

begin

 

Text_SetString(PeakTextRef2, PeakStr2);

 

if TLDir = -1 then

 

Text_SetLocation(PeakTextRef2, SwingDate, SwingTime, SwingPrice - VertOffset2)

 

else

 

Text_SetLocation(PeakTextRef2, SwingDate, SwingTime, SwingPrice + VertOffset1);

 

end;

 

 

 

UpdateTL = false;

 

end;

 

 

 

if SaveSwing then

 

begin

 

if TLDir = -1 then

 

begin

 

DayValue[0] = Swingprice;

 

DayValue[1] = LastSwingprice;

 

end

 

else

 

begin

 

DayValue[1] = Swingprice;

 

DayValue[0] = LastSwingprice;

 

end;

 

Diff = DayValue[0] - DayValue[1];

 

 

 

if (showDebug) then

 

print("Day0 = ", DayValue[0], " DayMax= ", DayValue[1], " Diff =", Diff, " TLDir = ", TLDir);

 

 

 

 

 

 

 

for x=0 to ArrayMax

 

begin

 

if TrendLine[x] > 0 then

 

begin

 

{ SetEnd before SetBegin }

 

TL_SetEnd (TrendLine[x], Date, Time, DayValue[x]);

 

TL_SetBegin (TrendLine[x], Date, Time, DayValue[x]);

 

end; // if TrendLine

 

end; // for loop

 

SaveSwing = False;

 

end; // if SaveSwing

 

 

 

ENJOY:cool:

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.


  • Topics

  • Posts

    • 📁 Population in 2100, as projected by UN Population Division.   🇮🇳 India: 1,533 million 🇨🇳 China: 771 million 🇳🇬 Nigeria: 546 million 🇵🇰 Pakistan: 487 million 🇨🇩 Congo: 431 million 🇺🇸 US: 394 million 🇪🇹 Ethiopia: 323 million 🇮🇩 Indonesia: 297 million 🇹🇿 Tanzania: 244 million 🇪🇬 Egypt: 205 million 🇧🇷 Brazil: 185 million 🇵🇭 Philippines: 180 million 🇧🇩 Bangladesh: 177 million 🇳🇪 Niger: 166 million 🇸🇩 Sudan: 142 million 🇦🇴 Angola: 133 million 🇺🇬 Uganda: 132 million 🇲🇽 Mexico: 116 million 🇰🇪 Kenya: 113 million 🇷🇺 Russia: 112 million 🇮🇶 Iraq: 111 million 🇦🇫 Afghanistan: 110 million   @FinancialWorldUpdates Profits from free accurate cryptos signals: https://www.predictmag.com/   
    • “If the West finds itself falling behind in AI, it won’t be due to a lack of technological prowess or resources. It won’t be because we weren’t smart enough or didn’t move fast enough. It will be because of something many of our Eastern counterparts don’t share with us: fear of AI.   The root of the West's fear of AI can no doubt be traced back to decades of Hollywood movies and books that have consistently depicted AI as a threat to humanity. From the iconic "Terminator" franchise to the more recent "Ex Machina," we have been conditioned to view AI as an adversary, a force that will ultimately turn against us.   In contrast, Eastern cultures have a WAY different attitude towards AI. As UN AI Advisor Neil Sahota points out, "In Eastern culture, movies, and books, they've always seen AI and robots as helpers and assistants, as a tool to be used to further the benefit of humans."   This positive outlook on AI has allowed countries like Japan, South Korea, and China to forge ahead with AI development, including in areas like healthcare, where AI is being used to improve the quality of services.   The West's fear of AI is not only shaping public opinion but also influencing policy decisions and regulatory frameworks. The European Union, for example, recently introduced AI legislation prioritizing heavy-handed protection over supporting innovation.   While such measures might be well-intentioned, they risk stifling AI development and innovation, making it harder for Western companies and researchers to compete.   Among the nations leading common-sense AI regulation, one stands out for now: Singapore.” – Chris C Profits from free accurate cryptos signals: https://www.predictmag.com/ 
    • $NFLX Netflix stock hold at 556.59 support or breakdown?  https://stockconsultant.com/?NFLX
    • $RDNT Radnet stock flat top breakout watch, https://stockconsultant.com/?RDNT
    • $GNK Genco Shipping stock narrow range breakout watch, also see $GOGL https://stockconsultant.com/?GNK
×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.