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.

BlueHorseshoe

Getting A Value Out Of A Loop

Recommended Posts

Hello,

 

I have a variable, X, the value for which is dependent on an input, N. I want to vary the input, and then return the input value that generates the maximum value for X.

 

I can obviously vary the input as follows:

 

For N=A to B begin . . . X= . . . End;

 

But for this range of N, how do I then return the value N that gives the maximum value for X?

 

Any help would be greatly appreciated.

 

BlueHorseshoe

Share this post


Link to post
Share on other sites

from my basic programming....

you need a simple 'compare' within the loop

 

eg;

MaxX=0

MaxNValue=0

 

for N=A to B begin

X=formula....

'Compare values and assign.....

if X>MaxX then 'this is only triggered at the start and if X>MaxX

MaxX=X

MaxNValue=N

end if

next N 'loop returns

Share this post


Link to post
Share on other sites
from my basic programming....

you need a simple 'compare' within the loop

 

eg;

MaxX=0

MaxNValue=0

 

for N=A to B begin

X=formula....

'Compare values and assign.....

if X>MaxX then 'this is only triggered at the start and if X>MaxX

MaxX=X

MaxNValue=N

end if

next N 'loop returns

 

Hi SIUYA,

 

This seems the obvious way, but unfortunately it doesn't seem to work in EasyLanguage. I am unable to suss out why, but basically it will return the first X greater than the initial MaxX or a MaxNValue equal to B . . . I tried moving the formula out to a seperate function, but it won't run a function with a variable input within a loop . . .

 

All very frustrating, but thanks for your help!

 

BlueHorseshoe

Share this post


Link to post
Share on other sites

I have no clue about easy language,only C,but have you tried putting the resulting values of X in an array over which you have a sort algo run afterwards and then have the largest value returned?

Share this post


Link to post
Share on other sites
Hello,

 

I have a variable, X, the value for which is dependent on an input, N. I want to vary the input, and then return the input value that generates the maximum value for X.

 

I can obviously vary the input as follows:

 

For N=A to B begin . . . X= . . . End;

 

But for this range of N, how do I then return the value N that gives the maximum value for X?

 

Any help would be greatly appreciated.

 

BlueHorseshoe

 

you have to be more explicit about what you want to do,

otherwise there is very little people can help.

Share this post


Link to post
Share on other sites

ditto Tams

like how many in N? if it's only two A and B then you don't need loop, etc.

 

pls post the code you developed from BHS' suggestion

(leaving out how you're getting X if it is proprietary...etc)

his 'logic' is sound so we may be just looking for a bug

Share this post


Link to post
Share on other sites
you have to be more explicit about what you want to do,

otherwise there is very little people can help.

 

ditto Tams

like how many in N? if it's only two A and B then you don't need loop, etc.

 

pls post the code you developed from BHS' suggestion

(leaving out how you're getting X if it is proprietary...etc)

his 'logic' is sound so we may be just looking for a bug

 

Here is the code, with a logic virtually identical to that suggested by SIUYA earlier in the thread:

 


MaxE=0;
MaxValue1=0;

For Value1=1 to 50 begin

If E>MaxE then
MaxE=E
Else
MaxE=MaxE;

If P<Value1 and P[1]>Value1 then begin
If M[1]=0 then
M=1
Else
M=M[1];
End
Else
M=M[1];

If P>Var2 and P[1]<Var2 then
M=0;

If M[1]=0 and M=1 then
B=C
Else
B=B[1];

If M[1]=1 and M=0 then
E=E[1]+(C-B)
Else
E=E[1];


If E>MaxE then
MaxValue1=Value1
Else
MaxValue1=MaxValue1;

End;

Plot1(MaxValue1);

 

As far as I can work out this should return the value for Value1 that is associated with the maximum value for E. What am I missing? Why doesn't this work?

 

I have been banging my head against a wall with this for several days now, so any help would be greatly appreciated.

 

Thanks,

 

BlueHorseshoe

 

ps As per ZDO's suggestion I have done this 'manually' with code for a handful of values and it works perfectly - but I want to be able to run a wide range of values without needing pages and pages of repetitive code.

Edited by BlueHorseshoe

Share this post


Link to post
Share on other sites
this might be totally useless as i dont know enough EL - but it looks like you will have an END in the wrong spot. :2c:

 

Yes, I'm guessing it's going to be something stupid like that and someone else will spot it instantly.

 

:doh:

 

BlueHorseshoe

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

    • Date: 22nd November 2024.   BTC flirts with $100K, Stocks higher, Eurozone PMI signals recession risk.   Asia & European Sessions:   Geopolitical risks are back in the spotlight on fears of escalation in the Ukraine-Russia after Russia reportedly used a new ICBM to retaliate against Ukraine’s use of US and UK made missiles to attack inside Russia. The markets continue to assess the election results as President-elect Trump fills in his cabinet choices, with the key Treasury Secretary spot still open. The Fed’s rate path continues to be debated with a -25 bp December cut seen as 50-50. Earnings season is coming to an end after mixed reports, though AI remains a major driver. Profit taking and rebalancing into year-end are adding to gyrations too. Wall Street rallied, led by the Dow’s 1.06% broadbased pop. The S&P500 advanced 0.53% and the NASDAQ inched up 0.03%. Asian stocks rose after  Nvidia’s rally. Nikkei added 1% to 38,415.32 after the Tokyo inflation data slowed to 2.3% in October from 2.5% in the prior month, reaching its lowest level since January. The rally was also supported by chip-related stocks tracked Nvidia. Overnight-indexed swaps indicate that it’s certain the Reserve Bank of New Zealand will cut its policy rate by 50 basis points on Nov. 27, with a 22% chance of a 75 basis points reduction. European stocks futures climbed even though German Q3 GDP growth revised down to 0.1% q/q from the 0.2% q/q reported initially. Cryptocurrency market has gained approximately $1 trillion since Trump’s victory in the Nov. 5 election. Recent announcement for the SEC boosted cryptos. Chair Gary Gensler will step down on January 20, the day Trump is set to be inaugurated. Gensler has pushed for more protections for crypto investors. MicroStrategy Inc.’s plans to accelerate purchases of the token, and the debut of options on US Bitcoin ETFs also support this rally. Trump’s transition team has begun discussions on the possibility of creating a new White House position focused on digital asset policy.     Financial Markets Performance: The US Dollar recovered overnight and closed at 107.00. Bitcoin currently at 99,300,  flirting with a run toward the 100,000 level. The EURUSD drifts below 1.05, the GBPUSD dips to June’s bottom at 1.2570, while USDJPY rebounded to 154.94. The AUDNZD spiked to 2-year highs amid speculation the RBNZ will cut the official cash rate by more than 50 bps next week. Oil surged 2.12% to $70.46. Gold spiked to 2,697 after escalation alerts between Russia and Ukraine. Heightened geopolitical tensions drove investors toward safe-haven assets. Gold has surged by 30% this year. Haven demand balanced out the pressure from a strong USD following mixed US labor data. Silver rose 0.9% to 31.38, while palladium increased by 0.9% to 1,040.85 per ounce. Platinum remained unchanged. 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. Andria Pichidi 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 FX and CFDs 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.
    • A few trending stocks at support BAM MNKD RBBN at https://stockconsultant.com/?MNKD
    • BMBL Bumble stock watch, pull back to 7.94 support area with high trade quality at https://stockconsultant.com/?BMBL
    • LUMN Lumen Technologies stock watch, pull back to 7.43 support area with bullish indicators at https://stockconsultant.com/?LUMN
×
×
  • Create New...

Important Information

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