Distribution Of Returns Indicator
Forums › ProRealTime English forum › ProBuilder support › Distribution Of Returns Indicator
- This topic has 19 replies, 6 voices, and was last updated 5 years ago by Vonasi.
-
-
05/21/2019 at 3:01 PM #99021
After reading this:
https://www.managedfuturesinvesting.com/analyzing-a-ctas-daily-returns-part-1/
I decided to try to code a distribution of returns indicator. I post it here in case it of any use to anyone.
The indicator checks all the candles between the latest one and whatever start date you set (or all candles if you set StartDate to zero) and calculates the rate of return from close to close of each candle. It then counts how many candles fit into each specific range (in buckets of 0.25%) from -5% return to +5% return and displays it as a bar chart.
The values above the bars represent the (rounded) percentage of candles whose return fell into that specific range.
The values below the chart indicates rate of return. Each bar represents a 0.25% range of return (so 0.0% to 0.25% then 0.25% to 0.5% and so on). The bars at either end of the chart represent returns greater than 5% and returns lower than -5%.
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357//Distribution Of Returns Indicator//Coded by Vonasi//Date 20190221defparam drawonlastbaronly = true//startdate = 20170101 //Set to zero to analyse all dates.if opendate >= startdate or startdate = 0 thendailyreturn = ((close[1] - close) / close[1]) * 100if dailyreturn >= 0 and dailyreturn < 0.25 thendr025 = dr025 + 1endifif dailyreturn >= 0.25 and dailyreturn < 0.50 thendr050 = dr050 + 1endifif dailyreturn >= 0.50 and dailyreturn < 0.75 thendr075 = dr075 + 1endifif dailyreturn >= 0.75 and dailyreturn < 1.00 thendr100 = dr100 + 1endifif dailyreturn >= 1 and dailyreturn < 1.25 thendr125 = dr125 + 1endifif dailyreturn >= 1.25 and dailyreturn < 1.50 thendr150 = dr150 + 1endifif dailyreturn >= 1.55 and dailyreturn < 1.75 thendr175 = dr175 + 1endifif dailyreturn >= 1.75 and dailyreturn < 2.00 thendr200 = dr200 + 1endifif dailyreturn >= 2.00 and dailyreturn < 2.25 thendr225 = dr225 + 1endifif dailyreturn >= 2.25 and dailyreturn < 2.50 thendr250 = dr250 + 1endifif dailyreturn >= 2.50 and dailyreturn < 2.75 thendr275 = dr275 + 1endifif dailyreturn >= 2.75 and dailyreturn < 3.00 thendr300 = dr300 + 1endifif dailyreturn >= 3.00 and dailyreturn < 3.25 thendr325 = dr325 + 1endifif dailyreturn >= 3.25 and dailyreturn < 3.50 thendr350 = dr350 + 1endifif dailyreturn >= 3.50 and dailyreturn < 3.75 thendr375 = dr375 + 1endifif dailyreturn >= 3.75 and dailyreturn < 4.00 thendr400 = dr400 + 1endifif dailyreturn >= 4.00 and dailyreturn < 4.25 thendr425 = dr425 + 1endifif dailyreturn >= 4.25 and dailyreturn < 4.50 thendr450 = dr450 + 1endifif dailyreturn >= 4.50 and dailyreturn < 4.75 thendr475 = dr475 + 1endifif dailyreturn >= 4.75 and dailyreturn < 5.00 thendr500 = dr500 + 1endifif dailyreturn >= 5.00 thendr525 = dr525 + 1endifif dailyreturn < 0 and dailyreturn > -0.25 thendr025n = dr025n + 1endifif dailyreturn <= -0.25 and dailyreturn > -0.50 thendr050n = dr050n + 1endifif dailyreturn <= -0.50 and dailyreturn > -0.75 thendr075n = dr075n + 1endifif dailyreturn <= -0.75 and dailyreturn > -1.00 thendr100n = dr100n + 1endifif dailyreturn <= -1 and dailyreturn > -1.25 thendr125n = dr125n + 1endifif dailyreturn <= -1.25 and dailyreturn > -1.50 thendr150n = dr150n + 1endifif dailyreturn <= -1.55 and dailyreturn > -1.75 thendr175n = dr175n + 1endifif dailyreturn <= -1.75 and dailyreturn > -2.00 thendr200n = dr200n + 1endifif dailyreturn <= -2.00 and dailyreturn > -2.25 thendr225n = dr225n + 1endifif dailyreturn <= -2.25 and dailyreturn > -2.50 thendr250n = dr250n + 1endifif dailyreturn <= -2.50 and dailyreturn > -2.75 thendr275n = dr275n + 1endifif dailyreturn <= -2.75 and dailyreturn > -3.00 thendr300n = dr300n + 1endifif dailyreturn <= -3.00 and dailyreturn > -3.25 thendr325n = dr325n + 1endifif dailyreturn <= -3.25 and dailyreturn > -3.50 thendr350n = dr350n + 1endifif dailyreturn <= -2.50 and dailyreturn > -2.75 thendr275n = dr275n + 1endifif dailyreturn <= -2.75 and dailyreturn > -3.00 thendr300n = dr300n + 1endifif dailyreturn <= -3.00 and dailyreturn > 3.25 thendr325n = dr325n + 1endifif dailyreturn <= -3.25 and dailyreturn > -3.75 thendr375n = dr375n + 1endifif dailyreturn <= -3.75 and dailyreturn > -4.00 thendr400n = dr400n + 1endifif dailyreturn <= -4.00 and dailyreturn > -4.25 thendr425n = dr425n + 1endifif dailyreturn <= -4.25 and dailyreturn > -4.50 thendr450n = dr450n + 1endifif dailyreturn <= -4.50 and dailyreturn > -4.75 thendr475n = dr475n + 1endifif dailyreturn <= -4.75 and dailyreturn > -5.00 thendr500n = dr500n + 1endifif dailyreturn <= -5.00 thendr525n = dr525n + 1endiftotal = total + 1upperline = max(dr025,dr025n) * 1.02lowerline = 0 - (upperline * 0.02)endifdr525perc = round((dr525 / total) * 100)dr500perc = round((dr500 / total) * 100)dr475perc = round((dr475 / total) * 100)dr450perc = round((dr450 / total) * 100)dr425perc = round((dr425 / total) * 100)dr400perc = round((dr400 / total) * 100)dr375perc = round((dr375 / total) * 100)dr350perc = round((dr350 / total) * 100)dr325perc = round((dr325 / total) * 100)dr300perc = round((dr300 / total) * 100)dr275perc = round((dr275 / total) * 100)dr250perc = round((dr250 / total) * 100)dr225perc = round((dr225 / total) * 100)dr200perc = round((dr200 / total) * 100)dr175perc = round((dr175 / total) * 100)dr150perc = round((dr150 / total) * 100)dr125perc = round((dr125 / total) * 100)dr100perc = round((dr100 / total) * 100)dr075perc = round((dr075 / total) * 100)dr050perc = round((dr050 / total) * 100)dr025perc = round((dr025 / total) * 100)dr525nperc = round((dr525n / total) * 100)dr500nperc = round((dr500n / total) * 100)dr475nperc = round((dr475n / total) * 100)dr450nperc = round((dr450n / total) * 100)dr425nperc = round((dr425n / total) * 100)dr400nperc = round((dr400n / total) * 100)dr375nperc = round((dr375n / total) * 100)dr350nperc = round((dr350n / total) * 100)dr325nperc = round((dr325n / total) * 100)dr300nperc = round((dr300n / total) * 100)dr275nperc = round((dr275n / total) * 100)dr250nperc = round((dr250n / total) * 100)dr225nperc = round((dr225n / total) * 100)dr200nperc = round((dr200n / total) * 100)dr175nperc = round((dr175n / total) * 100)dr150nperc = round((dr150n / total) * 100)dr125nperc = round((dr125n / total) * 100)dr100nperc = round((dr100n / total) * 100)dr075nperc = round((dr075n / total) * 100)dr050nperc = round((dr050n / total) * 100)dr025nperc = round((dr025n / total) * 100)dr025nperc = round((dr025n / total) * 100)drawrectangle(barindex-1,0,barindex,dr525) coloured(0,0,255)drawrectangle(barindex-2,0,barindex-1,dr500) coloured(0,0,255)drawrectangle(barindex-3,0,barindex-2,dr475) coloured(0,0,255)drawrectangle(barindex-4,0,barindex-3,dr450) coloured(0,0,255)drawrectangle(barindex-5,0,barindex-4,dr425) coloured(0,0,255)drawrectangle(barindex-6,0,barindex-5,dr400) coloured(0,0,255)drawrectangle(barindex-7,0,barindex-6,dr375) coloured(0,0,255)drawrectangle(barindex-8,0,barindex-7,dr350) coloured(0,0,255)drawrectangle(barindex-9,0,barindex-8,dr325) coloured(0,0,255)drawrectangle(barindex-10,0,barindex-9,dr300) coloured(0,0,255)drawrectangle(barindex-11,0,barindex-10,dr275) coloured(0,0,255)drawrectangle(barindex-12,0,barindex-11,dr250) coloured(0,0,255)drawrectangle(barindex-13,0,barindex-12,dr225) coloured(0,0,255)drawrectangle(barindex-14,0,barindex-13,dr200) coloured(0,0,255)drawrectangle(barindex-15,0,barindex-14,dr175) coloured(0,0,255)drawrectangle(barindex-16,0,barindex-15,dr150) coloured(0,0,255)drawrectangle(barindex-17,0,barindex-16,dr125) coloured(0,0,255)drawrectangle(barindex-18,0,barindex-17,dr100) coloured(0,0,255)drawrectangle(barindex-19,0,barindex-18,dr075) coloured(0,0,255)drawrectangle(barindex-20,0,barindex-19,dr050) coloured(0,0,255)drawrectangle(barindex-21,0,barindex-20,dr025) coloured(0,0,255)drawrectangle(barindex-22,0,barindex-21,dr025n) coloured(0,0,255)drawrectangle(barindex-23,0,barindex-22,dr050n) coloured(0,0,255)drawrectangle(barindex-24,0,barindex-23,dr075n) coloured(0,0,255)drawrectangle(barindex-25,0,barindex-24,dr100n) coloured(0,0,255)drawrectangle(barindex-26,0,barindex-25,dr125n) coloured(0,0,255)drawrectangle(barindex-27,0,barindex-26,dr150n) coloured(0,0,255)drawrectangle(barindex-28,0,barindex-27,dr175n) coloured(0,0,255)drawrectangle(barindex-29,0,barindex-28,dr200n) coloured(0,0,255)drawrectangle(barindex-30,0,barindex-29,dr225n) coloured(0,0,255)drawrectangle(barindex-31,0,barindex-30,dr250n) coloured(0,0,255)drawrectangle(barindex-32,0,barindex-31,dr275n) coloured(0,0,255)drawrectangle(barindex-33,0,barindex-32,dr300n) coloured(0,0,255)drawrectangle(barindex-34,0,barindex-33,dr325n) coloured(0,0,255)drawrectangle(barindex-35,0,barindex-34,dr350n) coloured(0,0,255)drawrectangle(barindex-36,0,barindex-35,dr375n) coloured(0,0,255)drawrectangle(barindex-37,0,barindex-36,dr400n) coloured(0,0,255)drawrectangle(barindex-38,0,barindex-37,dr425n) coloured(0,0,255)drawrectangle(barindex-39,0,barindex-38,dr450n) coloured(0,0,255)drawrectangle(barindex-40,0,barindex-39,dr475n) coloured(0,0,255)drawrectangle(barindex-41,0,barindex-40,dr500n) coloured(0,0,255)drawrectangle(barindex-42,0,barindex-41,dr525n) coloured(0,0,255)drawtext("#dr525perc# ",barindex,upperline) coloured(255,0,0)drawtext("#dr500perc# ",barindex-1,upperline) coloured(255,0,0)drawtext("#dr475perc# ",barindex-2,upperline) coloured(255,0,0)drawtext("#dr450perc# ",barindex-3,upperline) coloured(255,0,0)drawtext("#dr425perc# ",barindex-4,upperline) coloured(255,0,0)drawtext("#dr400perc# ",barindex-5,upperline) coloured(255,0,0)drawtext("#dr375perc# ",barindex-6,upperline) coloured(255,0,0)drawtext("#dr350perc# ",barindex-7,upperline) coloured(255,0,0)drawtext("#dr325perc# ",barindex-8,upperline) coloured(255,0,0)drawtext("#dr300perc# ",barindex-9,upperline) coloured(255,0,0)drawtext("#dr275perc# ",barindex-10,upperline) coloured(255,0,0)drawtext("#dr250perc# ",barindex-11,upperline) coloured(255,0,0)drawtext("#dr225perc# ",barindex-12,upperline) coloured(255,0,0)drawtext("#dr200perc# ",barindex-13,upperline) coloured(255,0,0)drawtext("#dr175perc# ",barindex-14,upperline) coloured(255,0,0)drawtext("#dr150perc# ",barindex-15,upperline) coloured(255,0,0)drawtext("#dr125perc# ",barindex-16,upperline) coloured(255,0,0)drawtext("#dr100perc# ",barindex-17,upperline) coloured(255,0,0)drawtext("#dr075perc# ",barindex-18,upperline) coloured(255,0,0)drawtext("#dr050perc# ",barindex-19,upperline) coloured(255,0,0)drawtext("#dr025perc# ",barindex-20,upperline) coloured(255,0,0)drawtext("#dr525nperc# ",barindex-41,upperline) coloured(255,0,0)drawtext("#dr500nperc# ",barindex-40,upperline) coloured(255,0,0)drawtext("#dr475nperc# ",barindex-39,upperline) coloured(255,0,0)drawtext("#dr450nperc# ",barindex-38,upperline) coloured(255,0,0)drawtext("#dr425nperc# ",barindex-37,upperline) coloured(255,0,0)drawtext("#dr400nperc# ",barindex-36,upperline) coloured(255,0,0)drawtext("#dr375nperc# ",barindex-35,upperline) coloured(255,0,0)drawtext("#dr350nperc# ",barindex-34,upperline) coloured(255,0,0)drawtext("#dr325nperc# ",barindex-33,upperline) coloured(255,0,0)drawtext("#dr300nperc# ",barindex-32,upperline) coloured(255,0,0)drawtext("#dr275nperc# ",barindex-31,upperline) coloured(255,0,0)drawtext("#dr250nperc# ",barindex-30,upperline) coloured(255,0,0)drawtext("#dr225nperc# ",barindex-29,upperline) coloured(255,0,0)drawtext("#dr200nperc# ",barindex-28,upperline) coloured(255,0,0)drawtext("#dr175nperc# ",barindex-27,upperline) coloured(255,0,0)drawtext("#dr150nperc# ",barindex-26,upperline) coloured(255,0,0)drawtext("#dr125nperc# ",barindex-25,upperline) coloured(255,0,0)drawtext("#dr100nperc# ",barindex-24,upperline) coloured(255,0,0)drawtext("#dr075nperc# ",barindex-23,upperline) coloured(255,0,0)drawtext("#dr050nperc# ",barindex-22,upperline) coloured(255,0,0)drawtext("#dr025nperc# ",barindex-21,upperline) coloured(255,0,0)drawtext("5.0%",barindex-1,lowerline) coloured(255,0,0)drawtext("4.5%",barindex-3,lowerline) coloured(255,0,0)drawtext("4.0%",barindex-5,lowerline) coloured(255,0,0)drawtext("3.5%",barindex-7,lowerline) coloured(255,0,0)drawtext("3.0%",barindex-9,lowerline) coloured(255,0,0)drawtext("2.5%",barindex-11,lowerline) coloured(255,0,0)drawtext("2.0%",barindex-13,lowerline) coloured(255,0,0)drawtext("1.5%",barindex-15,lowerline) coloured(255,0,0)drawtext("1.0%",barindex-17,lowerline) coloured(255,0,0)drawtext("0.5%",barindex-19,lowerline) coloured(255,0,0)drawtext("-5.0%",barindex-41,lowerline) coloured(255,0,0)drawtext("-4.5%",barindex-39,lowerline) coloured(255,0,0)drawtext("-4.0%",barindex-37,lowerline) coloured(255,0,0)drawtext("-3.5%",barindex-35,lowerline) coloured(255,0,0)drawtext("-3.0%",barindex-33,lowerline) coloured(255,0,0)drawtext("-2.5%",barindex-31,lowerline) coloured(255,0,0)drawtext("-2.0%",barindex-29,lowerline) coloured(255,0,0)drawtext("-1.5%",barindex-27,lowerline) coloured(255,0,0)drawtext("-1.0%",barindex-25,lowerline) coloured(255,0,0)drawtext("-0.5%",barindex-23,lowerline) coloured(255,0,0)drawtext("%",barindex-42,upperline) coloured(255,0,0)drawsegment(barindex-21,lowerline-25,barindex-21,upperline+25)COLOURED(0,0,0)return upperline*1.05 coloured(0,0,0,0) as "-", -25 coloured(0,0,0,0) as "-"05/21/2019 at 4:34 PM #9904905/21/2019 at 7:05 PM #99072I have a few ideas to add to it like maybe an indication of where current price is on the bell curve. If I manage to find time to develop it a bit further and it looks useful then I will post it to the library.
1 user thanked author for this post.
05/21/2019 at 10:13 PM #99088I really shouldn’t rush to post stuff! In the process of trying to improve this indicator I spotted a major flaw in the calculation of returns and a mass of typos due to cut and paste. Please ignore the previously posted code and ITF file as it is pants!
Here is a new and improved (correct I hope) version with not only the corrections but it also draws an arrow to show in which bucket the latest bar on the charts return is on the chart.
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481//Distribution Of Returns Indicator v1.1//Coded by Vonasi//Date 20190221defparam drawonlastbaronly = true//startdate = 20170101 //Set to zero to analyse all dates.if opendate >= startdate or startdate = 0 thendailyreturn = ((close - close[1]) / close[1]) * 100t = 0if dailyreturn >= 0 and dailyreturn < 0.25 thendr025 = dr025 + 1x = barindex - 20y = dr025t = 1endifif dailyreturn >= 0.25 and dailyreturn < 0.50 thendr050 = dr050 + 1x = barindex - 19y = dr050t = 1endifif dailyreturn >= 0.50 and dailyreturn < 0.75 thendr075 = dr075 + 1x = barindex - 18y = dr075t = 1endifif dailyreturn >= 0.75 and dailyreturn < 1.00 thendr100 = dr100 + 1x = barindex - 17y = dr100t = 1endifif dailyreturn >= 1 and dailyreturn < 1.25 thendr125 = dr125 + 1x = barindex - 16y = dr125t = 1endifif dailyreturn >= 1.25 and dailyreturn < 1.50 thendr150 = dr150 + 1x = barindex - 15y = dr150t = 1endifif dailyreturn >= 1.50 and dailyreturn < 1.75 thendr175 = dr175 + 1x = barindex - 14y = dr175t = 1endifif dailyreturn >= 1.75 and dailyreturn < 2.00 thendr200 = dr200 + 1x = barindex - 13y = dr200t = 1endifif dailyreturn >= 2.00 and dailyreturn < 2.25 thendr225 = dr225 + 1x = barindex - 12y = dr225t = 1endifif dailyreturn >= 2.25 and dailyreturn < 2.50 thendr250 = dr250 + 1x = barindex - 11y = dr250t = 1endifif dailyreturn >= 2.50 and dailyreturn < 2.75 thendr275 = dr275 + 1x = barindex - 10y = dr275t = 1endifif dailyreturn >= 2.75 and dailyreturn < 3.00 thendr300 = dr300 + 1x = barindex - 9y = dr300t = 1endifif dailyreturn >= 3.00 and dailyreturn < 3.25 thendr325 = dr325 + 1x = barindex - 8y = dr325t = 1endifif dailyreturn >= 3.25 and dailyreturn < 3.50 thendr350 = dr350 + 1x = barindex - 7y = dr350t = 1endifif dailyreturn >= 3.50 and dailyreturn < 3.75 thendr375 = dr375 + 1x = barindex - 6y = dr375t = 1endifif dailyreturn >= 3.75 and dailyreturn < 4.00 thendr400 = dr400 + 1x = barindex - 5y = dr400t = 1endifif dailyreturn >= 4.00 and dailyreturn < 4.25 thendr425 = dr425 + 1x = barindex - 4y = dr425t = 1endifif dailyreturn >= 4.25 and dailyreturn < 4.50 thendr450 = dr450 + 1x = barindex - 3y = dr450t = 1endifif dailyreturn >= 4.50 and dailyreturn < 4.75 thendr475 = dr475 + 1x = barindex - 2y = dr475t = 1endifif dailyreturn >= 4.75 and dailyreturn < 5.00 thendr500 = dr500 + 1x = barindex - 1y = dr500t = 1endifif dailyreturn >= 5.00 thendr525 = dr525 + 1x = barindexy = dr525t = 1endifif dailyreturn < 0 and dailyreturn > -0.25 thendr025n = dr025n + 1x = barindex - 22y = dr025nt = -1endifif dailyreturn <= -0.25 and dailyreturn > -0.50 thendr050n = dr050n + 1x = barindex - 23y = dr050nt = -1endifif dailyreturn <= -0.50 and dailyreturn > -0.75 thendr075n = dr075n + 1x = barindex - 24y = dr075nt = -1endifif dailyreturn <= -0.75 and dailyreturn > -1.00 thendr100n = dr100n + 1x = barindex - 25y = dr100nt = -1endifif dailyreturn <= -1.00 and dailyreturn > -1.25 thendr125n = dr125n + 1x = barindex - 26y = dr125t = -1endifif dailyreturn <= -1.25 and dailyreturn > -1.50 thendr150n = dr150n + 1x = barindex - 27y = dr150nt = -1endifif dailyreturn <= -1.50 and dailyreturn > -1.75 thendr175n = dr175n + 1x = barindex - 28y = dr175nt = -1endifif dailyreturn <= -1.75 and dailyreturn > -2.00 thendr200n = dr200n + 1x = barindex - 29y = dr200nt = -1endifif dailyreturn <= -2.00 and dailyreturn > -2.25 thendr225n = dr225n + 1x = barindex - 30y = dr225nt = -1endifif dailyreturn <= -2.25 and dailyreturn > -2.50 thendr250n = dr250n + 1x = barindex - 31y = dr250nt = -1endifif dailyreturn <= -2.50 and dailyreturn > -2.75 thendr275n = dr275n + 1x = barindex - 32y = dr275nt = -1endifif dailyreturn <= -2.75 and dailyreturn > -3.00 thendr300n = dr300n + 1x = barindex - 33y = dr300nt = -1endifif dailyreturn <= -3.00 and dailyreturn > -3.25 thendr325n = dr325n + 1x = barindex - 34y = dr325nt = -1endifif dailyreturn <= -3.25 and dailyreturn > -3.50 thendr350n = dr350n + 1x = barindex - 35y = dr350nt = -1endifif dailyreturn <= -3.50 and dailyreturn > -3.75 thendr375n = dr375n + 1x = barindex - 36y = dr375nt = -1endifif dailyreturn <= -3.75 and dailyreturn > -4.00 thendr400n = dr400n + 1x = barindex - 37y = dr400nt = -1endifif dailyreturn <= -4.00 and dailyreturn > -4.25 thendr425n = dr425n + 1x = barindex - 38y = dr425nt = -1endifif dailyreturn <= -4.25 and dailyreturn > -4.50 thendr450n = dr450n + 1x = barindex - 39y = dr450nt = -1endifif dailyreturn <= -4.50 and dailyreturn > -4.75 thendr475n = dr475n + 1x = barindex - 40y = dr475nt = -1endifif dailyreturn <= -4.75 and dailyreturn > -5.00 thendr500n = dr500n + 1x = barindex - 41y = dr500nt = -1endifif dailyreturn <= -5.00 thendr525n = dr525n + 1x = barindex - 42y = dr525nt = -1endiftotal = total + 1upperline = max(dr025,dr025n) * 1.02lowerline = 0 - (upperline * 0.02)endifdr525perc = round((dr525 / total) * 100)dr500perc = round((dr500 / total) * 100)dr475perc = round((dr475 / total) * 100)dr450perc = round((dr450 / total) * 100)dr425perc = round((dr425 / total) * 100)dr400perc = round((dr400 / total) * 100)dr375perc = round((dr375 / total) * 100)dr350perc = round((dr350 / total) * 100)dr325perc = round((dr325 / total) * 100)dr300perc = round((dr300 / total) * 100)dr275perc = round((dr275 / total) * 100)dr250perc = round((dr250 / total) * 100)dr225perc = round((dr225 / total) * 100)dr200perc = round((dr200 / total) * 100)dr175perc = round((dr175 / total) * 100)dr150perc = round((dr150 / total) * 100)dr125perc = round((dr125 / total) * 100)dr100perc = round((dr100 / total) * 100)dr075perc = round((dr075 / total) * 100)dr050perc = round((dr050 / total) * 100)dr025perc = round((dr025 / total) * 100)dr525nperc = round((dr525n / total) * 100)dr500nperc = round((dr500n / total) * 100)dr475nperc = round((dr475n / total) * 100)dr450nperc = round((dr450n / total) * 100)dr425nperc = round((dr425n / total) * 100)dr400nperc = round((dr400n / total) * 100)dr375nperc = round((dr375n / total) * 100)dr350nperc = round((dr350n / total) * 100)dr325nperc = round((dr325n / total) * 100)dr300nperc = round((dr300n / total) * 100)dr275nperc = round((dr275n / total) * 100)dr250nperc = round((dr250n / total) * 100)dr225nperc = round((dr225n / total) * 100)dr200nperc = round((dr200n / total) * 100)dr175nperc = round((dr175n / total) * 100)dr150nperc = round((dr150n / total) * 100)dr125nperc = round((dr125n / total) * 100)dr100nperc = round((dr100n / total) * 100)dr075nperc = round((dr075n / total) * 100)dr050nperc = round((dr050n / total) * 100)dr025nperc = round((dr025n / total) * 100)dr025nperc = round((dr025n / total) * 100)drawrectangle(barindex-1,0,barindex,dr525) coloured(0,0,255)drawrectangle(barindex-2,0,barindex-1,dr500) coloured(0,0,255)drawrectangle(barindex-3,0,barindex-2,dr475) coloured(0,0,255)drawrectangle(barindex-4,0,barindex-3,dr450) coloured(0,0,255)drawrectangle(barindex-5,0,barindex-4,dr425) coloured(0,0,255)drawrectangle(barindex-6,0,barindex-5,dr400) coloured(0,0,255)drawrectangle(barindex-7,0,barindex-6,dr375) coloured(0,0,255)drawrectangle(barindex-8,0,barindex-7,dr350) coloured(0,0,255)drawrectangle(barindex-9,0,barindex-8,dr325) coloured(0,0,255)drawrectangle(barindex-10,0,barindex-9,dr300) coloured(0,0,255)drawrectangle(barindex-11,0,barindex-10,dr275) coloured(0,0,255)drawrectangle(barindex-12,0,barindex-11,dr250) coloured(0,0,255)drawrectangle(barindex-13,0,barindex-12,dr225) coloured(0,0,255)drawrectangle(barindex-14,0,barindex-13,dr200) coloured(0,0,255)drawrectangle(barindex-15,0,barindex-14,dr175) coloured(0,0,255)drawrectangle(barindex-16,0,barindex-15,dr150) coloured(0,0,255)drawrectangle(barindex-17,0,barindex-16,dr125) coloured(0,0,255)drawrectangle(barindex-18,0,barindex-17,dr100) coloured(0,0,255)drawrectangle(barindex-19,0,barindex-18,dr075) coloured(0,0,255)drawrectangle(barindex-20,0,barindex-19,dr050) coloured(0,0,255)drawrectangle(barindex-21,0,barindex-20,dr025) coloured(0,0,255)drawrectangle(barindex-22,0,barindex-21,dr025n) coloured(0,0,255)drawrectangle(barindex-23,0,barindex-22,dr050n) coloured(0,0,255)drawrectangle(barindex-24,0,barindex-23,dr075n) coloured(0,0,255)drawrectangle(barindex-25,0,barindex-24,dr100n) coloured(0,0,255)drawrectangle(barindex-26,0,barindex-25,dr125n) coloured(0,0,255)drawrectangle(barindex-27,0,barindex-26,dr150n) coloured(0,0,255)drawrectangle(barindex-28,0,barindex-27,dr175n) coloured(0,0,255)drawrectangle(barindex-29,0,barindex-28,dr200n) coloured(0,0,255)drawrectangle(barindex-30,0,barindex-29,dr225n) coloured(0,0,255)drawrectangle(barindex-31,0,barindex-30,dr250n) coloured(0,0,255)drawrectangle(barindex-32,0,barindex-31,dr275n) coloured(0,0,255)drawrectangle(barindex-33,0,barindex-32,dr300n) coloured(0,0,255)drawrectangle(barindex-34,0,barindex-33,dr325n) coloured(0,0,255)drawrectangle(barindex-35,0,barindex-34,dr350n) coloured(0,0,255)drawrectangle(barindex-36,0,barindex-35,dr375n) coloured(0,0,255)drawrectangle(barindex-37,0,barindex-36,dr400n) coloured(0,0,255)drawrectangle(barindex-38,0,barindex-37,dr425n) coloured(0,0,255)drawrectangle(barindex-39,0,barindex-38,dr450n) coloured(0,0,255)drawrectangle(barindex-40,0,barindex-39,dr475n) coloured(0,0,255)drawrectangle(barindex-41,0,barindex-40,dr500n) coloured(0,0,255)drawrectangle(barindex-42,0,barindex-41,dr525n) coloured(0,0,255)drawtext("#dr525perc# ",barindex,upperline) coloured(255,0,0)drawtext("#dr500perc# ",barindex-1,upperline) coloured(255,0,0)drawtext("#dr475perc# ",barindex-2,upperline) coloured(255,0,0)drawtext("#dr450perc# ",barindex-3,upperline) coloured(255,0,0)drawtext("#dr425perc# ",barindex-4,upperline) coloured(255,0,0)drawtext("#dr400perc# ",barindex-5,upperline) coloured(255,0,0)drawtext("#dr375perc# ",barindex-6,upperline) coloured(255,0,0)drawtext("#dr350perc# ",barindex-7,upperline) coloured(255,0,0)drawtext("#dr325perc# ",barindex-8,upperline) coloured(255,0,0)drawtext("#dr300perc# ",barindex-9,upperline) coloured(255,0,0)drawtext("#dr275perc# ",barindex-10,upperline) coloured(255,0,0)drawtext("#dr250perc# ",barindex-11,upperline) coloured(255,0,0)drawtext("#dr225perc# ",barindex-12,upperline) coloured(255,0,0)drawtext("#dr200perc# ",barindex-13,upperline) coloured(255,0,0)drawtext("#dr175perc# ",barindex-14,upperline) coloured(255,0,0)drawtext("#dr150perc# ",barindex-15,upperline) coloured(255,0,0)drawtext("#dr125perc# ",barindex-16,upperline) coloured(255,0,0)drawtext("#dr100perc# ",barindex-17,upperline) coloured(255,0,0)drawtext("#dr075perc# ",barindex-18,upperline) coloured(255,0,0)drawtext("#dr050perc# ",barindex-19,upperline) coloured(255,0,0)drawtext("#dr025perc# ",barindex-20,upperline) coloured(255,0,0)drawtext("#dr525nperc# ",barindex-41,upperline) coloured(255,0,0)drawtext("#dr500nperc# ",barindex-40,upperline) coloured(255,0,0)drawtext("#dr475nperc# ",barindex-39,upperline) coloured(255,0,0)drawtext("#dr450nperc# ",barindex-38,upperline) coloured(255,0,0)drawtext("#dr425nperc# ",barindex-37,upperline) coloured(255,0,0)drawtext("#dr400nperc# ",barindex-36,upperline) coloured(255,0,0)drawtext("#dr375nperc# ",barindex-35,upperline) coloured(255,0,0)drawtext("#dr350nperc# ",barindex-34,upperline) coloured(255,0,0)drawtext("#dr325nperc# ",barindex-33,upperline) coloured(255,0,0)drawtext("#dr300nperc# ",barindex-32,upperline) coloured(255,0,0)drawtext("#dr275nperc# ",barindex-31,upperline) coloured(255,0,0)drawtext("#dr250nperc# ",barindex-30,upperline) coloured(255,0,0)drawtext("#dr225nperc# ",barindex-29,upperline) coloured(255,0,0)drawtext("#dr200nperc# ",barindex-28,upperline) coloured(255,0,0)drawtext("#dr175nperc# ",barindex-27,upperline) coloured(255,0,0)drawtext("#dr150nperc# ",barindex-26,upperline) coloured(255,0,0)drawtext("#dr125nperc# ",barindex-25,upperline) coloured(255,0,0)drawtext("#dr100nperc# ",barindex-24,upperline) coloured(255,0,0)drawtext("#dr075nperc# ",barindex-23,upperline) coloured(255,0,0)drawtext("#dr050nperc# ",barindex-22,upperline) coloured(255,0,0)drawtext("#dr025nperc# ",barindex-21,upperline) coloured(255,0,0)drawtext("5.0%",barindex-1,lowerline) coloured(255,0,0)drawtext("4.5%",barindex-3,lowerline) coloured(255,0,0)drawtext("4.0%",barindex-5,lowerline) coloured(255,0,0)drawtext("3.5%",barindex-7,lowerline) coloured(255,0,0)drawtext("3.0%",barindex-9,lowerline) coloured(255,0,0)drawtext("2.5%",barindex-11,lowerline) coloured(255,0,0)drawtext("2.0%",barindex-13,lowerline) coloured(255,0,0)drawtext("1.5%",barindex-15,lowerline) coloured(255,0,0)drawtext("1.0%",barindex-17,lowerline) coloured(255,0,0)drawtext("0.5%",barindex-19,lowerline) coloured(255,0,0)drawtext("-5.0%",barindex-41,lowerline) coloured(255,0,0)drawtext("-4.5%",barindex-39,lowerline) coloured(255,0,0)drawtext("-4.0%",barindex-37,lowerline) coloured(255,0,0)drawtext("-3.5%",barindex-35,lowerline) coloured(255,0,0)drawtext("-3.0%",barindex-33,lowerline) coloured(255,0,0)drawtext("-2.5%",barindex-31,lowerline) coloured(255,0,0)drawtext("-2.0%",barindex-29,lowerline) coloured(255,0,0)drawtext("-1.5%",barindex-27,lowerline) coloured(255,0,0)drawtext("-1.0%",barindex-25,lowerline) coloured(255,0,0)drawtext("-0.5%",barindex-23,lowerline) coloured(255,0,0)drawtext("%",barindex-42,upperline) coloured(255,0,0)drawsegment(barindex-21,lowerline-25,barindex-21,upperline+25)COLOURED(0,0,0)if t = 1 thendrawarrowup(x,y) coloured(0,255,0)endifif t = -1 thendrawarrowdown(x,y) coloured(255,0,0)endifreturn upperline*1.05 coloured(0,0,0,0) as "-", -25 coloured(0,0,0,0) as "-"05/22/2019 at 6:53 AM #9910505/22/2019 at 10:53 AM #99144The indicator is now in the library and can be found here:
https://www.prorealcode.com/prorealtime-indicators/distribution-of-returns/
05/22/2019 at 3:12 PM #99175I spotted a typo in the code. There is a minus sign missing on line 274. I have edited the code in my previous post and Nicolas will amend the code and the ITF file in the library but anyone who has already downloaded the ITF file or cut and pasted the code should change line 274 to the following for the indicator to work correctly:
1if dailyreturn <= -4.00 and dailyreturn > -4.25 then1 user thanked author for this post.
05/27/2019 at 11:57 AM #99520Vonassi,
I can see what you/ the code is doing. Seems like a Bell curve to me.
In all your comments I am missing WHY you developed it, and what it is meant to tell us as users.
Presumably if the curve is very steep and small, the underlying stock/indices/commodity are very stable with their price movements, which you also would expect with obligations.
When most of its area is on the right side (not sure if this can happen using your code), the stock is in an uptrend. And vice versa, when most of the area is on the left side, the stock is in a downtrend.
Looking forward for your comments what you can do with it and what the predictive value could be.
KR Jan
1 user thanked author for this post.
05/27/2019 at 2:40 PM #99529The indicator simply shows how balanced a market is. The shape of the curve tells us this and more. Remember that the curve is created by checking close to close price movements. If the bars near the centre are all tall and the rest of the curve is flat then we can see that prices (close to close) don’t move very far from where they started. If however the curve is more triangular shaped then we can see that the market has a different characteristic and price closes over a larger range. Each bar tells us the probability of price closing so far from where it started.
The indicator is not really about trend as it needs a lot of candles to be analysed to get a curve so it is seriously lagging. If a curve is lop sided in shape then the we can see that maybe our downside risk is very different to our upside risk. If there are only one or two tall bars on the right of centre then we know that the probability of price closing at a distance of three or four bars away is seriously reduced and if there are lots of tall bars on the left of the centre line then we know that our downside risk is greater and deeper.
I have now created a version where you can vary the bar size. Having bucket sizes fixed at 0 to 0.25% then 0.25% to 0.50% is not ideal for all instruments. I have also created an automatic bar size calculator that the indicator can call so that it works out the best bucket size for any instrument that you use it on.
I have also been working on a similar indicator which I call ‘Distribution of Range’. On this indicator the right side of the curve shows distribution of high minus open and the left side open minus close. The number of bars has been increased to 82 and it also works with the automatic bar size indicator as well as manually sized bars.
Hopefully I will finish these indicators and post them to the library later this week.
1 user thanked author for this post.
10/28/2019 at 11:20 AM #111404Great coding!
Did you find time and energy to finalise the adaptable indicator? One of my first thoughts would be to make bucket distribution automatic based on highest and lowest return values and a given number of buckets (which could be set in a variable).
/F
10/28/2019 at 12:57 PM #111411I spent a lot of time on it and I did create something that was automatic but unfortunately any out of the ordinary candles created massive distortions in the bucket sizes calculated meaning that the output was not really of much use as the majority of results ended up being in just two bars – so I kind of gave up on the concept.
I’ve attached the ITF file for as far as I got.
If you set BarSize to zero then it automatically calculates the bar size (bucket size). I have added a variable called ‘factor’ which helps spread the bell curve out by dividing the automatically calculated bar size by its value. This helps to improve the curve and stops all the results being just in the middle two bars! It is a bit of a fudged work around which is the main reason why I did not post the indicator in the library.
There is also the issue that the bar size calculation is always changing as time goes on and it is difficult to know exactly how much this effects the final results.
There are three arrows – the blue one is where price is right now on the bell curve and the red and green are the extremes of where it has been for the current candle.
At the bottom of the chart it shows the size in % of each bar and also what the extreme bars represent.
Sorry if the code is a bit of a mess but it is an abandoned project for all the many reasons mentioned!
10/28/2019 at 3:46 PM #11143810/31/2019 at 4:35 PM #111755A great idea for an indicator Vonasi, as the distribution of returns shows the inherent bias/skew and volatility for any market. I was reading this very interesting quant traders ideas about Returns Distribution and Cumulative Probability here:
https://www.quanttrader.com/index.php/money-for-nothing/KahlerPhilipp2018
https://www.quanttrader.com/index.php/tradesignal-returns-distribution-indikator
How hard would it be to convert Kahler’s code from the second link supplied above? I think it would be a great addition to the library and maybe it could solve some of the issues you’ve encountered?
To save having translate his post from German:
The Returns Distribution indicator makes it possible to show the distribution of the returns of a time series. The presentation and calculation of the returns is done in percent.
If the input “returnperiod” is set to 0, the absolute price distribution is displayed.
The smoothing of the curve can be determined via the Input Smooth.
In addition to the distribution of the returns, the sum of the probabilities can also be displayed. This can be used to determine what percentage of events are above or below a certain value.
11/07/2019 at 12:10 PM #112309Hi @Vonasi, I’m unsure of the rules about double posting. Should I add my entire last post above to: https://www.prorealcode.com/free-code-conversion/
or https://www.prorealcode.com/forum/prorealtime-english-forum/probuilder-support/
and what is the real difference between these two links and how do you know when to post to one or the other? Thanks.
11/07/2019 at 2:31 PM #112336Everything is possible – but sometimes an awful lot of hard work. I have seen those posts that you provided links to before and have actually already started coding something similar. Unfortunately that original indicator code uses arrays and PRT does not have arrays so to create a DOR line requires a separate piece of code just to allocate each result to the correct variable (or bucket) rather than just a couple of loops. Then we have to do this again to get the other two DOR lines. I have also found deciding on the size of each bucket is impossible at the start of an indicator run unless a loop is used to check all of history in reverse first then you have to do the whole lot of distributions counting in reverse with a massive loop which either fails or is painfully slow. Starting at the beginning of history is easier and faster but then you have no idea what bucket size to use. I did overcome this with a separate indicator that calculates bucket size but then you have to manually enter it for the three DOR lines which is not ideal. Calculating a smoothed average of all the individual variable results is also not a lot of fun unless one likes repetitive typing! After all that I then need to workout all the correct locations in an indicator window to draw all the segments from one variable result to the next. The biggest DOR chart I have created so far is just 80 bars and that was a mammoth task.
I have shelved the project at the moment but might resurrect it if I thought that I could sell it! 🙂
-
AuthorPosts
Find exclusive trading pro-tools on