MATLAB连通域标记函数

L = bwlabel(BW,n)
返回一个和BW大小相同的L矩阵,包含了标记了BW中每个连通区域的类别标签,这些标签的值为1、2、num(连通区域的个数)。n的值为4或8,表示是按4连通寻找区域,还是8连通寻找,默认为8。

[L,num] = bwlabel(BW,n)
这里num返回的就是BW中连通区域的个数。

一些连通域处理函数,转自AmazingJack的专栏:http://m.blog.csdn.net/blog/AmazingJack/24417891

1、 matlab函数bwareaopen──删除小面积对象

格式:BW2 = bwareaopen(BW,P,conn)
作用:删除二值图像BW中面积小于P的对象,默认情况下使用8邻域。
算法:
(1)Determine the connected components.
L = bwlabeln(BW, conn);
(2)Compute the area of each component.
S = regionprops(L, ‘Area‘);
(3)Remove small objects.
bw2 = ismember(L, find([S.Area] >= P));

2、matlab函数bwarea──计算对象面积
格式:total = bwarea(BW)
作用:估计二值图像中对象的面积。
注:该面积和二值图像中对象的像素数目不一定相等。

3、matlab函数imclearborder──边界对象抑制
格式:IM2 = imclearborder(IM,conn)
作用:抑制和图像边界相连的亮对象。若IM是二值图,imclearborder将删除和图像边界相连的对象。默认情况conn=8。
注:For grayscale images, imclearborder tends to reduce the overall intensity level in addition to suppressing border structures.
算法:
(1)Mask image is the input image.
(2)Marker image is zero everywhere except along the border, where it equals the mask image.

4、matlab函数bwboundaries──获取对象轮廓
格式:B = bwboundaries(BW,conn)(基本格式)
作用:获取二值图中对象的轮廓,和OpenCV中cvFindContours函数功能类似。B是一个P×1的cell数组,P为对象个数,每个cell 是Q×2的矩阵,对应于对象轮廓像素的坐标。

5、matlab函数imregionalmin──获取极小值区域
格式:BW = imregionalmin(I,conn)
作用:寻找图像I的极小值区域(regional maxima),默认情况conn=8。
Regional minima are connected components of pixels with a constant intensity value, and whose external boundary pixels all have a higher value.

6、matlab函数bwulterode──距离变换的极大值
格式:BW2 = bwulterode(BW,method,conn)
作用:终极腐蚀。寻找二值图像BW的距离变换图的区域极大值(regional maxima)。用于距离变换的距离默认为euclidean,连通性为8邻域。

7、regionprops统计被标记的区域的面积分布,显示区域总数。
函数regionprops语法规则为:STATS = regionprops(L,properties)
该函数用来测量标注矩阵L中每一个标注区域的一系列属性。
L中不同的正整数元素对应不同的区域,例如:L中等于整数1的元素对应区域1;L中等于整数2的元素对应区域2;以此类推。
返回值STATS是一个 长度为max(L()的结构数组,结构数组的相应域定义了每一个区域相应属性下的度量。
Properties可以是由逗号分割的字符串列表、包含字符 串的单元数组、单个字符串‘all‘或者‘basic‘。如果properties等于字符串‘all‘,则表1中的度量数据都将被计算;如果properties等于字符串‘basic‘,则属性:‘Area‘,‘Centroid‘和‘BoundingBox‘将被计算。表1就是所有有效的属性字符串。

表1 属性字符串列表


properties值


度量图像区域的属性或功能


‘Area‘


图像各个区域中像素总个数


‘BoundingBox‘


包含相应区域的最小矩形


‘Centroid‘


每个区域的质心(重心)


‘MajorAxisLength‘


与区域具有相同标准二阶中心矩的椭圆的长轴长度(像素意义下)


‘MinorAxisLength‘


与区域具有相同标准二阶中心矩的椭圆的短轴长度(像素意义下)


‘Eccentricity‘


与区域具有相同标准二阶中心矩的椭圆的离心率(可作为特征)


‘Orientation‘


与区域具有相同标准二阶中心矩的椭圆的长轴与x轴的交角(度)


‘Image‘


与某区域具有相同大小的逻辑矩阵


‘FilledImage‘


与某区域具有相同大小的填充逻辑矩阵


‘FilledArea‘


填充区域图像中的on像素个数


‘ConvexHull‘


包含某区域的最小凸多边形


‘ConvexImage‘


画出上述区域最小凸多边形


‘ConvexArea‘


填充区域凸多边形图像中的on像素个数


‘EulerNumber‘


几何拓扑中的一个拓扑不变量——欧拉数


‘Extrema‘


八方向区域极值点


‘EquivDiameter‘


与区域具有相同面积的圆的直径


‘Solidity‘


同时在区域和其最小凸多边形中的像素比例


‘Extent‘


同时在区域和其最小边界矩形中的像素比例


‘PixelIdxList‘


存储区域像素的索引下标

时间: 2024-10-17 13:36:13

MATLAB连通域标记函数的相关文章

二值图像连通域标记

来源:http://www.cnblogs.com/ronny/p/img_aly_01.html 一.前言 二值图像,顾名思义就是图像的亮度值只有两个状态:黑(0)和白(255).二值图像在图像分析与识别中有着举足轻重的地位,因为其模式简单,对像素在空间上的关系有着极强的表现力.在实际应用中,很多图像的分析最终都转换为二值图像的分析,比如:医学图像分析.前景检测.字符识别,形状识别.二值化+数学形态学能解决很多计算机识别工程中目标提取的问题. 二值图像分析最重要的方法就是连通区域标记,它是所有

转-二值图像连通域标记

转自:图像分析:二值图像连通域标记 一.前言 二值图像,顾名思义就是图像的亮度值只有两个状态:黑(0)和白(255).二值图像在图像分析与识别中有着举足轻重的地位,因为其模式简单,对像素在空间上的关系有着极强的表现力.在实际应用中,很多图像的分析最终都转换为二值图像的分析,比如:医学图像分析.前景检测.字符识别,形状识别.二值化+数学形态学能解决很多计算机识别工程中目标提取的问题. 二值图像分析最重要的方法就是连通区域标记,它是所有二值图像分析的基础,它通过对二值图像中白色像素(目标)的标记,让

matlab实现MSER(最大极值稳定区域)来进行文本定位

一.自然场景文本定位综述   场景图像中文本占据的范围一般都较小,图像中存在着大范围的非文本区域.因此,场景图像文本定位作为一个独立步骤越来越受到重视.这包括从最先的CD和杂志封面文本定位到智能交通系统中的车牌定位.视频中的字幕提取,再到限制条件少,复杂背景下的场景文本定位.与此同时文本定位算法的鲁棒性越来越高,适用的范围也越来越广泛.文本定位的方式一般可以分为三种,基于连通域的.基于学习的和两者结合的方式.基于连通域的流程一般是首先提取候选文本区域,然后采用先验信息滤除部分非文本区域,最后根据

Matlab得到二值图像中最大连通区域

有时候要将二值化图像中最大的连通域保存下来,下面函数提供了一种方法: %function [img]=maxLianTongYu(I):求图像中最大的连通域 %输入:I 输入图像 %输出:img 仅包含最大连通域的图像 function [img]=maxLianTongYu(I) if length(size(I))>2 I = rgb2gray(I); end if ~islogical(I) imBw = im2bw(I); %转换为二值化图像 else imBw = I; end imB

图像连通域标记算法研究

把之前一篇记录过的日志贴过来 图像连通域标记算法研究 ConnectedComponent Labeling 最近在研究一篇复杂下背景文字检测的论文. “Detecting Text in Natural Scenes with Stroke Width Transform ” CPVR 2010的文章,它主要探讨利用文字内部笔画宽度一致作为主要线索来检测文字的一个新奇的算法,当然,我不是想讨论文字检测,论文算法实施的过程中有一步涉及到图像连通域标记算法,在这里我遇到了一些问题,查阅了一些相关文

matlab学习笔记之五种常见的图形绘制功能

分类: 离散数据图形绘制 函数图形绘制 网格图形绘制 曲面图形绘制 特殊图形绘制 本文重点介绍matlab五种图形绘制方法的后三种. 一.网格图形绘制 以绘制函数z=f(x,y)三维网格图为例,下面为绘制步骤: 确定自变量x和y的取值范围和取值间隔 x = x1:dx:x2; y = y1:dy:y2; 2.构成xoy平面上的自变量采样格点矩阵 1)  利用“格点”矩阵生成原理生成矩阵 X = ones(size(y))*x; Y = y*ones(size(x)); 2)  利用meshgri

在Opencv中实现Matlab的bwareaopen函数功能

在Matlab中,我们通常利用bwareaopen函数去除八邻域内面积小于一定值的连通域. matlab函数bwareaopen──删除小面积对象 格式:BW2 = bwareaopen(BW,P,conn) 作用:删除二值图像BW中面积小于P的对象,默认情况下使用8邻域. Opencv里没有特定的函数实现该功能,但我们可以自己设计一个孔洞填充/小区域去除的方式来实现. 函数接口设计如下: C++ void RemoveSmallRegion(Mat& Src, Mat& Dst, int

利用MATLAB进行曲线拟合

软件环境:MATLAB2013a 一.多项式拟合 多项式拟合是利用多项式最佳地拟合观测数据,使得在观测数据点处的误差平方和最小. 在MATLAB中,利用函数ployfit和ployval进行多项式拟合. 函数ployfit根据观测数据及用户指定的多项式阶数得到光滑曲线的多项式表示,polyfit的一般调用格式为:P = polyfit(x,y,n).其中x为自变量,y为因变量,n为多项式阶数. polyval的输入可以是标量或矩阵,调用格式为 pv = polyval(p,a) pv = pol

MATLAB检查指定路径中的子文件夹中的文件名中是否带有空格

测试文件夹为: clear;close all;clc; %% %程序实现的功能 %检查指定路径中的子文件夹中的文件名中是否带有空格,并去掉文件名中的空格 %% %程序中用到的之前不清楚的函数如下 %1)strfind(a,b):即找a中是否有b,如果a中有b,则输出b的位置序号.没有输出空数组 %2)isempty(a):判断数组是否为空 %3)strrep(a,b,c):就是把a中所有出现的b换为c %4)movefile(a,b):a移动为b,如C:\test1.jpg移动为C\test2