How to use FFT in matlab using imported data in time domain excel file

9 vues (au cours des 30 derniers jours)
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 commentaires
Linda Yakoubi
Linda Yakoubi le 10 Mai 2017
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 ?
Adam
Adam le 10 Mai 2017
doc fft
is the best place to start!

Connectez-vous pour commenter.

Réponse acceptée

Star Strider
Star Strider le 8 Mar 2017
Use the examples in the documentation on fft (link) to calculate the Fourier transform.
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 commentaires
Jonathan James-Gunn
Jonathan James-Gunn le 9 Juin 2024
@Star Strider Thank you! I really appreciate the help.
Star Strider
Star Strider le 9 Juin 2024
My pleasure!
A Vote would be appreciated!

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur MATLAB dans Help Center et File Exchange

Tags

Community Treasure Hunt

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

Start Hunting!

Translated by