算子 segment_contours_xld
算子segment_contours_xld
功能:将 XLD 轮廓分割为线段、圆弧或椭圆弧。
签名
segment_contours_xld(Contours : ContoursSplit : Mode, SmoothCont, MaxLineDist1, MaxLineDist2)
参数详解
输入参数
Contours (输入对象)
类型:XLD 轮廓数组
描述:待分割的输入轮廓。
Mode (输入控制)
类型:字符串
可选值:
'lines':仅分割为线段。'lines_circles':分割为线段和圆弧。'lines_ellipses':分割为线段和椭圆弧。
默认值:
'lines_circles'作用:选择分割模式。
SmoothCont (输入控制)
类型:整数
默认值:5
建议值:0, 3, 5, 7, 9
限制:
SmoothCont == 0或SmoothCont >= 3且为奇数。作用:平滑轮廓的采样点数。
设为
0表示不进行平滑。值越大,轮廓越平滑(抑制噪声,但可能丢失细节)。
MaxLineDist1 (输入控制)
类型:实数
默认值:4.0
建议值:1.0, 1.5, 2.0, 2.5, 3.0, 3.5
作用:
第一阶段的线段近似最大距离。
控制初始多边形近似的精度(值越大,线段越少,但可能忽略细节)。
MaxLineDist2 (输入控制)
类型:实数
默认值:2.0
建议值:1.0, 1.5, 2.0, 2.5, 3.0, 3.5
作用:
第二阶段的线段近似最大距离(仅对
'lines_circles'和'lines_ellipses'有效)。用于细化第一阶段未处理的区域(通常设为比
MaxLineDist1更小的值)。
输出参数
ContoursSplit (输出对象)
类型:XLD 轮廓数组
描述:分割后的轮廓,每个子轮廓的全局属性
'cont_approx'标识其类型:-1:线段0:圆弧('lines_circles'模式)1:椭圆弧('lines_ellipses'模式)
算法原理
预处理:
若
SmoothCont > 0,先对输入轮廓进行平滑(类似smooth_contours_xld),抑制噪声。使用 Ramer 算法(
gen_polygons_xld)进行初始多边形近似,最大距离为MaxLineDist1。
分割逻辑:
模式
'lines':直接输出多边形近似结果。模式
'lines_circles'或'lines_ellipses':第一阶段:用
MaxLineDist1生成初始线段。合并圆弧:若相邻线段可替换为圆弧(误差更小),则合并为圆弧。
第二阶段:用
MaxLineDist2对剩余线段重新分割,进一步合并短弧。
优势:两步法比单步法更高效,尤其适合长弧检测。
输出限制:
输出轮廓长度 ≥ 3 像素,且包含 ≥ 6 个连续点。
过短的输入轮廓直接复制到输出,不做处理。
参数调试指南
1. Mode 选择
'lines':适用于简单直线检测(如 PCB 板边缘)。'lines_circles':适合工业零件中的圆孔、轴承检测。'lines_ellipses':用于椭圆目标(如倾斜的圆形标记)。
2. SmoothCont
噪声较多时:增大值(如 5 或 7),但需权衡细节丢失。
高精度场景:设为 0 或 3,保留原始轮廓特征。
3. MaxLineDist1 和 MaxLineDist2
调试步骤:
初始设置:
MaxLineDist1=4.0,MaxLineDist2=2.0。若圆弧漏检:减小
MaxLineDist1(如 3.0)。若线段过多:增大
MaxLineDist1或MaxLineDist2。平衡速度与精度:
MaxLineDist1大 → 计算快,但可能漏细节。MaxLineDist2小 → 精度高,但计算量增加。
4. 示例调试场景
场景 1:金属零件圆孔检测
# 参数设置
Mode = 'lines_circles'
SmoothCont = 5 # 抑制加工毛刺
MaxLineDist1 = 3.0 # 初始近似保留大圆弧
MaxLineDist2 = 1.5 # 细化小圆弧场景 2:实时机器人抓取
Mode = 'lines' # 仅需线段信息
SmoothCont = 0 # 禁用平滑以降低延迟
MaxLineDist1 = 5.0 # 快速生成粗略轮廓
示例代码(HDevelop 翻译)
read_image (Image, 'pumpe')
edges_sub_pix (Image, Edges, 'canny', 1.5, 15, 40)
segment_contours_xld (Edges, ContoursSplit, 'lines_circles', 5, 4, 2)
count_obj (ContoursSplit, Number)
gen_empty_obj (Lines)
gen_empty_obj (Circles)
for I := 1 to Number by 1
select_obj (ContoursSplit, Contour, I)
get_contour_global_attrib_xld (Contour, 'cont_approx', Type)
if (Type == -1)
concat_obj (Lines, Contour, Lines)
else
concat_obj (Circles, Contour, Circles)
endif
endfor
fit_line_contour_xld (Lines, 'tukey', -1, 0, 5, 2, RowBegin, ColBegin, RowEnd, ColEnd, Nr, Nc, Dist)
fit_circle_contour_xld (Circles, 'atukey', -1, 2, 0, 3, 2, Row, Column, Radius, StartPhi, EndPhi, PointOrder)
调试技巧
可视化验证:
使用
dev_display显示分割后的轮廓,检查线段和圆弧是否符合预期。对比不同参数下
ContoursSplit的差异。
性能监控:
在实时系统中,监控算子执行时间,调整
MaxLineDist1和SmoothCont以优化速度。
鲁棒性测试:
在不同光照、噪声水平的图像上测试参数,确保泛化能力。
通过合理调整参数,segment_contours_xld 可广泛应用于工业检测、机器人导航和医学图像分析等领域。
算子 segment_contours_xld的更多相关文章
- HALCON中的算子大全(中英对照)
HALCON中的算子大全(中英对照) Chapter 1 :Classification1.1 Gaussian-Mixture-Models1.add_sample_class_gmm功能:把一个训 ...
- HALCON学习之算子大全
1.1 Gaussian-Mixture-Models 1.add_sample_class_gmm 功能:把一个训练样本添加到一个高斯混合模型的训练数据上. 2.classify_class_gmm ...
- halcon 算子功能查找大全中文版(可直接下载)
原文作者:aircraft 原文链接:https://www.cnblogs.com/DOMLX/p/11543364.html haicon算子中文查找大全百度云链接 链接:https://pan. ...
- (八)map,filter,flatMap算子-Java&Python版Spark
map,filter,flatMap算子 视频教程: 1.优酷 2.YouTube 1.map map是将源JavaRDD的一个一个元素的传入call方法,并经过算法后一个一个的返回从而生成一个新的J ...
- opencv中的SIFT,SURF,ORB,FAST 特征描叙算子比较
opencv中的SIFT,SURF,ORB,FAST 特征描叙算子比较 参考: http://wenku.baidu.com/link?url=1aDYAJBCrrK-uk2w3sSNai7h52x_ ...
- 特征描述算子-sift
特征描述算子-sift http://boche.github.io/download/sift/Introduction%20to%20SIFT.pdf
- EasyPR--开发详解(3)高斯模糊、灰度化和Sobel算子
在上篇文章中我们了解了PlateLocate的过程中的所有步骤.在本篇文章中我们对前3个步骤,分别是高斯模糊.灰度化和Sobel算子进行分析. 一.高斯模糊 1.目标 对图像去噪,为边缘检测算法做准备 ...
- Spark算子选择策略
摘要 1.使用reduceByKey/aggregateByKey替代groupByKey 2.使用mapPartitions替代普通map 3.使用foreachPartitions替代forea ...
- sobel算子的一些细节
1. 形式 Gy 上下颠倒的 (*A表示卷积图像,忽略先): 看得出来,sobel算子感觉并不统一,特别是方向,我们知道matlab的图像格式是,x轴从左到右,y轴从上到下,原点在左上角. 所以,第二 ...
- halcon算子
halcon的算子列表 Chapter 1 :Classification 1.1 Gaussian-Mixture-Models 1.add_sample_class_gmm 功能:把一个训练样 ...
随机推荐
- HttpClientFacotry Part 4: 集成 Polly 处理瞬时失效
HttpClientFacotry Part 4: 集成 Polly 处理瞬时失效 原文地址:https://www.stevejgordon.co.uk/httpclientfactory-usin ...
- CreateElement vs DOM Parser
Benchmark: CreateElement vs DOM Parser - MeasureThat.net 可见 createElement 效率并不逊于 HTML.
- 【前端】【探究】HTML - input类型为file时如何实现自定义文本以更好的美化
想到英语四级考了两次都没过,我觉得要多使用英文,所以本文使用英文书写. 本文讲述了遇到的问题,解决的思路,并讲述了解决方案,也许对你会有帮助. 目录 Problem description Solut ...
- MYSQL支持的数据类型-数值类型
一.数值类型分类 MYSQL支持所有标准SQL中的数值类型,其中包括严格数值类型(INTEGER.SMALLINT.DECIMAL和NUMERIC),以及近似数值数据类型(FLOAT.REAL和DOU ...
- [转]win10 vue-cli 下载成功,显示 vue不是内部或外部命令,也不是可运行的程序
vue不是内部或外部命令,也不是可运行的程序 1.安装vue-cli npm install -g @vue/cli 2.查看是否安装成功 vue -V 经过上述步骤,一般在CMD窗口输入" ...
- Web端IM聊天消息该不该用浏览器本地存储?一文即懂!
本文由转转技术团队刘筱雨分享,原题"一文读懂浏览器本地存储:Web Storage",下文进行了排版和内容优化. 1.引言 鉴于目前浏览器技术的进步(主要是HTML5的普及),在W ...
- Pytorch损失函数总结
损失函数 nn.L1Loss 创建一个衡量输入中每个元素之间的平均绝对误差 (MAE) 的标准XX和目标是的是的. nn.MSELoss 创建一个标准,用于测量输入中每个元素之间的均方误差(平方 L2 ...
- fopen在VS中不安全的问题
问题 fopen函数哎VS中使用,报错: error C4996: 'fopen': This function or variable may be unsafe. Consider using f ...
- Object类中toString()的使用
/* * Object类中toString()的使用: * * 1. 当我们输出一个对象的引用时,实际上就是调用当前对象的toString() * * 2. Object类中toString()的定义 ...
- Iterator迭代器接口(遍历Collection的两种方式之一)
使用 Iterator 接口遍历集合元素: Iterator对象称为迭代器(设计模式的一种),主要用于遍历 Collection 集合中的元素. GOF给迭代器模式的定义为:提供一种方法访问一个容 ...