Nested for loop troubles

2 visualizzazioni (ultimi 30 giorni)
Cary
Cary il 29 Giu 2015
Commentato: Walter Roberson il 30 Giu 2015
Hi Everyone,
I am having difficulty troubleshooting a nested for loop. Things work fine on the first pass (when i=49) but break down on the second pass (when i=50). More specifically, instead of appending to consolFut1 on the second pass, it overwrites the data from the first pass. Can anyone spot the error? Thanks for reading.
for i = 49:52
exp=find(tifDate==expDate(i));
for j = [1; 18; 43; 63]
tifCls1 = tifCls(j:exp);
for k = [1112; 1129; 1154; 1174]
consolFut1=consolFut(k:expDateIdx(i),i);
arbTIF=tifCls1-consolFut1;
break;
end
end
end
  2 Commenti
James Tursa
James Tursa il 29 Giu 2015
Modificato: James Tursa il 29 Giu 2015
What are the dimensions of your variables? The usual procedure is to pre-allocate an array to contain the outputs from each iteration. I assume the break statement is there for debugging, because as written it will always exit the k loop on the first iteration.
Cary
Cary il 30 Giu 2015
I would be really grateful to anyone who can help me solve this issue. I've spent all day and night trying to fix it. On the second pass, consolFut1 overwrites the column instead of adding to the bottom of it. I don't understand why it does this as tifCls1 works perfectly. Thank you for your time. I sincerely appreciate it.

Accedi per commentare.

Risposte (1)

Image Analyst
Image Analyst il 29 Giu 2015
Nothing on the left hand side of your equations takes an index, so they all get overwritten at each iteration. Add an index if you want to store the different values.
exp is a built in function. Don't use it as the name of a variable!
  4 Commenti
Cary
Cary il 29 Giu 2015
I'm not trying to append to the right. On the first pass the data is stored in consolFut1 (a column). On the second pass, instead of appending to the bottom of the column, it overwrites the data from the beginning. The column should be getting longer and longer with each pass, while keeping the old data.
Walter Roberson
Walter Roberson il 30 Giu 2015
consolFut1 = [ consolFut1; consolFut(k:expDateIdx(i), i).' ];
Having multiple elements in the first dimension of the consolFut is for selecting part of a row. If you want those elements to be written into a column then you need to transpose the row to become a column.

Accedi per commentare.

Categorie

Scopri di più su Loops and Conditional Statements in Help Center e File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by