ThresholdLocally
Performs LOCAL Otsu thresholding on an image; user can specify blocksize. Facilitates the threshold-segmentation of images with uneven illumination, without the need for background normalization.
 
SYNTAX: B = thresholdLocally(A,blksz,varargin)
 
THRESHOLDLOCALLY processes an image, calling graythresh on LOCAL blocks in an image. This facilitates easy thresholding of images with uneven background illumination, for which global thresholding is inadequate. Uses the Image Processing Toolbox function BLOCKPROC (R2009b).
 
INPUTS:
A:  Any image (or path/name of an image) suitable for processing with im2bw()
BLKSZ: (Optional) Block size of A, for determination of Otsu thresholding using graythresh(). In the form or [M,N]. Default is as determined by BESTBLK.
OPTIONAL:
1) Any P-V pair accepted by BLOCKPROC.
2) FudgeFactor: a scalar value by which to multiply the local value returned by graythresh.
OUTPUT:
B:  Output image
 
EXAMPLE:
img = imread('rice.png');
thresholded = thresholdLocally(img);
Cite As
Brett Shoelson (2025). ThresholdLocally (https://uk.mathworks.com/matlabcentral/fileexchange/29764-thresholdlocally), MATLAB Central File Exchange. Retrieved .
MATLAB Release Compatibility
Platform Compatibility
Windows macOS LinuxCategories
- Image Processing and Computer Vision > Image Processing Toolbox > Image Segmentation and Analysis > Image Segmentation > Image Thresholding >
Tags
Acknowledgements
Inspired: SegmentTool: An Interactive GUI for Segmenting Images
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!Discover Live Editor
Create scripts with code, output, and formatted text in a single executable document.
| Version | Published | Release Notes | |
|---|---|---|---|
| 1.4.0.1 | Updated license | ||
| 1.4.0.0 | Minor change to replace default blocksize of [32 32] by that returned by function BESTBLK. | ||
| 1.3.0.0 | Fixed problem with screenshot. (Image was inappropriately rotated.) | ||
| 1.2.0.0 | Modified significantly to accept as optional inputs all parameter-value pairs accepted by BLOCKPROC, as well as an additional "fudge factor" parameter that allows one to scale the local graythresh value by a scalar multiple. | ||
| 1.0.0.0 | 
