How to design a 5by5 ,5cross and X-1 median filter

I need to filter speckle noise from a noisy image by the application of 5*5 median filter,cross shaped median filter and a X-1 shaped median filter. I just cannot understand and do the code for it. Request for code.Thank you.

 Accepted Answer

Anand
Anand on 23 Mar 2013
Edited: Anand on 25 Mar 2013
You can use the following two functions:
Here's an example:
out = medfilt2(im,[5 5]); %5x5 neighborhood
For a neighborhood that is not all 1's, use
nhood = [1 0 0 0 1;...
0 1 0 1 0;...
0 0 1 0 0;...
0 1 0 1 0;...
1 0 0 0 1;];
out = ordfilt2(im,ceil(nnz(nhood)/2),nhood); %cross-shaped neighborhood

8 Comments

Thank you Anand.Going by your idea,I implemented a 5x5 Plus shaped and your Cross shaped mask.Both of them give a black image as output after filtering!Is there something wrong?
How do you know? Did you examine the variable, or did you just use imshow()? If you used imshow, then it may be because it's a floating point array and floating point arrays need to use [], like imshow(medianFilteredArray, []); though you would probably get all white rather than all black.
filtered_img =ordfilt2(gaus_noiseimg,ceil(numel(nhood_cross)/2),nhood_cross); imshow(filtered_img) is what I did and it outputs a black image.The 5x5 median filtered works fine by using the medfilt2 command.
As ImageAnalyst suggested, try
imshow(filtered_img,[])
chitra, you did not answer my question about whether you actually examined the variable, and you did not take my suggestion about how to use imshow(). Why did you ignore my attempt to help you? Try this:
maxValue = max(filtered_img(:)) % Don't use a semicolon
minValue = min(filtered_img(:)) % Don't use a semicolon
What do you see in the command window?
I did imshow(filtered_img) the output of which is a black image. The values of maxValue = 0 and minValue = 0. The original iamge is subjected to speckle noise and I intend to filter is with a cross shaped/plus filter.
I just realized the mistake in my call to ordfilt2. Here's how you use it:
out = ordfilt2(im,ceil(nnz(nhood)/2),nhood);
The domain has nnz(nhood) non-zero elements, and so the median is the (nnz(nhood)/2)th element.
Yes now it works.So,could you please explain why you are dividing the mask by 2 and using nnz?

Sign in to comment.

More Answers (0)

Asked:

on 23 Mar 2013

Community Treasure Hunt

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

Start Hunting!