How does nufft function work in matlab?
11 ビュー (過去 30 日間)
古いコメントを表示
I am trying to understand how to use nufft function. For this, I started by comparing the results of the fft and nufft transforms of a Gaussian to see if they yield the same result. I find that for a spacing in t space that is not unity, they yield different results. The exmple in MATLAB for nufft also has unit spacing between the t coordinates. Does nufft function not work for non-unit spacing? This would be a problem for me since the next step is to get the fourier transform of a gaussian with different spacings in the t space, i.e, dt varies for each element.
Thank you.
tmax = 12;
n = 2^11;
tau = 1; % Width of the gaussian pulse
dt = 2*tmax/n;
t = (-tmax:dt:tmax-dt);
fmax = 1/(2*dt);
df = 2*fmax/n;
f = -fmax:df:fmax-df;
Pulse = exp(-(t/tau).^2);
%Pulse = sin(t/tau);
fftPulse = ifftshift(fft(Pulse));
subplot(2,1,1)
plot(t,Pulse)
subplot(2,1,2)
plot(f,abs(fftPulse)); hold on;
nufftPulse = ifftshift(nufft(Pulse,t));
plot(f,abs(nufftPulse))
4 件のコメント
回答 (1 件)
Paul
2024 年 6 月 29 日
tmax = 12;
n = 2^11;
tau = 1; % Width of the gaussian pulse
dt = 2*tmax/n;
t = (-tmax:dt:tmax-dt);
fmax = 1/(2*dt);
df = 2*fmax/n;
f = -fmax:df:fmax-df;
Pulse = exp(-(t/tau).^2);
%fftPulse = ifftshift(fft(Pulse));
fftPulse = fftshift(fft(ifftshift(Pulse)));
nufftPulse = nufft(Pulse,t,f);
figure
subplot(2,1,1)
% plot the phase of the transform instead of the original signal
%plot(t,Pulse)
plot(f,angle(fftPulse),f,angle(nufftPulse));
subplot(2,1,2)
plot(f,abs(fftPulse)); hold on;
plot(f,abs(nufftPulse))
The hair on the angle plot is just numerical noise that results from taking the angle of complex number that has very small magnitude. At low frquencies where the magnitude isn't small we see that the angle is essentially zero as would be expected.
0 件のコメント
参考
カテゴリ
Help Center および File Exchange で Fourier Analysis and Filtering についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!