Stock Portfolio Organizer

The ultimate porfolio management solution.

Shares, Margin, CFD's, Futures and Forex
EOD and Realtime
Dividends and Trust Distributions
And Much More ....
For Portfolio Manager Click Here

WiseTrader Toolbox

#1 Selling Amibroker Plugin featuring:

Advanced Adaptive Indicators
Advanced Pattern Exploration
Neural Networks
And Much More ....
Find Out More Here

3 Price Break for Amibroker (AFL)

Rating:
5 / 5 (Votes 1)
Tags:

Nice formula to indicate breakout/downs.

Screenshots

Indicator / Formula

Copy & Paste Friendly
Title = Name() + " Price Break Indicator.";
//+ "  Trend is " + Trend_Text + ".  SEQUENCE IS " + Sequence_Text;
Plot(C, Title, colorBlack, styleCandle);

/////////   Parameters  ////////

nBars_To_Scan = Param("Number of bars to Scan", 20, 10, 480, 10); //Number of bars to include in scan
PB_Interval = Param("Number of Bars for Price Break", 3, 2, 3, 1);

/////////  Use Array of Prices and Price Breaks to Look Back and Determine What Price break is for Current Bar
Seedbar = nBars_To_Scan + 1; //Need an initial value to start the PB process
if (BarCount > Seedbar)
//Make sure there are enough bars available to evaluate
{

  Price[0] = LastValue(Ref(C,  - Seedbar)); //Seed the 0 Bar in the Array with Values
  Trend[0] = 1; //1 = Long, 0=Short
  Sequence[0] = 0; //Sequence counter - counts number of new price breaks
  Price_Break[0] = LastValue(Ref(C,  - Seedbar));
  High_C1[0] = LastValue(Ref(C,  - Seedbar)); //Highest Close 1 Ago
  High_C2[0] = LastValue(Ref(C,  - Seedbar)); //Highest Close 2 Ago
  High_C3[0] = LastValue(Ref(C,  - Seedbar)); //Highest Close 3 Ago
  Low_C1[0] = LastValue(Ref(C,  - Seedbar)); //Lowest Close 1 Ago
  Low_C2[0] = LastValue(Ref(C,  - Seedbar)); //Lowest Close 2 Ago
  Low_C3[0] = LastValue(Ref(C,  - Seedbar)); //Lowest Close 3 Ago

  for (i = 1; i < Seedbar; i++)
  //Cycle through prices filling in price array AND caculating price breaks 
  {
    Prior = i - 1; //Index for Prior entry in array.  Set the current array values to 
    Trend[i] = Trend[Prior]; //prior values to make sure everything that isn't changed later
    Price_Break[i] = Price_Break[Prior]; //gets carried forward to the next row in the array.
    Low_C1[i] = Low_C1[Prior]; //Carryover current values
    Low_C2[i] = Low_C2[Prior];
    Low_C3[i] = Low_C3[Prior];
    High_C1[i] = High_C1[Prior]; //Carryover current values
    High_C2[i] = High_C2[Prior];
    High_C3[i] = High_C3[Prior];
    Sequence[i] = Sequence[Prior];

    Price[i] = LastValue(Ref(C,  - (Seedbar - i))); //Seedbar is the bar just in front of where I start the method.  Works since i starts at 1

    if (Price[i] > Price[Prior] AND Trend[Prior] == 1)
    // If Close is Greater than the prior Close AND the Trend is Long
    {
      if (Price[i] > High_C1[Prior])
      //If the Close is greater than the last Highest Close
      {
        //Test For Price Break.  The IIF is there to accomodate a 2 price OR 3 price break option
        //based on the PB_Interval parameter
        Price_Break[i] = IIf(PB_Interval == 3, High_C3[Prior], IIf(PB_Interval == 2, High_C2[Prior], High_C3[Prior]));
        //The 3PB method says I take the highest close 4 ago as the new price break.
        Sequence[i] = Sequence[i] + 1; //Increment Sequence if Price Break
        High_C3[i] = High_C2[Prior]; //Stacking the higher closes like this avoids having to go back AND iterate through the.
        High_C2[i] = High_C1[Prior]; //closes to find and count the higher closes.  They are just carried forward in the stack.
        High_C1[i] = Price[i]; //When a higher close occurs, it is put on the top of the stack, each Close below is
      } //pushed down in sequence, and the earliest (farthest back) close goes away.
    }

    if (Price[i] > Price[Prior] AND Trend[Prior] == 0)
    // If Close is Greater than the prior Close AND the Trend is Short
    {
      if (Price[i] > Price_Break[Prior])
      //If Close > Price Break in trend is Short, Reverse AND go Long
      {
        High_C1[i] = High_C2[i] = High_C3[i] = Price[i]; //Initialize sequence of new Highs
        Price_Break[i] = Price[i]; //Set new value for Price Break
        Trend[i] = 1; //Set the trend Long
        Sequence = 0;
      }
    }

    if (Price[i] < Price[Prior] AND Trend[Prior] == 0)
    // If The Close is less than the prior Close AND the Trend is Short
    {
      if (Price[i] < Low_C1[Prior])
      //If the Close is less than the last lowest Close
      {
        Price_Break[i] = IIf(PB_Interval == 3, Low_C3[Prior], IIf(PB_Interval == 2, Low_C2[Prior], Low_C3[Prior])); //Test For Price Break
        Sequence[i] = Sequence[i] + 1; //Increment Sequence if Price Break
        Low_C3[i] = Low_C2[Prior]; //Update sequence of new Lows
        Low_C2[i] = Low_C1[Prior];
        Low_C1[i] = Price[i];
      }
    }

    if (Price[i] < Price[Prior] AND Trend[Prior] == 1)
    // If The Close is less than the prior Close AND the Trend is Long
    {
      if (Price[i] < Price_Break[Prior])
      //If Close < Price Break in Long Trend, reverse AND go Short
      {
        Low_C1[i] = Low_C2[i] = Low_C3[i] = Price[i]; //Initialize sequence of new Lows
        Price_Break[i] = Price[i]; //Set new value for Price Break
        Trend[i] = 0; //Set Trend Short
        Sequence = 0;
      }
    }

    ////  Plot the Price Breaks.
    Bar_x1 = BarCount - (nBars_To_Scan - Prior);
    Bar_x2 = BarCount - (nBars_To_Scan - i);
    PB_Color = IIf(Trend[i] == 1, colorGreen, colorRed);
    Plot(LineArray(Bar_x1, Price_Break[i], Bar_x2, Price_Break[i], extend = 0), "", PB_Color, styleThick);
    Sequence_Text = NumToStr(Sequence, format = 1.0);
    Trend_Text = WriteIf(Trend[i] > 0, "Long", "Short");

  } //Close the For Loop

}

0 comments

Leave Comment

Please login here to leave a comment.

Back