Halcon 第五章『模板匹配Matching』◆第4节:基于形状的模板匹配|Shape-Based

2023-05-16

        一、介绍

        基于形状的模板匹配,也称为基于边缘方向梯度的匹配,是一种最常用也最前沿的模板匹配算法。该算法以物体边缘的梯度相关性作为匹配标准,原理是提取ROI中的边缘特征,结合灰度信息创建模板,并根据模板的大小和清晰度的要求生成多层级的图像金字塔模型。接着在图像金字塔层中自上而下逐层搜索模板图像,直到搜索到最底层或者得到确定的匹配结果为止。

        该方法使用边缘特征定位物体,对于很多干扰因素不敏感,如光照和图像的灰度变化,甚至可以支持局部边缘缺失、杂乱场景、噪声、失焦和轻微形变的模型。它甚至可以支持多个模板同步进行搜索。但是在搜索过程中,如果目标图像发生大的旋转或缩放,则会影响搜索的结果,因此不适用于选择和缩放比较大的情况。

        二、步骤

        基于形状的匹配,就是使用目标对象的轮廓形状来描述模板。Halcon中有操作助手,可以直观地进行形状模板匹配的参数选择以及效果测试。步骤如下:

        ①从参考图像上选择检测的目标。使用适合的形状工具,如矩形选区等,从参考图像上选择ROI,然后使用reduce_domain算子将该区域裁剪成一个独立的图像区域。

        ②创建模板。在创建模板之前,建议使用inspect_shape_model算子列出模板图像的各层级的金字塔图像和根据模板图像自动提取出的形状。查看这些信息有助于为创建模板选择合适的参数。

        设置inspect_shape_model算子的最后两个参数NumLevels(金字塔层级)和Contrast(点的最小对比度)。该算子执行后将会把预设参数的金字塔分级图像显示出来,可以根据需要判断参数选区得是否合理。

        Matching匹配 / Shape-Based外形匹配

        创建一个轮廓匹配模型基于金字塔的图像。

inspect_shape_model(Image : ModelImages, ModelRegions : NumLevels, Contrast : )

        Image:输入参数,输入图像。

        ModelImages:输出参数,输出图像基于金字塔的影像。

        ModelRegions:输出参数,输出模型区域。

        NumLevels:输入参数,使用的金字塔层数。默认4,范围1~10。

        Contrast:输入参数,设置对比度。默认30,参考10,20,30,40,60,80,100,120,140,160。

        在确定了金字塔层级和最小对比度之后,使用create_shape_model算子创建形状模板。创建模板时,除了NumLevel和Contrast两个参数已经明确外,AngleStep用于约束角度变化的步长。 

        Matching匹配 / Shape-Based外形匹配

        准备一个匹配轮廓模型(不可缩放比例)

create_shape_model(Template : : NumLevels, AngleStart, AngleExtent, AngleStep, Optimization, Metric, Contrast, MinContrast : ModelID)

        Template:输入参数,输入图像,用来产生模型的图像。

        NumLevels:输入参数,最大的金字塔层数。默认'auto',范围【0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 'auto'】。

        AngleStart:输入参数输入匹配时的起始角度。默认-0.39,建议值【 -3.14, -1.57, -0.79, -0.39, -0.20, 0.0】。

        AngleExtent:输入参数输入匹配时的角度范围。默认0.79,建议值【 6.29, 3.14, 1.57, 0.79, 0.39】,范围>= 0。

        AngleStep:输入参数输入匹配旋转角度的步长。默认'auto',建议值【'auto', 0.0175, 0.0349, 0.0524, 0.0698, 0.0873】,范围AngleStep >= 0 && AngleStep <= pi / 16。

        Optimization:输入参数,设置模板优化和模板创建方法。默认 'auto',范围

【'auto', 'no_pregeneration',

'none'存储所有模型点,

'point_reduction_high', 'point_reduction_low',

'point_reduction_medium', 'pregeneration'

】。

 如果模板图像特别大,可以用此参数进行优化,减少点的数量。对于小型模型,减少模型点的数量并不会导致搜索速度的加快,因为在这种情况下,通常需要检查模型的更多潜在实例。 如果Optimization设置为'auto',则create_shape_model会自动决定减少模型点的数量。  

        Metric:输入参数,设置匹配方法。默认 'use_polarity',范围

'ignore_color_polarity', 表示匹配过程忽略颜色对比度的变化,一般适用于多通道图像。如果不确定检测时会显示哪个通道的图像,可以选择此项。

'ignore_global_polarity', 适用于全局对比度发生变化的情况,表示忽略全局对比度的变化,即匹配过程中的图像对比度可以与模板中的完全相反。例如,模板中是一个暗背景上有一个亮的目标,那么在检索时,即使目标对象很亮而背景很暗,也能匹配成功。

'ignore_local_polarity', 表示忽略局部对比度的变化,如果图像因为光照改变等原因发生局部对比度变化,可以选择这一项。

'use_polarity'表示匹配得到的图像必须和模板图像的对比度“方向”相同。例如:模板中是一个暗背景上有一个亮的目标,那么在检索时,只有符合匹配条件并且亮度比背景亮的目标才能匹配成功。

】。

        Contrast:输入参数,设置对比度,阈值灬滞后阈值为模板的图像对象的对比和可选的最小的对象零件尺寸。默认'auto',【'auto', 'auto_contrast', 'auto_contrast_hyst', 'auto_min_size', 10, 20, 30, 40, 60, 80, 100, 120, 140, 160】。

        MinContrast:输入参数,搜索图像中的对象的最小对比度。默认 'auto',建议值【 'auto', 1, 2, 3, 5, 7, 10, 20, 30, 40】,范围MinContrast < Contrast。

        ModelID:输出参数,输出模型句柄。

        ③搜索目标。创建好模板后,接下来读取待检测的图像。使用find_shape_model算子搜索最佳匹配区域,将检测图像和模板句柄ModelID输入该算子中,搜索到的目标对象的匹配分值会存入参数Score中。如果各项参数都设定得很合适,那么在图像中应该会找到至少一个大于最小匹配分值的区域。find_shape_model算子返回的结果,除了匹配分值,还有目标的坐标和旋转角度,可以对位置和旋转角度进行计算。

        Matching匹配 / Shape-Based外形匹配

        在图像中找到形状模型的最佳匹配。

find_shape_model(Image : : ModelID, AngleStart, AngleExtent, MinScore, NumMatches, MaxOverlap, SubPixel, NumLevels, Greediness : Row, Column, Angle, Score)

        Image:输入参数,输入匹配模型的图像。

        ModelID:输入参数,输入模型句柄。

        AngleStart:输入参数,输入匹配时的起始角度。默认 -0.39,建议值【-3.14, -1.57, -0.79, -0.39, -0.20, 0.0】。

        AngleExtent:输入参数,输入匹配时的角度范围。默认0.79,建议值【6.29, 3.14, 1.57, 0.79, 0.39, 0.0】,范围≥0。

        MinScore:输入参数,输入最低的匹配分数(匹配质量),考虑到模板的一半被遮挡。默认0.5,范围0 ≤ MinScore ≤ 1。

        NumMatches:输入参数,在图像上找到模板的最大个数。默认1,建议值【0, 1, 2, 3, 4, 5, 10, 20】。

        MaxOverlap:输入参数,定义了找到的两个目标区域最多重叠的系数,如果=0,说明找到的目标区域不能存在重叠,如果=1,所有找到的目标区域都要返回。默认0.5,范围0 ≤ MaxOverlap ≤ 1。

        SubPixel:输入参数,确定找到的目标是否使用亚像素精度提取。默认'least_squares',范围

【 'none', (或false)模型的姿态仅由create_shape_model指定的像素精度和角度分辨率决定。 

'interpolation', (或true)位置以及旋转将以亚像素精度确定。在这种模式下,模型的姿态是从评分函数中插值出来的。 这种模式几乎不需要花费任何计算时间,并且能够达到对大多数应用程序足够高的精度。 然而,在某些应用中,精度要求极高。 在这种情况下,模型的姿态可以通过最小二乘调整来确定,即最小化模型点到对应图像点的距离。 与“插值”相比,这种模式需要额外的计算时间。

'least_squares', 'least_squares_high', 'least_squares_very_high',最小二乘调整的不同模式可用于确定搜索最小距离的精度。 然而,选择的精度越高,亚像素提取所需的时间就越长。如果需要最小二乘调整,则应该选择“最小二乘”,因为这将在运行时和精度之间产生最佳权衡。  

'max_deformation 1', 'max_deformation 2', 'max_deformation 3', 'max_deformation 4', 'max_deformation 5', 'max_deformation 6'在某些情况下,与模型相关的轻微变形的对象不能被发现,或者被发现的精度很低。 对于这样的对象,可以在参数SubPixel中额外传递一个最大允许的对象变形。 变形必须以像素为单位指定。 这可以通过传递可选参数值'max_deformation ',后跟一个介于0到32之间的整数值(在同一个字符串中)来实现,该整数值指定最大变形量。

】。

        NumLevels:输入参数,搜索时使用的金字塔层数。默认0。范围0~10。

        Greediness:输入参数,搜索时的“贪婪程度”。0—慢而安全;1—快而可能匹配失败。默认0.9,范围 0 ≤ Greediness ≤ 1。

        Row:输出参数,输出目标外形轮廓的y值坐标(轮廓中心位置)。

        Column:输出参数,输出目标外形轮廓的x值坐标(轮廓中心位置)。

        Angle:输出参数,输出已发现的模型实例的旋转角度。

        Score:输出参数,输出已找到的模型实例的评分。。

        为了直观地显示结果,可以在画面上依据计算结果绘图,dev_display_shape_matching_results算子绘制匹配结果。

        Matching匹配 / Shape-Based外形匹配

        显示形状匹配结果。

dev_display_shape_matching_results( : : ModelID, Color, Row, Column, Angle, ScaleR, ScaleC, Model : )

        ModelID:输入参数,要显示结果的形状模型的ID。

        Color:输入参数,输入匹配后的结果所用什么颜色显示。默认red。

        Row:输入参数,输入匹配对应的y值坐标位置。

        Column:输入参数,输入匹配对应的x值坐标位置。

        Angle:输入参数,输入匹配对应的角度。

        ScaleR:输入参数,输入水平方向的缩放比例。默认1.0。

        ScaleC:输入参数,输入垂直方向的缩放比例。默认1.0。

        Model:输入参数,输入模型句柄。

.        ④清除模板。匹配结束后,使用clear_shape_model算子将模板清楚,并释放内存资源。

*读取参考图像
read_image(Image, 'data/labelShape-0')
*根据要匹配的目标,围绕目标创建一个矩形,获取ROI区域
gen_rectangle1 (Rectangle, 34, 290, 268, 460)
*对ROI区域进行裁剪,得到模板图像
reduce_domain (Image, Rectangle, ImageReduced)
*测试金字塔的层级参数
inspect_shape_model (ImageReduced, ModelImages, ModelRegions, 4, 30)
*设置显示图像、绘制线条的线宽等窗口参数
dev_set_draw ('margin')
dev_set_line_width(3)
dev_display(Image)
dev_display(Rectangle)
*根据剪裁的模板图像创建基于形状的模板,返回模板句柄ShapeModelID
create_shape_model (ImageReduced, 5, rad(-10), rad(20), 'auto', 'none', 'use_polarity', 20, 10, ShapeModelID)
stop()
*读取用于测试的图像
read_image(SearchImage, 'data/labelShape-1')
*使用匹配算子进行形状模板匹配
find_shape_model (SearchImage, ShapeModelID, 0, rad(360), 0.5, 3, 0, 'least_squares', 0, 0.5, 	RowCheck, ColumnCheck, AngleCheck, Score)
*显示匹配结果,将匹配得到的实例以形状轮廓的形式绘制出来
dev_display_shape_matching_results (ShapeModelID, 'red', RowCheck, ColumnCheck, AngleCheck, 1, 1, 0)
*匹配结束,释放模板资源
clear_shape_model (ShapeModelID)
labelShape-0
ModelImages
ModelRegions
labelShape-1
dev_display_shape_matching_results (ShapeModelID, 'red', RowCheck, ColumnCheck, AngleCheck, 1, 1, 0)

 备注:rad()是角度转为弧度的意思。deg()是弧度转为角度。相关的算子是tuple_rad和tuple_deg。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Halcon 第五章『模板匹配Matching』◆第4节:基于形状的模板匹配|Shape-Based 的相关文章

  • Spark基础练习系列

    因最近学习了scala重温spark xff0c 本篇主要是spark sql与rdd的基础编程题 第一部分SparkRDD xff1a 原题目地址 xff1a 题目地址 数据准备 本题所需的数据 data txt 数据结构如下依次是 xf
  • sparkstream消费kafka序列化报错

    本篇介绍在window运行环境下 xff0c 使用spark消费kafka数据遇到的几个坑 调试环境IDEA 依赖 span class token operator lt span dependency span class token
  • Hadoop的安装和使用

    前言 xff1a 这个Hadoop的安装和使用操作起来很容易出错 xff0c 反正各种的问题 xff0c 所以在实验过程中需要细心 重复 xff0c 有的时候是机器的问题 xff0c 还有配置的问题 下面我讲一下我遇到的坑 xff01 第3
  • 树莓派 | 解决VNC Viewer无法连接显示问题

    如果觉得本篇文章对您的学习起到帮助作用 xff0c 请 点赞 43 关注 43 评论 xff0c 留下您的足迹 x1f4aa x1f4aa x1f4aa VNC Viewer是一个很不错的远程桌面应用 xff0c 但是我们在树莓派中使用时
  • kubeadm部署k8s,coredns一直处于containercreating状态failed to find plugin “flannel“ in path [/opt/cni/bin]]

    问题 xff1a coredns始终处于containercreating状态 coredns镜像拉取不下来 xff0c 只能手动拉去之后修改tag进行解决这个问题 xff0c 具体步骤如下 xff1a span class token n
  • Docker Compose部署Springboot+Mysql项目

    声明 xff1a 本文CSDN作者原创投稿文章 xff0c 未经许可禁止任何形式的转载 xff0c 原文链接 在上一篇文章Spring Boot Maven 43 Docker打包中 xff0c 我们实现了将Springboot项目源代码一
  • 华为交换机配置LACP模式链路聚合

    文章目录 1 拓扑图2 任务描述3 SwA配置4 SwB配置5 查看配置6 普通模式链路聚合演示 https blog csdn net qq 45042462 article details 120972306 1 拓扑图 2 任务描述
  • Linux 或 树莓派 4B 使用 apt 或 pip 安装 scipy

    下面的安装过程都是在树莓派4B上安装成功的 xff0c 记录一下 xff0c 仅供参考 python 3 7 使用 apt 安装 注 xff1a 这种好像python版本只能在3 8以下 xff0c 其他版本也可尝试 sudo apt ge
  • 树莓派4B 安装 sklearn

    本文记录在树莓派4B中安装sklearn库的步骤以及安装时遇到的问题 安装步骤 sudo pip3 install numpy 61 61 1 23 5 sudo apt get install python3 numpy python3
  • navicat连接mysql报错1251的解决方法

    navicat连接mysql报错1251的解决方法 1 新安装的mysql8 xff0c 使用破解版的navicat连接的时候一直报错 xff0c 如图所示 xff1a 2 网上查找原因发现是mysql8 之前的版本中加密规则是mysql
  • 一个简单的flask实例

    Flask是python编写的轻量级的web框架 span class token comment 导入Flask类 span span class token keyword from span flask span class toke
  • 基础命令(四)

    LINUX基础命令 xff08 四 xff09 一 Tail命令 1 tail使用方法 tail命令用途是依照要求将指定的文件的最后部分输出到标准设备 xff0c 通常是终端 xff0c 通俗讲来 xff0c 就是把某个档案文件的最后几行显
  • Snipaste常用快捷键(详细总结)

    Snipaste快捷键 xff08 详细总结 xff09 全局快捷键 全局操作截屏F1贴图F3退出当前截图Esc截屏并自动复制Ctrl 43 F1隐藏 显示所有贴图Shift 43 F3切换到另一组贴图Ctrl 43 F3 鼠标贴图相关操作
  • 4位数值比较器电路

    4位数值比较器电路 题目描述 xff1a 使用门级描述方式 xff0c 实现4位数值比较器 某4位数值比较器的功能如下表 96 timescale 1ns 1ns module comparator 4 input 3 0 A input
  • Maven项目pom.xml project标签爆红解决方法

    今天在打开项目的时候 xff0c 发现了一个Maven项目的问题 xff0c 在Maven项目的pom xml文件中 xff0c project标签爆出了一个错误 parent relativePath of POM com hrp spr
  • 人工智能学习笔记五——孪生神经网络

    本文将用孪生神经网络模型 xff0c 对手写数字集minist进行相似度比较 xff0c 用的框架是keras 如果还不清楚神经网络 xff0c 可以看一下这篇文章 神经网络 caodong0225 github io MNIST 是一个手
  • Docker Swarm实战初探

    声明 xff1a 本文CSDN作者原创投稿文章 xff0c 未经许可禁止任何形式的转载 xff0c 原文链接 环境 宿主机 xff1a macOS 10 15 7虚拟机平台 xff1a Parallels Desktop 15 1 2虚拟机
  • 零基础DIY四轴飞行器超级详细保姆级教程(STM32F407ZGT6主控、WIFI图传、陀螺仪平衡、气压计/超声波定高、手机蓝牙控制等功能)

    前言 大四毕业后暑假没事做就花了一点DIY了一个四轴飞行器 xff0c 是比较大的那种F450机架 xff0c 不是那种PCB板做机架的小四轴 xff0c 因为我也是从零基础开始做的四轴 xff0c 现在就想把自己的过程写成博客分享在网上
  • shell教程

    shell 简介 Shell是一种脚本语言 xff0c 通常用于在Unix和类Unix操作系统上进行命令行交互 它是用户与操作系统内核之间的接口 xff0c 允许用户通过命令行或脚本文件来控制计算机上的操作 Shell程序通常用于执行复杂的
  • matlab画图常用函数image、imagesc、imshow区别

    1 image函数 从数组显示图像 xff0c 直接把矩阵中的值当作索引值 xff08 称为直接映射 xff09 xff0c 即数值1对应RGB1 xff0c 数值2对应于RGB2 xff0c 当小于1或大于64时表现为两端的颜色 语法1

随机推荐