Halcon入门(3)——回形针目标提取

原始图像如下所示:

Halcon入门(3)——回形针目标提取_第1张图片

由于发现背景比较好分离,所以我们可以根据直方图进行分割,如下选取直方图

Halcon入门(3)——回形针目标提取_第2张图片

Halcon入门(3)——回形针目标提取_第3张图片

 然后调节最大的范围,因为我们的ROI区域是比较暗,

Halcon入门(3)——回形针目标提取_第4张图片

 Halcon入门(3)——回形针目标提取_第5张图片

 这时候就可以分割出来了。

Halcon入门(3)——回形针目标提取_第6张图片

发现选择的时候都是粘连再一起的,所以我们需要分割开。

connection(Regions, ConnectedRegions)

Halcon入门(3)——回形针目标提取_第7张图片

我们发现上面图中有一个长的不是我们想要的。然后选择特征直方图选取列,然后进行调节,再插入代码:

Halcon入门(3)——回形针目标提取_第8张图片

 然后进行旋转角度的计算:

首先找到各个回形针的轮廓:

*smallest_rectangle1是不可旋转的矩阵,smallest_rectangle2是可以旋转的矩形
smallest_rectangle2(SelectedRegions, Row, Column, Phi, Length1, Length2)

gen_rectangle2(Rectangle, Row, Column, Phi, Length1, Length2)

Halcon入门(3)——回形针目标提取_第9张图片

然后我们把填充改为边界,选择图片右击->画->margin如下所示:

Halcon入门(3)——回形针目标提取_第10张图片 结果如下:

Halcon入门(3)——回形针目标提取_第11张图片

 还有一些其他操作这儿就不体现了:

完整代码如下:

read_image(Image, 'clip')
* 提取图像中的回形针并计算角度
threshold (Image, Regions, 10, 77)
connection(Regions, ConnectedRegions)
count_obj(ConnectedRegions, Number)
select_shape (ConnectedRegions, SelectedRegions, 'column', 'and', 39.45, 1000)
*smallest_rectangle1是不可旋转的矩阵,smallest_rectangle2是可以旋转的矩形
smallest_rectangle2(SelectedRegions, Row, Column, Phi, Length1, Length2)

gen_rectangle2(Rectangle, Row, Column, Phi, Length1, Length2)

* 形态学变换来对回形针进行填充,从而计算回形针的占有面积
fill_up(SelectedRegions, RegionFillUp)

*腐蚀
erosion_rectangle1(RegionFillUp, RegionErosion, 11, 11)

* 膨胀
dilation_rectangle1(RegionErosion, RegionDilation, 11, 11)

* 合并
union1(RegionDilation, RegionUnion)

* 减操作
difference(RegionUnion, RegionUnion, RegionDifference)

 

你可能感兴趣的:(Halcon入门,Halcon,图像处理,人工智能)