Я пытаюсь понять, как работает нормализация MATLAB FFT.Matlab FFT2 нормализация после обработки
Давайте обсудим следующий пример.
%%
sum2D = @(a) sum(reshape(a,1,[])); % sum elements in 2D matrix
a = [0 0 0; 1 2 1; 1 1 1; 1 1 1; 0 0 0]
f1 = fft2(a)
m = [0 32 0; 0 0 0; 0 1 0; 0 2 0; 0 0 0]
fs = m.*fftshift(f1);
fs = fs./sqrt(numel(fs));
fm = ifft2(fs);
fm = fm.*sqrt(numel(fm))
% imshow(abs(fs))
norm(a(:))^2,norm(fs(:))^2,norm(fm(:))^2
sum2D(abs(a).^2)
sum2D(abs(fs).^2)
sum2D(abs(fm).^2)
sum2D(abs(fp).^2)
Если т = 1, нормализация работы и энергия одинакова в начальный сигнал, и FFT обратного БПФ. Но если я умножу сигнал после создания fft на некоторый вектор m, то я не знаю, как нормализовать это снова.
Если энергия изменяется после умножения на m, или я делаю что-то неправильно.