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

devtools/2025/2/7 12:28:08/

目录

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.ppmy.cn/devtools/156801.html

相关文章

docker安装es及分词器ik

系统是macos,docker是docker-desktop 拉取镜像 docker pull bitnami/elasticsearch 启动docker镜像 docker create -e "discovery.typesingle-node" \ --name elasticsearch1 -p 9200:9200 -p 9300:9300 \ bitnami/elasticsearch:8.17.1 测试是否好…

lambda表达式写java比较器

文章目录 示例 1:按字符串长度比较示例 2:按数字大小比较示例 3:按对象属性比较(简洁:推荐)示例 4:使用 Comparator 的静态方法示例 5:链式比较 在Java中,Comparator 是一…

【自然语言处理】TextRank 算法提取关键词(Python实现)

文章目录 前言PageRank 实现TextRank 简单版源码实现jieba工具包实现TextRank 前言 TextRank 算法是一种基于图的排序算法,主要用于文本处理中的关键词提取和文本摘要。它基于图中节点之间的关系来评估节点的重要性,类似于 Google 的 PageRank 算法。Tex…

Java 大视界 -- Java 大数据在智能安防中的应用与创新(73)

💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也…

PFAS(全氟烷基和多氟烷基物质)测试流程详细介绍

PFAS(全氟烷基和多氟烷基物质)测试详细介绍 什么是PFAS? PFAS是(Per-and polyfluoroalkyl substances)的简称,中文名:全氟烷基和多氟烷基物质,是一系列合成有机氟化物的总称,是指至少含有一个…

【LeetCode 刷题】贪心算法(1)-基础

此博客为《代码随想录》二叉树章节的学习笔记,主要内容为贪心算法基础的相关题目解析。 文章目录 455.分发饼干1005.K次取反后最大化的数组和860.柠檬水找零 455.分发饼干 题目链接 class Solution:def findContentChildren(self, g: List[int], s: List[int]) -…

央行发布《贸易金融分布式账本技术要求》,参考架构包括5部分

《银行科技研究社》(作者 木子剑):2024年12月11日,中国人民银行发布金融行业标准《贸易金融分布式账本技术要求》(JR/T 0308-2024)(以下简称“《要求》”),当日实施。据悉,该文件的起草单位包括6大行和多家股份制银行等。 《要求》规定了分布式账本技术在贸易金融领域…

Hive自定义函数简介及实践案例

摘要: Hive自定义函数简介及实践 关键词: 大数据、Hive、自定义函数 整体说明 从自定义函数的简介,到自定义函数的使用类型分类和使用周期分类,以及每种自定义函数的实践案例,解决具体的需求,简单图示如下: 一、简介 允许用户扩展 Hive 的功能,以实现特定的数据处…