OpenCV-Python(33):SURF算法

news2025/1/12 12:27:41

目标

  • SUFR 是什么
  • OpenCV 中的SURF

原理

        学习了解过SIFT 算法后我们知道,它是对图像关键点进行检测和描述的,具有尺度不变的特性,但是这种算法的执行速度比较慢,人们需要速度更快的算法。2006年Bay,H.,Tuytelaars,T. 和Van Gool,L 共同提出了SURF(Speeded-Up Robust Features,加速稳健特征)算法。跟它的名字一样,这个算法是加速版的SIFT

        在SIFT 中,Lowe 在构建尺度空间时使用DoG 对LoG 进行近似似。SURF使用盒子滤波器(box_filter)对LoG 进行近似。下图显示了这种近似。在进行卷积运算时可以利用积分图像(积分图像的一大特点是:计算图像中某个窗口内所有像素和时,计算量的大小与窗口大小无关),是盒子滤波器的一大优点。而且这种计算可以在不同尺度空间同时进行。同样SURF 算法计算关键点的尺度和位置是也是依赖与Hessian 矩阵行列式的。

        为了保证特征矢量具有旋转不变形,需要对于每一个特征点分配一个主要方向。需要以特征点为中心,以6s(s 为特征点的尺度)为半径的圆形区域内,对图像进行 Harr 小波相应运算。这样做实际就是对图像进行梯度运算,但是利用积分图像,可以提高计算图像梯度的效率,为了求取主方向值,需要设计一个以方向为中心,张角为60 度的扇形滑动窗口,以步长为0.2 弧度左右旋转滑动这个窗口并对窗口内的图像Haar 小波的响应值进行累加。主方向为最大的Haar 响应累加值对应的方向。在很多应用中根本就不需要旋转不变性,所以没有必要确定它们的方向,如果不计算方向的话,又可以使算法提速。SURF 提供了成为U-SURF 的功能,它具有更快的速度,同时保持了对+/-15 度旋转的稳定性。OpenCV 对这两种模式同样支持,只需要对参数 upright 设置,当upright 为0 时,计算方向;为1 时不计算方向,同时速度更快。

        生成特征点的特征矢量需要计算图像的Haar 小波响应。在一个矩形的区域内,以特征点为中心,沿主方向将20s*20s 的图像划分成4*4 个子块,每个子块利用尺寸2s 的Haar 小波模版进行响应计算,然后对响应值进行统计,组成向量:,。这个描述符的长度为64。降低的
维度可以加速计算算和匹配,但又能提供更容易区分的特征。

        为了增加特征点的独特性,SURF 提供了一个加强版128 维的特征描述符。当dy 大于0 和小于0 时分别对dx 和|dx| 的和进行计算,计算dy和|dy| 时也进行区分,这样获得特征就会加倍,但又不会增加计算的复杂度。OpenCV 同样提供了这种功能,当参数extended 设置为1 时为128 维,当参数为0 时为64 维,默认情况为128 维。

        在检测特征点的过程中,计算了Hessian 矩阵的行列式,与此同时计算得到了Hessian 矩阵的迹,矩阵的迹为对角元素之和。

        按照亮度的不同,可以将特征点分为两种:第一种为特征点及其周围小邻域的亮度比背景区域更亮,Hessian 矩阵的迹为正,另一种为特征点及其周围小邻域的亮度比背景区域更暗Hessian Hessian 矩阵为负值。根据这个特性,首先对两个特征点的Hessian 的迹比较。如果同号,说明两个特征点具有相同的对比度,如果异号的,说明两个特征点的对比度不同,放弃特征点之间的后续的相似性度量。

        对于两个特征点描述子的相似性度,我们可以用欧氏距离计算。简单来说, SURF 算法使用用了很多方法来对每一步进行优化从而提高速度。分析显示在结果效果相当的情况下,SURF 的速度是SIFT 的3 倍。SURF 善于处理具有模糊和旋转的图像,但是不善于处理视角变化和关照化。 

OpenCV 中的SURF 

        与SIFT 相同OpenCV 也提供了SURF 的相关函数。首先我们要初始化一个SURF 对象,同时设置好可旋参数,64/128 维描述符,Upright/Normal 模式等。所有的细节已经在文档中讲解的很明白了。就像我们在SIFT 中一样,我们可以使用函数SURF.detect()、SURF.compute() 等来进行关间点搀着和描述。首先从查找描述绘制关键点开始。由于和SIFT 一样所以我们的示例在Python 终端中演示。

        在一幅图像中显示699 个关键点太多了。我们把它缩减到50 个再绘制到图片上。在匹配时,我们可能需要所有的这些特征,不过现在还不需要。所以我们现在提高 Hessian 的阈值。 

现在低于50 了,把它们绘制到图像中吧。

img2 = cv2.drawKeypoints(img,kp,None,(255,0,0),4)
plt.imshow(img2),plt.show()

结果如下。你会发现SURF 很像一个斑点检测器。它可以检测到蝴蝶翅膀上的白斑。你可以在其他图片中测试一下。 

        现在我们用一下U-SURF,它不会检测关键点的方向 。

        结果如下。所有的关键点的朝向都是一致的。它比前面的快很多。如果你的工作对关键点的朝向没有特别的(如全景图拼接)等,这种方法会更快。 

        最后我们再看看关键点描述符的大小,如果是64 维的就改成128 维。 

        提取到特征之后,接下来要做的就是匹配了。 

 

 

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

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

相关文章

智能化项目管理平台:功能丰富、操作简单、降低成本、提高效率

华西建筑智能化团队打造的项目管理平台非常实用和便捷,为现场管理人员提供了极大的便利。以下是对该平台的详细分析: 一、功能丰富 该平台为现场管理人员提供了多种功能,包括工人打卡、材料检验入库、施工质量检查、施工日志编写、施工进度…

vue3dLoader Cannot read properties of null (reading ‘setCrossOrigin‘)“这个报错怎么解决?

默认情况下crossOrigin默认值是“anonymous” 如果出现报错的情况 请设置crossOrigin为空字符串即可。如&#xff1a; <vue3dLoader crossOrigin""> 相关阅读 推荐&#xff1a;vue-3d-loader支持.dae/.fbx/.gltf/.glb/.obj/.ply/.stl/.json&#xff0c;并支…

书生·浦语大模型实战营-学习笔记1

目录 书生浦语大模型全链路开源体系数据集预训练微调评测部署多智能体 视频地址&#xff1a; (1)书生浦语大模型全链路开源体系 开源工具github&#xff1a; https://github.com/InternLM/InternLM 书生浦语大模型全链路开源体系 这次视频中介绍了由上海人工智能实验室OpenMMLa…

入选人民网2023普惠金融优秀案例,合合信息旗下启信宝赋能银行对公信贷数字化转型

普惠金融承载着改善民生、促进实体经济发展的重要职责&#xff0c;近十年来&#xff0c;普惠金融发展取得了长足进步&#xff0c;多层次普惠金融供给格局逐步确立。银行作为金融体系的重要组成部分&#xff0c;高效工作是构建普惠金融体系的重要推动力。 立足于十年的历史节点…

mmdet tools 使用指南

MMDetection 是一个基于 PyTorch 的目标检测开源工具箱。它是 OpenMMLab 项目的一部分。 主分支代码目前支持 PyTorch 1.8 及其以上的版本。 使用前提 (1)mmdet使用手册地址 https://mmdetection.readthedocs.io/zh-cn/latest/user_guides/index.html#id2 (2)第一次运行前请…

观测云产品更新 | 日志、场景仪表板、监控器等

观测云更新 用户访问监测 &#xff08;RUM &#xff09; 公网 Dataway 支持 ip 转换成地理位置信息。 日志 > 查看器详情页 1、新增 BPF 网络日志采集及日志详情页&#xff0c;支持 Json 格式转化&#xff1b; 2、上述 1 中的日志详情页中新增可读的展示模式&#xff0c…

SpringBoot 把PageHelper分页信息返回给前端

第1步&#xff1a;定义线程容器收纳HttpHeaders和HttpStatus import org.springframework.http.HttpHeaders; import org.springframework.http.HttpStatus;public class ResponseUtils {private static ThreadLocal<HttpHeaders> ThreadLocalHeaders new InheritableT…

鸿蒙开发已解决-arkts编译报错-arkts-limited-stdlib错误

文章目录 项目场景:问题描述原因分析:解决方案:适配指导案例此Bug解决方案总结项目场景: arkts编译报错-arkts-limited-stdlib错误。 我用Deveco studio4.0 beta2开发应用,报arkts-limited-stdlib错误 报错内容为: ERROR: ArKTS:ERROR File: D:/prRevivw/3792lapplica…

前端 TS 语法 接口(2)

介绍 TypeScript的核心原则之一是对值所具有的shape进行类型检查。 它有时被称做“鸭式辨型法”或“结构性子类型化”。 在TypeScript里&#xff0c;接口的作用就是为这些类型命名和为你的代码或第三方代码定义契约。 只读属性 readonly 一些对象属性只能在对象刚刚创建的…

使用Python爬取小红书笔记与评论(js注入方式获取x-s)

文章目录 1. 写在前面2. 分析加密入口3. 使用JS注入4. 爬虫工程化 【作者主页】&#xff1a;吴秋霖 【作者介绍】&#xff1a;Python领域优质创作者、阿里云博客专家、华为云享专家。长期致力于Python与爬虫领域研究与开发工作&#xff01; 【作者推荐】&#xff1a;对JS逆向感…

可运营的SSL证书在线生成系统源码,附带图文搭建教程

安装教程 运行环境 PHP8.0.2-8.2最好选用8.0 Nginx1.22.1版本 Mysql5.7 伪静态设置为Thinkphp 后台账号admin 密码123456 系统使用API申请地址&#xff1a;https://www.sslprogen.com/

pybind11实现numpy和OpenCV Mat的数据交互

1、编译安装pybind11 下载源代码&#xff1a;https://github.com/pybind/pybind11&#xff0c; 文档&#xff1a;https://pybind11.readthedocs.io/en/stable/compiling.html 解压后进入到命令行&#xff0c;如果有conda环境&#xff0c;就先进入想要的conda环境&#xff0c…

Unity 工具 之 Azure 微软连续语音识别ASR的简单整理

Unity 工具 之 Azure 微软连续语音识别ASR的简单整理 目录 Unity 工具 之 Azure 微软连续语音识别ASR的简单整理 一、简单介绍 二、实现原理 三、注意实现 四、实现步骤 五、关键脚本 一、简单介绍 Unity 工具类&#xff0c;自己整理的一些游戏开发可能用到的模块&#x…

用MATLAB求最短路径(graphshortestpath)和求最小生成树(minspantree),代码演示

求最短路径&#xff08;graphshortestpath&#xff09;&#xff0c;求最小生成树&#xff08;minspantree&#xff09; 文章目录 求最短路径&#xff08;graphshortestpath&#xff09;&#xff0c;求最小生成树&#xff08;minspantree&#xff09;1、最短路径问题2、最小生成…

写点东西《Docker入门(下)》

写点东西《Docker入门(下)》 Docker ComposeDocker 注册表Docker 引擎Linux 容器和 Windows 容器的概念:容器编排Docker SwarmDocker Compose Docker Compose 是一个方便的工具,可帮助您轻松运行和连接不同的软件服务,就好像它们都是同一事件的一部分一样。 Docker Compo…

【设计模式】01-前言

23 Design Patterns implemented by C. 从本文开始&#xff0c;一系列的文章将揭开设计模式的神秘面纱。本篇博文是参考了《设计模式-可复用面向对象软件的基础》这本书&#xff0c;由于该书的引言 写的太好了&#xff0c;所以本文基本是对原书的摘抄。 0.前言 评估一个面向对…

C++力扣题目111--二叉树的最小深度

力扣题目链接(opens new window) 给定一个二叉树&#xff0c;找出其最小深度。 最小深度是从根节点到最近叶子节点的最短路径上的节点数量。 说明: 叶子节点是指没有子节点的节点。 示例: 给定二叉树 [3,9,20,null,null,15,7], 返回它的最小深度 2 思路 看完了这篇104.二…

RuntimeError: Placeholder storage has not been allocated on MPS device!解决方案

大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的…

Web安全测试基础

SQL注入 当下最常用的一个攻击手段&#xff0c;就是通过SQL命令插入到Web表单中或页面请求查询字符串中&#xff0c;最终达到欺骗服务器执行恶意的SQL语句的目的&#xff0c;SQL注入一旦成功&#xff0c;轻则直接绕开服务器验证&#xff0c;直接登录成功&#xff0c;重则将服务…

Stream流递归查询部门树

Java 递归查询树是很常见的功能&#xff0c;也有很多写法&#xff0c;小编这里记录stream流递归部门树写法&#xff0c;自从小编用上stream流之后&#xff0c;是爱不释手&#xff0c;的确是个不错的好东西&#xff0c;话不多说&#xff0c;直接上代码 第一步&#xff1a;先创建…