| [mmgrain] [Up] [mmstats] | Measurements |
| User Feedback |
| f | Image Gray-scale (uint8 or uint16) or binary image |
| Bc | Structuring Element
Default: ( connectivity). |
| _lambda | Double
Default: Connectivity given by |f(q)-f(p)|<=_lambda. |
| y | Image
If number of labels is less than 65535, the data type is uint16, otherwise it is int32. |
mmlabelflat creates the image y by labeling the flat zones of f, according to the connectivity defined by the structuring element Bc. A flat zone is a connected region of the image domain in which all the pixels have the same gray-level (lambda=0). When lambda is different than zero, a quasi-flat zone is detected where two neighboring pixels belong to the same region if their difference gray-levels is smaller or equal lambda. The minimum label of the output image is 1 and the maximum is the number of flat-zones in the image.
f=uint8([5,5,8,3,0; 5,8,8,0,2])
f =
5 5 8 3 0
5 8 8 0 2
g=mmlabelflat(f)
g =
1 1 2 3 5
1 2 2 4 6
g1=mmlabelflat(f,mmsecross,2)
g1 =
1 1 2 3 4
1 2 2 4 4
A quantized distance transform image is built to be used to compute its flat zones. Note that the background and the hole in the bottom right area are also labeled. The number of the flat zones can be determined by the maximum label value.
f=mmreadgray('blob.tif');
d=mmdist(f,mmsebox,'euclidean');
g=uint8(rdivide(double(d),8));
Warning: Conversion rounded non-integer floating point value to nearest uint8 value.
mmshow(g);
fz=mmlabelflat(g,mmsebox);
mmlblshow(fz);
mmstats(fz,'max')
ans =
20
![]() |
![]() |
|
| g | fz |
In this case two pixels belong to the same quasi-flat zones if they are 8-neighbors (mmsebox) and if their gray-values difference is smaller or equal 3.

| [mmgrain] [Up] [mmstats] | |
| User Feedback | |
| Copyright (c) 1998-2008 by SDC Information Systems |