matrixfx Posted June 25, 2011 Report Share Posted June 25, 2011 I'm working to an indicator called elasticity, which may show us if the price starts to move reported to the volumes involved. The formula should be: (%of volume change/% of price cange) > 1 to have elasticity, <1 for inelasticity. I have an attempt I made today, it's almost done, but I'm stuck. Can somebody help me, please? Any help will be great appreciated. //+------------------------------------------------------------------+ //| E.mq4 | //| | //+------------------------------------------------------------------+ #property copyright "" #property indicator_separate_window #property indicator_buffers 4 #property indicator_color1 Lime #property indicator_color2 Magenta #property indicator_color3 Gray #property indicator_width1 2 #property indicator_width2 2 #property indicator_width3 2 #property indicator_minimum 0 #property indicator_maximum 10 extern color LimeZone = Lime; //Elasticity conditions extern color PinkZone = Magenta; // InelasticityConditions extern color GrayZone = Gray; // Not defined double Vol[]; double MA[]; string name; extern string TF = "-- Time Frame To Display --"; extern int TimeFrame1 = 0; int TimeFrame2 = 60; int TimeFrame3 = 240; string TimeFrames = "M1;5,15,30,60H1;240H4;1440D1;10080W1;43200MN|0-CurrentTF"; extern int MAPeriod=14; extern double BarLevl = 0; extern int range = 1; extern int ma_shift = 0; extern int ma_method = MODE_SMA; extern int applied_price = PRICE_WEIGHTED; extern int alertSwitch = 0; //0=OFF , 1=ON extern int alertShift = 0; // 0=change color current Bars, 1=chamge color previous Bar, .... // double buffer1[], buffer2[], buffer3[], VolSMA[]; int lastABar; int init() { SetIndexStyle(0,DRAW_ARROW, 2); SetIndexArrow(0,167); SetIndexBuffer(0,buffer1); SetIndexEmptyValue(0,EMPTY_VALUE); SetIndexStyle(1,DRAW_ARROW, 2); SetIndexArrow(1,167); SetIndexBuffer(1,buffer2); SetIndexEmptyValue(1,EMPTY_VALUE); SetIndexStyle(2,DRAW_ARROW, 2); SetIndexArrow(2,167); SetIndexBuffer(2,buffer3); SetIndexEmptyValue(2,EMPTY_VALUE); SetIndexBuffer(3,VolSMA); TimeFrame1=MathMax(TimeFrame1,Period()); TimeFrame2=MathMax(TimeFrame2,Period()); TimeFrame3=MathMax(TimeFrame3,Period()); IndicatorShortName("E_"+TimeFrame1); return(0); } int start() { datetime TimeArray1[], TimeArray2[], TimeArray3[]; int i,shift,limit,y1=0, y2=0, y3=0, counted_bars=IndicatorCounted(); double Vol[], MA[], VolSMA[]; // Plot defined timeframe on to current timeframe ArrayCopySeries(TimeArray1,MODE_TIME,Symbol(),TimeFrame1); ArrayCopySeries(TimeArray2,MODE_TIME,Symbol(),TimeFrame2); ArrayCopySeries(TimeArray3,MODE_TIME,Symbol(),TimeFrame3); limit=Bars-counted_bars+TimeFrame1/Period(); limit=Bars-counted_bars+TimeFrame2/Period(); limit=Bars-counted_bars+TimeFrame3/Period(); for(i=0,y1=0,y2=0,y3=0;i<limit;i++) { if (Time<TimeArray1[y1]) y1++; if (Time<TimeArray2[y2]) y2++; if (Time<TimeArray3[y3]) y3++; buffer1 = 0; buffer2 = 0; buffer3 = 0; /*********************************************************** Add your main indicator loop below. You can reference an existing indicator with its iName or iCustom. Rule 1: Add extern inputs above for all neccesary values Rule 2: Use 'TimeFrame' for the indicator timeframe Rule 3: Use 'y' for the indicator's shift value **********************************************************/ MA = iMA(NULL,TimeFrame1,MAPeriod,ma_shift,ma_method,applied_price,y1); Vol = iVolume(Symbol(),TimeFrame1,y1); VolSMA=iMAOnArray(Vol,Bars,MAPeriod,0,MODE_SMA,y1); buffer1=EMPTY_VALUE; buffer2=EMPTY_VALUE; buffer3=EMPTY_VALUE; if (((VolSMA[y1]-VolSMA[y1+1])/VolSMA[y1+1])/((MA[y1]-MA[y1+1])/MA[y1+1])>1) buffer1 = BarLevl; else if (((VolSMA[y1]-VolSMA[y1+1])/VolSMA[y1+1])/((MA[y1]-MA[y1+1])/MA[y1+1])<1) buffer2 = BarLevl; else buffer3 = BarLevl; } if (alertSwitch == 1 && Bars > lastABar) { if (buffer1[alertShift] != EMPTY_VALUE && buffer1[alertShift+1] == EMPTY_VALUE) { Alert("Elasticity, "+Symbol()+" , M_"+Period()); lastABar = Bars; } if (buffer2[alertShift] != EMPTY_VALUE && buffer2[alertShift+1] == EMPTY_VALUE) { Alert("Inelasticity, "+Symbol()+" , M_"+Period()); lastABar = Bars; } } return(0); } Quote Link to comment Share on other sites More sharing options...
soundfx Posted June 25, 2011 Report Share Posted June 25, 2011 matrixfx, What are you expecting this indicator to look like on the chart ? Quote Link to comment Share on other sites More sharing options...
bgrtz Posted June 26, 2011 Report Share Posted June 26, 2011 ...I have an attempt I made today, it's almost done, but I'm stuck... Stuck on what? Quote Link to comment Share on other sites More sharing options...
matrixfx Posted June 26, 2011 Author Report Share Posted June 26, 2011 soundfx, It should signal with lime led when we have elasticity (price change is higher then volume change; indi is >1) and magenta when we have inelasticity in the market. This may be a filter for entries and exits. Elasticity it is used in micro-economy to compare the price change from demand/supply, and also I saw some ideas using it in stock market, but I didn't find any indi on the market. The formula should be OK. The MAPeriod should be tested which one fits better. bgrtz, It didn't return the values and I have no leds open when it is launched. Thanks for replies. Rgds, soundfx 1 Quote Link to comment Share on other sites More sharing options...
matrixfx Posted June 26, 2011 Author Report Share Posted June 26, 2011 The formula for the coefficient of price elasticity of demand for a good is: E_d = {%change in quantity demanded}/{%change in price} = [Delta Q/Q]/[Delta P/P] Our quantity is the volume, the price I used the the weighted price. It also may be used as a version the ATR, just beeing aware the ATR can increase without a significant price change. For this reason I choose the price. Quote Link to comment Share on other sites More sharing options...
matrixfx Posted June 26, 2011 Author Report Share Posted June 26, 2011 The percentage of price elasticity will measure how rapidly the market responds to price changes. If the price elasticity is higher than one, then this means that the pair choosen is price elastic. When the price changes, there is a high corresponding response in number of contracts traded on the market. If the price elasticity is exactly equal to one, then that means that the pair is unit elastic, but that result is relatively rare. It is more common for the price elasticity to be lower than one. This means that the price is inelastic, and price changes will not have a corresponding effect on the number of contracts sold. Now, this is the theory, we need the indicator running to check it out and optimize the parameters. Quote Link to comment Share on other sites More sharing options...
bgrtz Posted June 26, 2011 Report Share Posted June 26, 2011 I simplify the code. Modify to suit your needs, then share your final result with others here with more comprehensive description (what this do, how to use, or, if any, the relation to other indi's) #property indicator_separate_window #property indicator_buffers 6 #property indicator_color1 Blue #property indicator_width1 3 #property indicator_color2 Red #property indicator_width2 3 #property indicator_color3 Yellow #property indicator_width3 3 #property indicator_minimum 0 #property indicator_maximum 2 extern int MA_Period = 14; extern int MA_Method = 0; extern int MA_Price = 6; string shortName = "Elasticity"; double buffer1[]; double buffer2[]; double buffer3[]; double valMA[]; double valVol[]; double valVolMA[]; int init() { SetIndexBuffer(0, buffer1); SetIndexStyle(0, DRAW_LINE, STYLE_SOLID, 1); SetIndexLabel(0, "Elasticity"); SetIndexBuffer(1, buffer2); SetIndexStyle(1, DRAW_LINE, STYLE_SOLID, 1); SetIndexLabel(1, "Inelasticity"); SetIndexBuffer(2, buffer3); SetIndexStyle(2, DRAW_LINE, STYLE_SOLID, 1); SetIndexLabel(2, "Idle"); SetIndexBuffer(3, valMA); SetIndexStyle(3, DRAW_NONE); SetIndexBuffer(4, valVol); SetIndexStyle(4, DRAW_NONE); SetIndexBuffer(5, valVolMA); SetIndexStyle(5, DRAW_NONE); IndicatorShortName(shortName); return(0); } int start() { int limit = 1500; for (int i=0; i<=limit; i++) { valMA[i] = iMA(Symbol(), 0, MA_Period, 0, MA_Method, MA_Price, i); valVol[i] = iVolume(Symbol(), 0, i); valVolMA[i] = iMAOnArray(valVol, 0, MA_Period, 0, MODE_SMA, i); if (((valVolMA[i] - valVolMA[i+1]) / valVolMA[i+1]) / ((valMA[i] - valMA[i+1]) / valMA[i+1]) > 1) { buffer1[i] = 1; buffer2[i] = EMPTY_VALUE; buffer3[i] = EMPTY_VALUE; } else if (((valVolMA[i] - valVolMA[i+1]) / valVolMA[i+1]) / ((valMA[i] - valMA[i+1]) / valMA[i+1]) < 1) { buffer1[i] = EMPTY_VALUE; buffer2[i] = 1; buffer3[i] = EMPTY_VALUE; } else { buffer1[i] = EMPTY_VALUE; buffer2[i] = EMPTY_VALUE; buffer3[i] = 1; } } return(0); } http://img857.imageshack.us/img857/7340/elasticity.png Blue line is "elasticity", red is "inelasticity" Regards soundfx and matrixfx 2 Quote Link to comment Share on other sites More sharing options...
4xmeter Posted June 26, 2011 Report Share Posted June 26, 2011 I see only a Red Line! Quote Link to comment Share on other sites More sharing options...
matrixfx Posted June 26, 2011 Author Report Share Posted June 26, 2011 Thank you a lot, bgrtz! You are a pro! I will up date you with the results from my side. The code seems to have a small problem, if I press compile it's working as you showed me, if I try installing the indicator from MT4 I have just a red line and I should press compile each time I change something. Can you, please, help me out fixing it? Quote Link to comment Share on other sites More sharing options...
bgrtz Posted June 26, 2011 Report Share Posted June 26, 2011 (edited) sorry matrixfx, 4xmeter, my bad... for (i=0; i<=limit; i++) { valMA[i] = iMA(Symbol(), 0, MA_Period, 0, MA_Method, MA_Price, i); valVol[i] = iVolume(Symbol(), 0, i); } for (i=0; i<=limit; i++) { valVolMA[i] = iMAOnArray(valVol, 0, MA_Period, 0, MODE_SMA, i); if (((valVolMA[i] - valVolMA[i+1]) / valVolMA[i+1]) / ((valMA[i] - valMA[i+1]) / valMA[i+1]) > 1) { buffer1[i] = 1; buffer2[i] = EMPTY_VALUE; buffer3[i] = EMPTY_VALUE; } else if (((valVolMA[i] - valVolMA[i+1]) / valVolMA[i+1]) / ((valMA[i] - valMA[i+1]) / valMA[i+1]) < 1) { buffer1[i] = EMPTY_VALUE; buffer2[i] = 1; buffer3[i] = EMPTY_VALUE; } else { buffer1[i] = EMPTY_VALUE; buffer2[i] = EMPTY_VALUE; buffer3[i] = 1; } } Edited June 26, 2011 by bgrtz 4xmeter 1 Quote Link to comment Share on other sites More sharing options...
mtuppers Posted June 26, 2011 Report Share Posted June 26, 2011 sorry matrixfx, 4xmeter, my bad... for (i=0; i<=limit; i++) { valMA[i] = iMA(Symbol(), 0, MA_Period, 0, MA_Method, MA_Price, i); valVol[i] = iVolume(Symbol(), 0, i); } for (i=0; i<=limit; i++) { valVolMA[i] = iMAOnArray(valVol, 0, MA_Period, 0, MODE_SMA, i); if (((valVolMA[i] - valVolMA[i+1]) / valVolMA[i+1]) / ((valMA[i] - valMA[i+1]) / valMA[i+1]) > 1) { buffer1[i] = 1; buffer2[i] = EMPTY_VALUE; buffer3[i] = EMPTY_VALUE; } else if (((valVolMA[i] - valVolMA[i+1]) / valVolMA[i+1]) / ((valMA[i] - valMA[i+1]) / valMA[i+1]) < 1) { buffer1[i] = EMPTY_VALUE; buffer2[i] = 1; buffer3[i] = EMPTY_VALUE; } else { buffer1[i] = EMPTY_VALUE; buffer2[i] = EMPTY_VALUE; buffer3[i] = 1; } } could you post in full mq4 files in code? part of code is hard to read and do not know where to put it. thanks in advice Quote Link to comment Share on other sites More sharing options...
matrixfx Posted June 26, 2011 Author Report Share Posted June 26, 2011 Hi bgrtz, Thank you for your time and interest. Now the indicator it's working. I realized I did a mistake beacause the price and volume change values should be absolute value or modulus (http://en.wikipedia.org/wiki/Elasticity_%28economics%29), otherwise comparing with "1" doesn't make sense. The elasticity ideea I have it from the time I worked for my PhD from Harry Markovitz (who received the Nobel Price in 1990 I think). Anyhow, I was impressed how outstanding it is the indicator (the wrong one :)) in this form, so I decided to keep it and allocate more time to test and implement it. I just pray not to repaint (and I think there are no reasons) and to see it tomorrow performing as it did in the history. Quote Link to comment Share on other sites More sharing options...
matrixfx Posted June 26, 2011 Author Report Share Posted June 26, 2011 Here it is the indicator code up-dated to be tested. //+------------------------------------------------------------------+ //| Price-Volume Changes.mq4 | //+------------------------------------------------------------------+ #property copyright "No copyright, 2011, bgrtz and matrixfx" #property indicator_separate_window #property indicator_buffers 6 #property indicator_color1 Red #property indicator_width1 3 #property indicator_color2 Blue #property indicator_width2 3 #property indicator_color3 Gray #property indicator_width3 3 #property indicator_minimum 0 #property indicator_maximum 2 extern int MA_Period = 14; extern int MA_Method = 0; extern int MA_Price = 6; string shortName = "Elasticity"; double buffer1[]; double buffer2[]; double buffer3[]; double valMA[]; double valVol[]; double valVolMA[]; int init() { SetIndexBuffer(0, buffer1); SetIndexStyle(0, DRAW_LINE, STYLE_SOLID, 3); SetIndexLabel(0, "Elasticity"); SetIndexBuffer(1, buffer2); SetIndexStyle(1, DRAW_LINE, STYLE_SOLID, 3); SetIndexLabel(1, "Inelasticity"); SetIndexBuffer(2, buffer3); SetIndexStyle(2, DRAW_LINE, STYLE_SOLID, 3); SetIndexLabel(2, "Idle"); SetIndexBuffer(3, valMA); SetIndexStyle(3, DRAW_NONE); SetIndexBuffer(4, valVol); SetIndexStyle(4, DRAW_NONE); SetIndexBuffer(5, valVolMA); SetIndexStyle(5, DRAW_NONE); IndicatorShortName("Elasticity_"+MA_Period); return(0); } int start() { int i, limit = 1500; for (i=0; i<=limit; i++) { valMA = iMA(Symbol(), 0, MA_Period, 0, MA_Method, MA_Price, i); valVol = iVolume(Symbol(), 0, i); } for (i=0; i<=limit; i++) { valVolMA = iMAOnArray(valVol, 0, MA_Period, 0, MODE_SMA, i); if (((valVolMA - valVolMA[i+1]) / valVolMA[i+1]) / ((valMA - valMA[i+1]) / valMA[i+1]) > 0) { buffer1 = 1; buffer2 = EMPTY_VALUE; buffer3 = EMPTY_VALUE; } else if (((valVolMA - valVolMA[i+1]) / valVolMA[i+1]) / ((valMA - valMA[i+1]) / valMA[i+1]) <= 0) { buffer1 = EMPTY_VALUE; buffer2 = 1; buffer3 = EMPTY_VALUE; } else { buffer1 = EMPTY_VALUE; buffer2 = EMPTY_VALUE; buffer3 = 1; } } return(0); } Quote Link to comment Share on other sites More sharing options...
matrixfx Posted June 26, 2011 Author Report Share Posted June 26, 2011 (edited) I used MA Periods: 5; 8; 14. The main ideea is to cummulate their signals (blue for all for a pre-buy signal, red for all for a pre-sell signal). When 5 or 8 change their color may be the entry point, re-entry or compounding, but also a sign that the trend may be finished. I also use the ATR slope as a filter in the testing; if the signal is with a negativ ATR slope I would consider a reverse chance also. I may consider using a MTF filter if it will work well. I have tried to paste a print screen with my set-up but it did not take it. bgrtz, if you have any question please contact me. Many thanks again for your help and I'll keep in touch as things progress. Edited June 26, 2011 by matrixfx Quote Link to comment Share on other sites More sharing options...
vladv Posted June 26, 2011 Report Share Posted June 26, 2011 Please share your template & any other indicators for this trading system idea,matrixfx! I would like to test it myself,so can improve it together. Quote Link to comment Share on other sites More sharing options...
bgrtz Posted June 26, 2011 Report Share Posted June 26, 2011 matrixfx and people... Version #1 Individual set of MA Period for each window http://www.4shared.com/file/MwK_TvFr/Elasticity_v1.html Version #2 3 Set of MA Period in single window http://www.4shared.com/file/jX_JKyi_/Elasticity_v2.html http://img546.imageshack.us/img546/7340/elasticity.png hermes and john1368 2 Quote Link to comment Share on other sites More sharing options...
matrixfx Posted June 27, 2011 Author Report Share Posted June 27, 2011 Thanks a lot bgrtz. You have did a step forward Version 2 looks good, just should be changed the colors (blue to red and red to blue). I start testing it. Most likely should be added a trend indicator (like Price channel v1.2) as a filter, too. Let's see how its going. I wonder if we can increase the leds back for a visual back testing. Thanks again. Quote Link to comment Share on other sites More sharing options...
matrixfx Posted June 27, 2011 Author Report Share Posted June 27, 2011 Sorry for the colors, there were OK or does not metter too much. Honestly, there are some differences from what I saw yesterday, without data feeding. I should think again if we can find a use to this indicator. Anyway, I thank bgrtz for his help. Actually, what this indicator mesure is when the the change in price is made with a opposite change in volume. For example, if the price decrease with an increase in volume or if the price increase with a decrease in volume we have the red led. If the price increase were with an increase in volume we have blue red. Quote Link to comment Share on other sites More sharing options...
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.