energy of a signal in t and f domain

5 views (last 30 days)
Ray Lee
Ray Lee on 3 Dec 2014
Answered: Paul on 10 Nov 2024 at 4:22
The energy of a signal is expected to be the same in t and f domain.
n = 1e4;
dx = 0.25;
x = rand(n,1) -0.5;
ex = sum(x.^2) *dx; % energy in t domain
y = fft(x);
fs = 1/dx;
df = fs/n;
ya = abs(y);
ey = sum(ya.^2) *df; % energy in f domain
but from the code, ey/ex=16, exactly the squared fs.
what's the problem?

Accepted Answer

Star Strider
Star Strider on 3 Dec 2014
You need to normalise the fft by dividing it by the length of the signal:
y = fft(x)/length(x);
See the documentation for fft for details.
  2 Comments
Ray Lee
Ray Lee on 4 Dec 2014
Before, I got ey/ex=16
after normalization, I got ey/ex=1.6000e-07
Ray Lee
Ray Lee on 5 Dec 2014
it seems y = fft(x) / fs

Sign in to comment.

More Answers (2)

Ray Lee
Ray Lee on 5 Dec 2014
I found the solution myself.
Normalizing spectral amplitude by fs will work.
But I don't know why to do this.

Paul
Paul on 10 Nov 2024 at 4:22
For a finite duration signal x[n] of length N, and its Discrete Fourier Transform (DFT) X[k] (as computed by fft), the energy relationship is given by Parseval's Theorem: sum(abs(x[n]^2)) = sum(abs(X[k])^2))/N
n = 1e4;
dx = 0.25;
x = rand(n,1) -0.5;
%ex = sum(x.^2) *dx; % energy in t domain
y = fft(x);
fs = 1/dx;
%df = fs/n;
%ya = abs(y);
%ey = sum(ya.^2) *df; % energy in f domain
Parseval's Theorem:
[sum(abs(x).^2) sum(abs(y).^2)/n]
ans = 1×2
825.5910 825.5910
<mw-icon class=""></mw-icon>
<mw-icon class=""></mw-icon>
If the first term is multiplied by dx, then the second must also be multiplied by dx = 1/fs
[sum(abs(x).^2)*dx sum(abs(y).^2)/n/fs]
ans = 1×2
206.3977 206.3977
<mw-icon class=""></mw-icon>
<mw-icon class=""></mw-icon>

Community Treasure Hunt

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

Start Hunting!