暫無描述

BOS_CHOCH.mq5 17KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593
  1. //+------------------------------------------------------------------+
  2. //| MK_BOS_CHOCH.mq5 |
  3. //| Copyright 2023, MetaQuotes Ltd. |
  4. //| https://www.mql5.com |
  5. //+------------------------------------------------------------------+
  6. #property copyright "Copyright 2023, MetaQuotes Ltd."
  7. #property link "https://www.mql5.com"
  8. #property version "1.00"
  9. sinput string str = "<><><><><><> Object Name <><><><><><>";
  10. input string object_name = "line";
  11. int ind = 0;
  12. string trend;
  13. bool bearish_found = false;
  14. bool bullish_found = false;
  15. int index_of_last_high = 0;
  16. int index_of_last_low = 0;
  17. double hi;
  18. double lo;
  19. int index_of_low = 0;
  20. int index_of_high = 0;
  21. int high_index=0;
  22. int low_index =0;
  23. double high,low,low1,high1,low2,high2;
  24. int Store_bos_last_index = 0;
  25. //int ind = 0;
  26. bool choch = false;
  27. int index = 0;
  28. int arrow_code_high = 108;
  29. int arrow_code_low = 108;
  30. //+------------------------------------------------------------------+
  31. //| Expert initialization function |
  32. //+------------------------------------------------------------------+
  33. void Bos(int i)
  34. {
  35. if(trend == "uptrend")
  36. {
  37. high = iHigh(Symbol(),PERIOD_CURRENT,high_index);
  38. high1 = iHigh(Symbol(),PERIOD_CURRENT,i);
  39. if(high1 > high)
  40. {
  41. if(object_find("high") > 0)
  42. {
  43. ObjectDelete(0,"high");
  44. }
  45. high = high1;
  46. ObjectCreate(0,"high",OBJ_TREND,0,iTime(Symbol(),PERIOD_CURRENT,i),high,iTime(Symbol(),PERIOD_CURRENT,0),high);
  47. ObjectSetInteger(0,"high",OBJPROP_RAY_RIGHT,true);
  48. ObjectSetInteger(0,"high",OBJPROP_COLOR,clrBlue);
  49. ObjectCreate(0,"line1"+iTime(Symbol(),PERIOD_CURRENT,i),OBJ_TEXT,0,iTime(Symbol(),PERIOD_CURRENT,i),high);
  50. ObjectSetString(0,"line1"+iTime(Symbol(),PERIOD_CURRENT,i), OBJPROP_TEXT,"bos");
  51. Store_bos_last_index = i;
  52. int count = (high_index-1) - i;
  53. for(int j=1; j <= count; j++)
  54. {
  55. if(checkCandle(high_index-j) == "Bearish")
  56. {
  57. low = iLow(Symbol(),PERIOD_CURRENT,high_index-j);
  58. bearish_found = true;
  59. }
  60. }
  61. if(bearish_found == true)
  62. {
  63. for(int k=1; k < count; k++)
  64. {
  65. low1 = iLow(Symbol(),PERIOD_CURRENT,high_index - k);
  66. if(low1 <= low)
  67. {
  68. low = low1;
  69. index_of_low =high_index- k;
  70. }
  71. }
  72. if(object_find("low") > 0)
  73. {
  74. ObjectDelete(0,"low");
  75. }
  76. ObjectCreate(0,"low",OBJ_TREND,0,iTime(Symbol(),PERIOD_CURRENT,index_of_low),low,iTime(Symbol(),PERIOD_CURRENT,0),low);
  77. ObjectSetInteger(0,"low",OBJPROP_RAY_RIGHT,true);
  78. ObjectSetInteger(0,"low",OBJPROP_COLOR,clrRed);
  79. bearish_found = false;
  80. }
  81. high_index = i;
  82. }
  83. }
  84. if(trend == "downtrend")
  85. {
  86. low = iLow(Symbol(),PERIOD_CURRENT,low_index);
  87. low1 = iLow(Symbol(),PERIOD_CURRENT,i);
  88. if(low1 < low)
  89. {
  90. if(object_find("low") > 0)
  91. {
  92. ObjectDelete(0,"low");
  93. }
  94. low = low1;
  95. ObjectCreate(0,"low",OBJ_TREND,0,iTime(Symbol(),PERIOD_CURRENT,i),low,iTime(Symbol(),PERIOD_CURRENT,0),low);
  96. ObjectSetInteger(0,"low",OBJPROP_RAY_RIGHT,true);
  97. ObjectSetInteger(0,"low",OBJPROP_COLOR,clrRed);
  98. ObjectCreate(0,"line2"+iTime(Symbol(),PERIOD_CURRENT,i),OBJ_TEXT,0,iTime(Symbol(),PERIOD_CURRENT,i),low);
  99. ObjectSetString(0,"line2"+iTime(Symbol(),PERIOD_CURRENT,i), OBJPROP_TEXT,"bos");
  100. Store_bos_last_index = i;
  101. int count = (low_index-1) - i;
  102. for(int j=1; j <= count; j++)
  103. {
  104. if(checkCandle(low_index-j) == "Bullish")
  105. {
  106. high = iHigh(Symbol(),PERIOD_CURRENT,low_index-j);
  107. bullish_found = true;
  108. }
  109. }
  110. if(bullish_found == true)
  111. {
  112. for(int k=1; k < count; k++)
  113. {
  114. high1 = iHigh(Symbol(),PERIOD_CURRENT,low_index - k);
  115. if(high1 >= high)
  116. {
  117. high = high1;
  118. index_of_high = low_index - k;
  119. }
  120. }
  121. if(object_find("high") > 0)
  122. {
  123. ObjectDelete(0,"high");
  124. }
  125. ObjectCreate(0,"high",OBJ_TREND,0,iTime(Symbol(),PERIOD_CURRENT,index_of_high),high,iTime(Symbol(),PERIOD_CURRENT,0),high);
  126. ObjectSetInteger(0,"high",OBJPROP_RAY_RIGHT,true);
  127. ObjectSetInteger(0,"high",OBJPROP_COLOR,clrBlue);
  128. bullish_found = false;
  129. }
  130. low_index = i;
  131. }
  132. }
  133. }
  134. //+------------------------------------------------------------------+
  135. //| |
  136. //+------------------------------------------------------------------+
  137. void Entry_Action_1_up(int Store_bos_last_index, int i)
  138. {
  139. for(int j=Store_bos_last_index+1; j < iBars(Symbol(),PERIOD_CURRENT); j++)
  140. {
  141. if(checkCandle(j) == "Bearish")
  142. {
  143. ind = j;
  144. bearish_found = true;
  145. break;
  146. }
  147. }
  148. if(bearish_found == true)
  149. {
  150. ObjectCreate(0,"line10"+iTime(Symbol(),PERIOD_CURRENT,ind),OBJ_TREND,0,iTime(Symbol(),PERIOD_CURRENT,ind),iHigh(Symbol(),PERIOD_CURRENT,ind),iTime(Symbol(),PERIOD_CURRENT,i),iHigh(Symbol(),PERIOD_CURRENT,ind));
  151. ObjectCreate(0,"line11"+iTime(Symbol(),PERIOD_CURRENT,ind),OBJ_TREND,0,iTime(Symbol(),PERIOD_CURRENT,ind),iLow(Symbol(),PERIOD_CURRENT,ind),iTime(Symbol(),PERIOD_CURRENT,i),iLow(Symbol(),PERIOD_CURRENT,ind));
  152. ObjectSetInteger(0,"line10"+iTime(Symbol(),PERIOD_CURRENT,ind),OBJPROP_COLOR,clrBlue);
  153. ObjectSetInteger(0,"line11"+iTime(Symbol(),PERIOD_CURRENT,ind),OBJPROP_COLOR,clrBlue);
  154. ObjectCreate(0,"line12"+iTime(Symbol(),PERIOD_CURRENT,ind),OBJ_TREND,0,iTime(Symbol(),PERIOD_CURRENT,ind),iClose(Symbol(),PERIOD_CURRENT,ind),iTime(Symbol(),PERIOD_CURRENT,i),iClose(Symbol(),PERIOD_CURRENT,ind));
  155. ObjectCreate(0,"line13"+iTime(Symbol(),PERIOD_CURRENT,ind),OBJ_TREND,0,iTime(Symbol(),PERIOD_CURRENT,ind),iOpen(Symbol(),PERIOD_CURRENT,ind),iTime(Symbol(),PERIOD_CURRENT,i),iOpen(Symbol(),PERIOD_CURRENT,ind));
  156. ObjectSetInteger(0,"line12"+iTime(Symbol(),PERIOD_CURRENT,ind),OBJPROP_STYLE,STYLE_DOT);
  157. ObjectSetInteger(0,"line13"+iTime(Symbol(),PERIOD_CURRENT,ind),OBJPROP_STYLE,STYLE_DOT);
  158. bearish_found = false;
  159. }
  160. }
  161. //+------------------------------------------------------------------+
  162. //| |
  163. //+------------------------------------------------------------------+
  164. void Entry_Action_1_down(int Store_bos_last_index, int i,int diff)
  165. {
  166. diff++;
  167. for(int j=Store_bos_last_index+1; j < iBars(Symbol(),PERIOD_CURRENT); j++)
  168. {
  169. if(checkCandle(j) == "Bullish")
  170. {
  171. ind = j;
  172. bullish_found = true;
  173. diff++;
  174. break;
  175. }
  176. }
  177. // Print(diff);
  178. if(bullish_found == true)
  179. {
  180. ObjectCreate(0,"line14"+iTime(Symbol(),PERIOD_CURRENT,ind),OBJ_TREND,0,iTime(Symbol(),PERIOD_CURRENT,ind),iHigh(Symbol(),PERIOD_CURRENT,ind),iTime(Symbol(),PERIOD_CURRENT,i),iHigh(Symbol(),PERIOD_CURRENT,ind));
  181. ObjectCreate(0,"line15"+iTime(Symbol(),PERIOD_CURRENT,ind),OBJ_TREND,0,iTime(Symbol(),PERIOD_CURRENT,ind),iLow(Symbol(),PERIOD_CURRENT,ind),iTime(Symbol(),PERIOD_CURRENT,i),iLow(Symbol(),PERIOD_CURRENT,ind));
  182. ObjectSetInteger(0,"line14"+iTime(Symbol(),PERIOD_CURRENT,ind),OBJPROP_COLOR,clrBlue);
  183. ObjectSetInteger(0,"line15"+iTime(Symbol(),PERIOD_CURRENT,ind),OBJPROP_COLOR,clrBlue);
  184. ObjectCreate(0,"line16"+iTime(Symbol(),PERIOD_CURRENT,ind),OBJ_TREND,0,iTime(Symbol(),PERIOD_CURRENT,ind),iClose(Symbol(),PERIOD_CURRENT,ind),iTime(Symbol(),PERIOD_CURRENT,i),iClose(Symbol(),PERIOD_CURRENT,ind));
  185. ObjectCreate(0,"line17"+iTime(Symbol(),PERIOD_CURRENT,ind),OBJ_TREND,0,iTime(Symbol(),PERIOD_CURRENT,ind),iOpen(Symbol(),PERIOD_CURRENT,ind),iTime(Symbol(),PERIOD_CURRENT,i),iOpen(Symbol(),PERIOD_CURRENT,ind));
  186. ObjectSetInteger(0,"line16"+iTime(Symbol(),PERIOD_CURRENT,ind),OBJPROP_STYLE,STYLE_DOT);
  187. ObjectSetInteger(0,"line17"+iTime(Symbol(),PERIOD_CURRENT,ind),OBJPROP_STYLE,STYLE_DOT);
  188. bullish_found = false;
  189. }
  190. }
  191. //+------------------------------------------------------------------+
  192. //| |
  193. //+------------------------------------------------------------------+
  194. void choch(int i)
  195. {
  196. if(trend == "uptrend")
  197. {
  198. double close = iClose(Symbol(),PERIOD_CURRENT,i);
  199. if(close < low)
  200. {
  201. ObjectCreate(0,"line3"+iTime(Symbol(),PERIOD_CURRENT,i),OBJ_TEXT,0,iTime(Symbol(),PERIOD_CURRENT,i),iLow(Symbol(),PERIOD_CURRENT,i));
  202. ObjectSetString(0,"line3"+iTime(Symbol(),PERIOD_CURRENT,i), OBJPROP_TEXT,"choch");
  203. ObjectCreate(0,"line8"+iTime(Symbol(),PERIOD_CURRENT,i),OBJ_ARROW_DOWN,0,iTime(Symbol(),PERIOD_CURRENT,i),iHigh(Symbol(),PERIOD_CURRENT,i)+100*Point());
  204. ObjectSetInteger(0,"line8"+iTime(Symbol(),PERIOD_CURRENT,i),OBJPROP_COLOR,clrRed);
  205. Print("last bos index is ",Store_bos_last_index);
  206. Entry_Action_1_up(Store_bos_last_index,i);
  207. low = iLow(Symbol(),PERIOD_CURRENT,i);
  208. low_index = i;
  209. if(object_find("low") > 0)
  210. {
  211. ObjectDelete(0,"low");
  212. }
  213. ObjectCreate(0,"low",OBJ_TREND,0,iTime(Symbol(),PERIOD_CURRENT,i),low,iTime(Symbol(),PERIOD_CURRENT,0),low);
  214. ObjectSetInteger(0,"low",OBJPROP_RAY_RIGHT,true);
  215. ObjectSetInteger(0,"low",OBJPROP_COLOR,clrRed);
  216. Print("low update due to choch : ", low);
  217. trend = "downtrend";
  218. Print("choch at uptrend index --- ", iTime(Symbol(),PERIOD_CURRENT,i));
  219. }
  220. }
  221. if(trend == "downtrend")
  222. {
  223. double close = iClose(Symbol(),PERIOD_CURRENT,i);
  224. if(close > high)
  225. {
  226. ObjectCreate(0,"line4"+iTime(Symbol(),PERIOD_CURRENT,i),OBJ_TEXT,0,iTime(Symbol(),PERIOD_CURRENT,i),iHigh(Symbol(),PERIOD_CURRENT,i));
  227. ObjectSetString(0,"line4"+iTime(Symbol(),PERIOD_CURRENT,i), OBJPROP_TEXT,"choch");
  228. ObjectCreate(0,"line7"+iTime(Symbol(),PERIOD_CURRENT,i),OBJ_ARROW_UP,0,iTime(Symbol(),PERIOD_CURRENT,i),iLow(Symbol(),PERIOD_CURRENT,i)-100*Point());
  229. ObjectSetInteger(0,"line7"+iTime(Symbol(),PERIOD_CURRENT,i),OBJPROP_COLOR,clrGreen);
  230. Print("last bos index is ",Store_bos_last_index);
  231. int diff = Store_bos_last_index - i;
  232. Print(diff);
  233. Entry_Action_1_down(Store_bos_last_index,i,diff);
  234. high = iHigh(Symbol(),PERIOD_CURRENT,i);
  235. high_index = i;
  236. if(object_find("high") > 0)
  237. {
  238. ObjectDelete(0,"high");
  239. }
  240. ObjectCreate(0,"high",OBJ_TREND,0,iTime(Symbol(),PERIOD_CURRENT,i),high,iTime(Symbol(),PERIOD_CURRENT,0),high);
  241. ObjectSetInteger(0,"high",OBJPROP_RAY_RIGHT,true);
  242. ObjectSetInteger(0,"high",OBJPROP_COLOR,clrBlue);
  243. trend = "uptrend";
  244. Print("high is update due to choch : ", high);
  245. Print("choch at downtrend index ---- ", iTime(Symbol(),PERIOD_CURRENT,i));
  246. }
  247. }
  248. }
  249. //+------------------------------------------------------------------+
  250. //| |
  251. //+------------------------------------------------------------------+
  252. void third_Condition(int i)
  253. {
  254. if(trend == "uptrend")
  255. {
  256. low2 = iLow(Symbol(),PERIOD_CURRENT,i);
  257. if(low2 < low)
  258. {
  259. ObjectCreate(0,"line5"+iTime(Symbol(),PERIOD_CURRENT,i),OBJ_TEXT,0,iTime(Symbol(),PERIOD_CURRENT,i),iLow(Symbol(),PERIOD_CURRENT,i));
  260. ObjectSetString(0,"line5"+iTime(Symbol(),PERIOD_CURRENT,i), OBJPROP_TEXT,"3_C");
  261. low = low2;
  262. //low_index = i;
  263. if(object_find("low") > 0)
  264. {
  265. Print("object deleted ");
  266. ObjectDelete(0,"low");
  267. }
  268. ObjectCreate(0,"low",OBJ_TREND,0,iTime(Symbol(),PERIOD_CURRENT,i),low,iTime(Symbol(),PERIOD_CURRENT,0),low);
  269. ObjectSetInteger(0,"low",OBJPROP_RAY_RIGHT,true);
  270. ObjectSetInteger(0,"low",OBJPROP_COLOR,clrRed);
  271. Print("low update due to third condition",low," time of the candle is ",iTime(Symbol(),PERIOD_CURRENT,i));
  272. }
  273. }
  274. if(trend == "downtrend")
  275. {
  276. high2 = iHigh(Symbol(),PERIOD_CURRENT,i);
  277. if(high2 > high)
  278. {
  279. ObjectCreate(0,"line6"+iTime(Symbol(),PERIOD_CURRENT,i),OBJ_TEXT,0,iTime(Symbol(),PERIOD_CURRENT,i),iHigh(Symbol(),PERIOD_CURRENT,i));
  280. ObjectSetString(0,"line6"+iTime(Symbol(),PERIOD_CURRENT,i), OBJPROP_TEXT,"3_C");
  281. high = high2;
  282. //high_index = i;
  283. if(object_find("high") > 0)
  284. {
  285. ObjectDelete(0,"high");
  286. }
  287. ObjectCreate(0,"high",OBJ_TREND,0,iTime(Symbol(),PERIOD_CURRENT,i),high,iTime(Symbol(),PERIOD_CURRENT,0),high);
  288. ObjectSetInteger(0,"high",OBJPROP_RAY_RIGHT,true);
  289. ObjectSetInteger(0,"high",OBJPROP_COLOR,clrBlue);
  290. Print("high update due to third condition",high);
  291. }
  292. }
  293. }
  294. //+------------------------------------------------------------------+
  295. //| |
  296. //+------------------------------------------------------------------+
  297. void foo(int value)
  298. {
  299. int l = 0;
  300. for(int i=value-1; i > 0; i--)
  301. {
  302. //Print("hi");
  303. //if(l < 2)
  304. {
  305. Bos(i);
  306. choch(i);
  307. third_Condition(i);
  308. l++;
  309. }
  310. //Bos(i);
  311. }
  312. }
  313. //+------------------------------------------------------------------+
  314. //| |
  315. //+------------------------------------------------------------------+
  316. int OnInit()
  317. {
  318. object_find(object_name);
  319. if(object_find(object_name) == true)
  320. {
  321. datetime time_of_candle = (datetime)ObjectGetInteger(0,"line",OBJPROP_TIME,0);
  322. index = iBarShift(Symbol(), PERIOD_CURRENT, time_of_candle, false);
  323. checkCandle(index);
  324. if(checkCandle(index) == "Bullish")
  325. {
  326. trend = "uptrend";
  327. }
  328. if(checkCandle(index) == "Bearish")
  329. {
  330. trend = "downtrend";
  331. }
  332. high = iHigh(Symbol(),PERIOD_CURRENT,index);
  333. low = iLow(Symbol(),PERIOD_CURRENT,index);
  334. high_index = index;
  335. low_index = index;
  336. foo(index);
  337. }
  338. else
  339. {
  340. Print("Object Not Found");
  341. }
  342. return(INIT_SUCCEEDED);
  343. }
  344. //+------------------------------------------------------------------+
  345. //| Expert deinitialization function |
  346. //+------------------------------------------------------------------+
  347. void OnDeinit(const int reason)
  348. {
  349. //---
  350. }
  351. //+------------------------------------------------------------------+
  352. //| Expert tick function |
  353. //+------------------------------------------------------------------+
  354. void OnTick()
  355. {
  356. }
  357. //+------------------------------------------------------------------+
  358. //| |
  359. //+------------------------------------------------------------------+
  360. bool NewBar()
  361. {
  362. static datetime Last_bar ;
  363. datetime Current_bar = iTime(Symbol(), PERIOD_CURRENT,0);
  364. if(Current_bar != Last_bar)
  365. {
  366. Last_bar = Current_bar;
  367. return (true);
  368. }
  369. else
  370. {
  371. return (false);
  372. }
  373. }
  374. //+------------------------------------------------------------------+
  375. //| |
  376. //+------------------------------------------------------------------+
  377. bool object_find(string obj) // to find object placed by user in the chart
  378. {
  379. if(ObjectFind(0,obj) >= 0)
  380. {
  381. return true;
  382. }
  383. return false;
  384. }
  385. //+------------------------------------------------------------------+
  386. //| |
  387. //+------------------------------------------------------------------+
  388. string checkCandle(int i) // to check the candle is bullish or bearish
  389. {
  390. double close = iClose(Symbol(),PERIOD_CURRENT,i);
  391. double open = iOpen(Symbol(),PERIOD_CURRENT,i);
  392. if(close > open)
  393. {
  394. return "Bullish";
  395. }
  396. else
  397. if(close < open)
  398. {
  399. return "Bearish";
  400. }
  401. return "empty";
  402. }
  403. //+------------------------------------------------------------------+
  404. //+------------------------------------------------------------------+