Jump to content

Welcome to the new Traders Laboratory! Please bear with us as we finish the migration over the next few days. If you find any issues, want to leave feedback, get in touch with us, or offer suggestions please post to the Support forum here.

  • Welcome Guests

    Welcome. You are currently viewing the forum as a guest which does not give you access to all the great features at Traders Laboratory such as interacting with members, access to all forums, downloading attachments, and eligibility to win free giveaways. Registration is fast, simple and absolutely free. Create a FREE Traders Laboratory account here.

nilu_2005

Help Needed On MQL Code

Recommended Posts

Hello,

 

I need help on this EA. Actually I already got system in Amibroker TA.

I am trying to code same system as Metatrader EA.

 

Below is amibroker code(AFL) for system that I want to code as EA.

no= Param("period",7,1,100,1);

res=EMA(HHV(H,no),3);

sup=EMA(LLV(L,no),3);

 

 

 

a = Cross(H,res);

b = Cross(sup,L);

eq=Param("0 equity",1,0,1,1);

 

state = IIf(BarsSince(a)<BarsSince(b),1,0); //(<<this return 1 or 0 based on condition)

 

buy=cover=state>Ref(state,-1);

sell=short=state<Ref(state,-1);

 

As you can see there is external parameter ("no") which can be selected by user is an integer value.

 

Calculation of lines/variables RES & SUP (Resistance & Support)

 

“res” can be calculated using EMA of period 3 & PRICE will be highest high price of last 7 bars. This 7 bars value is an integer value which set by external parameter by user “no”.

Same goes for “sup” which is EMA of period 3, But only difference is that price of EMA calculation is lowest low price of last 7 bars.

SYNTAX hhv( ARRAY, periods )

RETURNS ARRAY

FUNCTION Calculates the highest value in the ARRAY over the preceding periods (periods includes the current day).

EXAMPLE The formula "hhv( close, 4)" returns the highest closing price over the preceding four periods; "hhv( high, 8)" returns the highest high price over the preceding eight periods.

 

///////////////////////////////////////////////////////////////////////////////////

SYNTAX llv( ARRAY, periods )

RETURNS ARRAY

FUNCTION Calculates the lowest value in the ARRAY over the preceding periods (periods includes the current day).

EXAMPLE The formula "llv( close, 14 )" returns the lowest closing price over the preceding 14 periods.

SEE ALSO The hhv() function (see Highest High Value ).

 

 

Now variable “a” will set to “1” or “0” based on the crossing of current bars high & variable “res”.

For variable “b” will set to “1” or “0” based on the crossing of current bars low & variable “sup”.

Here is definition of this “CROSS” afl code.

 

SYNTAX Cross( ARRAY1, ARRAY2 )

RETURNS ARRAY

FUNCTION Gives a "1" or true on the day that ARRAY1 crosses above ARRAY2. Otherwise the result is "0".

To find out when ARRAY1 crosses below ARRAY2, use the formula cross(ARRAY2, ARRAY1)

EXAMPLE cross( close, ema(close,9) )

 

Now the variable “state” which also can be set to “1” or “0” based on following condition.

 

BarsSince(a) : Calculates the number of bars (time periods) that have passed since ARRAY was true (or 1) in this case array was variable “a”

 

BarsSince(b) : Calculates the number of bars (time periods) that have passed since ARRAY was true (or 1) in this case array was variable “b”.

 

state = IIf(BarsSince(a)<BarsSince(b),1,0);

 

SYNTAX IIf( EXPRESSION, TRUE_PART, FALSE_PART )

RETURNS ARRAY

FUNCTION "Immediate-IF" - a conditional function that returns the value of the second parameter (TRUE_PART) if the conditional expression defined by the first parameter (EXPRESSION) is true; otherwise, the value of third parameter is returned (FALSE_PART). Please note that IIF is a function - so the result of evaluation is returned by that function and should be assigned to some variable. IIf always evaluates both TRUE_PART and FALSE_PART, even though it returns only one of them. Because of this, you should watch for undesirable side effects. The following example shows one common error made with IIF function: IIF( condition, result = 7, result = 9 ); // THIS IS WRONG Correct usage is: result = IIF( condition, 7, 9 ); /* 7 or 9 is *returned* and assigned to a variable depending on condition */

EXAMPLE The formula result = iif( macd()<signal(), Volume, -Volume) will assign positive volume values to the result variable on days when macd was below its signal line, and negative volume values on the other days.

 

Now I created EA based on above system. I have already used MQL code from MQL Programming Guide named tradingexpert. Means there is all code for Oder & Money Management. But my knowledge with MQL is not good. So I am not able to covert trading system into MQL code. As you can see attached MQL. I have stuck on trading system start part.

 

When

If this afl condition true => buy=cover=state>Ref(state,-1);

in MQL I follow

Opn_B=true;

Cls_S=true;

 

If condition for sell true=> sell=short=state<Ref(state,-1);

 

in MQL I follow

Opn_S=true;

Cls_B=true;

 

 

Please download attached MQL code file & Amibroker chart. I need help on converting same Amibroker AFL code into MQL code at the Trading system start position in the MQL code. right now I am not able to get same results in Metatrader which was I am getting in Amibroker. Please, Can any experienced MQL programmer help to resolve this code issue?

 

Note: This system generates buy/sell without vanishing. When buy/sell comes at some point it stays there so no fake signals.

 

Thank You

chart.thumb.JPG.7d5346db84a9a8be2a77ba7668f4725f.JPG

tradingexpert.mq4

Share this post


Link to post
Share on other sites

Right now I have coded this MQL code for above system.

 

val_high=High[iHighest(NULL,60,MODE_HIGH,6,0)]; // highest high

val_low=Low[iLowest(NULL,60,MODE_LOW,6,0)]; // lowest Low

res=iMA(NULL,0,Period_EMA,0,MODE_EMA,val_high,0); // variable res

sup=iMA(NULL,0,Period_EMA,0,MODE_EMA,val_low,0); // variale sup

 

 

if (iHigh(NULL,60,0)>res) // Current bar high crosses above res

{

a=1;

}

else

{

a=0;

}

if(sup>iLow(NULL,60,0)) // sup crosses above current bar Low

{

b=1;

}

else

{

b=0;

}

 

if (condition for buy) //

{ //

Opn_B=true; //

Cls_S=true; //

}

if (condition for sell) //

{ //

Opn_S=true; //

Cls_B=true; //

}

 

I want to know how to calculate or start counting number of bars since certain condition true for sometime till false value set. Say current close is greater than moving average close for say 5 bars in 1 hour chart including current bar when condition found to be true. How to calculate this number of "5" bars. I think this will solve my last code of part if I am able to count this numbers of bars after condition true till condition false .

Share this post


Link to post
Share on other sites

Hi nilu

 

Sorry if I can't help U

 

I'm learning AFL Language

 

I've added these 3 lines code 2 C on a chart your system

 

X MM System.txt is the complete working code 4 AmiBroker

 

Good luck

 

aaa

 

Plot( C, "", colorBlack, styleCandle ); 
shape = Buy * shapeUpArrow + Sell * shapeDownArrow;
PlotShapes( shape, IIf( Buy, colorBlue, colorYellow ), 0, IIf( Buy, Low, High ));

 

 

attachment.php?attachmentid=17047&stc=1&d=1262423074

X MM System.txt

Snap1.jpg.6d4fbc8bb117ebb18baf0ebbc9e0c99c.jpg

Share this post


Link to post
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.


  • Topics

  • Posts

    • AXON Enterprise stock, top of range breakout at https://stockconsultant.com/?AXON
    • FOUR Shift4 Payments stock with a solid breakout above 122.9, from Stocks to Watch at https://stockconsultant.com/?FOUR
    • EBS Emergent Biosolutions stock watch, pullback to 9.9 triple+ support area with bullish indicators at https://stockconsultant.com/?EBS
    • POAI Predictive Oncology stock with a bull flag breakout, target 2 area at https://stockconsultant.com/?POAI
    • Date: 18th February 2025.   UK Unemployment Rate Falls and The Pound Spikes Upwards.     The British Pound spikes upwards against all currencies as the UK releases its employment data. However, the latest employment data release does not give long-term confidence as the UK continues to see a higher possibility of economic stagnation in 2025. Can the GBP maintain momentum?   UK Releases Latest Employment Data! The UK employment data had its positive and negative points. The Monthly Unemployment Claims rose 22,000 which is at a 3 month high, and higher than analysts’ previous expectations. This is known to be negative for the British Pound. However, the UK also saw some positive data which investors are clinging onto. The UK Unemployment Rate fell for the first time since October 2024. The UK Unemployment Rate, to the surprise of analysts, fell from 4.5% to 4.4%. Lastly, the Average UK Salaries Index rose to 6.00%, the highest in 13 months and higher than previous expectations. This is the main reason why the GBP is increasing in value. That said, the Bank of England and economists continue to expect the UK to witness stagnation in 2025.     The British Pound The British Pound is now one of the best-performing currencies of the day so far. The US Dollar and Japanese Yen are also strongly increasing in value. The Governor of the Bank of England, Mr Bailey, is due to speak at 09:30 GMT and is likely to comment on the latest employment data.   Previously, Bailey described the UK’s economic growth as “static,” despite stronger-than-expected Q4 2024 data—0.1% growth instead of the forecasted –0.1% quarterly and 1.4% annually versus the expected 1.1%. Meanwhile, the BoE revised its 2025 GDP growth forecast down to 0.75% from 1.0% in November. Traders are also hoping Governor Bailey will comment on the possible future rate cuts.   Tomorrow at 09:00 (GMT+2), the UK will release January inflation data. Analysts expect the annual CPI to rise from 2.5% to 2.8%, while monthly prices may drop by 0.3% after a similar increase in December. The Core CPI is projected to climb from 3.2% to 3.6%.   When evaluating the GBP Index, the GBP is currently trading 0.95% higher in 2025. However, the upward price movement is largely due to last week’s Gross Domestic Product which beat expectations. The performance of the GBP will also depend on whether the US imposes tariffs. Additionally, pressure on the UK to increase defence spending could further strain the country's already scrutinized budget.   GBPUSD - Technical Analysis and Price Condition The GBPUSD is trading above the main moving averages on the 2-hour timeframe and is trading high on most oscillators. These factors indicate that the buyers are currently controlling momentum, but traders are concerned about two factors. The first is that the GBPUSD is struggling to break above the 1.26300 level and the fact that both the USD and GBP is simultaneously increasing in value. As both currencies are increasing in value, technical analysts view the price action as conflicting. On the 5-minute chart, the GBPUSD is trading at the 200-bar average price movement indicating a neutral signal. This also follows the concerns of traders that the price action is conflicting.     If the price breaks above 1.25918, the GBPUSD may witness sell signals materialize. However, if the price breaks above 1.26200, buy signals may arise which will also be in line with the indications on the 2-hour timeframe.   Key Takeaway Points: GBP rises as the UK employment data lifts GBP, but stagnation concerns remain. UK Salaries hit a 13-month high, boosting the Pound. The Bank of England Governor, Mr Bailey may hint at future rate cuts and advises the UK will witness economic stagnation. The key risks for the GBP remain inflation data, US tariffs, and UK defence spending pressure. Always trade with strict risk management. Your capital is the single most important aspect of your trading business.   Please note that times displayed based on local time zone and are from time of writing this report.   Click HERE to access the full HFM Economic calendar.   Want to learn to trade and analyse the markets? Join our webinars and get analysis and trading ideas combined with better understanding of how markets work. Click HERE to register for FREE!   Click HERE to READ more Market news.   Michalis Efthymiou HFMarkets   Disclaimer: This material is provided as a general marketing communication for information purposes only and does not constitute an independent investment research. Nothing in this communication contains, or should be considered as containing, an investment advice or an investment recommendation or a solicitation for the purpose of buying or selling of any financial instrument. All information provided is gathered from reputable sources and any information containing an indication of past performance is not a guarantee or reliable indicator of future performance. Users acknowledge that any investment in Leveraged Products is characterized by a certain degree of uncertainty and that any investment of this nature involves a high level of risk for which the users are solely responsible and liable. We assume no liability for any loss arising from any investment made based on the information provided in this communication. This communication must not be reproduced or further distributed without our prior written permission.
×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.