MATLAB: Mean Amplitude of the signal

amplitudefftmean amplitudesignal

Hi, My problem is to calculate mean amplitude of the signal and plot it on the graph with signal course. Below you can see my source code:
y % signal vector, where [3083 1]= size(y)
Fs=100;
L=length(y);
NFFT = 2^nextpow2(L);
Y = fft(y,NFFT)/L;
f = Fs/2*linspace(0,1,NFFT/2+1);
n1=1/100; %1
m1=L/100; %end
[a b]=size(y);
nov=(m1-n1)/(a-1);
x=n1:nov:m1;
figure
subplot(2,1,1)
plot(f,2*abs(Y(1:NFFT/2+1)),color) % amplitude spectrum
subplot(2,1,2)
plot(x,y,'b') % course of the signal
Could you tell me how can I calculated mean amplitude based on this? Or maybe there exists another way to find it? When I used mean(abs(Y(1:NFFT/2+1))) and ploted it on the second subplot it was far away from signal…

Best Answer

Hi Karolina, No, it's proportional to the amplitude squared of the Fourier coefficients. You can get amplitude estimates like this:
t = 0:0.01:5-0.01;
x = cos(2*pi*4*t)+1/2*cos(2*pi*8*t)+randn(size(t));
xdft = fft(x);
xdft = (2/length(x))*xdft(1:length(x)/2+1);
Now, you have to be able to figure out that the 4-Hz component lives in DFT bin (21) and the 8-Hz component lives in DFT bin (41)
abs(xdft(21))
abs(xdft(41))
Give you the amplitude estimates for those frequencies.
abs(xdft(16:51))
Gives you the amplitude estimates for 3-10 Hz.
Note that the spacing between DFT bins ist Fs/N where Fs is the sampling frequency and N is the length of the signal.
Related Question