How to use FFT in matlab using imported data in time domain excel file
9 ビュー (過去 30 日間)
古いコメントを表示
I have used a multimeter to measure my phototransistor and I got one excel file with time versus Magnitude. But I got some noise, so I want to use Matlab to do FFT from time domain to frequency domain(frequency versus magnitude) called Photorespone. I attach my file as below. I wanna make this kind of figure, freq versus amplitude.

3 件のコメント
Linda Yakoubi
2017 年 5 月 10 日
I have a similar task. I already imported the data from excel in Matlab but I don't know what to do next and how to use the function "fft()". Any ideas ?
採用された回答
Star Strider
2017 年 3 月 8 日
Example Code For Your Signal —
[d,s] = xlsread('1.5V.csv');
t = d(:,1)*1E-3; % Convert To ‘seconds’ From ‘milliseconds’
v = d(:,2); % Voltage (?)
L = length(t);
Ts = mean(diff(t)); % Sampling Interval (sec)
Fs = 1/Ts; % Sampling Frequency
Fn = Fs/2; % Nyquist Frequency
vc = v - mean(v); % Subtract Mean (‘0 Hz’) Component
FTv = fft(vc)/L; % Fourier Transform
Fv = linspace(0, 1, fix(L/2)+1)*Fn; % Frequency Vector (Hz)
Iv = 1:length(Fv); % Index Vector
figure(1)
plot(Fv, abs(FTv(Iv))*2)
grid
xlabel('Frequency (Hz)')
ylabel('Amplitude (V?)')
I did not post the plot, since my code will plot the Fourier transform of your data.
12 件のコメント
その他の回答 (0 件)
参考
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!



