天天看点

halcon 仿射变换和区域跟随1. 应用场景2. 应用示例

仿射变换和区域跟随

  • 1. 应用场景
  • 2. 应用示例

1. 应用场景

  • 当感兴趣区域不容易被捕捉,但是又必须要定位它的位置的时候,可以先选择定位其他的特征区域。我们先找到特征区域,因为这个特征区域和感兴趣区域相对位置确定,我们就可以根据仿射变换矩阵找到感兴趣区域了。Mark点就是这样应用的。

2. 应用示例

halcon 仿射变换和区域跟随1. 应用场景2. 应用示例
halcon 仿射变换和区域跟随1. 应用场景2. 应用示例
dev_set_line_width (3)
dev_set_draw ('margin')

read_image (Image, '1.png')

gen_rectangle1 (ROI_0, 121.5, 226.5, 219.5, 382.5)
reduce_domain (Image, ROI_0, ImageReduced)

gen_rectangle2 (FollowRegion, 278.5, 313.5, rad(-7.12502), 56.4358, 47.0092)
area_center (ROI_0, Area, Row, Column)

create_shape_model (ImageReduced, 'auto', rad(0), rad(360), 0.0349, 'auto', 'use_polarity', 30, 10, ModelID)
get_shape_model_contours (ModelContours, ModelID, 1)


stop()
*========================加载第二张图像==================
read_image (Image, '2.png')
find_shape_model (Image, ModelID, rad(0), rad(360), 0.5, 1, 0.5, 'least_squares', 0, 0.9, Row1, Column1, Angle, Score)

if (|Row1|=1)
    *基于形状的模板匹配
    vector_angle_to_rigid (0, 0, 0, Row1, Column1, Angle, HomMat2D)
    affine_trans_contour_xld (ModelContours, ContoursAffinTrans, HomMat2D)
    
    *跟随区域仿射变换矩阵的计算
    vector_angle_to_rigid (Row, Column, 0, Row1, Column1, -Angle, HomMat2D1)
    affine_trans_region (FollowRegion, RegionAffineTrans, HomMat2D1, 'nearest_neighbor')
endif
           

继续阅读