bwmorph
Morphological operations on binary images
Description
Examples
Read binary image and display it.
BW = imread('circles.png');
imshow(BW);
Remove interior pixels to leave an outline of the shapes.
BW2 = bwmorph(BW,'remove');
figure
imshow(BW2)
Get the image skeleton.
BW3 = bwmorph(BW,'skel',Inf);
figure
imshow(BW3)
Input Arguments
Binary image, specified as a 2-D numeric matrix or 2-D logical matrix. For numeric input,
any nonzero pixels are considered to be 1
(true
).
Morphological operation to perform, specified as one of the following.
Operation | Description |
---|---|
| Perform the morphological bottom hat operation, returning the image minus the morphological closing of the image. The
|
| Find branch points of skeleton. For example: 0 0 1 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 1 1 1 1 1 becomes 0 0 1 0 0 0 0 1 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 Note: To find
branch points, the image must be skeletonized. To create a skeletonized image,
use |
| Bridge unconnected pixels, that is, sets 1 0 0 1 1 0 1 0 1 becomes 1 1 1 0 0 1 0 1 1 |
| Remove isolated pixels (individual 0 0 0 0 1 0 0 0 0 |
| Perform morphological closing (dilation followed by erosion). The
|
| Use diagonal fill to eliminate 8-connectivity of the background. For example: 0 1 0 0 1 0 1 0 0 becomes 1 1 0 0 0 0 0 0 0 |
| Find end points of skeleton. For example: 1 0 0 0 1 0 0 0 0 1 0 0 becomes 0 0 0 0 0 0 1 0 0 0 1 0 0 0 0 0 0 0 0 0 Note: To find end
points, the image must be skeletonized. To create a skeletonized image, use
|
| Fill isolated interior pixels (individual 1 1 1 1 0 1 1 1 1 |
| Remove H-connected pixels. For example: 1 1 1 1 1 1 0 1 0 becomes 0 0 0 1 1 1 1 1 1 |
| Set a pixel to |
| Perform morphological opening (erosion followed by dilation). The
|
| Remove interior pixels. This option sets a pixel to |
| With |
| With When working
with 3-D volumes, or when you want to prune a skeleton, use the |
| Remove spur pixels. For example: 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 becomes 0 0 0 0 0 1 0 0 0 1 0 0 1 1 0 0 1 1 0 0 |
| With |
| With |
| Perform the morphological top hat operation, returning the image minus the morphological opening of the image. The
|
Data Types: char
| string
Number of times to perform the operation, specified as a positive integer or
Inf
. When you specify n
as
Inf
, the bwmorph
function repeats the
operation until the image no longer changes.
Example: 100
Data Types: single
| double
| int8
| int16
| int32
| int64
| uint8
| uint16
| uint32
| uint64
Output Arguments
Image after morphological operations, returned as a 2-D logical matrix.
Data Types: logical
Algorithms
When used with the "thin"
option, bwmorph
uses the
following algorithm [3]:
In the first subiteration, delete pixel p if and only if the conditions G1, G2, and G3 are all satisfied.
In the second subiteration, delete pixel p if and only if the conditions G1, G2, and are all satisfied.
where
x1, x2, ..., x8 are the values of the eight neighbors of p, starting with the east neighbor and numbered in counter-clockwise order.
where
The two subiterations together make up one iteration of the
thinning algorithm. When the user specifies an infinite number of
iterations (n=Inf
), the iterations are repeated
until the image stops changing. The conditions are all tested using applylut
with
precomputed lookup tables.
References
[1] Haralick, Robert M., and Linda G. Shapiro, Computer and Robot Vision, Vol. 1, Addison-Wesley, 1992.
[2] Kong, T. Yung and Azriel Rosenfeld, Topological Algorithms for Digital Image Processing, Elsevier Science, Inc., 1996.
[3] Lam, L., Seong-Whan Lee, and Ching Y. Suen, "Thinning Methodologies-A Comprehensive Survey," IEEE Transactions on Pattern Analysis and Machine Intelligence, Vol 14, No. 9, September 1992, page 879, bottom of first column through top of second column.
[4] Pratt, William K., Digital Image Processing, John Wiley & Sons, Inc., 1991.
Extended Capabilities
Usage notes and limitations:
bwmorph
supports the generation of C code (requires MATLAB® Coder™). Note that if you choose the genericMATLAB Host Computer
target platform,bwmorph
generates code that uses a precompiled, platform-specific shared library. Use of a shared library preserves performance optimizations but limits the target platforms for which code can be generated. For more information, see Types of Code Generation Support in Image Processing Toolbox.When generating code, the character vectors or string scalars specifying the operation must be a compile-time constant and, for best results, the input image must be of class
logical
.
Usage notes and limitations:
When generating code, the character vectors or string scalars specifying the operation must be a compile-time constant and, for best results, the input image must be of class
logical
.
This function fully supports GPU arrays. For more information, see Image Processing on a GPU.
Version History
Introduced before R2006a
See Also
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Seleziona un sito web
Seleziona un sito web per visualizzare contenuto tradotto dove disponibile e vedere eventi e offerte locali. In base alla tua area geografica, ti consigliamo di selezionare: .
Puoi anche selezionare un sito web dal seguente elenco:
Come ottenere le migliori prestazioni del sito
Per ottenere le migliori prestazioni del sito, seleziona il sito cinese (in cinese o in inglese). I siti MathWorks per gli altri paesi non sono ottimizzati per essere visitati dalla tua area geografica.
Americhe
- América Latina (Español)
- Canada (English)
- United States (English)
Europa
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)