news 2026/2/9 2:40:34

【Halcon-2D测量】get_metrology_object_param 函数功能(用于按需获取计量模型中指定计量对象的任意可配置参数)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【Halcon-2D测量】get_metrology_object_param 函数功能(用于按需获取计量模型中指定计量对象的任意可配置参数)

HALCON算子get_metrology_object_param全解析

一、算子核心定位

get_metrology_object_param是HALCON 2D计量(2D Metrology)模块的参数读取核心算子,核心功能是按需获取计量模型中指定计量对象的任意可配置参数——涵盖几何参数(如圆的圆心/半径、矩形的尺寸/角度)、测量区域参数(如Sigma、阈值、测量条长度)、检测规则参数(如实例数、最小分数)等全维度参数,是验证计量对象配置、调试测量逻辑、读取几何基准值的核心工具,支持批量读取多个参数、多个计量对象的参数值。

二、算法核心原理

  1. 句柄与索引校验:验证计量模型句柄(MetrologyHandle)有效性,解析Index参数确定要查询的计量对象范围(all遍历所有,指定索引则仅处理对应对象);
  2. 参数名解析:校验输入的GenParamName参数名是否合法(是否为该计量对象支持的参数),排除无效参数名;
  3. 参数值读取:针对每个指定的计量对象,按GenParamName的顺序依次读取对应参数的当前值;
  4. 结果封装:将读取的参数值按“计量对象索引顺序 + 参数名顺序”封装为数组,输出到GenParamValue
  5. 无修改逻辑:仅读取参数值,不改变计量模型/对象的任何配置或状态。

三、参数全详解

(一)输入参数(Input Parameters)

参数名类型功能说明默认值关键取值规则注意事项
MetrologyHandlemetrology_model → (handle)指定要查询的2D计量模型句柄-必须为已有效创建/加载的计量模型句柄1. 需通过create_metrology_model/read_metrology_model生成,且未被释放;
2. 无效句柄直接触发“句柄无效”异常
Indexinteger(-array) → (string / integer)指定要查询的计量对象索引‘all’可选值:
▪ ‘all’:查询模型内所有计量对象的参数;
▪ 整数/整数数组:查询指定索引的计量对象(如0、[0,1])
整数索引必须是get_metrology_object_indices返回的有效索引,否则抛异常
GenParamNameattribute.name-array → (string)要读取的参数名数组‘num_measures’支持的参数分为3类:
1. 通用参数(所有计量对象):min_scorenum_instancesmeasure_sigmameasure_threshold等;
2. 几何类型参数(专属):
▪ 圆:rowcolumnradius
▪ 矩形:rowcolumnphilength1length2
▪ 线:row_begincolumn_beginrow_endcolumn_end
▪ 椭圆:rowcolumnphiradius1radius2
3. 元参数:object_type(几何类型)、object_params(所有几何参数集合)
1. 若参数名对当前计量对象无效(如给线对象读radius),直接抛异常;
2. 支持批量传入多个参数名(如[‘object_type’,‘measure_sigma’,‘num_instances’])

(二)输出参数(Output Parameters)

参数名类型功能说明关联说明
GenParamValueattribute.value-array → (string / real / integer)返回参数值数组1. 顺序严格匹配GenParamName(如GenParamName为[‘a’,‘b’],则GenParamValue为[val_a, val_b]);
2. 若Index为数组/all,则按“计量对象1的参数1→计量对象1的参数2→计量对象2的参数1→计量对象2的参数2”排列;
3. 类型匹配参数(如object_type返回字符串,measure_sigma返回实数,num_instances返回整数)

四、使用关键注意事项

  1. 参数名与计量对象类型匹配
    • 专属几何参数仅适用于对应类型的计量对象(如radius仅圆对象有效,length1仅矩形对象有效),跨类型读取会抛异常;
    • 通用参数(如measure_sigmanum_instances)适用于所有类型计量对象;
  2. 参数值顺序约束GenParamValue的顺序完全由GenParamNameIndex决定,批量读取时需严格对应顺序解析;
  3. 几何参数的特殊性
    • 计量对象的几何参数(如圆的row/column/radius、矩形的length1/length2)仅能通过add_metrology_object_*算子设置,无法通过set_metrology_object_param修改,get_metrology_object_param仅可读取;
    • object_params会返回该计量对象所有几何参数的集合(如矩形返回[row, column, phi, length1, length2]);
  4. 多线程特性
    • 多线程类型:可重入(能与非排他算子并行运行);
    • 多线程范围:全局(可从任意线程调用);
    • 无并行优化:仅单线程读取参数,无性能加速;
  5. 返回值规则:执行成功返回2(H_MSG_TRUE),参数无效(如参数名错误、索引错误)时直接抛出异常。

五、算子调用链路

(一)前置算子(Possible Predecessors)

  • create_metrology_model:创建空的2D计量模型(基础前置);
  • add_metrology_object_*(如add_metrology_object_rectangle2_measure):向模型添加计量对象(生成基础参数);
  • set_metrology_object_param:(可选)修改计量对象参数后,读取验证修改结果;
  • get_metrology_object_indices:获取有效计量对象索引(用于精准指定Index)。

(二)后置算子(Possible Successors)

  • set_metrology_object_param:根据读取的参数值调整配置(如动态修改num_instances);
  • get_metrology_object_num_instances:结合参数值统计检测实例数;
  • dev_print_var:打印参数值,用于调试或日志输出;
  • clear_metrology_model:释放计量模型句柄(收尾操作)。

六、与相似算子的核心差异

算子名称核心区别适用场景
get_metrology_object_param读取计量对象的所有类型参数(几何、测量、规则),支持批量读取验证配置、调试参数、读取基准几何值
get_metrology_object_fuzzy_param仅读取计量对象的模糊规则参数(如模糊分数阈值)调试模糊检测规则
get_metrology_object_num_instances仅读取计量对象的检测实例数量统计检测到的目标数量
get_metrology_object_measures仅读取计量对象的测量区域轮廓+边缘原始坐标可视化测量区域、验证边缘检测原始结果

八、总结

关键点回顾

  1. get_metrology_object_param是2D计量模块的全维度参数读取工具,支持读取计量对象的几何、测量、检测规则类所有参数;
  2. 参数值顺序严格匹配GenParamName,且专属几何参数仅适用于对应类型的计量对象,跨类型读取会抛异常;
  3. 计量对象的几何参数(如row/column/radius)仅能通过add算子设置,无法通过set修改,get仅可读取基准值。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/6 12:08:07

终极轻量级CSS框架Chota:3kb实现专业前端开发

终极轻量级CSS框架Chota:3kb实现专业前端开发 【免费下载链接】chota A micro (3kb) CSS framework 项目地址: https://gitcode.com/gh_mirrors/ch/chota 在当今前端开发领域,框架臃肿化已成为普遍问题,而Chota轻量级CSS框架以其仅3kb…

作者头像 李华
网站建设 2026/2/4 7:12:16

Fabric8 Kubernetes Java客户端:云原生开发的终极利器

Fabric8 Kubernetes Java客户端:云原生开发的终极利器 【免费下载链接】kubernetes-client Java client for Kubernetes & OpenShift 项目地址: https://gitcode.com/gh_mirrors/ku/kubernetes-client 在当今云原生技术蓬勃发展的时代,Kuber…

作者头像 李华
网站建设 2026/2/6 19:55:17

调研也能“秒出专业问卷”?百考通AI平台,让每个人都是调研高手!

还在为设计问卷熬夜改稿?明明有清晰的研究问题,却不知如何转化为科学、中立、逻辑严谨的题目?担心措辞不当引发偏差,或结构混乱导致填写中断?别再让这些技术门槛阻碍你的学术进展或项目落地!百考通全新升级…

作者头像 李华
网站建设 2026/2/6 10:23:11

Calflops终极指南:3分钟快速掌握深度学习模型FLOPs计算技巧

Calflops终极指南:3分钟快速掌握深度学习模型FLOPs计算技巧 【免费下载链接】calculate-flops.pytorch The calflops is designed to calculate FLOPs、MACs and Parameters in all various neural networks, such as Linear、 CNN、 RNN、 GCN、Transformer(Bert、…

作者头像 李华
网站建设 2026/2/7 0:29:01

Il2CppInspector 终极指南:Unity逆向工程的强力工具

Il2CppInspector是一款专为Unity IL2CPP逆向工程设计的自动化工具,能够帮助开发者和安全研究人员深入分析Unity游戏和应用的二进制结构。通过本指南,您将掌握使用Il2CppInspector进行高效逆向分析的核心技巧。 【免费下载链接】Il2CppInspector Powerful…

作者头像 李华