【如何实现机器视觉的C++模版匹配】

本文介绍了在机器视觉中使用C++进行模板匹配的方法,重点讲解了CkVision库中的ModelDemo函数,包括模板学习、参数设置、搜索范围和匹配功能。通过设置边缘轮廓的精细级别、滤波器、梯度阈值等参数,实现形状定位、计数和有无判断。此外,还讨论了匹配的自由度,如角度范围和比例范围。

在机器视觉开发中用的最多的功能非匹配莫属了,匹配时最基本的也是最重要的一个功能,软件系统是否能正确完成任务匹配定位起了至关重要的作用,这里就就介绍一些CkVision的匹配函数。具体的Demo代码可以在CkVision官网下载。

ModelDemo.exe模板轮廓匹配定

使用图像的边缘轮廓特征作为模板,在图像中搜索形状上相似的目标,可以设置角度和比例范围,可用于定位、计数和判断有无等

设置学习范围:将会在画面中出现一个青蓝色的ROI矩形框,点击选取矩形框,再将该矩形移动到需要作为标准模板的图像区域并调整大小(如上图)。

学习模板:按学习ROI在图像上学模板轮廓。

编辑模板:学模板之后可查看编辑模板。

精细级别:定义边缘轮廓的细腻程度,有Fine、Noraml和Coarse3个选项,Fine模式精度最高,但边缘太模糊时将无法检测到边缘,Noraml和Coarse3模式则会通过压缩方式来提取模糊的边缘,同时会丢失细节部分,并会影响定位进精度。

滤波器:用于增强边缘提取功能,跟精细级别类似,但不会影响定位精度。

梯度阈值:取值范围0到255,只有梯度值大于该值的边缘点才被检测到,梯度值是度量图像边缘的清晰度或对比度。

最短边缘:用于过滤长度小于该值的边缘轮廓。

重新学习:当修改参数后需要点击“重新学习”按钮来获得新的边缘轮廓。

编辑选项:手动编辑模板功能,“指示”可修改当前十字点位置,点击“擦除”或“恢复”按钮后可以使用鼠标在画面中对着边缘轮廓进行擦除或者恢复,上图中蓝色轮廓部分为被擦除,绿色部分为正在使用的边缘轮廓。

画笔大小:设置擦除或者恢复画笔的尺寸大小。

标记点:画面中红色十字标为模板的标记点,在“指示”模式下可以使用鼠标点击选取并拖动调整位置。

装载模板:从文件中加载模板数据。

保存模板:将模板数据保存到文件中。

设置自由度,

角度范围:匹配目标相对于模板可能存在的最小角度,值范围-180到180。

比例范围: 匹配目标相对于模板可能存在的最小比例,值范围80到120 ( 原始比例值100 )。

设置搜索范围:在图像上画出一个红色的ROI矩形框,该矩形框为搜索目标是的搜索范围,如果是全图搜索可以不用设置。

搜索数量:最多被允许搜索到的目标数量。

最小分数:分数表示目标和模板的相似程度,分数越高越相似,最大值100表示完全匹配,目标分数必须大于该值才会被搜索到,该参数值将会影响搜索速度。

梯度阈值:提取边缘轮廓时使用的参数,当边缘对比度较差时需要降低梯度阈值,如果目标边缘清晰,则可以设置比较高,取值范围0~255,一般设为40左右,该参数值将会影响搜索速度。

匹配极性:可以设置正常和反转,正常表示目标和模板极性相同,反转则表示相反。

压缩级别:在搜索过程中对图像进行压缩处理可以提升搜索速度,但也会降低识别率(影响程度跟模板和目标图像背景复杂度有关),一般采用“自动”设置。

分数:匹配目标与模板的相似度。

位置:匹配目标相对于当前图像的坐标位置。

角度:匹配目标相对于模板的旋转角度。

比例:匹配目标相对于模板的缩放比例。

ModelDemo模板轮廓匹配定位(老版本)

在 StdAfx.h 的头文件中添加CKVISION相关定义

#include "..\\..\\Include\\CKGDI.h"

#include "..\\..\\Include\\CKBase.h"

#include "..\\..\\Include\\CKLocate.h"

#ifdef _WIN64

#pragma comment(lib, "..\\..\\Lib_x64\\CKBase.lib")

#pragma comment(lib, "..\\..\\Lib_x64\\CKGDI.lib")

#pragma comment(lib, "..\\..\\Lib_x64\\CKLocate.lib")

#else

#pragma comment(lib,

课程目的:OpenCV是应用非常广泛的开源视觉处理库,在图像处理计算机视觉和自动驾驶中有着非常重要的作用。课程设计特色:(课程当前为第一期)1、C++与Python双语教学Python语言是在计算机视觉中应用最多的一种语言,在工作中,深度学习模型的训练基本上都是使用Python语言编写的训练代码。OpenCV在这个过程中用于图像的预处理(例如图像读取、数据增强)和后处理,还可以用于显示处理的结果,功能强大,使用方便。但是在功能的部署的时候,不管是部署在服务端还是PC端,开发语言基本上用的是C++,所以如何有效的使用OpenCV进行模型或者功能的部署尤为重要。C++语言应用的好坏,在面试中可以看出一个面试者的工程实践能力的强弱,两种语言的开发掌握好了可以使工作如虎添翼。2、全模块讲解我出版了一本图书《学习OpenCV4:基于Python的算法实战》,虽然这本书是写的基于Python的算法实战,但是实际上这本书有详细的介绍算法的C++接口,还有一些C++方向的案例,是以Python为主。图书出版的时候就想双语写作,只是限于篇幅没有成行。本课程不仅采用双语教学,更是对C++的每个模块都讲解,我们知道,很多的书其实只讲imgproc,如果你翻开一本书图像的形态学运算和图像滤波都是作为独立章节讲解的,那么这本书基本上就可以确定是只是讲解了imgproc模块,但是其他的模块在工作中也有很重要的作用。例如:core模块定义了C++的基本数据结构和基本运算(如四则运算);highgui模块是可视化与交互的模块;feature2d是特征点与特征匹配相关算法所在的模块;ml是机器学习相关的模块;dnn是深度学习相关的模块,可以使用OpenCV进行深度学习模型的部署。这些是很多的书和课程都不会讲的。3、讲解细致本课程会从环境搭建开始讲解,环境搭建尤为重要。从我多年的授课经验总结来看,如果只是给了代码,很多的入门用户环境问题处理不好的话,后面的学习很难进行下去,甚至会丧失学习的信心。4、会讲解C++和Python的开发语法问题是入门用户的一大难关,特别是C++语言。大学只是教授了C语言相关的内容,C++很多同学只懂一点皮毛,所以写代码步履维艰,我们在讲解代码的过程中会顺带讲解C++和Python的内容。我们还会讲解编译相关知识,还有库的装载与链接,这些是学校里不会教的,目前也几乎没有课程讲解。5、讲师经验丰富我讲解过C++和OpenCV的多个课程,广受学员好评。我出版过两本图书《深度学习计算机视觉实战》和《学习OpenCV4》,两本书都是细致入微的讲解,主要针对的就是初学者,所以能够很好的处理课程的难易程度。6、讲义准备充分讲义准备的充分细致,标识清楚明确,重点和疑难点突出。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值