Gaussian Low Pass Filter
56 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
Steve
am 16 Jun. 2012
Kommentiert: Image Analyst
am 1 Nov. 2021
Hello Dear Experts,
I need to build a function performing the low pass filter: Given a gray scale image (type double) I should perform the Gaussian low pass filter. The filter size is given by a ratio parameter r. The values of the r parameter are between 0 and 1 - 1 means we keep all the frequencies and 0 means no frequency is passed. The DC should always stay.
Here is what I did:
function [nImg,mask] = lowPassFilter(img,r)
F = fftshift(fft2(img));
mask = fspecial('gaussian',[3 3], r);
M = fft2(mask, size(F,1), size(F,2));
Filtered = M.*F;
nImg = real(ifft2(ifftshift(Filtered)));
end
P.S Please tell me what I did wrong, I have been advised by Anton Semechko: "The are two fundamental ways you can perform linear filtering of an image. One approach is to use convolution in the spatial domain. The second approach is to find the product of the filter's and image's Fourier transforms in the frequency domain and then take the inverse. Now what you are attempting to do is more like the send approach. But I see two major problems with your code. First, you don't center the image on the DC component (see fftshift) after taking the FT. Secondly, you don't zero pad the filter to match the dimensions of the image."
Please tell me if I did it right or where are my mistakes. Maybe you have an example image to test on and compare to real right result that should be.
Will appreciate if your answer will be informative and straight to the point.
0 Kommentare
Akzeptierte Antwort
Image Analyst
am 17 Jun. 2012
A 3 by 3 filter is no where near large enough to filter out all frequencies. You just don't have the resolution. Think about it: Many Gaussians that can fit inside a 3x3 box will have their "tails" clipped off by the edges of the box. And super narrow Gaussians are so quantized with only three sample points that you can't get the frequency resolution that you need. And of course there is still the problem that Anton mentioned that you didn't fix, which is you performed fftshift() on the spectrum of img but not on the spectrum of mask.
2 Kommentare
Image Analyst
am 17 Jun. 2012
The fftshift()'s are not necessary at all for the multiplication. They are only needed for display, which you aren't even doing at all in your function. The arrays will multiply just fine with the origin at the corners instead of the center.
Weitere Antworten (1)
Habtamu Fanta
am 1 Nov. 2021
function [nImg,mask] = lowPassFilter(img,r)
F = fftshift(fft2(img));
\mask = fspecial('gaussian',[3 3], r);
M = fft2(mask, size(F,1), size(F,2));
Filtered = M.*F;
nImg = real(ifft2(ifftshift(Filtered)));
end.
1 Kommentar
Image Analyst
am 1 Nov. 2021
@Habtamu Fanta, I'm not sure how this is an answer. You just introduced a couple of errors (bad characters) into the original poster's code - that's all. It doesn't fix or address either of the two items mentioned by Steve's advisor professor.
Siehe auch
Produkte
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!