필터 지우기
필터 지우기

for loop for 15x2045 matrix

조회 수: 2 (최근 30일)
Sag
Sag 2016년 2월 16일
댓글: Sag 2016년 2월 18일
I am trying to run fft function for every row of 15x2045 matrix. 13 out of 15 rows have NaN as the last element (2045th element) How I can do it? so far I have tried this:
for k = 1:length(Final) %Final is 15x2045 matrix (I have converted a cell to this matrix)
HH = fft(Final{k},NFFT)/L;
power=(2*abs(HH(1:NFFT/2+1)));
end
%error I get is:Cell contents reference from a non-cell array object.
I appreciate any help, Thanks!

채택된 답변

Walter Roberson
Walter Roberson 2016년 2월 17일
편집: Walter Roberson 2016년 2월 17일
for k = 1 : size(Final,1) %Final is 15x2045 matrix (I have converted a cell to this matrix)
HH(k,:) = fft(Final(k,:),NFFT)/L;
Fpower(k,:) = (2*abs(HH(k,1:NFFT/2+1)));
end
I renamed power to Fpower to avoid interfering with the MATLAB function named power (which is more commonly known as the .^ operator)
Note: you do not need to do this column by column. You can vectorize it as
HH = fft(Final, NFFT, 2)./L;
Fpower = 2 * abs(HH(:,1:NFFT/2+1));
  댓글 수: 7
Walter Roberson
Walter Roberson 2016년 2월 18일
You need to expect NaN as the result for any row of Final that has a NaN in it. NaN "pollutes" or "taints" any calculation that it takes part in. Think of NaN as meaning "Any calculation involving this value is an error!". FFT has to determine contributions at various frequencies and with a data value that is error, it is not possible to determine the contributions.
If you are using NaN as a place-holder indicating that the data is missing or unknown and that the calculation should try to proceed without that data point, then FFT is the wrong calculation routine to use. You need to use a non-uniform FFT for such a situation. See http://www.mathworks.com/matlabcentral/fileexchange/25135-nufft--nfft--usfft and http://www.mathworks.com/matlabcentral/answers/113873-non-uniform-fft-with-matlab
Sag
Sag 2016년 2월 18일
Thanks!

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

태그

Community Treasure Hunt

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

Start Hunting!

Translated by