文章目录

  • 一、概述
  • 二、仿射变换类型
  • 三、仿射变换流程
  • 四、根据特征点、角度计算仿射变换矩阵
    • 1.1 从空变换矩阵创建仿射变换矩阵
    • 1.2 把旋转角度添加到仿射变换矩阵
    • 1.3 把缩放添加到仿射变换矩阵
    • 1.4 把平移添加到防射变换矩阵
    • 1.5 把斜切添加到仿射变换矩阵
    • 1.6 根据点和角度计算刚性仿射变换矩阵
    • 1.7 实战Demo(把车牌号码转正)
  • 五、根据多个特征点计算仿射变换矩阵
    • 1.1 根据两个以上特征点计算仿射变换矩阵
    • 1.2 根据三个以上特征点获取仿射变换矩阵
    • 1.3 计算仿射变换参数
  • 六、对图像、region和XLD进行仿射变换
    • 1.1 对XLD进行仿射变换
    • 1.2 对image进行仿射变换
    • 1.3 对region进行仿射变换
    • 1.4 对polygon_xld进行仿射变换

一、概述

仿射变换,即在二维平面内,对象进行平移(Translation)、缩放(Scale)、翻转(Flip)、旋转(Rotation)和斜切(Shear)等操作。

仿射变换可以保持原来的线共点、点共线的关系不变;保持原来相互平行的线仍然平行;保持原来的中点仍然是中点;保持原来在一直线上几段线段之间的比例关系不变;但不能保持原来的线段长度和夹角角度不变。

二、仿射变换类型

仿射变换有:平移、旋转、缩放、斜切(就是将斜体字导正)。

三、仿射变换流程

(1.)获取特征点坐标、角度

(2.)计算仿射变换矩阵

(3.)对图像、区域、轮廓进行仿射变换

四、根据特征点、角度计算仿射变换矩阵

1.1 从空变换矩阵创建仿射变换矩阵

hom_mat2d_identity( : : : HomMat2DIdentity)
功能:产生仿射变换矩阵(产生一个空的二维空变换矩阵)
* 清理窗口
dev_clear_window ()
* 读取图片
read_image (Image, 'E:/NetProjects/测试项目/Halcon/素材/chepai1.jpg')
* 生成一个仿射变换矩阵(齐次矩阵)
hom_mat2d_identity (HomMat2DIdentity)
* 二值化
rgb1_to_gray (Image, GrayImage)
* 按照rgb仿射拆成3个通道
decompose3 (Image, r, g, b)
* 创建一个缩放得仿射变换矩阵
hom_mat2d_scale (HomMat2DIdentity, 0.5, 0.5, 0, 0, HomMat2DScale)
* 仿射变换图片
affine_trans_image (Image, ImageAffineTrans, HomMat2DScale, 'constant', 'false')

1.2 把旋转角度添加到仿射变换矩阵

hom_mat2d_rotate( : : HomMat2D, Phi, Px, Py : HomMat2DRotate)//功能:把旋转角度添加到仿射变换矩阵HomMat2D :(输入参数)仿射变换矩阵Phi  :旋转角度(单位弧度)Px   :变换的固定点行坐标。固定点是指以该点为支撑进行仿射变换  (这里是指围绕这点进行旋转)Py :  变换的固定点列坐标HomMat2DRotate:输出的旋转变换的二维矩阵
dev_clear_window ()
dev_get_window (WindowHandle)
read_image (Image, 'E:/NetProjects/测试项目/Halcon/素材/chepai1.jpg')
hom_mat2d_identity (HomMat2DIdentity)
hom_mat2d_rotate (HomMat2DIdentity, rad(90), 200, 200, HomMat2DRotate)
affine_trans_image (Image, ImageAffineTrans, HomMat2DRotate, 'constant', 'false')

1.3 把缩放添加到仿射变换矩阵

hom_mat2d_scale( : : HomMat2D, Sx, Sy, Px, Py : HomMat2DScale)//把缩放添加到仿射变换矩阵HomMat2D(输入参数):仿射变换矩阵Sx(输入参数):x轴方向的缩放因子Sy(输入参数):y轴方向的缩放因子Px(输入参数):变换的固定点行坐标Py(输入参数):  变换的固定点列坐标HomMat2DScale(输出参数):输出缩放变换矩阵
dev_clear_window ()
dev_get_window (WindowHandle)
read_image (Image, 'E:/NetProjects/测试项目/Halcon/素材/chepai1.jpg')
hom_mat2d_identity (HomMat2DIdentity)
hom_mat2d_scale (HomMat2DIdentity, 0.5, 0.5, 0, 0, HomMat2DScale)
affine_trans_image (Image, ImageAffineTrans, HomMat2DScale, 'constant', 'false')

1.4 把平移添加到防射变换矩阵

hom_mat2d_translate( : : HomMat2D, Tx, Ty : HomMat2DTranslate)功能:把平移添加到防射变换矩阵HomMat2D:(输入参数)仿射变换矩阵Tx(输入参数):沿x轴方向平移的距离Ty:输入参数):沿y轴方向平移的距离HomMat2DTranslate(输出参数):输出变换矩阵
dev_clear_window ()
dev_get_window (WindowHandle)
read_image (Image, 'E:/NetProjects/测试项目/Halcon/素材/chepai1.jpg')
hom_mat2d_identity (HomMat2DIdentity)
hom_mat2d_translate (HomMat2DIdentity, 200, 200, HomMat2DTranslate)
affine_trans_image (Image, ImageAffineTrans, HomMat2DTranslate, 'constant', 'false')

1.5 把斜切添加到仿射变换矩阵

 hom_mat2d_slant( : : HomMat2D, Theta, Axis, Px, Py : HomMat2DSlant)功能:把斜切添加到防射变换矩阵HomMat2D        (输入参数):仿射变换矩阵Theta           (输入参数):斜切角度(单位:弧度)Axis            (输入参数):斜切的坐标轴。取值列表:x,yPx               (输入参数):变换的固定点x坐标Py              (输入参数):变换的固定点y坐标HomMat2DSlant  (输出参数):输出斜切仿射变换矩阵
dev_clear_window ()
dev_get_window (WindowHandle)
read_image (Image, 'E:/NetProjects/测试项目/Halcon/素材/chepai1.jpg')
hom_mat2d_identity (HomMat2DIdentity)
hom_mat2d_slant (HomMat2DIdentity, 0.52, 'y', 0, 0, HomMat2DSlant)
affine_trans_image (Image, ImageAffineTrans, HomMat2DSlant, 'constant', 'false')

1.6 根据点和角度计算刚性仿射变换矩阵

 vector_angle_to_rigid(::Row1,Column1,Angle1,Row2,Column2,Angle2:HomMat2D)功能:根据点和角度计算刚性仿射变换矩阵,支持旋转和平移Row1(输入参数):原始点行坐标Column1(输入参数):原始点列坐标Angle1(输入参数):原始点角度Row2(输入参数):变换的目的点行坐标Column2(输入参数):变换的目的点列坐标Angle2(输入参数):变换的目的点角度HomMat2D(输出参数):输出仿射变换矩阵
dev_clear_window ()
dev_get_window (WindowHandle)
read_image (Image, 'E:/NetProjects/测试项目/Halcon/素材/chepai1.jpg')
area_center (Image, Area, Row, Column)
orientation_region (Image, Phi)
vector_angle_to_rigid (Row, Column, Phi, Row, Column, rad(-180), HomMat2D)
affine_trans_image (Image, ImageAffineTrans, HomMat2D, 'constant', 'false')

1.7 实战Demo(把车牌号码转正)

dev_clear_window ()
read_image (Image, 'C:/Users/Gerry/Pictures/Saved Pictures/halcon/5.png')
* 转为灰度图片
rgb1_to_gray (Image, GrayImage)
* 二值化
threshold (GrayImage, Regions, 105, 151)
* 打断以不同颜色进行呈现
connection (Regions, ConnectedRegions)
* 在根据特征筛选,找到车牌
select_shape (ConnectedRegions, SelectedRegions, ['area','row','column','width'], 'and', [0,112.1,191.31,6.57], [506.57,150.56,355.53,51.59])
* 开运算
opening_circle (SelectedRegions, RegionOpening, 1)
* 联合所有区域为一个区域
union1 (RegionOpening, RegionUnion)
* 生成一个联合区域矩阵
shape_trans (RegionUnion, RegionTrans, 'rectangle2')* 1 获取矩阵中心点位坐标
area_center (RegionTrans, Area, Row, Column)
* 2 获取当前矩阵的旋转的原始弧度
orientation_region (RegionTrans, Phi)
* 生成仿射变换矩阵
vector_angle_to_rigid (Row, Column, Phi, Row, Column, rad(180), HomMat2D)
* 根据仿射变换矩阵扶正图片
affine_trans_image (Image, ImageAffineTrans, HomMat2D, 'constant', 'false')

五、根据多个特征点计算仿射变换矩阵

1.1 根据两个以上特征点计算仿射变换矩阵

 vector_to_rigid(::Px,Py,Qx,Qy:HomMat2D)功能:根据两个以上点对计算计算刚性仿射变换矩阵,支持旋转和平移Px:(输入参数)原始点组的x坐标Py:(输入参数)原始点组的y坐标Qx:(输入参数)变换的目的点组的x坐标Qy:输入参数)变换的目的点组的y坐标HomMat2D:(输出参数)输出仿射变换矩阵
* 生成椭圆形
gen_ellipse_contour_xld (ContEllipse, 200, 100, rad(0), 70, 95, rad(0), rad(360), 'positive', 2.5)
get_contour_xld (ContEllipse, Row, Col)
* 根据多个点生成仿射变换矩阵
vector_to_rigid (Col, Row, Col, Row, HomMat2D)
* 平移
hom_mat2d_translate (HomMat2D, 50, 150, HomMat2DTranslate)
* 旋转
hom_mat2d_rotate (HomMat2DTranslate, rad(90), 244, 257, HomMat2DRotate)
* 仿射变换轮廓
affine_trans_contour_xld (ContEllipse, ContoursAffineTrans, HomMat2DRotate)

vector_to_similarity(::Px,Py,Qx,Qy:HomMat2D)
功能:根据两个以上点对计算相似仿射变换矩阵,支持旋转、平移和缩放
Px:(输入参数)原始点组的x坐标
Py:(输入参数)原始点组的y坐标
Qx:(输入参数)变换的目的点组的x坐标
Qy:(输入参数)变换的目的点组的y坐标
HomMat2D:(输出参数)输出仿射变换矩阵
dev_clear_window ()
* 生成椭圆形轮廓
gen_ellipse_contour_xld (ContEllipse, 200, 100, rad(60), 100, 50, rad(0), rad(306), 'positive', 1.5)
get_contour_xld (ContEllipse, Row, Col)
* 创建一个矩阵
hom_mat2d_identity (HomMat2DIdentity)
hom_mat2d_translate (HomMat2DIdentity, 200, 150, HomMat2DTranslate)
affine_trans_contour_xld (ContEllipse, ContoursAffineTrans, HomMat2DTranslate)
hom_mat2d_rotate (HomMat2DTranslate, rad(90), 200, 150, HomMat2DRotate)
affine_trans_contour_xld (ContEllipse, ContoursAffineTrans, HomMat2DRotate)
affine_trans_point_2d (HomMat2DRotate, Col, Row, Col1, Row1)
* 生成一个近似的仿射变换矩阵
vector_to_similarity (Col, Row, Col1, Row1, HomMat2D)
hom_mat2d_translate (HomMat2D, 200, 150, HomMat2DTranslate)
affine_trans_contour_xld (ContEllipse, ContoursAffineTrans1, HomMat2DTranslate)

1.2 根据三个以上特征点获取仿射变换矩阵

   vector_to_hom_mat2d(::Px,Py,Qx,Qy:HomMat2D)功能:根据三个以上点对计算仿射变换矩阵,支持旋转、平移、缩放、斜切Px:(输入参数)原始点组的x坐标Py:(输入参数)原始点组的y坐标Qx:(输入参数)变换的目的点组的x坐标Qy:(输入参数)变换的目的点组的y坐标HomMat2D:(输出参数)输出仿射变换矩阵
* 图像坐标
r:=[455,343,673,34,53]
c:=[354,432,522,32,65]
* 物理坐标(机械手坐标)
r1:=[0,2,-2,-1,1]
c1:=[0,1,-4,-2,10]
* 生成仿射变换矩阵
vector_to_hom_mat2d (r, c, r1, c1, HomMat2D)
* 图像坐标仿射变换为物理坐标
affine_trans_point_2d (HomMat2D, 500, 200, Qx, Qy)
* 物理坐标仿射为图像坐标
hom_mat2d_invert (HomMat2D, HomMat2DInvert)
affine_trans_point_2d (HomMat2DInvert, Qx, Qy, Qx1, Qy1)

1.3 计算仿射变换参数

hom_mat2d_to_affine_par( : : HomMat2D : Sx, Sy, Phi, Theta, Tx, Ty)
功能:根据仿射变换矩阵(齐次二维变换矩阵)计算仿射变换参数HomMat2D   (输入参数):仿射变换矩阵Sx          (输出参数):x方向的缩放因子(如果从图像空间变换到物理空间,就是x方向的像素单量)Sy          (输出参数):y方向的缩放因子(如果从图像空间变换到物理空间,就是y方向的像素单量)Phi         (输出参数):旋转角度Theta       (输出参数):斜切角度Tx          (输出参数):沿x方向平移的距离Ty          (输出参数):沿y方向平移的距离
dev_clear_window ()
dev_get_window (WindowHandle)
read_image (Image, 'C:/Users/Gerry/Pictures/Saved Pictures/halcon/OCM识别.png')
hom_mat2d_identity (HomMat2DIdentity)
hom_mat2d_rotate (HomMat2DIdentity, 0.78, 10, 10, HomMat2DRotate)
hom_mat2d_scale (HomMat2DRotate, 2, 2, 0, 0, HomMat2DScale)
hom_mat2d_to_affine_par (HomMat2DScale, Sx, Sy, Phi, Theta, Tx, Ty)

六、对图像、region和XLD进行仿射变换

1.1 对XLD进行仿射变换

affine_trans_contour_xld(Contours : ContoursAffinTrans : HomMat2D : )
功能:对XLD轮廓进行二维仿射变换 (支持缩放,旋转,平移,斜切)Contours(输入参数):输入XLD轮廓ContoursAffinTrans(输出参数):输出变换的XLD轮廓HomMat2D(输入参数):仿射变换矩阵
read_image (Image, 'printer_chip/printer_chip_01')
threshold (Image, Region, 128, 255)
connection (Region, ConnectedRegions)
select_shape (ConnectedRegions, SelectedRegions, 'area', 'and', 25000, 100000)
select_obj (SelectedRegions, ObjectSelected, 1)
gen_contour_region_xld (ObjectSelected, Contours, 'border')
*将区域移动到图像中心
area_center_xld (Contours, Area, Row, Column, PointOrder)
orientation_xld (Contours, Phi)
get_image_size (Image, Width, Height)
vector_angle_to_rigid (Row, Column, Phi, Height/2, Width/2, Phi, HomMat2D)
affine_trans_contour_xld (Contours, ContoursAffineTrans, HomMat2D)
dev_display (Image)
dev_display (ContoursAffineTrans)

1.2 对image进行仿射变换

affine_trans_image(Image : ImageAffinTrans : HomMat2D, Interpolation, AdaptImageSize : )功能:对图像轮廓进行二维仿射变换 (支持缩放、旋转、平移,斜切)
Image          (输入参数):输入图像
ImageAffinTrans (输出参数):变换后的图像
HomMat2D      (输入参数):仿射变换矩阵
Interpolation    (输入参数):插值算法。参数值列表 nearest_neighbor,bilinear,constant,weighted
AdaptImageSize  (输入参数):结果图像尺寸是否自适应。默认值:false
dev_clear_window ()
dev_get_window (WindowHandle)
read_image (Image, 'C:/Users/Gerry/Pictures/Saved Pictures/halcon/OCM识别.png')
rgb1_to_gray (Image, GrayImage)
threshold (GrayImage, Regions, 212, 255)
erosion_circle (Regions, RegionErosion, 1)
connection (RegionErosion, ConnectedRegions)
select_shape (ConnectedRegions, SelectedRegions, ['area','row','column','area'], 'and', [0,173.61,320.7,0], [717.59,189.35,538.82,717.59])
union1 (SelectedRegions, RegionUnion)
shape_trans (RegionUnion, RegionTrans, 'rectangle2')
gen_contour_region_xld (RegionTrans, Contours, 'border')
area_center (RegionTrans, Area, Row, Column)
orientation_region (RegionTrans, Phi)
vector_angle_to_rigid (Row, Column, Phi, Row, Column, rad(180), HomMat2D)
affine_trans_contour_xld (Contours, ContoursAffineTrans, HomMat2D)
affine_trans_image (Image, ImageAffineTrans, HomMat2D, 'constant', 'false')

1.3 对region进行仿射变换

affine_trans_region(Region : RegionAffineTrans : HomMat2D, Interpolate : )
功能:对区域进行任意二维仿射变换
Region              (输入参数):输入区域
RegionAffineTrans   (输出参数):变换的区域
HomMat2D            (输入参数):仿射变换矩阵
Interpolate          (输入参数):插值算法。默认值:nearest_neighbor。参数值列表:constant,nearest_neighbor
dev_clear_window ()
dev_get_window (WindowHandle)
read_image (Image, 'C:/Users/Gerry/Pictures/Saved Pictures/halcon/OCM识别.png')
rgb1_to_gray (Image, GrayImage)
threshold (GrayImage, Regions, 212, 255)
erosion_circle (Regions, RegionErosion, 1)
connection (RegionErosion, ConnectedRegions)
select_shape (ConnectedRegions, SelectedRegions, ['area','row','column','area'], 'and', [0,173.61,320.7,0], [717.59,189.35,538.82,717.59])
union1 (SelectedRegions, RegionUnion)
shape_trans (RegionUnion, RegionTrans, 'rectangle2')
gen_contour_region_xld (RegionTrans, Contours, 'border')
area_center (RegionTrans, Area, Row, Column)
orientation_region (RegionTrans, Phi)
vector_angle_to_rigid (Row, Column, Phi, Row, Column, rad(180), HomMat2D)
affine_trans_contour_xld (Contours, ContoursAffineTrans, HomMat2D)
affine_trans_region (RegionTrans, RegionAffineTrans, HomMat2D, 'nearest_neighbor')
*affine_trans_image (Image, ImageAffineTrans, HomMat2D, 'constant', 'false')

1.4 对polygon_xld进行仿射变换

affine_trans_polygon_xld(Polygon:PolygonsAffinTrans:HomMat2D:)
功能:对XLD多边形进行任意二维仿射变换   Polygon(输入参数):输入XLD多边形
PolygonsAffinTrans(输出参数):变换的XLD多边形
HomMat2D(输入参数):仿射变换矩阵
gen_region_polygon_filled(reg,[100,50,50,100,300,300,300,100],[50,100,200,400,400,200,50,50])
gen_contour_region_xld (reg, Contours, 'border')
area_center_xld (Contours, Area, Row, Column, PointOrder)
orientation_xld (Contours, Phi)
vector_angle_to_rigid (Row, Column, Phi, Row, Column, Phi, HomMat2D)
hom_mat2d_scale (HomMat2D, 0.5, 0.5, Column, Row, HomMat2DScale)
affine_trans_contour_xld (Contours, ContoursAffineTrans, HomMat2DScale)

【朝夕教育】2023年04月 Halcon机器视觉-仿射变换详解相关推荐

  1. 【愚公系列】2023年04月 Halcon机器视觉-基于Halcon车牌识别

    文章目录 前言 1.Halcon是什么 2.车牌识别 3.车牌识别系统 一.基于Halcon车牌识别 1.车牌识别的流程 二.车牌识别前预处理 三.开始车牌识别 四.识别车牌上面的中文 1.处理需要识 ...

  2. Halcon 解码算子详解 一

    Halcon 解码算子详解 一 create_data_code_2d_model SymbolType (输入参数) GenParamName(输入参数) GenParamValue(输入参数) D ...

  3. 【Linux】Ubuntu 20.04安装教程(图文详解)

    Ubuntu 20.04安装教程(图文详解) 准备工作 打开 VWMARE 进行安装配置 虚拟机已经配置完毕后的 Ubuntu20.0.4 安装 安装VMware Tools 准备工作 下载 Ubun ...

  4. 小白也能接广告赚钱,实操月入3000+项目详解

    小白也能接广告赚钱,实操月入3000+项目详解 大家好,我是独孤思维.今天是原创日更134篇. 01 微头条接广告 自从上次分享了微头条的搬运项目,很多粉丝朋友已经开始实操了,有的甚至两天都涨粉破百, ...

  5. 2023 年 04 月编程语言排行榜

    来自公众号:菜鸟教程 TIOBE 2023 年 04  月份的编程语言排行榜已经公布,官方的标题是:Zig 语言进入 TIOBE 指数前 50. Zig 是一种通用的编程语言和工具链,用于维护健壮.最 ...

  6. 2023年04月个人工作生活总结

    本文为 2023 年 4 月工作生活总结. 研发编码 Go 因为一些原因,需要将工程移植到 arm64 平台,看了些资料,go 可以指定OS和ARCH编译,但试了不成功,因此,只能在 arm64 系统 ...

  7. Halcon —— 边缘检测算子详解

    一.算子介绍 1.1 种类 halcon内常用的边缘检测算子包括如下几种: 1.edges_image: 提取2D 图像边缘 2.edges_sub_pix:提取2D图像亚像素边缘 3.edges_o ...

  8. 【朝夕教育】2023年04月 WPF运动控制平台-002.运动控制平台知识点学习

    文章目录 前言 一.知识点学习 1.MCT2008软件配置限位生效并导出配置文件 2.轴卡的初始化功能实现 3.轴卡的点位运动功能实现 4.轴卡的限位+Home回原功能实现 前言 运动控制(Motio ...

  9. 【愚公系列】2023年04月 攻防世界-MOBILE(Android2.0)

    文章目录 前言 一.Android2.0 1.题目 2.答题 前言 下面介绍两个反编译工具 jadx是一个用于反编译Android APK文件的开源工具,静态反编译,查找索引功能强大 jeb和IDA很 ...

最新文章

  1. 手把手教你学51单片机-c语言版期末考试,手把手从零教你学51单片机
  2. [linux] SIGPIPE信号处理
  3. 简单字符串比较——JAVA
  4. vi 按了ctrl+s怎么办
  5. 前端怎么使用jsessionid_前端搞微前端 | 侑夕 - 如何落地微前端一体化运营工作台...
  6. KNN代码复现python版
  7. AJAX框架衣柜推拉门设计,带镜子的推拉门衣柜如何设计好看
  8. 图片传输_一幅图片的奇妙旅行,网络传输分层通信协议原理揭秘
  9. 快速突破面试算法之树结构篇
  10. macOS 常用键盘快捷键大全
  11. python爬虫出来空值_pandas | DataFrame基础运算以及空值填充
  12. 专利欠费怎么办?教你在网上缴纳专利年费,全网最详细步骤
  13. 各种级数(调和、几何)总结
  14. .net编程的十大技巧 转载之Jeffery.Sun
  15. php实现五维雷达图,Unity 属性雷达图
  16. 无线网络性能测试 软件,WiFi性能测试
  17. 为什么Google是人工智能发展的主要动力?
  18. 内部异常 FileNotFoundException: 设备未就绪。 (异常来自 HRESULT:0x80070015)
  19. yuv与rgb图像格式转换
  20. Win10+vs2017跑yolov3

热门文章

  1. NOIP 2010 普及组 复赛 sanguo 三国游戏
  2. 集 承 享——浅谈基于内容的全链档案管理与服务
  3. 对联的quot;平仄相谐quot;要素
  4. (ECCV2016)A Software Platform for Manipulating the Camera Imaging Pipeline—论文阅读
  5. JavaScript常用正則表達式
  6. 【Flutter进阶】 Web开发中如何加载网络图片
  7. 蓝牙搜索不到周围其他蓝牙设备
  8. 制作和添加测试点与MARK点、元件重新编号与反标、丝印信息处理和BMP文件导入
  9. 可以重新缴费参加计算机考试吗,计算机二级考试报考成功后可以退费吗
  10. 撬开操纵上海房价的手 楼盘供不应求原是假象