halcon-轴断面检测定位

前言

通常情况下轴检测时,通常会检测轴的各个阶段的长度。但是由于各种原因,在轴断面的区域现实不明显,无法正确提取,这时候需要根据轴断面的突出部分进行检测,但是由于部分轴的粗轴和细轴区域的宽度差距相当接近,所以就需要通过另外的处理,将轴的断面进行单独提取

1.halcon程序

* Image Acquisition 01: Code generated by Image Acquisition 01
list_files ('D:/2024Work/work/4.12断层检测', ['files','follow_links'], ImageFiles)
tuple_regexp_select (ImageFiles, ['\\.(tif|tiff|gif|bmp|jpg|jpeg|jp2|png|pcx|pgm|ppm|pbm|xwd|ima|hobj)$','ignore_case'], ImageFiles)
for Index := 0 to |ImageFiles| - 1 by 1read_image (Image, ImageFiles[Index])*gen_rectangle1 (ROI_0, 707.927, 631.228, 1072.01, 1398.08)*gen_rectangle1 (ROI_0, 735.583, 1488.93, 1089.37, 2298.93)gen_rectangle1 (ROI_0, 761.136, 824.068, 1021.81, 1090.71)reduce_domain (Image, ROI_0, ImageReduced)*矫正图像binary_threshold (ImageReduced, Region, 'max_separability', 'dark', UsedThreshold)erosion_circle (Region, RegionErosion,1)smallest_rectangle2 (RegionErosion, Row, Column, Phi2, Length1, Length2)vector_angle_to_rigid (Row, Column, Phi2, Row, Column, 1.5707963, HomMat2D)affine_trans_image (ImageReduced, ImageAffineTrans, HomMat2D, 'constant', 'false')reduce_domain (ImageAffineTrans, ROI_0, ImageReduced2)*获取断面下半部分binary_threshold (ImageReduced2, Region2, 'smooth_histo', 'dark', UsedThreshold1)*将上下断面进行联合shape_trans (Region2, RegionTrans, 'convex')*取区域的最大内接矩形inner_rectangle1 (RegionTrans, Row1, Column1, Row2, Column2)*创建矩形区域。根据实际情况,可以对内接矩形的左右列坐标进行修改,使得较粗的部分可以较多*较细的部分尽可能的少gen_rectangle1 (Rectangle1, Row1, Column1-4, Row2, Column2-3)*求取差值,将轴区域与内接矩形区域求差值,可得粗轴外轮廓difference (Region2, Rectangle1, RegionDifference)*剔除细轴多余的区域opening_circle (RegionDifference, RegionOpening1, 1)connection (RegionOpening1, ConnectedRegions)select_shape (ConnectedRegions, SelectedRegions, 'area', 'and', 200.96, 10000)union1 (SelectedRegions, RegionUnion)*进行横向闭运算,将粗轴进行相连接。closing_rectangle1 (RegionUnion, RegionClosing, 1000000000, 1)opening_circle (RegionClosing, RegionOpening, 5)connection (RegionOpening, ConnectedRegions1)    select_shape (ConnectedRegions1, SelectedRegions1, 'area', 'and', 10833.3, 363400.6)shape_trans (SelectedRegions1, RegionTrans1, 'convex')*获取断面上半部分*做差值提取到断面上半部分,剔除多余的噪点difference (Region2, RegionTrans1, RegionDifference2)connection (RegionDifference2, ConnectedRegions3)   select_shape (ConnectedRegions3, SelectedRegions3, 'area', 'and', 5196.22, 500000)opening_circle (SelectedRegions3, RegionOpening2, 3.5)*上下部分*对上下部分进行膨胀取交集dilation_circle (RegionOpening2, RegionDilation2, 1)dilation_circle (RegionTrans1, RegionDilation3, 3)intersection (RegionDilation2, RegionDilation3, RegionIntersection1)*结果显示skeleton (RegionIntersection1, Skeleton)junctions_skeleton (Skeleton, EndPoints, JuncPoints)get_region_points (EndPoints, Rows1, Columns1)gen_cross_contour_xld (Cross, Rows1[0], Columns1[0], 50, 0)gen_cross_contour_xld (Cross1, Rows1[1], Columns1[1], 50, 0)dev_display (ImageAffineTrans)dev_display (Cross)dev_display (Cross1)stop ()
endfor

在这里插入图片描述

2.程序解析

2.1图像矫正

在进行检测前,需要将图像矫正在垂直状态,在几何图像中是最大内接矩形是不容易判断的,例如在圆中的最大内接矩形是无限个。所以halcon并没有提供带角度的最大内接矩形,只是提供了垂直角度下的最大内接矩形。所以,我们需要对图像进行矫正到垂直。

    *矫正图像binary_threshold (ImageReduced, Region, 'max_separability', 'dark', UsedThreshold)erosion_circle (Region, RegionErosion,1)smallest_rectangle2 (RegionErosion, Row, Column, Phi2, Length1, Length2)vector_angle_to_rigid (Row, Column, Phi2, Row, Column, 1.5707963, HomMat2D)affine_trans_image (ImageReduced, ImageAffineTrans, HomMat2D, 'constant', 'false')reduce_domain (ImageAffineTrans, ROI_0, ImageReduced2)

2.2获取断面粗轴部分

本文中以,断面的下半部分作为轴的粗轴部分。首先是将上下断面区域进行联合,取区域的内接矩形,做差值后,就可以提取出粗轴的部分。
在这里插入图片描述
在这里插入图片描述

*获取断面下半部分binary_threshold (ImageReduced2, Region2, 'smooth_histo', 'dark', UsedThreshold1)*将上下断面进行联合shape_trans (Region2, RegionTrans, 'convex')*取区域的最大内接矩形inner_rectangle1 (RegionTrans, Row1, Column1, Row2, Column2)*创建矩形区域。根据实际情况,可以对内接矩形的左右列坐标进行修改,使得较粗的部分可以较多*较细的部分尽可能的少gen_rectangle1 (Rectangle1, Row1, Column1-4, Row2, Column2-3)*求取差值,将轴区域与内接矩形区域求差值,可得粗轴外轮廓difference (Region2, Rectangle1, RegionDifference)*剔除细轴多余的区域opening_circle (RegionDifference, RegionOpening1, 1)connection (RegionOpening1, ConnectedRegions)select_shape (ConnectedRegions, SelectedRegions, 'area', 'and', 200.96, 10000)union1 (SelectedRegions, RegionUnion)*进行横向闭运算,将粗轴进行相连接。closing_rectangle1 (RegionUnion, RegionClosing, 1000000000, 1)opening_circle (RegionClosing, RegionOpening, 5)connection (RegionOpening, ConnectedRegions1)    select_shape (ConnectedRegions1, SelectedRegions1, 'area', 'and', 10833.3, 363400.6)shape_trans (SelectedRegions1, RegionTrans1, 'convex')

2.3获取断面细轴部分

将整个轴的区域减去粗轴的区域,获得的就是断面区域

    difference (Region2, RegionTrans1, RegionDifference2)connection (RegionDifference2, ConnectedRegions3)   select_shape (ConnectedRegions3, SelectedRegions3, 'area', 'and', 5196.22, 500000)opening_circle (SelectedRegions3, RegionOpening2, 3.5)

2.4获取断面并显示

对上下部分进行膨胀,膨胀后取交集,即可获取到断面区域的。可以根据实际情况条件膨胀的参数使得结果在所需要的位置

*上下部分*对上下部分进行膨胀取交集dilation_circle (RegionOpening2, RegionDilation2, 1)dilation_circle (RegionTrans1, RegionDilation3, 3)intersection (RegionDilation2, RegionDilation3, RegionIntersection1)*结果显示skeleton (RegionIntersection1, Skeleton)junctions_skeleton (Skeleton, EndPoints, JuncPoints)get_region_points (EndPoints, Rows1, Columns1)gen_cross_contour_xld (Cross, Rows1[0], Columns1[0], 50, 0)gen_cross_contour_xld (Cross1, Rows1[1], Columns1[1], 50, 0)dev_display (ImageAffineTrans)dev_display (Cross)dev_display (Cross1)

总结

断面检测的核心在于对区域的内接矩形和差值的运用。通过内接矩形剔除细轴的区域,在不断通过差值进行计算即可。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/815052.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

windows SDK编程 --- 第一个程序

一、基础知识 1.Unicode 和 ANSI 在 Windows 编程中,Unicode 和 ANSI 是两种不同的字符编码方法,它们用于定义如何在计算机中表示和存储字符数据。 ANSI ANSI(American National Standards Institute)编码是一种基于单字节的字符…

使用阿里云试用Elasticsearch学习:4. 聚合——2

近似聚合 如果所有的数据都在一台机器上,那么生活会容易许多。 CS201 课上教的经典算法就足够应付这些问题。如果所有的数据都在一台机器上,那么也就不需要像 Elasticsearch 这样的分布式软件了。不过一旦我们开始分布式存储数据,就需要小心…

Android 蓝牙开发与 12/S 系统适配

蓝牙通信方式 经典蓝牙(Bluetooth Classic)通信: 经典蓝牙通信通常用于在较短的距离内传输大量数据,例如音频流、文件传输等。在 Android 中,你可以使用 BluetoothAdapter 和 BluetoothSocket 类来建立经典蓝牙连接&am…

Vue的学习之旅-part6-循环的集中写法与ES6增强语法

Vue的学习之旅-循环的集中写法与ES6增强语法 vue中的几种循环写法for循环for in 循环 for(let i in data){}for of 循环 for(let item of data){}reduce() 遍历 reduce( function( preValue, item){} , 0 ) ES6增强写法 类似语法糖简写对象简写函数简写 动态组件中使用 <kee…

【面试笔记】项目经理常见面试题

1、项目经理的能力和职能&#xff1f; 作为一个项目经理&#xff0c;我的主要能力和职能包括以下几个方面&#xff1a; 项目规划与管理&#xff1a;根据项目需求制定详尽的项目计划&#xff0c;包括时间表、资源分配、预算控制以及风险管理计划。确保项目在预定时间内按照既定…

实现卡片中每一条数据key的右对齐

前言&#xff1a; 在公司里面导师要求实现了卡片&#xff08;公司使用的框架是react&#xff0c;卡片引用的ant-design-moble的组件&#xff09;的功能&#xff0c;每一条数据横向展示&#xff0c;但是数据的key要实现右对齐&#xff0c;经过不断的修改&#xff0c;最后总结结…

AI应用实战2:使用scikit-learn进行回归任务实战

代码仓库在gitlab&#xff0c;本博客对应于02文件夹。 1.问题分析 在此篇博客中我们来对回归任务进行实战演练&#xff0c;背景是直播带货平台的业绩预测。第一步&#xff0c;就是分析问题。 问题痛点&#xff1a; 在直播带货平台上&#xff0c;由于市场环境多变、用户行为复…

5 个让日常编码更简单的 Python 库

今天我们一起来研究一些非常有用的第三方模块&#xff0c;可以使得我们的日常编码变得更加简单方便 sh https://github.com/amoffat/sh 如果曾经在 Python 中使用过 subprocess 库&#xff0c;那么我们很有可能对它感到失望&#xff0c;它不是最直观的库&#xff0c;可能还有些…

ubuntu 更改 ssh 默认端口 22 以加固安全

出于加固安全考虑&#xff0c;一般公司会禁用 ssh 的 22 端口号&#xff0c;因此我们需要改为其他端口。 1、ssh 命令行登录 进入台式机&#xff0c;修改 /etc/ssh/sshd_config 文件中的 Port 配置行&#xff0c;将 22 改为 8022&#xff0c;保存修改后&#xff0c;重启 ssh 服…

Vue3点击事件实现使table中最后一列可编辑的同时,表格中的滚动条自动滚动到该列位置

这个小功能我大概花了小半天的时间才实现&#xff0c;所以无比痛恨给我提这个需求的人&#xff0c;还好最后没有放弃&#xff0c;谨以此博客作为记录我被迫走上前端之路的第n天&#xff01;&#xff01;&#xff01; 代码来自项目里面的一部分&#xff0c;所以可能有点乱#&…

作文笔记6 写作顺序

时间顺序 举例&#xff1a;清晨 中午 傍晚&#xff0c;一般用来写景物 空间顺序/游览顺序 上下左右&#xff0c;前后内外 事情发展顺序 故事一般按照该顺序&#xff0c;起因&#xff0c;经过&#xff0c;结果 逻辑顺序 事理说明文&#xff0c;比如说一个事物&#xff0c…

【汇编】存储器

存储器 计算机存储器可分为内部存储器&#xff08;又称内存或主存&#xff09;和外部存储器&#xff0c;其中内存是CPU能直接寻址的储存空间&#xff0c;由半导体器件制成 存储单元的地址和内容 计算机存储信息的基本单位是一个二进制位&#xff0c;一位可存储一个二进制数&…

企业利器大曝光:CRM系统功能剖析

企业存在的根本目标是吸引并留住顾客。为了能够追踪顾客的信息以及与他们保持联系&#xff0c;不论企业规模大小&#xff0c;都长期使用了多种传统的手工方式。——彼得德鲁克 CRM系统的功能有哪些&#xff1f;如何做客户管理一直是企业管理中的热门话题&#xff0c;CRM&#…

[大模型]Qwen1.5-7B-Chat-GPTQ-Int4 部署环境

Qwen1.5-7B-Chat-GPTQ-Int4 部署环境 说明 Qwen1.5-72b 版本有BF16、INT8、INT4三个版本&#xff0c;三个版本性能接近。由于BF16版本需要144GB的显存&#xff0c;让普通用户忘却止步&#xff0c;而INT4版本只需要48GB即可推理&#xff0c;给普通用户本地化部署创造了机会。&…

C语言——数据在内存中的存储

引言 数据是程序运行的核心。当我们用C语言编写程序时&#xff0c;我们实际上是在操纵内存中的数据。这些数据在内存中是如何储存的&#xff0c;今天我们就来学习这些内容。 基本数据类型 1.整型 int: 基本整型&#xff0c;通常占用4个字节 short: 短整型&#xff0c;通常占用…

图像处理特征提取

图像处理中的特征提取是指从图像数据中提取出具有区分性和代表性的特征&#xff0c;以用于图像分类、目标检测、图像匹配等任务。下面介绍几种常见的图像处理特征提取方法&#xff1a; 颜色特征&#xff1a;颜色是图像中最直观且重要的特征之一。常见的颜色特征提取方法包括颜色…

zustand状态库在react类组件中使用

如果想在React类组件中使用zustand状态管理库&#xff0c;可以在类组件中调用create函数创建一个状态store&#xff0c;并使用useStore钩子来访问和更新状态。虽然zustand通常与函数式组件一起使用&#xff0c;但也可以在类组件中使用。 以下是一个简单的示例&#xff0c;展示…

MS软件Perl脚本提能培训方案

热忱欢迎贵公司选派研发人员参加铜陵浩辰科技有限公司举办的《MS软件Perl脚本提能培训方案》&#xff0c;此次培训将特邀具有多年授课经验的老师主讲。 一、培训概述 本培训旨在提高学员Perl脚本编写能力&#xff0c;能实现自行编写脚本&#xff0c;提高Perl脚本进行高级分析…

Gradle 在 Spring 中的使用-ApiHug准备-工具篇-006

&#x1f917; ApiHug {Postman|Swagger|Api...} 快↑ 准√ 省↓ GitHub - apihug/apihug.com: All abou the Apihug apihug.com: 有爱&#xff0c;有温度&#xff0c;有质量&#xff0c;有信任ApiHug - API design Copilot - IntelliJ IDEs Plugin | Marketplace ApiHug …

【计算机组成原理】CISC和RISC

目录 前言1. CISC&#xff08;复杂指令集计算&#xff09;2. RISC&#xff08;精简指令集计算&#xff09;3. 差异 前言 对于这方面的知识常见于408或者软考 CISC&#xff08;Complex Instruction Set Computing&#xff09;和RISC&#xff08;Reduced Instruction Set Compu…