(资料图)
仿射变换,即在二维平面内,对象进行平移(Translation)、缩放(Scale)、翻转(Flip)、旋转(Rotation)和斜切(Shear)等操作。
仿射变换可以保持原来的线共点、点共线的关系不变;保持原来相互平行的线仍然平行;保持原来的中点仍然是中点;保持原来在一直线上几段线段之间的比例关系不变;但不能保持原来的线段长度和夹角角度不变。
仿射变换有:平移、旋转、缩放、斜切(就是将斜体字导正)。
(1.)获取特征点坐标、角度
(2.)计算仿射变换矩阵
(3.)对图像、区域、轮廓进行仿射变换
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")
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")
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")
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")
hom_mat2d_slant( : : HomMat2D, Theta, Axis, Px, Py : HomMat2DSlant) 功能:把斜切添加到防射变换矩阵 HomMat2D (输入参数):仿射变换矩阵 Theta (输入参数):斜切角度(单位:弧度) Axis (输入参数):斜切的坐标轴。取值列表:x,y Px (输入参数):变换的固定点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")
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")
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")
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)
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)
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)
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)
affine_trans_image(Image : ImageAffinTrans : HomMat2D, Interpolation, AdaptImageSize : ) 功能:对图像轮廓进行二维仿射变换 (支持缩放、旋转、平移,斜切)Image (输入参数):输入图像ImageAffinTrans (输出参数):变换后的图像HomMat2D (输入参数):仿射变换矩阵Interpolation (输入参数):插值算法。参数值列表 nearest_neighbor,bilinear,constant,weightedAdaptImageSize (输入参数):结果图像尺寸是否自适应。默认值: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")
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")
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)
仿射变换,即在二维平面内,对象进行平移(Translation)、缩放(Scale)、翻转(Flip)、旋转(Rotation)和斜切(Shear)等操作。
1、一个人在暗光下会害怕,但这首歌的歌名是《放不下想又怕》。2、没有余地3、不敢再想起他。4、两行眼泪5、我不敢把它擦掉
【环球网报道记者李诗睿】据俄罗斯塔斯社8日报道,克里姆林宫发言人、俄罗斯总统新闻秘书佩斯科夫在接受采访时表示,马克龙
走文化廊道,进经济园区,看山东高质量发展。4月5日,“走大运河文化体验廊道”行进式主题采访活动走进泰安市。京杭运河八里湾船闸工程位于...
中央气象台4月8日18时发布沙尘暴蓝色预警
4月7日晚间,中法发布最新联合声明,其中提及了在核能、清洁能源等能源领域加强合作。联合声明提出,为实现能源体系低碳转型的共同愿望,中法
虚盘范文第1篇公输盘给楚国打造云梯这种器械,造成后,将用它攻打宋国。墨子听说这件事,就从鲁国起身,走了十天十夜才到楚国国都郢,拜见公输
王际文前几天某单位因为领导安排员工在清明节期间加班,而被员工怒怼的新闻在网络上弄得沸沸扬扬,广受关注。然而,两天之后,事情出现了反转
近日,从石家庄市人大常委会获悉,《石家庄市优化营商环境条例》已经河北省第十四届人民代表大会常务委员会第二次会议审查批准,将于5月1日起
但在他看来,腾讯视频和抖音的合作并不会影响视频号的发展,因为视频号起步较晚,抖音已有成熟的创作者生态,双方在内容培育上处于不同阶段。
1、通过孵化器或抱窝母鸡孵化21天后,小鸡才破壳而出。2、比如抱窝鸡孵化,选择正在抱巢、温顺而健康的母鸡,一次可孵蛋20个左右。3、用放上软
1、原文爱莲说(北宋)周敦颐水陆草木之花,可爱者甚蕃。2、晋陶渊明独爱菊;自李唐来,世人皆爱牡丹;予独爱莲
刚刚辞去浙江省副省长职务的王成国,其新职务已获官方披露。据微信公众号“玉环发布”消息,4月7日,玉环举行了高铭暄学术馆开
日前,我们从官方渠道获悉,长城汽车首个6X6超级越野平台将在上海车展发布,该平台新车将配备“3轴6驱5把锁”,可谓相当硬核。
4月7日,人行玉林市中心支行行政处罚信息公示表显示,广西北流柳银村镇银行股份有限公司因未按规定重新识别客户,被处罚款23 3万元,同时时任
《我想和你唱4》迎来大张伟和张栋梁,《我怎么这么好看》两度澎湃全场---今晚,《我想和你唱4》第六期将在湖南卫视、芒果TV双平台登录,音乐嘉
自4月5日起以色列将相继迎来多个公共假期和宗教节日。驻以色列使馆提醒在以中国公民遵守当地规定和风俗习惯,提高安全意识,加
4月5日,Haworth海沃氏旗下的Cassina宣布收购意大利传奇设计家具品牌Zanotta。随着这一新的举动,Zanotta加入了办公家具巨头Haworth海沃氏集团
浙农股份00275804月07日在投资者关系平台上答复了投资者关心的问题投资者贵公司有大豆玉米或者其他农作物种植嘛浙农股份董秘尊敬的投资者你好
承德露露4月7日在互动平台表示,根据公司发展需要,露露(北京)项目目前正在进行规划调整,廊坊工厂目前仍处于停产状态。
英雄之光!35名个人和4个群体获湖北省政府表彰---4月7日,湖北省见义勇为英雄先进表彰大会在武汉召开,会上宣读了湖北省人民政府《关于表彰湖
FazeClan知名内容创作者Nickmercs的一条推文引发众多玩家关注,他发文称游戏中的作弊者都应该被关进监狱。
原标题:@阿公阿婆(引题)警惕!“代理退保”或是诈骗(主题)羊城晚报讯记者戴曼曼报道:据银保监会4月6日官网消息,近期,一些不法分子...
今天来聊聊关于电脑网速慢了怎么办,电脑网速太慢怎么办的文章,现在就为大家来简单介绍下电脑网速慢了怎么办,电脑网速太慢怎么
1、应该选B完全替代的互补的是折线。本文到此分享完毕,希望对你有所帮助。
厦门网讯(厦门日报记者应洁)近期,集美区多所公办校招聘非编教师。集美区蔡林学校招聘初中生物、语文顶岗教师各1名(预计
1、黑暗物质三部曲第二季未开播。2、2、BBC联手HBO强势打造的电视剧《黑暗物质三部曲》已经开播,第一季拍摄时就直接续
掌上济宁梁山讯(通讯员郑丕民)近年来,梁山县快递行业党委在县委组织部的领导下,通过加强基层党组织建设、推进阵地共建共享、打造“红蜜...
据中国报告大厅对2023年4月6日N-乙酰基-5甲氧基色胺价格最新走势监测显示:2023年4月6日N-乙酰基-5甲氧基色
00:26记者从中国铁路北京局集团有限公司获悉,6日,随着最后一根500米长的钢轨平稳铺设在津兴铁路胜芳右线特大桥桥尾,
广告
X 关闭
广告
X 关闭
管好居家“神兽” 家长应先“自救”
疫情中的导游危中寻机
花钱就能“随心改”?代改IP地址暗藏隐私泄露风险
网上N95、KN95口罩宣传花样太多 信科学别信忽悠