Help with loops _ multiple variables
2 vues (au cours des 30 derniers jours)
Afficher commentaires plus anciens
Maddison Wagner
le 11 Nov 2018
Modifié(e) : Stephen23
le 12 Nov 2018
I’ve been trying to write a loop where the below equations will take place for each of the 4 values in the arrays below ie x1 is first calculated with the first value of each and then calculated with the 2nd values of each, etc. I keep getting a result that moves to the end of the loop and repeats the calculation for x1 using all variables instead of just the appropriate variable of each array. Not expecting someone to write the code but an example using loops for several variables and arrays would be great .
Sm1= [2;3;1;4];
Fc1 = [5;2;3;7];
A1= [1;4;1;2];
Fs = 60;
t1 = (0:sm1-1)/Fs;
x1 = A1*cos(2*pi*Fc1*t1);
For sm1(1:end)
t1 = (0:sm1-1)/Fs;
End
For A1(1:end
For Fc1(1:end)
x1 = A1*cos(2*pi*Fc1*t1);
End
End
0 commentaires
Réponse acceptée
Stephen23
le 11 Nov 2018
Modifié(e) : Stephen23
le 11 Nov 2018
Use indexing and vectorize the appropriate operations:
Sm1 = [2;3;1;4];
Fc1 = [5;2;3;7];
A1 = [1;4;1;2];
Fs = 60;
N = numel(A1);
C = cell(1,N); % optional.
for k = 1:N
t1 = (0:Sm1(k)-1)/Fs
x1 = A1(k).*cos(2*pi*Fc1(k)*t1)
... your code here
C{k} = x1; % optional: store the vector x1.
end
2 commentaires
Stephen23
le 12 Nov 2018
Modifié(e) : Stephen23
le 12 Nov 2018
"...I’m attempting to concatenate each x1 value into a single column..."
The easiest way to get one single column as the output is to collect the intermediate vectors into the cell array, and concatenate them after the loop:
C = cell(1,N);
for k = 1:N
...
C{k} = x1(:);
end
V = vertcat(C{:});
Gives:
>> V
V =
1.00000
0.86603
4.00000
3.91259
3.65418
1.00000
2.00000
1.48629
0.20906
-1.17557
Read more about how that concatenation works:
Plus de réponses (1)
madhan ravi
le 11 Nov 2018
"Not expecting someone to write the code but an example using loops for several variables and arrays would be great"
0 commentaires
Voir également
Catégories
En savoir plus sur Loops and Conditional Statements dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!