File Exchange

image thumbnail

Soft thresholding for image segmentation

version 4.0 (14.5 KB) by

Image segmentation based on histogram soft thresholding

4.71429
7 Ratings

51 Downloads

Updated

View License

FTH is a fuzzy thresholding method for image segmentation. The method is based on relating each pixel in the image to the different regions via a membership function, rather than through hard decisions. The membership function of each of the regions is derived from a fuzzy c-means centroid search. As a consequence, each pixel will belong to different regions with a different level of membership. This feature is exploited through spatial processing to make the thresholding robust to noisy environments.
Method proposed in:
Aja-Fernández, S., A. Hernán Curiale, and G. Vegas-Sánchez-Ferrero, "A local fuzzy thresholding methodology for multiregion image segmentation", Knowledge-Based Systems, vol. 83, pp. 1-12, 07/2015.
URL http://www.sciencedirect.com/science/article/pii/S095070511500129X
DOI 10.1016/j.knosys.2015.02.029

This new version is highly improved.

New Version, 4.0

Comments and Ratings (19)

would you please tell me how you show the threshold image after running the code?

Peps Reynoso

Hello, Santiago. This code is helping me immensely. I'm still trying to understand the code and paper, but I wanted to thank you for sharing this.

DaDu

DaDu (view profile)

Martin

Martin (view profile)

Answer to Arnold: Your output will strongly depend on the input image. COntact me by mail and I can check where it is failing.

arnold

arnold (view profile)

doesn't work for me. Gives 'S' and 'MG' which contains just ones.

Kindly tell me the steps to follow run this code
Regards
Bilal

Xidian NO.1

Ramkumar

thank u for sharing

Dear Sir..
Thanx alot about sharing... I can not run it because of this error:

??? Error using ==> shiftmat
Too many input arguments.

Error in ==> seg_fuzzy at 207
        M_tmp = shiftmat(Mx,i,1);

can you explain us how to implement it..
with my Regards...

Edwin

Edwin (view profile)

Thanks for your sharing. would you please tell me how you show the threshold image after running the code?

Thanks for your help in advanced!

Thank you so much for your sharing code, it is very impressive.
I've read your paper and I would like to ask about the median MG (step 6). I confuse the use of MG and about calculating the MX in step 5 and step 6, since in your code, you didn't do anything about MG.
Thank you very much for your kind response.

Modify anything you want, of course. It should be easy. I cannot say when next version will be ready, sorry. I'll try to do it along these months.

leila

leila (view profile)

thank you. I want to try it on 3d US images, can I change it? when the next version will be written?
thanks.

The function is a basic implementation thought for 2D, but with very small changes it could work for 3D. The square neighborhoods used for smoothing and aggregation must be replaced by 3D neighborhoods. (I'll do it for the next version...)

leila

leila (view profile)

does the function support 3d images?

The original file lacks of a control for more than 5 output sets. New version with problem corrected is added.

Sven

Sven (view profile)

Your example itself fails with an error:

>> [S,MG,Nmax]=seg_fuzzy(I,1,2)

Undefined function or variable "Mx".

Error in seg_fuzzy (line 196)
Mx2(:,:,1)=Mx;

Updates

4.0

Reference to the published paper added.

1.6

- The centroids are now searched by a fuzzy c-means.
- 5 different spatial aggregations are considered.
- The optimization step has been avoided.
- A threshold to prune output sets has been added.

1.5

Small change to correct a bug in 3D

1.4

A bug in shiftmat is corrected

1.3

Version 3: It admits 3D data and rgb images. It has no limit of number of output sets. Some minor bugs were corrected

1.2

Bug corrected for more than 5 maxima in smoothed histogram

MATLAB Release
MATLAB 7 (R14)
Acknowledgements

Inspired by: elmat+ 2.2

Download apps, toolboxes, and other File Exchange content using Add-On Explorer in MATLAB.

» Watch video