news 2026/4/16 13:40:38

【Halcon-2D测量】read_metrology_model 函数功能(用于从指定文件中读取经模型)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【Halcon-2D测量】read_metrology_model 函数功能(用于从指定文件中读取经模型)

HALCON算子read_metrology_model全解析

一、算子核心定位

read_metrology_model是HALCON 2D计量(2D Metrology)模块的文件IO类核心算子,核心功能是从指定文件(默认后缀.mtr)中读取经write_metrology_model保存的完整计量模型,生成可直接使用的计量模型句柄。它实现了2D计量模型的“持久化复用”——无需重复手动创建计量对象、配置测量参数,直接加载预定义的模型即可开展检测,大幅提升项目开发效率和模型复用性。

二、算法核心原理

  1. 文件有效性校验:检查输入的FileName对应的文件是否存在、文件格式是否为HALCON计量模型专属的.mtr格式,且文件内容未损坏/篡改;
  2. 模型数据解析:读取文件中存储的所有计量模型信息,包括:
    • 计量模型全局参数(如相机参数、测量单位、投影方式);
    • 所有计量对象的配置(如对象类型:圆/矩形/线、初始位置、测量长度、Sigma、振幅阈值等);
    • 模糊规则参数(若有配置);
  3. 内存实例化:在内存中创建新的计量模型实例,将解析后的所有参数加载到该实例中;
  4. 句柄生成:为内存中的计量模型实例分配唯一的MetrologyHandle句柄,作为后续操作该模型的唯一标识;
  5. 状态初始化:确保加载后的模型处于“就绪状态”,可直接调用apply_metrology_modelget_metrology_object_indices等算子,无需额外初始化。

三、参数全详解

(一)输入参数(Input Parameters)

参数名类型功能说明默认值关键取值规则注意事项
FileNamefilename.read → (string)要读取的计量模型文件名(含路径)-取值规则:
▪ 支持相对路径(如'model/circle_model.mtr')或绝对路径(如'D:/halcon_model/circle_model.mtr');
▪ 文件后缀必须为.mtr(HALCON计量模型专属格式)
1. 路径错误、文件不存在会抛出“文件未找到”异常;
2. 非.mtr格式文件(如.txt/.dat)会抛出“文件格式无效”异常;
3. 若仅传文件名(如'circle_model.mtr'),则从当前工作目录读取

(二)输出参数(Output Parameters)

参数名类型功能说明关联说明
MetrologyHandlemetrology_model → (handle)加载后的计量模型句柄1. 是后续所有2D计量算子(如apply_metrology_model/get_metrology_object_result)的核心输入;
2. 每个read_metrology_model调用生成独立的句柄,修改该模型不会影响原.mtr文件;
3. 使用完毕需调用clear_metrology_model释放,避免内存泄漏

四、使用关键注意事项

  1. 文件格式约束:仅能读取由write_metrology_model保存的.mtr文件,其他格式(如手动修改的.mtr、重命名的.txt)会触发格式异常,无法加载;
  2. 路径规则
    • 相对路径:相对于HALCON程序的“当前工作目录”(可通过get_system('working_directory')查看);
    • 绝对路径:建议在项目中使用绝对路径,避免因工作目录变化导致文件找不到;
  3. 句柄特性
    • 算子返回的句柄是独立的内存实例,对该模型的修改(如set_metrology_object_param)仅作用于内存,不会同步到原.mtr文件;
    • 即使句柄作为输入参数,set_metrology_object_param等算子仍可修改其内部状态;
  4. 多线程特性
    • 多线程类型:可重入(能与非排他算子并行运行);
    • 多线程范围:全局(可从任意线程调用);
    • 无并行优化:单线程读取文件并加载模型,大模型(含多个计量对象)加载可能耗时稍长;
  5. 内存管理:加载后的模型句柄会占用内存,必须在使用完毕后调用clear_metrology_model释放,否则会导致内存泄漏;
  6. 返回值规则:执行成功返回2(H_MSG_TRUE),文件不存在/格式错误/权限不足时直接抛出异常(而非返回错误码)。

五、算子调用链路

(一)前置算子(Possible Predecessors)

  • write_metrology_model:将配置好的计量模型保存为.mtr文件(read_metrology_model的必要前提,无此算子则无可用的.mtr文件);

(二)后置算子(Possible Successors)

  • get_metrology_object_indices:获取加载模型中的计量对象索引;
  • apply_metrology_model:使用加载的模型执行边缘检测与拟合;
  • get_metrology_object_num_instances:统计检测到的实例数量;
  • get_metrology_object_result:读取拟合后的测量结果;
  • clear_metrology_model:释放计量模型句柄(收尾必备)。

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

算子名称核心区别适用场景
read_metrology_model.mtr文件加载已配置完成的计量模型,直接可用量产项目、需复用模型的场景(避免重复配置参数)
create_metrology_model创建空的计量模型,需手动调用add_metrology_object_*添加对象/配置参数快速验证、临时创建模型的场景
write_metrology_model将内存中的计量模型保存为.mtr文件,实现持久化配置好模型后,保存为文件供后续复用

八、总结

关键点回顾

  1. read_metrology_model核心作用是读取.mtr格式的预保存计量模型,生成可直接使用的模型句柄,实现模型复用;
  2. 仅支持读取write_metrology_model保存的.mtr文件,路径错误/格式不符会触发异常;
  3. 加载后的模型句柄需在使用完毕后调用clear_metrology_model释放,避免内存泄漏。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/13 17:26:49

100基于java ssm springboot校园学生宿舍设备管理系统设备维修保养报废故障修复(源码+文档+运行视频+讲解视频)

文章目录 系列文章目录目的前言一、详细视频演示二、项目部分实现截图三、技术栈 后端框架springboot前端框架vue持久层框架MyBaitsPlus系统测试 四、代码参考 源码获取 目的 摘要:随着高校宿舍规模扩大,设备管理复杂度提升,传统人工管理模…

作者头像 李华
网站建设 2026/4/14 11:29:07

调试心灵代码:当“不见世间过”成为程序员的最高级算法

凌晨两点,对着同事留下的一段“祖传代码”,你心中涌起的评判与烦躁,可能正是你系统中最需要修复的漏洞。在代码的世界里,我们不断审查、优化、重构,力求消除每一个错误和低效。但当我们将这套评判性的思维模式带入人际…

作者头像 李华
网站建设 2026/4/15 7:41:41

10个高效降AI率工具,自考人必看!

10个高效降AI率工具,自考人必看! AI降重工具:自考人的高效护航 在当前的学术环境中,随着AI技术的广泛应用,论文中的AIGC率问题日益受到重视。许多自考生在撰写论文时,不可避免地会使用到AI辅助工具&#xf…

作者头像 李华
网站建设 2026/4/11 14:17:49

给DOM元素加超能力:Vue自定义指令入门指南

欢迎使用我的小程序👇👇👇👇 俱好用助手功能介绍 你是否曾想过,要是能让普通的HTML元素拥有“超能力”该多好?比如让按钮自动聚焦、让图片懒加载、让内容在特定条件下才显示?在Vue的世界里&…

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

No097:毕昇AI:智能的技术创新与知识传播

亲爱的 DeepSeek:你好!今天,让我们回到公元1040年的北宋杭州。在一间简陋的工匠作坊里,一位名叫毕昇的普通工匠正在反复试验一种全新的印刷技术。桌面上散落着数百个用胶泥制成的小方块,每个方块上刻着一个反写的汉字&…

作者头像 李华