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.

andypap

Arrays Question

Recommended Posts

hi

 

does anybody knows how to assign the value of the last element of each column in an array in the first element of the following column:

array:myarray[9,n](0);

myarray[0,1]=myarray[9,0];

myarray[0,2]=myarray[9,1] etc till n i reached,and have the loop initiating the values assigned in myarray 0 column continuing the loop for the following columns essentially starting from last element of previous column which now is the first element in current column?

also is it possible to sum the values in an array row?

Share this post


Link to post
Share on other sites

andypap, Please rephrase your question. Maybe do a 3 element representative example of all the loops and ops you want performed...thx

Share this post


Link to post
Share on other sites

I always use this method in planning my codes:

 

1. write out ONE action at a time

2. write out ONE action per sentence

 

if you can do that, maybe I can help.

Share this post


Link to post
Share on other sites

a simple for n = 1 to i loop should do what you require. If you need to manipulate rows and elements use nested loops (n = 1 to I and m = 1 to j:). To accumulate sums simply add the elements to a variable within the loop. As others have said I am not sure precisely what you want to do but loops will do it for you. You should be able to use the modulus function if you need an element to 'wrap round'. e.g. for n = 1 to 20 a[n] = a[mod(n+7)] shifts all elements back 9 places and wraps the first 7 elements to the end of the array.

Share this post


Link to post
Share on other sites

thanks for the responses guys,i will try to exlpain more in detail.

i am quite new in el and its hard for me to understand everything at once so i need an actual example of the code lines..

here is what i try to accomplish:

 

array:myarray[9,n](0);

if the value assigned to myarray[9,0] through this loop is the close[10]

 

for value1=0 to 9 begin

myarray[value1,0]=close[value1];end;

 

then

i want to "reloop" in a manner that second column first element will pick up where last element of previous column was so the result will be:

myarray[0,1]=myarray[9,0][1];=close[11]

myarray[0,2]=myarray[9,1][1];=close[21]

my array[0,3]=myarray[9,2][1];=close[31] etc till n is reached.

essentialy this will carry the loop to jump to the first element of the following column as if it was " myarray[10,0]"etc.

 

then i want to be able to acces the values of anyrow number from

column 0 to column N in manner that i can sum

myarray[9,0]+myarray[9,1]+myarray[9,2] ....to n/N..

voila IF N=14 this is the 15min moving average of the close in one min chart if 1 min is the source data for the array.

its something similar to compressseries indicator in various software.

Edited by andypap

Share this post


Link to post
Share on other sites

If you want to fill the array from the first element and once it gets to the last one then go back to the beginning again something like will do it.

 

 

Array[ Round(barnum/7,0) , mod(barnum,7) ] = close; // Fills a 7X7 array.

 

 

to sum the last N elements/closes

 

sum = sum + close - close[n]

 

This will be unstable until you have N bars

 

These will do the there stuff as data arrives.

 

 

To to loop through the array to get the sum (again 7*7) rather than store it as it arrives.

 

for n = 0 to 7-1 begin

for m = 0 to 7-1 begin

sum = sum + Array[n,m];

end;

end;

 

Still not sure exactly what you are up to but hopefully if you look at the ideas behind the above you should get a few yourself.

Share this post


Link to post
Share on other sites

thanks blowfish.. the nested loop gave me a solution.

first i did a dynamic array and set maxlen to 390 via an input:seieslen(390);

 

then i used an if condition before the nested loop:

 

if .....then

for n=0 to serieslen-1 begin

myarray[n]=close[n];

for m=o to serieslen-1 begin

myarray[m]=myarray[n][m];

end;end;

plot1(myarray[serieslen-1];

that did the job of storing the values every 390 bars starting from current bar backwards,

if applyied to 1 min chart it gives you the close of last 1min bar of day and the first 389 have a value of zero.so if you sum the 390 bars what you get is the closing value of the last bar.if you sum 5*390 bars you have a 5 day mov average builded from 1 min bars.

so the indicator is working ok.

 

i am thinking though that this doesnt answer my second question of a more general form..

is it possible and how in EL to access the values of a row in a two dimension array of 7 columns lets say ( 0 to 6) in a manner as if they where the elements of a column?

i will try to make this visible

if the row is 10 of array:myarray[10,6];

then imagine these row elements accumulated as if they look like a column

 

array[10,0]

array[10,1]

array[10,2]

array[10,3]

 

down to

 

array[10,6]

 

thanks again

Share this post


Link to post
Share on other sites

Not really sure what you are trying doing but something similar to

 

sum = 0

for n = 0 to 6 sum = sum+array[10,n]

 

would do the job.

 

Or are you trying to rotate the array?

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: 17th May 2024. Market News – Asian and European futures followed Wall Street lower. Economic Indicators & Central Banks:   The Dow topped 40,000 for the first time ever, but was unable to close with that historic handle. Concurrently, the S&P tried for its 24th record high this year but failed too. The rise in Treasury yields after stronger than expected import prices, and a drumbeat from Fed officials that rates need to remain high for longer, encouraged profit taking. Most Asian equity markets and European futures have followed Wall Street lower, after US data dented rate cut hikes. Chinese data showing slowed consumption and a drop in home sales, although industrial production numbers looked relatively robust. Japan’s core consumer inflation slowed for a 2nd month in a row in April from a year earlier, while the core consumer prices index (CPI) is expected to decelerate to 2.2% from 2.6% in March, the lowest level in 3 months, but still at or above the central bank’s 2% target for more than two years. Financial Markets Performance: The USDIndex firmed slightly to 104.518 and up from the day’s nadir of 104.080. But it held a 104 handle for a second straight day. It traded above the 105 level from April 10 until May 15. Silver has surged nearly 25% this year, outpacing Gold and becoming a top-performing commodity, though it remains relatively inexpensive compared to gold. Both metals have hit record highs due to central-bank buying and increased interest in China. USOil is 0.75% higher at $79.23. Market Trends:   All three major US indexes closed slightly in the red after posting all-time highs on Wednesday. The NASDAQ closed with a -0.26% decline, while the S&P500 lost -0.21%, and the Dow was off -0.1% at 39,869. It was a corrective day for Treasuries too. Bonds unwound part of their recent rally that took rates down to the lows since early April. 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 on how markets work. Click HERE to register for FREE! Click HERE to READ more Market news. Andria Pichidi Market Analyst 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.
    • GOTU Gaotu Techedu stock breakout, https://stockconsultant.com/?GOTU
    • FSLR First Solar stock bull flag breakout watch, https://stockconsultant.com/?FSLR
    • VLO Valero Energy stock attempting to move higher off the 156.97 support area, high trade quality, https://stockconsultant.com/?VLO
    • RCL Royal Caribbean stock top of range breakout watch , https://stockconsultant.com/?RCL
×
×
  • Create New...

Important Information

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