OpenCV:SIFT关键点检测与描述子计算

news2025/2/1 19:32:16

目录

1. 什么是 SIFT?

2. SIFT 的核心步骤

2.1 尺度空间构建

2.2 关键点检测与精细化

2.3 方向分配

2.4 计算特征描述子

3. OpenCV SIFT API 介绍

3.1 cv2.SIFT_create()

3.2 sift.detect()

3.3 sift.compute()

3.4 sift.detectAndCompute()

4. SIFT 关键点检测与描述子计算示例

5. SIFT 的应用场景

总结


1. 什么是 SIFT?

SIFT(Scale-Invariant Feature Transform,尺度不变特征变换) 是由 David Lowe 在 1999 年提出的一种关键点检测与描述子计算方法。它的核心优势是: 尺度不变性:可以检测不同大小的特征点。

  • 旋转不变性:特征点不受旋转影响。
  • 光照鲁棒性:能够适应不同光照条件。
  • 稳定可靠:适用于图像匹配、目标识别、目标跟踪等任务。

SIFT 主要由 关键点检测(Keypoint Detection)特征描述子计算(Descriptor Computation) 两个部分组成。本文将详细介绍 SIFT 的原理,并结合 OpenCV 实现 SIFT 关键点检测和特征描述子的计算。


2. SIFT 的核心步骤

SIFT 主要包括以下几个关键步骤:

2.1 尺度空间构建

  • 通过 高斯金字塔 生成不同尺度的图像。
  • 计算 高斯差分 ,在多尺度空间找到潜在的关键点。

2.2 关键点检测与精细化

  • 通过泰勒展开对关键点进行精细调整,去除边缘响应和低对比度点。

2.3 方向分配

  • 计算关键点周围的 梯度直方图,赋予每个关键点一个主方向,使其具有旋转不变性。

2.4 计算特征描述子

  • 在关键点周围生成一个 128 维的 特征向量(描述子)。
  • 该描述子用于匹配和识别相似特征点。

3. OpenCV SIFT API 介绍

在 OpenCV 中,SIFT 由 cv2.SIFT_create() 提供,主要有以下三个核心函数:

3.1 cv2.SIFT_create()

创建 SIFT 关键点检测器和特征提取器。

sift = cv2.SIFT_create()

3.2 sift.detect()

用于 关键点检测,返回检测到的 keypoints(关键点列表)。

keypoints = sift.detect(gray, None)

3.3 sift.compute()

用于 计算描述子,返回关键点 keypoints 及其对应的 descriptors(特征向量)。

keypoints, descriptors = sift.compute(gray, keypoints)

3.4 sift.detectAndCompute()

同时进行关键点检测和描述子计算,推荐使用:

keypoints, descriptors = sift.detectAndCompute(gray, None)

返回值说明

  • keypoints:关键点列表,每个关键点包含坐标、尺度、方向等信息。
  • descriptors:特征描述子矩阵,形状为 (N, 128),其中 N 是关键点个数,每个关键点对应一个 128 维特征向量。

4. SIFT 关键点检测与描述子计算示例

# 关键点与描述子
# 关键点: 位置、大小和方向
# 描述子:记录了关键点周围对其有贡献的像素点的一组向量值,
# 其不受仿射变换、光照变换等影响

# 描述子的作用是进行特征匹配

import cv2
import numpy as np

# 读取图像
image = cv2.imread("D:\\resource\\filter\\shudu.jpg")

# 灰度化
gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)

# 创建SIFT对象
sift = cv2.xfeatures2d.SIFT_create()

# 关键点检测 与 计算描述子
key_points,des = sift.detectAndCompute(gray, None)
print(des)

# 将keypoints绘制出来
cv2.drawKeypoints(gray, key_points, image)

# 显示结果
cv2.imshow("image", image)
cv2.waitKey(0)
cv2.destroyAllWindows()

▶️运行结果:

\

▶️打印描述子:

5. SIFT 的应用场景

SIFT 具有 尺度、旋转、光照不变性,适用于以下场景:

应用领域应用案例
图像匹配物体识别、全景拼接、商标识别
目标跟踪机器人视觉导航、运动检测
特征提取三维重建、立体匹配
图像检索通过 SIFT 关键点匹配数据库图像
自动驾驶车道检测、SLAM(同时定位与建图)

总结

  • SIFT 是经典的特征检测算法,可用于关键点检测、特征描述和图像匹配。
  • OpenCV 提供了 cv2.SIFT_create() API,可以高效检测关键点并计算 128 维特征描述子。
  • SIFT 具有鲁棒性强、匹配精度高的特点,适用于 目标识别、图像匹配、三维重建 等任务。
  • 若计算速度是关键因素,可考虑 ORB(免费)或 SURF(更快,但有专利限制)。

 继续学习中,后续补充其它特征检测与特征匹配相关的知识!

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

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

相关文章

爬虫基础(一)HTTP协议 :请求与响应

前言 爬虫需要基础知识,HTTP协议只是个开始,除此之外还有很多,我们慢慢来记录。 今天的HTTP协议,会有助于我们更好的了解网络。 一、什么是HTTP协议 (1)定义 HTTP(超文本传输协议&#xff…

【4Day创客实践入门教程】Day1 工具箱构建——开发环境的构建

Day1 工具箱构建——开发环境的构建 目录 Day1 工具箱构建——开发环境的构建1.元件选型2.准备工具3. 开发板准备焊接排针具体步骤注意事项与技巧 4. 软件环境配置与固件烧录Thonny IDE软件环境配置配置Micropython环境与烧录固件**问题:**买的是4M/16M,…

如何让一个用户具备创建审批流程的权限

最近碰到一个问题,两个sandbox,照理用户的权限应该是一样的,结果开发环境里面我可以左右的做各种管理工作,但是使用change set上传后,另一个环境的同一个用户,没有相对于的权限,权限不足。 当时…

本地部署DeepSeek开源多模态大模型Janus-Pro-7B实操

本地部署DeepSeek开源多模态大模型Janus-Pro-7B实操 Janus-Pro-7B介绍 Janus-Pro-7B 是由 DeepSeek 开发的多模态 AI 模型,它在理解和生成方面取得了显著的进步。这意味着它不仅可以处理文本,还可以处理图像等其他模态的信息。 模型主要特点:Permalink…

【详细教程】如何在Mac部署Deepseek R1?

DeepSeek是目前最火的国产大模型,官方App用户太多服务经常出现卡顿,部署一个本地DeepSeek R1可以方便使用。 1.系统最低要求 macOS 11 Big Sur 或更新 2.下载ollama https://ollama.com/ 3.安装DeepSeek R1 打开终端 运行命令 ollama run deepseek-…

DeepSeek能下围棋吗?(续)

休息了一下,接着琢磨围棋,其实前面一篇里的规则有个漏洞的,就是邻居关系定义有问题,先回顾一下游戏规则: 游戏规则 定义: 1.数字对,是指两个1到9之间的整数组成的有序集合。可与记为(m,n)&…

【产品经理学习案例——AI翻译棒出海业务】

前言: 本文主要讲述了硬件产品在出海过程中,翻译质量、翻译速度和本地化落地策略是硬件产品规划需要考虑的核心因素。针对不同国家,需要优化翻译质量和算法,关注市场需求和文化差异,以便更好地满足当地用户的需求。同…

被裁与人生的意义--春节随想

还有两个月就要被迫离开工作了十多年的公司了,不过有幸安安稳稳的过了一个春节,很知足! 我是最后一批要离开的,一百多号同事都没“活到”蛇年。看着一批批仁人志士被“秋后斩首”,马上轮到我们十来个,个中滋味很难言清…

4-图像梯度计算

文章目录 4.图像梯度计算(1)Sobel算子(2)梯度计算方法(3)Scharr与Laplacian算子4.图像梯度计算 (1)Sobel算子 图像梯度-Sobel算子 Sobel算子是一种经典的图像边缘检测算子,广泛应用于图像处理和计算机视觉领域。以下是关于Sobel算子的详细介绍: 基本原理 Sobel算子…

【算法设计与分析】实验5:贪心算法—装载及背包问题

目录 一、实验目的 二、实验环境 三、实验内容 四、核心代码 五、记录与处理 六、思考与总结 七、完整报告和成果文件提取链接 一、实验目的 掌握贪心算法求解问题的思想;针对不同问题,会利用贪心算法进行问题建模、求解以及时间复杂度分析&#x…

MySQL为什么默认引擎是InnoDB ?

大家好,我是锋哥。今天分享关于【MySQL为什么默认引擎是InnoDB ?】面试题。希望对大家有帮助; MySQL为什么默认引擎是InnoDB ? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 MySQL 默认引擎是 InnoDB,主要…

【AIGC专栏】AI在自然语言中的应用场景

ChatGPT出来以后,突然间整个世界都非常的为之一惊。很多人大喊AI即将读懂人类,虽然这是一句夸大其词的话,但是经过未来几十年的迭代,ChatGPT会变成什么样我们还真的很难说。在当前生成式内容来说,ChatGPT毫无疑问在当前…

docker安装nacos2.2.4详解(含:nacos容器启动参数、环境变量、常见问题整理)

一、镜像下载 1、在线下载 在一台能连外网的linux上执行docker镜像拉取命令 docker pull nacos:2.2.4 2、离线包下载 两种方式: 方式一: -)在一台能连外网的linux上安装docker执行第一步的命令下载镜像 -)导出 # 导出镜像到…

使用 postman 测试思源笔记接口

思源笔记 API 权鉴 官方文档-中文:https://github.com/siyuan-note/siyuan/blob/master/API_zh_CN.md 权鉴相关介绍截图: 对应的xxx,在软件中查看 如上图:在每次发送 API 请求时,需要在 Header 中添加 以下键值对&a…

51单片机开发——I2C通信接口

I2C是微电子通信控制领域广泛采用的一种总线标准。 起始和停止信号: void iic_start(void) {IIC_SDA1;//如果把该条语句放在SCL后面,第二次读写会出现问题delay_10us(1);IIC_SCL1;delay_10us(1);IIC_SDA0; //当SCL为高电平时,SDA由高变为低d…

【网络】3.HTTP(讲解HTTP协议和写HTTP服务)

目录 1 认识URL1.1 URI的格式 2 HTTP协议2.1 请求报文2.2 响应报文 3 模拟HTTP3.1 Socket.hpp3.2 HttpServer.hpp3.2.1 start()3.2.2 ThreadRun()3.2.3 HandlerHttp() 总结 1 认识URL 什么是URI? URI 是 Uniform Resource Identifier的缩写&…

优雅管理Python2 and python3

python2 和 python3, 由于没有像其他软件的向下兼容,必须同时安装Python2 和Python3 ,介绍在linux和windows下优雅管理。 一、linux中安装Python2和Python3 linux 中用conda 创建虚拟环境,来管理不同版版工具 由于主流使用Python3…

Python从0到100(八十六):神经网络-ShuffleNet通道混合轻量级网络的深入介绍

前言: 零基础学Python:Python从0到100最新最全教程。 想做这件事情很久了,这次我更新了自己所写过的所有博客,汇集成了Python从0到100,共一百节课,帮助大家一个月时间里从零基础到学习Python基础语法、Pyth…

大模型本地化部署(Ollama + Open-WebUI)

文章目录 环境准备下载Ollama模型下载下载Open-WebUI 本地化部署的Web图形化界面本地模型联网查询安装 Docker安装 SearXNG本地模型联网查询 环境准备 下载Ollama 下载地址:Ollama网址 安装完成后,命令行里执行命令 ollama -v查看是否安装成功。安装成…

【Linux系统】进程间通信:共享内存

认识共享内存 通过 一些系统调用,在物理内存中开辟一块空间,然后将该空间的起始地址,通过页表映射到两个进程的虚拟地址空间的共享区中,这样不就共享了一块空间吗!!! 这种技术就是共享内存&am…