| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694 |
- //+------------------------------------------------------------------+
- //| MK_BOS_CHOCH.mq5 |
- //| Copyright 2023, MetaQuotes Ltd. |
- //| https://www.mql5.com |
- //+------------------------------------------------------------------+
- #property copyright "Copyright 2023, MetaQuotes Ltd."
- #property link "https://www.mql5.com"
- #property version "1.00"
- sinput string str = "<><><><><><> Object Name <><><><><><>";
- input string object_name = "line";
- string trend;
- bool bearish_found = false;
- bool bullish_found = false;
- int index_of_last_high = 0;
- int index_of_last_low = 0;
- double hi;
- double lo;
- int index_of_low = 0;
- int index_of_high = 0;
- int high_index=0;
- double high,low,low1,high1;
- int Store_last_index_of_high = 0;
- int Store_last_index_of_low = 0;
- //int ind = 0;
- bool choch = false;
- //+------------------------------------------------------------------+
- //| Expert initialization function |
- //+------------------------------------------------------------------+
- void foo(int index)
- {
- for(int i=index; i > 0; i--)
- {
- //ind = index;
- if(trend == "uptrend")
- {
- high = iHigh(Symbol(),PERIOD_CURRENT,index);
- high1 = iHigh(Symbol(),PERIOD_CURRENT,i);
- if(high1 > high)
- {
- Store_last_index_of_high = i;
- high = high1;
- int count = (index-1) - i;
- //Print("count",count);
- for(int j=1; j < count; j++)
- {
- if(checkCandle(index-j) == "Bearish")
- {
- low = iLow(Symbol(),PERIOD_CURRENT,index-j);
- bearish_found = true;
- //Print("bearish is found at index ",index-j);
- }
- }
- if(bearish_found == true)
- {
- for(int k=1; k <= count; k++)
- {
- low1 = iLow(Symbol(),PERIOD_CURRENT,index - k);
- if(low1 <= low)
- {
- //Print("here");
- low = low1;
- index_of_low =index- k;
- Print("low update due to 2 condition : ",index- k);
- }
- }
- bearish_found = false;
- }
- Print(" high price is ", high);
- Print("low price is ", low);
- Print("index of last updated low is ", index_of_low);
- Print("index value is re", index);
- Print("ith value is ",i);
- index = i;
- // Print("index is ", i);
- for(int l=index_of_low; l > 0; l--)
- {
- // Print(l);
- // Print("index of low ", index_of_low," to check ", index);
- double close = iClose(Symbol(),PERIOD_CURRENT,l);
- double low3 = iLow(Symbol(),PERIOD_CURRENT,l);
- if(close < low)
- {
- //double price_low = iLow(Symbol(),PERIOD_CURRENT,l+1);
- //datetime time = iTime(Symbol(),PERIOD_CURRENT,l+1);
- //datetime time1 = iTime(Symbol(),PERIOD_CURRENT,l-1);
- ////ObjectCreate(0,"tline1",OBJ_TREND,0,time,price_low,time1,price_low);
- low = iLow(Symbol(),PERIOD_CURRENT,l);
- trend = "downtrend";
- index_of_last_high = Store_last_index_of_high;
- Print("choch at index --------------------------------------------------------------------------------------- ", l);
- choch = true;
- break;
- }
- if(low3 < low)
- {
- low = low3;
- Print("low update due to third condition",low);
- }
- }
- if(choch == true)
- {
- Print("here we are",index_of_last_high+1);
- hi = iHigh(Symbol(),PERIOD_CURRENT,index_of_last_high+1);
- datetime ti = iTime(Symbol(),PERIOD_CURRENT,index_of_last_high+1);
- lo = iLow(Symbol(),PERIOD_CURRENT,index_of_last_high+1);
- Print(" buy and sell high index is ",index_of_last_high+1);
- Print(" high price is ", hi);
- Print(" low price is ", lo);
- ObjectCreate(0,"line111"+iTime(Symbol(),PERIOD_CURRENT,index_of_last_high+1),OBJ_HLINE,0,ti,hi);
- ObjectCreate(0,"line12"+iTime(Symbol(),PERIOD_CURRENT,index_of_last_high+1),OBJ_HLINE,0,ti,lo);
- hi = 0.0;
- lo =0.0;
- choch = false;
- }
- }
- }
- if(trend == "downtrend")
- {
- low = iLow(Symbol(),PERIOD_CURRENT,index);
- low1 = iLow(Symbol(),PERIOD_CURRENT,i);
- if(low1 < low)
- {
- Store_last_index_of_low = i;
- low = low1;
- int count = (index-1) - i;
- //Print("count",count);
- for(int j=1; j < count; j++)
- {
- if(checkCandle(index-j) == "Bullish")
- {
- high = iHigh(Symbol(),PERIOD_CURRENT,index-j);
- bullish_found = true;
- //Print("bearish is found at index ",index-j);
- }
- }
- if(bullish_found == true)
- {
- for(int k=1; k <= count; k++)
- {
- high1 = iHigh(Symbol(),PERIOD_CURRENT,index - k);
- if(high1 >= high)
- {
- //Print("here");
- high = high1;
- index_of_high =index- k;
- Print("high update due to 2 condition : ",index- k);
- }
- }
- bearish_found = false;
- }
- Print(" high price is ", high);
- Print("low price is ", low);
- Print("index of last updated high is ", index_of_high);
- Print("index value is re", index);
- Print("ith value is ",i);
- index = i;
- // Print("index is ", i);
- }
- for(int l=index_of_high; l > 0; l--)
- {
- //Print(l);
- //Print("index of low ", index_of_high," to check ", index);
- double close = iClose(Symbol(),PERIOD_CURRENT,l);
- double high3 = iHigh(Symbol(),PERIOD_CURRENT,l);
- if(close > high)
- {
- //double price_low = iLow(Symbol(),PERIOD_CURRENT,l+1);
- //datetime time = iTime(Symbol(),PERIOD_CURRENT,l+1);
- //datetime time1 = iTime(Symbol(),PERIOD_CURRENT,l-1);
- ////ObjectCreate(0,"tline1",OBJ_TREND,0,time,price_low,time1,price_low);
- high = iHigh(Symbol(),PERIOD_CURRENT,l);
- trend = "uptrend";
- index_of_last_low = Store_last_index_of_low;
- Print("choch at index ", l);
- choch = true;
- break;
- }
- if(high3 > high)
- {
- high = high3;
- Print("high update due to third condition",high);
- }
- }
- if(choch == true)
- {
- hi = iHigh(Symbol(),PERIOD_CURRENT,index_of_last_low+1);
- lo = iLow(Symbol(),PERIOD_CURRENT,index_of_last_low+1);
- Print(" buy and sell high index is ",index_of_last_low+1);
- Print(" high price is ", hi);
- Print(" low price is ", lo);
- hi = 0.0;
- lo =0.0;
- choch = false;
- }
- }
- // if(trend == "downtrend")
- // {
- // low = iLow(Symbol(),PERIOD_CURRENT,index);
- //
- // low1 = iLow(Symbol(),PERIOD_CURRENT,i);
- //
- // if(low1 < low)
- // {
- // Store_last_index_of_low = i;
- //
- // low = low1;
- //
- //
- // int count = (index-1) - i;
- //
- // //Print("count",count);
- //
- // for(int j=1; j < count; j++)
- // {
- //
- // if(checkCandle(index-j) == "Bullish")
- // {
- //
- // high = iHigh(Symbol(),PERIOD_CURRENT,index-j);
- // bullish_found = true;
- //
- // //Print("bearish is found at index ",index-j);
- //
- //
- // }
- //
- // }
- //
- // if(bullish_found == true)
- // {
- //
- // for(int k=1; k < count; k++)
- // {
- //
- // high1 = iHigh(Symbol(),PERIOD_CURRENT,index - k);
- // if(high1 >= high)
- // {
- //
- // high = high1;
- // index_of_high =index- k;
- // Print(" high update due to 2 condition : ",index- k);
- //
- // }
- // }
- // bullish_found = false;
- //
- // }
- //
- // Print(" high price is ", high);
- // Print("low price is ", low);
- //
- // Print("index of last updated high is ", index_of_high);
- //
- //
- //
- // index = i;
- //
- //
- // // Print("index is ", i);
- //
- //
- //
- //
- // }
- //
- //
- // for(int l=index_of_high; l >= index; l--)
- // {
- // // print("hi");
- // double close = iClose(Symbol(),PERIOD_CURRENT,l);
- // double high3 = iHigh(Symbol(),PERIOD_CURRENT,l);
- //
- // if(close > high)
- // {
- //
- // //double price_low = iLow(Symbol(),PERIOD_CURRENT,l+1);
- // //datetime time = iTime(Symbol(),PERIOD_CURRENT,l+1);
- // //datetime time1 = iTime(Symbol(),PERIOD_CURRENT,l-1);
- // ////ObjectCreate(0,"tline1",OBJ_TREND,0,time,price_low,time1,price_low);
- //
- //
- // high = iHigh(Symbol(),PERIOD_CURRENT,l);
- // trend = "uptrend";
- //
- // index_of_last_low = Store_last_index_of_low;
- //
- //
- // choch = true;
- // break;
- //
- // }
- //
- // if(high3 > high)
- // {
- // high = high3;
- // Print("high update due to third condition",high);
- // }
- //
- // }
- //
- // if(choch == true)
- // {
- // hi = iHigh(Symbol(),PERIOD_CURRENT,index_of_last_low+1);
- // lo = iLow(Symbol(),PERIOD_CURRENT,index_of_last_low+1);
- //
- // Print(" buy and sell high index is ",index_of_last_low+1);
- // Print(" high price is ", hi);
- // Print(" low price is ", lo);
- //
- // hi = 0.0;
- // lo =0.0;
- // choch = false;
- // }
- //
- //
- //
- //
- //
- // }
- // if(checkCandle(index) == "Bearish")
- // {
- //
- // trend = "downtrend";
- //
- // // double high,low = 0.0;
- //
- // // to store high and low of the value after the object
- // low = iLow(Symbol(),PERIOD_CURRENT,index);
- //
- // //low = iLow(Symbol(),PERIOD_CURRENT,index-1);
- //
- // if(trend == "downtrend")
- // {
- //
- //
- //
- //
- // low1 = iLow(Symbol(),PERIOD_CURRENT,i);
- //
- // //double low1 = iLow(Symbol(),PERIOD_CURRENT,i);
- //
- // if(low1 < low)
- // {
- // low = low1;
- //
- // // Print("high break at index value",i);
- // // Print("index is ",index);
- //
- // int count = (index-1) - i;
- // Print("count is ", count);
- //
- // // Print("index updated ",index);
- //
- // // Print("count",count);
- //
- // for(int j=1; j <= count; j++)
- // {
- //
- // if(checkCandle(index-j) == "Bullish")
- // {
- // high = iHigh(Symbol(),PERIOD_CURRENT,index-j);
- // bullish_found = true;
- // }
- //
- // }
- //
- // if(bullish_found == true)
- // {
- // high1;
- // //Print("where");
- // for(int k=1; k <= count; k++)
- // {
- //
- // high1 = iHigh(Symbol(),PERIOD_CURRENT,index - k);
- // if(high1 >= high)
- // {
- // //Print("here");
- // high = high1;
- // index_of_high = index - k;
- // Print("high is updated at index : ",index - k);
- //
- // }
- // }
- // bullish_found = false;
- //
- // }
- //
- // Print(" high price is ", high);
- // Print("low price is ", low);
- // Print("index of last updated high is ", index_of_high);
- //
- // for(int l=index_of_high; l > 0; l--)
- // {
- // // print("hi");
- // double close = iClose(Symbol(),PERIOD_CURRENT,l);
- // double high3 = iHigh(Symbol(),PERIOD_CURRENT,l);
- //
- // if(close > high)
- // {
- //
- // double price_high = iLow(Symbol(),PERIOD_CURRENT,l+1);
- // datetime time = iTime(Symbol(),PERIOD_CURRENT,l+1);
- // datetime time1 = iTime(Symbol(),PERIOD_CURRENT,l-1);
- // //ObjectCreate(0,"tline2",OBJ_TREND,0,time,price_high,time1,price_high);
- //
- //
- // trend = "uptrend";
- // Print("choch");
- // Print(l);
- // index_of_last_low = i;
- // Print("close", close);
- // choch = true;
- // break;
- //
- // }
- //
- // if(high3 > high)
- // {
- //
- // double price_high = iLow(Symbol(),PERIOD_CURRENT,l+1);
- // datetime time = iTime(Symbol(),PERIOD_CURRENT,l+1);
- // datetime time1 = iTime(Symbol(),PERIOD_CURRENT,l-1);
- // // ObjectCreate(0,"tline2",OBJ_TREND,0,time,price_high,time1,price_high);
- //
- //
- // trend = "uptrend";
- // Print("choch in condition 3");
- // Print(l);
- // index_of_last_low = i;
- // Print("close", close);
- // choch = true;
- // break;
- //
- // }
- //
- //
- //
- //
- // }
- // if(choch == true)
- // {
- //
- // hi = iHigh(Symbol(),PERIOD_CURRENT,index_of_last_low+1);
- // lo = iLow(Symbol(),PERIOD_CURRENT,index_of_last_low+1);
- //
- // Print(" buy and sell high index is ",index_of_last_low+1);
- // Print(" high price is ", hi);
- // Print(" low price is ", lo);
- //
- // hi = 0.0;
- // lo = 0.0;
- // choch = false;
- // }
- // index = i;
- //
- // }
- //
- // }
- // //
- //
- // }
- }
- }
- //+------------------------------------------------------------------+
- //| |
- //+------------------------------------------------------------------+
- int OnInit()
- {
- //ObjectCreate(0,"line",OBJ_VLINE,0,D'2023.07.01 10:00:27',0);
- object_find(object_name);
- //Print(ObjectFind(0,"line")); // to find the object drawn on the chart
- if(object_find(object_name) == true)
- {
- datetime time_of_candle = (datetime)ObjectGetInteger(0,"line",OBJPROP_TIME,0);
- // Print("line time: ",time_of_candle);
- int index = iBarShift(Symbol(), PERIOD_CURRENT, time_of_candle, false);
- checkCandle(index);
- if(checkCandle(index) == "Bullish")
- {
- trend = "uptrend";
- }
- if(checkCandle(index) == "Bearish")
- {
- trend = "downtrend";
- }
- //Print(index);
- // Print(index);
- // datetime time_of_candle = (datetime)ObjectGetInteger(0,"line",OBJPROP_TIME,0);
- // Print("time is " , time_of_candle);
- //
- // int index = iBarShift(0, PERIOD_CURRENT,time_of_candle, true);
- // Print("index is " , index);
- foo(index);
- }
- else
- {
- Print("Object Not Found");
- }
- return(INIT_SUCCEEDED);
- }
- //+------------------------------------------------------------------+
- //| Expert deinitialization function |
- //+------------------------------------------------------------------+
- void OnDeinit(const int reason)
- {
- //---
- }
- //+------------------------------------------------------------------+
- //| Expert tick function |
- //+------------------------------------------------------------------+
- void OnTick()
- {
- if(NewBar())
- {
- ObjectSetInteger(0,"tline1",OBJPROP_TIME,iTime(Symbol(), PERIOD_CURRENT,0));
- ObjectSetInteger(0,"tline2",OBJPROP_TIME,iTime(Symbol(), PERIOD_CURRENT,0));
- }
- }
- //+------------------------------------------------------------------+
- //| |
- //+------------------------------------------------------------------+
- bool NewBar()
- {
- static datetime Last_bar ;
- datetime Current_bar = iTime(Symbol(), PERIOD_CURRENT,0);
- if(Current_bar != Last_bar)
- {
- Last_bar = Current_bar;
- return (true);
- }
- else
- {
- return (false);
- }
- }
- //+------------------------------------------------------------------+
- //| |
- //+------------------------------------------------------------------+
- bool object_find(string obj) // to find object placed by user in the chart
- {
- if(ObjectFind(0,obj) >= 0)
- {
- return true;
- }
- return false;
- }
- //+------------------------------------------------------------------+
- //| |
- //+------------------------------------------------------------------+
- string checkCandle(int i) // to check the candle is bullish or bearish
- {
- double close = iClose(Symbol(),PERIOD_CURRENT,i);
- double open = iOpen(Symbol(),PERIOD_CURRENT,i);
- if(close > open)
- {
- return "Bullish";
- }
- else
- if(close < open)
- {
- return "Bearish";
- }
- return "empty";
- }
- //+------------------------------------------------------------------+
- //+------------------------------------------------------------------+
|