当前位置: 首页 > article >正文

基于Halcon视觉技术的PCB元件缺失检测实战指南

1. 为什么选择Halcon进行PCB元件缺失检测在电子制造业中PCB印刷电路板的质量控制至关重要。一个缺失的电阻、电容或其他元件可能导致整个电路板无法正常工作。传统的人工目检方式效率低下且容易出错而Halcon作为工业视觉领域的标杆工具提供了强大的图像处理算法和高效的开发环境特别适合这类检测任务。我曾在多个项目中用Halcon处理过类似的检测需求实测下来它的模板匹配和Blob分析功能非常稳定。与其他视觉库相比Halcon最大的优势在于算法精度高亚像素级的处理能力开发效率高丰富的算子库和直观的语法硬件兼容性好支持大多数工业相机和采集卡举个例子某次我们需要检测PCB上0402封装的电阻尺寸仅1mm×0.5mmHalcon依然能准确识别出缺失情况这就是它的厉害之处。2. 检测前的准备工作2.1 硬件配置建议工欲善其事必先利其器。根据我的经验一套合理的硬件配置能事半功倍相机选择建议使用500万像素以上的工业相机像Basler ace系列就不错镜头搭配远心镜头更适合高精度检测普通CCTV镜头会有畸变照明方案环形光源是最稳妥的选择角度可调的条形光源也不错曾经有个项目因为用了普通USB摄像头导致图像边缘畸变严重后期处理花了大量时间校正。所以硬件投入千万别省否则后期调试会更费劲。2.2 图像采集技巧好的图像是成功的一半分享几个实用技巧曝光控制确保元件轮廓清晰但不过曝对焦调整使用Halcon的自动对焦算子auto_focus背景处理尽量选择与元件颜色对比度高的背景板* 示例自动对焦代码 auto_focus (Image, sharpness, 0, 0, 50, FocusScore)3. 核心检测流程详解3.1 ROI区域智能选取ROIRegion of Interest选取直接影响检测效率和精度。Halcon提供了多种ROI生成方式gen_rectangle1轴对齐矩形gen_rectangle2可旋转矩形gen_circle圆形区域draw_region手动绘制我推荐使用可旋转矩形因为它能更好地贴合元件角度。比如检测斜置的电阻时* 生成旋转矩形ROI gen_rectangle2 (ROI, Row, Column, Phi, Length1, Length2)3.2 模板匹配实战技巧模板匹配是检测的核心Halcon提供了多种匹配方法基于形状的匹配create_shape_model基于相关性的匹配create_ncc_model基于描述符的匹配create_local_deformable_model对于PCB元件检测形状匹配是最可靠的选择。这里有个关键参数容易踩坑Contrast参数设置过低会误匹配过高可能漏检AngleStep参数角度搜索步长影响速度和精度平衡* 创建形状模板 create_shape_model (TemplateImage, 5, 0, rad(360), auto, none, use_polarity, 30, 10, ModelID) * 查找模板 find_shape_model (Image, ModelID, 0, rad(360), 0.8, 1, 0.5, least_squares, 0, 0.9, Row, Column, Angle, Score)3.3 二值化与Blob分析当元件缺失时模板匹配会失败这时需要结合Blob分析将图像转为灰度进行阈值分割形态学处理开闭运算区域特征筛选* 二值化处理示例 rgb1_to_gray (Image, GrayImage) threshold (GrayImage, Regions, 100, 255) opening_rectangle1 (Regions, RegionOpening, 3, 3) connection (RegionOpening, ConnectedRegions) select_shape (ConnectedRegions, SelectedRegions, area, and, 500, 99999)4. 完整代码实现与优化4.1 检测流程完整实现结合前面介绍的技术完整的检测流程代码如下* 读取图像 read_image (Image, pcb_sample.bmp) * 创建模板 gen_rectangle2 (ROI, 100, 200, rad(45), 50, 20) reduce_domain (Image, ROI, ImageReduced) create_shape_model (ImageReduced, 5, 0, rad(360), auto, none, use_polarity, 30, 10, ModelID) * 模板匹配 find_shape_model (Image, ModelID, 0, rad(360), 0.7, 1, 0.5, least_squares, 0, 0.9, Row, Column, Angle, Score) * 结果判断 if (|Score| 0) * 元件存在时的处理 dev_display (Image) dev_display_shape_matching_results (ModelID, red, Row, Column, Angle, 1, 1, 0) else * 元件缺失时的处理 rgb1_to_gray (Image, GrayImage) threshold (GrayImage, Regions, 100, 255) opening_rectangle1 (Regions, RegionOpening, 3, 3) connection (RegionOpening, ConnectedRegions) select_shape (ConnectedRegions, SelectedRegions, area, and, 500, 99999) count_obj (SelectedRegions, Number) if (Number 0) * 确认元件缺失 disp_message (WindowHandle, 元件缺失, window, 12, 12, red, true) endif endif4.2 性能优化技巧在大批量检测时这几个优化技巧很实用并行处理使用Halcon的并行算子预编译模型将模板保存为.dcm文件ROI分级先大范围粗定位再小范围精确定位我曾经通过ROI分级将检测速度从200ms/帧提升到80ms/帧效果非常明显。5. 常见问题与解决方案5.1 误检问题处理误检是实际项目中最头疼的问题可以通过以下方法改善增加匹配分数阈值Score结合多个特征判断面积长宽比使用多模板验证有个项目因为元件反光导致误检后来我们增加了偏振片就完美解决了。5.2 特殊场景应对对于特殊场景需要特殊处理遮挡情况使用局部变形匹配反光元件调整光源角度或使用偏振片密集元件采用分水岭算法分割* 处理反光区域的示例 trans_from_rgb (Image, Image, Image, hsv, Hue, Saturation, Intensity) threshold (Saturation, Regions, 0, 50)6. 项目实战经验分享在实际项目中我总结出几个关键点参数调试先手动调试好参数再考虑自动优化异常处理一定要考虑各种异常情况模糊、遮挡等日志记录保存检测结果和过程图像方便追溯有个教训很深刻某次升级后检测率突然下降幸好有日志记录很快发现是照明亮度变化导致的。所以完善的日志系统非常重要。最后提醒大家Halcon的文档非常全面遇到问题时先查文档往往能找到解决方案。比如shape_model的文档就详细说明了各个参数的影响这对调试很有帮助。

相关文章:

基于Halcon视觉技术的PCB元件缺失检测实战指南

1. 为什么选择Halcon进行PCB元件缺失检测 在电子制造业中,PCB(印刷电路板)的质量控制至关重要。一个缺失的电阻、电容或其他元件可能导致整个电路板无法正常工作。传统的人工目检方式效率低下且容易出错,而Halcon作为工业视觉领域…...

Java8 Stream sorted排序实战:从Comparator基础到多级排序进阶

1. 从零开始理解Stream sorted排序 第一次接触Java8的Stream sorted方法时,我盯着那段链式调用的代码看了足足十分钟。就像刚拿到新手机的老人,明明按键就在眼前,却不知道从哪下手。后来在实际项目中踩过几次坑才明白,sorted()本质…...

DataX 实战:从零构建跨库数据同步解决方案

1. 为什么选择DataX进行跨库数据同步 第一次接触DataX是在处理一个电商平台的订单数据迁移项目。当时需要将MySQL中的3000万条订单数据同步到阿里云的AnalyticDB进行分析,尝试了多种方案后,DataX的表现让我印象深刻。相比传统的SQL导出导入方式&#xff…...

Excel炒股党必备:手把手教你用Power Query免费获取并刷新股票历史数据

Excel炒股党必备:手把手教你用Power Query免费获取并刷新股票历史数据 在投资分析领域,数据更新速度往往决定着决策质量。对于习惯使用Excel的投资者来说,每次手动复制粘贴股票数据不仅效率低下,还容易出错。其实Excel内置的Power…...

管理SELinux安全性知识点问答

1.SELinux是如何保护资源的? SELinux给进程和文件指定了规则,严格按照规则限制文件和进程,默认拒绝所有未明确的操作来保护资源。 2.什么是强制访问控制(MAC)?它有什么特点? 强制访问控制是由系统统一强制决定进程/用户对文件/设备的访问权限。用户和…...

kotlin中一般用高介函数代替return

在 Kotlin 里完全可以不用 break ,而且日常开发基本都这么写。 我给你按场景列全,都是实际开发里最常用的替代方案,一看就会。集合高阶函数(最常用,直接替代 break) 找到第一个满足条件就停(等…...

AI编程革命:Codex如何重塑脚本开发效率

技术文章大纲:告别重复造轮子——利用Codex高效编写脚本核心价值与痛点分析重复性脚本开发的低效现状 人工编写脚本的常见问题:语法错误、逻辑冗余、调试耗时 Codex如何通过自然语言理解降低脚本开发门槛Codex基础能力解析自然语言到代码的转换机制 支持…...

Kelsey Hightower在KubeCon 2026:面对AI,人人都是初级工程师

Electrolux站点可靠性产品经理Kristina Kondrashevich清晰地记得Kelsey Hightower对她工作产生的深刻影响。"我们参加了KubeCon 2023,Kelsey Hightower在那次大会上做了一场关于开源项目的演讲,"Kondrashevich告诉The New Stack,&q…...

告别数据焦虑:用MedAugment给你的医学影像数据集‘打鸡血’(附Python实战代码)

告别数据焦虑:用MedAugment给你的医学影像数据集‘打鸡血’(附Python实战代码) 当你面对只有几十张标注好的医学影像数据时,是否感到无从下手?作为经历过这种困境的开发者,我清楚地记得第一次尝试用200张皮…...

Allegro PCB覆铜设计的10个高效技巧

1. 覆铜基础设置:从零开始的高效起点 刚接触Allegro PCB设计时,我最常犯的错误就是忽略覆铜的基础设置。很多人觉得覆铜就是随便画个形状填满铜皮,但实际工作中,合理的初始设置能节省50%以上的后期修改时间。在Allegro 16.6之后的…...

Sunshine游戏串流技术架构深度解析

Sunshine游戏串流技术架构深度解析 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine Sunshine作为开源自托管游戏串流服务器,通过Moonlight协议实现低延迟跨设备游戏共享…...

生成式AI隐私影响评估(PIA)标准化模板(含12项强制审计指标+自动打分系统)

第一章:生成式AI应用数据隐私保护 2026奇点智能技术大会(https://ml-summit.org) 生成式AI在内容创作、代码生成与客户服务等场景中快速落地,但其对训练数据与用户输入的高度依赖,使敏感信息泄露、成员推断(membership inference…...

高效处理SDF文件:拆分与分子属性数据清理实战

1. SDF文件基础与化学信息学应用 SDF(Structure Data File)是化学信息学领域最常用的分子数据存储格式之一。这种纯文本格式最初由MDL公司开发,现已成为药物研发和分子建模中的通用标准。一个典型的SDF文件包含三个核心部分:分子结…...

[具身智能-380]:Habitat仿真平台概述以及如何利用该平台进行模型训练或算法调试?

📘 Habitat 仿真平台详解与训练/调试指南 Habitat 是由 Meta AI (FAIR) 开源的 3D 具身智能仿真平台,专注于室内视觉导航、多模态交互、具身感知与对话式 AI。它在学术界与工业界被广泛用于 Vision-and-Language Navigation (VLN)、ObjectGoal Navigati…...

【独立开发2】- Netunnel 内网穿透软件 - 你也在找无限制、便宜的吗?

设计初衷 总是找不到一款没有限制、便宜、操作简单的内网穿透软件。定价:0.5元/Gb ,最低一元。 https://github.com/aifuqiang02/netunnel 下载地址 , 访问不了github 的小伙伴, 可以加QQ群。找群主。 1、软件首页 (一睹为快&a…...

2026个人创业项目,0基础做门店WiFi商业变现

2026线下实体店流量红利依旧很大,很多人不知道,门店WiFi其实是一个非常适合个人起步的轻创业项目,不需要门店、不需要人脉、不需要营业执照,个人主体就能直接落地上线。 日常开店的餐饮、棋牌室、宾馆、便利店,几乎每…...

Golang colly爬虫框架如何用_Golang colly教程【进阶】

c.Visit()未触发OnHTML最常见原因是请求被目标站拦截导致403,因Colly默认UA易被拒绝;需设自定义UserAgent、加OnResponse打印状态码、处理重定向、传完整URL、用Limit()控并发、解压gzip、避开JS渲染页、选稳定选择器、用连接池channel安全存库。为什么 …...

安卓应用开发全流程实践与技术要点详解

引言 随着移动互联网的深入发展,安卓操作系统凭借其开放性和庞大的用户基数,在全球移动设备市场占据着举足轻重的地位。这催生了市场对高质量安卓应用和优秀安卓开发工程师的持续需求。作为一名安卓开发工程师,其职责远不止于编写代码,更涉及从需求理解、架构设计、编码实…...

新手小白创建SQL数据库,增删查改,升序,降序,不足之处望海涵

-- 创建数据表 CREATE TABLE users( id INT PRIMARY KEY, name VARCHAR(50) NOT NULL, id_card VARCHAR(18) NOT NULL, phone VARCHAR(11) NOT NULL, address TEXT, password VARCHAR(50) NOT NULL ); -- 添加数据 INSERT INTO school.users VALUES(1,gaga,622723190102214,176…...

告别Foxy导航‘幽灵错误’:手把手教你修改BT XML与源码,一劳永逸

根治ROS2 Foxy导航超时故障:从行为树配置到源码修改的终极指南 当你的ROS2 Foxy机器人突然在导航任务中"僵直",控制台不断刷出Action server failed while executing action callback: "send_goal failed"的错误时,这很可…...

康耐视相机与发那科机器人Ethernet I/P直连配置与视觉引导编程实战

1. 工业视觉与机器人协同的基础原理 在精密装配和分拣场景中,毫米级定位精度是刚需。康耐视相机就像机器人的"眼睛",通过Ethernet I/P协议将视觉数据实时传输给发那科机器人,形成闭环控制。这套系统最核心的优势在于硬件直连带来的…...

AI绘画商用翻车实录:为什么你买的“商用授权”根本无效?——深度拆解Stable Diffusion生态中7层隐性版权链

第一章:生成式AI应用版权合规指南 2026奇点智能技术大会(https://ml-summit.org) 生成式AI在内容创作、代码生成、设计辅助等场景中广泛应用,但其训练数据来源、输出内容权属及商业使用边界存在显著法律不确定性。开发者与企业需主动构建版权风险识别与…...

Spring Data MongoDB 最佳实践:如何构建高效数据访问层

在微服务、内容平台、物联网、日志系统和实时业务中,MongoDB 因其灵活的数据模型、优秀的水平扩展能力和较高的写入吞吐,被大量用于承载半结构化数据。对于 Java/Spring 技术栈来说,Spring Data MongoDB 是最常用的数据访问框架之一。它屏蔽了…...

MTKLogger存储空间总是不够用?教你调整‘Limit Log Size’并合理分配内部与SD卡存储

MTKLogger存储优化实战:精准控制日志大小与智能分配策略 每次测试进行到关键时刻,突然发现日志文件被自动覆盖,那种感觉就像马拉松终点前被强行拉回起点。作为深度依赖MTKLogger的测试工程师,我们都经历过存储空间不足导致的珍贵数…...

ESP32 IDF 无刷电机开环控制(完整工程+代码解析)

前言 本文基于 ESP-IDF 环境(推荐v6.0及以上),实现双无刷电机开环控制,包含完整工程创建、代码实现、IO管脚定义、接线指南及核心代码解析,适配ESP32核心板,新手可直接照搬工程,快速上手无刷电机…...

STM32F103C8T6连接ZH03B传感器,手把手教你做一个桌面PM2.5监测仪(附完整代码)

STM32F103C8T6与ZH03B传感器实战:打造高精度桌面PM2.5监测系统 最近工作室的空气质量总让我隐隐担忧,尤其是看到窗外雾蒙蒙的天空时。作为硬件爱好者,我决定用STM32F103C8T6和ZH03B激光粉尘传感器搭建一个实时监测装置。这个不到巴掌大的小盒…...

前端构建工具

前端构建工具的演进与核心价值 在当今快节奏的前端开发领域,构建工具已成为提升效率的关键。从早期的手动文件合并到如今的自动化流程,构建工具不仅简化了开发流程,还优化了代码性能。无论是个人项目还是企业级应用,选择合适的构…...

从交通拥堵到疾病预测:动态贝叶斯网络(DBN)在智慧城市中的3个落地场景与避坑指南

动态贝叶斯网络在智慧城市中的实战应用:从交通优化到疾病预警 引言:当城市开始"思考" 清晨7:30的早高峰,城市交通指挥中心的大屏上,红色拥堵路段正在以某种规律蔓延;同一时刻,疾控中心的监测系统…...

人工智能之数学基础:求解非线性约束

本文重点 在前面我们学习了两种方法,一种是内部法,另外一种是外部法,本文我们将学习一种新的方法,这种方法叫做乘子法。 乘子法 我们都听过拉格朗日函数,乘子法中,使用拉格朗日函数来代替f(x),所以此时f(x)为: 和外点法(内点法)一样,现在我们需要构建乘子罚函数:…...

XUnity自动翻译器:Unity游戏本地化的专业解决方案,5分钟实现高效汉化

XUnity自动翻译器:Unity游戏本地化的专业解决方案,5分钟实现高效汉化 【免费下载链接】XUnity.AutoTranslator 项目地址: https://gitcode.com/gh_mirrors/xu/XUnity.AutoTranslator 你是否曾因为语言障碍而错过优秀的Unity游戏?面对…...