Plot long/short retail positions (from myfxbook) on MT4 chart
I decided to move this from the recycle bin, as it seems the threads there have a limited life, and I put a fair bit of work into this, hence I felt it was worth preserving. Hopefully it might prove to be interesting or useful to somebody.
I suppose I'll be accused of promoting the evil forex game, or posting for personal or commercial gain, but........
Please feel welcome to download and use this FREE software. However, read the attached PDF first, as I won't be answering any more questions.
Latest release: 1.33, uploaded Aug 26, 2019. (If you want to keep up to date with the latest version, then please feel welcome to revisit this thread occasionally, as I don't intend to keep bumping it).
PDF file with all instructions. Download and read this first.FF thread 915949 -- Plot long & short retail positions (from myfxbook) on MT4 chart.pdf
ZIP file with all necessary install files. See instructions in the 'Installation' section of the PDF.Plot retail data from myfxbook outlook.zip
Summary of major conclusions reached
1. Plots of retail volume flows and currency strength are almost the mirror image of each other, telling us that the majority of retail traders look to buy weakness and sell strength (aka "buy low, sell high"). Pair-based plots tend to confirm this, i.e. that while price is rising, sell volumes increase (and buy volumes decrease, thus buy orders are being closed in profit), and all of these operations continue when price consolidates following a rise; and the reverse applies in mirror image scenarios.
2. There is little that can be gleaned from the retail volume flow plots that one can't deduce by merely studying price. In fact the plots lag price somewhat, presumably because it takes retail traders time to react to price movement. (However, one benefit of the retail analysis is that it is timeframe independent, i.e. same value for all TFs, keeping analysis tidy and unambiguous).
3. According to general market theory, buying weakness and selling strength works well enough during sideways periods; P/L is determined by how accurately the trader is able to pick market tops and bottoms. Losses accumulate during periods when the market trends far enough, often enough. Conversely, allowing winners to run, and even adding to winners, works effectively to whatever extent price 'trends'.
4. The stats on the myfxbook outlook page show that the majority of retailers' open positions are under water, many significantly so. This suggests that (1) buying weakness and selling strength is, on balance, an inferior entry strategy; and/or (2) retail traders are leaving their losing trades open longer than their winners.
5. Read this.
Important note: When I use the term "current sentiment" or "prevailing sentiment" (e.g. in posts #21, #25, #26), I don't mean the SSI value (current net long/net short ratio), which is calculated from historical transactions that bring us up to the current point; instead I mean the current (collective bullish or bearish) mood that will have an impact on orders that will be placed henceforth. The SSI/volumes value lags the current mood, e.g. for it to move from 80% net long to 80% net short, a large volume of selling must occur (and hence the mood was actually bearish throughout that time).
To see the accompanying plots, and for more observations, read the PDF. And also this FF thread, where the underlying concepts are discussed in more detail (acknowledgements to neilsdigest, osjoe2, and various others for their contributions).
Replies to posts.....
I don't intend replying to any more questions. If you're experiencing problems with the software, please see the 'Troubleshooting' section in the PDF file. If you can't resolve your issue, there are plenty more third party MT4 indicators around for you to play with.
To those members who post(ed) kind comments, these are very much appreciated. Many thanks.
1. Check the settings in your ..../MQL4/Files/myfxoutlook.ini file**
Mine are as follows:
You need a non-blank and non-zero entries in the green highlighted settings respectively, if you want the timeseries plots on your MT4 charts.
You will need to get the timezone settings (highlighted in yellow) correct for your own location, and your MT4 broker's location., to get the plots to align correctly with the candles. See page 9 of the PDF for more info.
[** In case you're unsure how to edit the ini file:
i) If the myfxbook icon is showing in your systray, right click it and choose Exit, to exit the Download_myfxbook_outlook.exe app.
ii) Go to MT4. Use MT4 dropdown menu option Files -> Open Data Folder
iii) Double click on folder MQL4, and then folder Files
iv) Locate the myfxoutlook.ini file. Right click, and select open with Notepad.
v) Make the necessary changes to the green and yellow highlighted settings, as shown above.
vi) In Notepad, choose dropdown menu option Files -> Save, and then Files -> Exit.
vii) Now you should be back in Windows file manager, double click on the Download_myfxbook_outlook.exe app to re-launch it.
viii) Close Windows file manager, which should return you to MT4.
ix) If you haven't already done so, open a blank new chart, and apply the hanover_consolidated template.]
2. For more detailed instructions, please read the 'Troubleshooting' section on page 17 in the PDF.
3. Note that it might take up to 24 hours of collecting data (while the FX markets are open) before any meaningful trends are discernible.
Make sure that you can see the little myfxbook icon in your systray, otherwise the download app isn't running, and no data will be collected.
The chart you're showing me is daily. Therefore you will need to gather data, using the new settings, for at least 2-3 days before anything will show on the chart.
Try a shorter TF, e.g. H1. Also if/while myfxbook window into the market is closed for the weekend, no data can be gathered.
Perhaps try setting UpdateEveryXminutes=15 for a while, so that the data files get updated every 15 minutes, instead of 60. Also if you set PlaySounds=2, your computer will give a small beep every time the data is updated.
Important: Try switching backwards and forwards between chart TFs, to force a refresh of all of the indicators.
One minor point, I expect your timezone settings are meant to be 5½ hours ahead of GMT, that is 5.5 hours, not 5.30 (entry should be hours, not hours and minutes)
Give it a day or two, then check that the csv files are starting to fill up with data. Don't leave the files open in Excel, though, because Excel locks the file and prevents any data from being added to it. Switch to a suitable TF chart and hopefully you'll start to see some data starting to emerge like the screenshots I took in the PDF.
Please read the PDF for more info. Everything you need to know is written there. I am just repeating myself.
There are no known bugs in the software, it is all working perfectly on my (Windows 7 64-bit) computer. We are both running the same software. Therefore there must be something different on your computer, but I can't possibly know what it is.
Note that, for the sake of efficiency, new values are appended to the files only if the currently scraped (or calculated) value differs from the last value in the file.
The net volumes where the currency is the first named in the pair are added, if the second named, they are subtracted.
Perhaps best explained by an example; I just took a snapshot of all of the NZD pairs, and their volumes (final value in each file) were as follows:
NET TOTAL where NZD is first named = 9258.5
NET TOTAL where NZD is second named = -2263.83
TOTAL net volume for NZD = 9258.5 - (-2263.83) = 11522.33, which is in fact the final value in $$_netVolume_[NZD].csv
Of course there are many other possible approaches (at one point I considered weighting each value in various ways), but for better or worse, that is the calculation that I ended up using.
Note that each curve is INDIVIDUALLY scaled to fit inside the subwindow; therefore the actual values of each plot should not be compared against each other. It's the changes in slope that are important, showing the rate at which total net volume is advancing or declining for that currency. Ideally either (1) each currency should be plotted in its own subwindow (but this would consume too much screen space); or (2) if you want to compare the actual values, then go to the 'Common' tab and set the SAME 'Fixed minimum' and 'Fixed maximum' value for each of the 8 plots (however, this will make it harder to see the changes of slope in the smallest transacted currencies).
'Pause script' and 'Suspend hotkeys' are not my invention; they are functions built into autohotkey (the programming language that I used to create the exe). As far as I know, selecting 'Pause script' should pause the exe and suspend it from processing (hence no data will be written); the icon in the systray should change to a red box with a 'H' in it. Then click 'Pause script' again to restart the exe from exactly where it left off. (Hence it works much the same as the 'Enable/disable AutoTrading' icon on MT4's toolbar). Of course you could achieve much the same thing by clicking 'Exit', and then running the exe again. Note that if you want the exe to recognize any changes you've made in the settings ini, you must Exit, then change the settings, then run the exe again.
To output consolidated totals for anything other than the 8 major currencies, I would need to enhance the program code. I stopped at the 8 majors because data for all of the relevant 28 pairs was available, making it possible to sum volumes across exactly 7 pairs for each currency, allowing for an even-handed comparison (which is important for the $$_netCount[xxx].csv output). However, I'll give your idea some thought when I get some spare time.**
[EDIT] ** I've made the necessary enhancement, and uploaded the new version. Please read the final page of the PDF ('Version 1.23 release') for more info.
AUDCAD,-0.4,-1.4,-1.2,-1.2,-2.6,0.1,8.5,-24.4,-24.2 AUDJPY,0.3,-0.6,0.5,0.5,-2.2,0.1,6.1,-30.5,-30.5 AUDNZD,0.0,-1.5,-1.7,-1.7,-3.6,2.8,16.7,64.2,64.2 AUDUSD,0.6,-0.4,-0.9,-0.9,-2.7,-2.9,1.1,-9.0,-8.5 CADJPY,-0.5,-0.2,0.9,0.9,-0.5,-1.0,2.6,-10.1,-10.6 EURAUD,0.3,1.7,3.7,3.7,5.5,2.7,-3.6,-90.4,-90.6 EURCAD,0.1,0.0,1.7,1.7,1.9,2.9,7.0,-124.1,-123.8 EURCHF,0.0,0.4,3.3,3.3,3.5,3.5,8.7,-2.8,-3.2 EURCZK,9.9,-20.1,-39.8,-39.8,-30.0,-30.0,-30.0,367.2,367.4 EURGBP,0.1,-1.0,-0.6,-0.6,0.4,-1.8,-2.6,28.8,29.0 EURJPY,-0.7,-0.9,2.6,2.6,0.5,1.0,3.3,-118.9,-118.8 EURUSD,0.3,-0.4,0.9,0.9,-0.9,-2.4,-3.4,-78.9,-79.2 GBPJPY,-0.9,0.8,3.7,3.7,-0.1,4.4,13.2,-161.1,-160.7 GBPUSD,0.0,1.0,2.2,2.2,-2.0,0.1,4.1,-114.0,-114.4 NZDUSD,0.4,0.0,-0.1,-0.1,-0.9,-4.8,-9.3,-40.4,-40.4 USDCAD,0.0,-0.4,0.8,0.8,2.4,5.6,13.9,-17.2,-17.2 USDCHF,-0.2,0.9,1.9,1.9,3.9,5.9,10.9,68.5,68.6 USDJPY,0.0,0.0,2.1,2.1,1.3,3.6,7.3,-29.1,-29.5 XAGUSD,0.6,0.7,-0.1,-0.1,0.5,-0.9,1.2,8.8,8.7 XAUUSD,13.0,49.0,-8.0,-8.0,29.0,-51.0,109.0,2020.0,2020.0
If you do want to run both MT4 and the download app on separate computers for whatever reason, then you would need to find a programmer to write another app that also runs concurrently in the background, and transfers the necessary files between the two computers. I'm not currently in a position to do this.
Then re-run the app, and check that your settings are the same as mine:
The items highlighted in green are crucial. [Also, please note that you'll need to get your timezone settings (yellow highlight) correct — more info on page 15 of the freshly uploaded PDF — if you want the timeseries to plot under the correct candles].
Note that it will take several hours for any meaningful trends to plot (with these settings it is loading only one datapoint every 60 minutes).
After that, try switching the chart to the next highest TF, and then back again. This forces a refresh of the chart.
Also, please read the comprehensive 'Troubleshooting' section starting on page 24 of the PDF. Good luck.
NOTE: By setting 'Update every ? minutes' to 1, you will be picking up virtually every change, hence the app will potentially gather vast amounts of data. In which case I would set the 'Housekeep cutoff date' to something like 24h (so that only the last 24 hours' worth of data will be kept/plotted). If there is a data overload, MT4 could slow, freeze or (if it runs out of computer memory) crash.
I'm done with both this thread, and with this research, as I've achieved what I set out to do. I'm satisfied that the software works correctly, and also with the validity of the conclusions that I reached. For more info, download and read the PDF.
I tried re-coding the downloader to use the outlook API, as was suggested, but the re-coded version returned a "Too many requests; please try again later" error for much of the time. So I will leave the app the way that it was originally, unless/until the myfxbook webpage format is changed, necessitating a compatibility upgrade.
Hanover, all your posts/threads are GEMS. Thank you very much.
Thank you very much for your excellent work here David!
I know you do not code anymore and are also not considering any changes to the work you have done. I have looked at the heatmap on the myfxbook website and I think if one could also import this data into the Excel file using your download_myfxbook_outlook executable it could be of value as a measure to indicate currency strength. I do not know if the myfxbook api allows for this.
Very interesting, A different approach to filter out TA, I really like this. I just hope I am tech savy enough to figure how to set up data.
Thanks Hannover. Good resource from you again.
It's an awesome piece of work, really helpful in my everyday trading.
Hanover, I'm trying to figure out how to make .csv files update independently on the computer where my MT4 is currently running. This way there would be no gaps in the plotted chart data. And therefore, one can just switch on their pc let's say in the morning and have all the overnight data available for trading.
My idea is to download the generated.csv files from a remote server where your Download_myfxbook_outlook.exe app is running 24/7. Hanover, could you make just one tweak to your Download_myfxbook_outlook.exe app so that it could be configured to download already generated files from a certain remote server?
If other members of community have ideas about how to code the server side/local pc script side for this, that would be much appreciated too!
Thanks for your attention.
Found solution to this anyways.
Filezilla Server-Winscp script-Autohotkey-Windows Task Scheduler.
If anybody is still following this thread, versions 1.30 and 1.31 add some significant new functionality, including a dashboard indicator for MT4. Version 1.31 can be downloaded from post #1. For details, please read the final pages in the PDF attached to post #1.
I'm going to try to leave FF — again — until my fascination with FX draws me back here, lol. I really must spend less time at the computer. Catch y'all later.
Nope. It did not work
Has anyone got it working yet
thank you and I will look at it to figure out how I can take advantage of the information therein
Cant get it working
It is working now, It needed real time data to load. Thanks
From this post: "RSI taken from Monthly, Weekly, daily and H4 as posted here. Two RSI readings RSI2 + RSI 9 and divided by eight for a master rating."
Composite RSI indicator is attached, which performs the above calculation, and plots the result as a timeseries. The calculation gives an identical result (for the current price) to fxbarwise's indicator here, hence I assume it's correct.
Being derived from price, the indicator values merely follow price (the peaks and valleys coincide, more or less), which is what I expected.
I have used this since the beginning more or less, but for some reason all volume plotting went flatline the 5 of july. Havent changed any settings in the ini file and the program is still gathering the volume info in the csv files.
Anybody else have the same problem?
I have updated the exe file when a new have come along. I can plot everything but the net-, total-, short- and long- volume of any currencypair. Im using the Hanover templates but this is what I get.
© Forex Factory