目录

前言

一、基础知识

二、NCC基本公式以及解决问题

1. NCC基本公式

2. 基本公式解读

三、简化分母 fuv

1. 要简化的分母

2. 积分图

3. 分母拆开化简

四、简化分子

1. 要简化的分子

2. 模板函数的近似

3. 基函数简单解释

五、Fast NCC归一化互相关值

1. 最终公式

2. 复杂性对比

3. 论文中的举例:

总结


前言

最近在看一篇关于模板匹配的论文,里面的使用模板匹配的算法是改进版的NCC,即Fast NCC,看网上没有关于Fast NCC的解说,就想着记录一下自己学习的过程,写一下自己对这个改进算法的解释,论文的全称是《Template Matching using Fast Normalized Cross Correlation》,有感兴趣的可以自己去了解一下。(因为有的内容不好打字,下面我会用手写图片)

一、基础知识

从最简单的初高中知识开始:均值、标准差、方差、协方差、相关系数

二、NCC基本公式以及解决问题

1. NCC基本公式

本文讨论的问题是确定给定模式在二维图像中的位置。设 f(x,y) 表示图像在点 (x,y) 处的强度值,图像大小为 Mx × My,其中 x∈{0,…,Mx -1},y∈{0,…,My -1}。模式由给定的模板 t 表示,模板大小为 Nx​ × Ny​。计算模板匹配程度高低就是在点 (x,y) 处计算归一化互相关值,即NCC系数,系数值越高说明越匹配,有系数基本公式:与 “一、基础知识” 中的相关系数 r 同理

如果图像越匹配,则图像和模板越趋向于线性关系(一次函数):

其中

2. 基本公式解读

三、简化分母 fuv

1. 要简化的分母

由上面我们可知:

即模板所在图像位置,那一块模板区域图像的均值,我们可以知道,移动一次模板就需要计算一次模板所在区域图像的均值,计算时间需要很久,于是就提出了用积分表快速计算 fuv。(因为模板部分方差容易计算就先不管,这里主要是简化计算图像部分的方差)

2. 积分图

(作图有点粗糙看得懂就行)

推广到区域积分:

就有了以下公式,只需要三次相加减就可以算出模板区域内的图像强度均值:

3. 分母拆开化简

NCC的分母可以拆开变成:

其中:

解释一下其中的参数:

但是不要忘记还有:

化简一下:

最后可得:

分母简化完毕!!!只靠积分表就实现了计算

四、简化分子

1. 要简化的分子

分子原式:

可以写成分子N(u,v)

其中:t'(x-u,y-v) 为

由于 t′ 的均值为零,因此其总和也为零,故有:

所以分子N(u,v)只剩下:

2. 模板函数的近似

展开成K个矩形基函数的加权和,得到近似值,详细为:

 为加权系数,为基函数。

3. 基函数简单解释

基函数在这里可以暂且理解为在一些区域等于1,其他区域都为0,所以可以化简:

举个例子,下图就是在6 <= x <= 14 ^ 8 <= y <= 12区域为1,其他区域为0的基函数

所以分子N(u,v)可以近似为:

论文中写了确定基函数有两种方法,第一种是手动确定,第二种是自动确定。

与上面的分母同理,这里也可以运用积分表:

也成功化简了分子!!!只需要三次相加减就可以求得分子

五、Fast NCC归一化互相关值

1. 最终公式

简化完分子和分母之后,可以得到NCC归一化的近似值:

最终式子即为:

完成了NCC算法的加速。

2. 复杂性对比

复杂性分析:

举例说明,可以得出Fast NCC的算法复杂性最低

3. 论文中的举例:

几个图的说明:

(a) 原始图像          (b) 经过Fast NCC算法的交叉相关矩阵(u,v)

(c) 原始模板图像    (d) 原始模板图像曲面图

(e) 基函数处理过后的模板图像      (f) 处理过后的模板图像曲面图


总结

这篇文章对Fast NCC进行了一个解读,介绍了如何简化分母和分子,并求得近似值进行加速计算,最后得到了最终Fast NCC的算法公式,其复杂度远低于直接计算以及FFT,但是其中的基函数还有待考究,后续学习会继续补充。

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

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

相关文章

短剧小程序系统开发:赋能创作者,推动短剧艺术创新发展

短剧作为一种新兴的艺术形式&#xff0c;具有独特的魅力和发展潜力。然而&#xff0c;在传统的发展模式下&#xff0c;短剧创作者面临着诸多限制和挑战。短剧小程序系统的开发&#xff0c;为创作者提供了强大的赋能&#xff0c;推动了短剧艺术的创新发展。创作工具丰富&#xf…

Redis知识点+项目+面试八股

基础篇&#xff1a;讲解Redis常用数据结构实战篇&#xff1a;黑马点评实战高级篇&#xff1a;Redis高级知识点原理篇&#xff1a;Redis原理面试篇&#xff1a;Redis八股⭕️第一章&#xff1a;基础篇⭕️1. Redis介绍Redis是一个key-value的数据库&#xff0c;key一般是String类…

WPS文字和Word文档如何选择多个不连续的行、段

要选择Word或WPS文字中不连续的多行、多段&#xff0c;使用鼠标加键盘即可快速搞定。Word和WPS文字中选择多行的操作一样&#xff0c;选择多段的方法略有不同。选中以后&#xff0c;可以对这些内容进行删除、复制、剪切、查找、替换、设置格式等操作。一、在Word和WPS文字中选择…

嵌入式C/C++面试大全

基础语法 1.在main执⾏之前和之后执⾏的代码可能是什么&#xff1f; main函数执⾏之前&#xff0c;主要就是初始化系统相关资源&#xff1a; 设置栈指针&#xff0c;其中栈存放的局部变量、函数参数、函数调用的返回地址初始化静态 static 变量和 global 全局变量&#xff0c;即…

Java应用架构实战指南:主流模式解析与Spring落地实践

在Java开发的世界里,选对应用架构不是纸上谈兵,而是项目成败的关键。 今天,我想和大家聊聊四种主流架构模式——分层、微服务、事件驱动和六边形架构。这些模式在实战中各有千秋,我会结合代码示例和架构图,带大家看清它们的内核。无论你是新手还是老手,这篇文章都能帮你…

重学JS-002 --- JavaScript算法与数据结构(二)JavaScript 基础知识

文章目录加入jsjs 的位置控制台变量关键字DOMbutton注释CSS转义函数参数对象属性属性访问数组Math加入js 首先创建一个 script 元素。 此元素用于将 JavaScript 加载到 HTML 文件中。 <script src"./script.js"></script>js 的位置 script 标签位于 HTML…

计算机视觉--opencv(代码详细教程)(二)

一、图片的边界填充在 OpenCV 中&#xff0c;cv2.copyMakeBorder()是用于给图像添加边框&#xff08;边缘&#xff09;的核心 API&#xff0c;其完整语法和参数说明如下&#xff1a;函数完整定义cv2.copyMakeBorder(src, top, bottom, left, right, borderType, valueNone)参数…

FPGA实现Aurora 64B66B视频点对点传输,基于GTX高速收发器,提供4套工程源码和技术支持

目录 1、前言Aurora 64B66B是啥&#xff1f;官方有Example&#xff0c;为何要用你这个&#xff1f;工程概述免责声明 2、相关方案推荐我已有的所有工程源码总目录----方便你快速找到自己喜欢的项目我这里已有的 GT 高速接口解决方案本方案在Aurora 8B10B上的应用 3、工程详细设…

【软件安装|1】CentOS7最新可用国内 yum 镜像源配置和Linux版MySQL8.0安装及其相关知识

文章目录一.更换yum镜像源二.安装并配置MySQL8.0安装配置相关知识什么是yum&#xff1f;什么是镜像源&#xff1f;相关知识请看最后&#xff0c;首先来更换yum镜像源 更换前需要准备好VmwareWorkstation和Finalshell&#xff0c;开启虚拟机&#xff0c;切换到root用户 Vmware和…

【深度学习】深度学习的四个核心步骤:从房价预测看机器学习本质

文章目录基础概念与原理第一步&#xff1a;准备数据 - 构建学习的基础数据生成与特征工程&#xff08;选择对预测有用的特征&#xff09;数据集划分的重要性第二步&#xff1a;设计模型 - 建立数学表达线性回归模型的数学表达损失函数的设计哲学第三步&#xff1a;训练优化 - 自…

Java使用Apache POI读取Excel文件

一、下载jar包 Apache POI有提供下载地址&#xff1a;Apache Archive Distribution Directory&#xff0c;直接打开链接并选择所需的版本下载即可(双击last modified可按最新更新时间排序)&#xff0c;本文章以poi-bin-4.1.1-20191023.zip为例&#xff0c;进入官网下载链接后&…

VLMs开发——基于Qwen2.5-VL 实现视觉语言模型在目标检测中的层级结构与实现方法

概述 目标检测作为计算机视觉领域的核心任务&#xff0c;传统方法依赖于 YOLO 等视觉模型对预定义类别进行位置预测。然而&#xff0c;此类方法受限于预训练类别体系&#xff0c;难以实现灵活的视觉交互。视觉语言模型&#xff08;Vision-Language Models, VLMs&#xff09;的…

Spring Boot + Redis + 布隆过滤器防止缓存穿透

✅ 项目概述 在高并发系统中&#xff0c;缓存穿透 是一个经典问题&#xff1a;当恶意请求或业务逻辑查询一个数据库中不存在的 Key&#xff0c;由于缓存中也没有&#xff0c;请求会直接打到数据库&#xff0c;导致数据库压力激增&#xff0c;甚至宕机。 本项目使用 Spring Bo…

电子电路学习日记

这里的 K 表示 千欧&#xff08;kilo-ohm&#xff09;&#xff0c;而 F 在很多国产 EDA 软件&#xff08;比如立创EDA、Altium 的一些中文封装库&#xff09;里用来标注精度&#xff08;公差&#xff09;&#xff0c; F 代表 1% 精度&#xff08;英文 Fine tolerance&#xff0…

oracle 怎么实现读一致性

​ Oracle 数据块读一致性判断流程&#xff08;正确版&#xff09; 假设&#xff1a;Query SCN 查询开始的 SCN&#xff08;Query SCN&#xff09; lastSubbmit SCN 行中最新的提交scn Row SCN 行最后修改的 SCN&#xff08;存储在行头&#xff0c;通过 ITL 推导&#xff09…

ISTA为什么要加上软阈值激活函数?r若没有L1 正则化也要加其他激活函数吗?

一、加上软阈值函数&#xff08;Soft-thresholding&#xff09;是因为 LISTA&#xff08;以及它的前身 ISTA&#xff09;本质上是在求解一个 带 L1 正则化的稀疏优化问题&#xff1a; min⁡x12∥y−Ax∥22λ∥x∥1 \min_x \frac{1}{2} \|y - Ax\|_2^2 \lambda \|x\|_1 xmin​2…

线程P4 | 线程安全问题及解决方法

何为线程安全&#xff1f;要谈及何为线程安全&#xff0c;总得说来&#xff0c;我们可以用一句话来概况&#xff1a;如果在多线程环境下代码运行结果和我们预期是相符的&#xff0c;即和单线程环境下的运行结果相同&#xff0c;那么我们就称这个程序是线程安全的&#xff0c;反…

水印消失术!JavaAI深度学习去水印技术深度剖析

一、飞算JavaAI平台概述1.1 飞算JavaAI定位与技术特色 飞算JavaAI是国内领先的智能化Java开发平台&#xff0c;通过AI技术赋能软件开发全流程&#xff0c;特别针对小程序、Web应用等轻量级开发场景提供*零基础编程→高质量交**的一站式解决方案。其核心优势体现在&#xff1a; …

醋酸钆:医学影像与科技创新中的重要角色

醋酸钆是一种由钆元素和醋酸根离子组成的化合物。钆是稀土金属之一&#xff0c;常常用于医学影像、核磁共振成像&#xff08;MRI&#xff09;以及某些工业应用。醋酸钆作为钆的盐之一&#xff0c;具有许多独特的性质&#xff0c;尤其在医学和科学研究领域表现突出。一、醋酸钆的…

插入排序专栏

插入排序&#xff08;Insertion Sort&#xff09;是一种简单直观的排序算法&#xff0c;其思想源于我们日常生活中整理扑克牌的方式。本文将详细解析插入排序的工作原理&#xff0c;通过 Java 实现代码进行分析&#xff0c;深入探讨其时间复杂度的计算过程&#xff0c;并阐述其…