一杯清酒邀明月
天下本无事,庸人扰之而烦耳。

在使用Halcon进行模板匹配的时候,我们使用find_shape_model、find_scaled_shape_model等算子找到模板后返回的是实例,得到的数据是模板中心的行列坐标、角度和缩放比例等数据,不是具体的区域,下面介绍怎么得到具体区域。

解决思路:

一:先获取模板的轮廓,此时获取的轮廓位置在(0,0)的位置;

二:求出模板到匹配实例的旋转矩阵;

三:利用仿射变换得到匹配实例的轮廓;

四:将轮廓转成区域;

代码及注释讲解:

 1 //获取初始模板轮廓
 2 get_shape_model_contours (ModelContours1, ModelID, 1)
 3 //进行模板匹配找模板
 4 find_scaled_shape_model (Image0, ModelID, -3.14, 6.29, 0.95, 1.1, 0.90, 6, 0.5, 'least_squares', 8, 0.9, RowModel3, ColumnModel3, AngleModel3, Scale, Score1)
 5 if(|RowModel3|>0)//如果找到的模板数量大于0
 6         //显示找到的模板轮廓
 7         dev_display_shape_matching_results (ModelID, 'red', RowModel3, ColumnModel3, AngleModel3, 1, 1, 0)
 8         //循环遍历每个找到的实例
 9     for I := 0 to |Score1| - 1 by 1
10         //求出初始模板到实例中间的旋转矩阵--注:初始模板的行列坐标和角度都是0
11         vector_angle_to_rigid (0, 0, 0, RowModel3[I], ColumnModel3[I], AngleModel3[I], HomMat2DRotate)
12         //给旋转矩阵添加缩放信息
13         hom_mat2d_scale (HomMat2DRotate, Scale[I], Scale[I], RowModel3[I], ColumnModel3[I], HomMat2DScale)
14         //通过初始模板和旋转矩阵运算得到模板实例的轮廓
15         affine_trans_contour_xld (ModelContours1, ModelTrans, HomMat2DScale)
16         //轮廓转区域
17         gen_region_contour_xld (ModelTrans, Region, 'filled')
18 endif

 

posted on 2021-02-25 12:02  一杯清酒邀明月  阅读(1995)  评论(0编辑  收藏  举报