Effacer les filtres
Effacer les filtres

Info

Cette question est clôturée. Rouvrir pour modifier ou répondre.

How can I fix this error?

1 vue (au cours des 30 derniers jours)
Ghazal Hnr
Ghazal Hnr le 12 Mar 2017
Clôturé : MATLAB Answer Bot le 20 Août 2021
Hello, I wrote this code:
figure(3)
dt = 0.001;
T = 60;
t = [0:dt:T] ;
omega0 = 2 * pi / T;
for k = 1:20
ck = cos (k * omega0 * t); % cosine component
a(k) = 2/T * ( sum (ECG_ac.*ck) * dt);
sk = sin (k * omega0 * t); % sine component
b(k) = 2/T * ( sum (ECG_ac.*sk) * dt);
end
magnitude = sqrt(a.^2 + b.^2);
plot(magnitude)
but i have this error:
Error using .*
Matrix dimensions must agree.
Error in Q2ECG (line 40)
a(k) = 2/T * ( sum (ck.*ECG_ac) * dt);
what's wrong?
Thanks for your help

Réponses (2)

Roger Stafford
Roger Stafford le 12 Mar 2017
Judging by your error message, the two arrays, ck and ECG_ac, have different sizes. That's a no-no.
  4 commentaires
Roger Stafford
Roger Stafford le 13 Mar 2017
Just change dt:
dt = linspace(0,T,15000);
Ghazal Hnr
Ghazal Hnr le 13 Mar 2017
I have the same error again!

Walter Roberson
Walter Roberson le 13 Mar 2017
T = 60;
t = linspace(0,T,length(ECG_ac));
dt = t(2)-t(1);
omega0 = 2 * pi / T;
for k = 1:20
ck = cos (k * omega0 * t); % cosine component
a(k) = 2/T * ( sum (ECG_ac.*ck) * dt);
sk = sin (k * omega0 * t); % sine component
b(k) = 2/T * ( sum (ECG_ac.*sk) * dt);
end
magnitude = sqrt(a.^2 + b.^2);
plot(magnitude)

Cette question est clôturée.

Community Treasure Hunt

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

Start Hunting!

Translated by