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