Python Opencv实践 - SIFT关键点检测

参考资料:

关键点检测SIFT算法笔记_亦枫Leonlew的博客-CSDN博客

SIFT特征检测算子和sift = cv2.xfeatures2d.SIFT_create出错的解决办法_self.sift=cv2.xfeatures2d.sift_create()_刘凯数据分析的博客-CSDN博客

复制代码
import cv2 as cv
import numpy as np
import matplotlib.pyplot as plt

img = cv.imread("../SampleImages/shunsuke.jpg", cv.IMREAD_COLOR)
plt.imshow(img[:,:,::-1])

#得到灰度图
img_gray = cv.cvtColor(img, cv.COLOR_BGR2GRAY)
plt.imshow(img_gray, plt.cm.gray)

#SIFT算法
#1. 实例化SIFT
#   sift = cv.xfeatures2d.SIFT_create()
#参考资料:https://blog.csdn.net/cliukai/article/details/102525486
sift = cv.xfeatures2d.SIFT_create()
#2. 使用sift对象的检测关键点方法
#   kp,des = sift.detectAndCompute(gray, None)
#   gray:灰度图
#   返回:kp - 关键点信息,包括位置,尺度和方向信息
#        des - 关键点描述符,每个关键点对应128个梯度信息的特征向量
#参考资料:https://blog.csdn.net/cliukai/article/details/102525486
keypoints,descriptors = sift.detectAndCompute(img_gray, None)
#3. 将关键点绘制到图像上
#   cv.drawKeypoints(img, keypoints, outputimage, color, flags)
#   img: 原图,关键点要绘制到的图像
#   keypoints:关键点信息
#   outputimage:输出图像,可以是原图
#   color: 颜色设置,(b,g,r)值
#   flags: 绘图的标志
#          cv.DRAW_MATCHES_FLAGS_DEFAULT: 创建输出图像矩阵,使用现存的输出图像绘制匹配对和特征点,对每一个关键点只绘制中间点
#          cv.DRAW_MATCHES_FLAGS_DRAW_OVER_OUTIMG: 不创建输出图像矩阵,而是在输出图像上绘制匹配对
#          cv.DRAW_MATCHES_FLAGS_DRAW_RICH_KEYPOINTS: 对每一个特征点绘制带大小和方向的关键点图像
#          cv.DRAW_MATCHES_FLAGS_NOT_DRAW_SINGLE_POINTS:单点的特征点不被绘制
cv.drawKeypoints(img, keypoints, img, (0,255,0), cv.DRAW_MATCHES_FLAGS_DRAW_RICH_KEYPOINTS)

plt.imshow(img[:,:,::-1])
相关推荐
vvoennvv30 分钟前
【Python TensorFlow】 TCN-GRU时间序列卷积门控循环神经网络时序预测算法(附代码)
python·rnn·神经网络·机器学习·gru·tensorflow·tcn
YJlio40 分钟前
[编程达人挑战赛] 用 PowerShell 写了一个“电脑一键初始化脚本”:从混乱到可复制的开发环境
数据库·人工智能·电脑
RoboWizard1 小时前
PCIe 5.0 SSD有无独立缓存对性能影响大吗?Kingston FURY Renegade G5!
人工智能·缓存·电脑·金士顿
自学互联网1 小时前
使用Python构建钢铁行业生产监控系统:从理论到实践
开发语言·python
无心水1 小时前
【Python实战进阶】7、Python条件与循环实战详解:从基础语法到高级技巧
android·java·python·python列表推导式·python条件语句·python循环语句·python实战案例
霍格沃兹测试开发学社-小明1 小时前
测试左移2.0:在开发周期前端筑起质量防线
前端·javascript·网络·人工智能·测试工具·easyui
懒麻蛇1 小时前
从矩阵相关到矩阵回归:曼特尔检验与 MRQAP
人工智能·线性代数·矩阵·数据挖掘·回归
xwill*1 小时前
RDT-1B: A DIFFUSION FOUNDATION MODEL FOR BIMANUAL MANIPULATION
人工智能·pytorch·python·深度学习
网安INF1 小时前
机器学习入门:深入理解线性回归
人工智能·机器学习·线性回归
陈奕昆1 小时前
n8n实战营Day2课时2:Loop+Merge节点进阶·Excel批量校验实操
人工智能·python·excel·n8n