# -*- coding: utf-8 -*-
import cv2
import numpy as np
from matplotlib import pyplot as plt
img = cv2.imread("./img/person.jpg")
img1 = img.copy()
img1 = cv2.cvtColor(img1,cv2.COLOR_BGR2RGB)
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
sift = cv2.xfeatures2d.SIFT_create(nfeatures=10)
kp = sift.detect(gray,None)
des = sift.compute(gray,kp)# 计算所有特征点的特征值
feature_value = des[1] # 拿到所有特征点的特征值
cv2.drawKeypoints(img1,kp,img)
cv2.drawKeypoints(img1,kp,img1,flags=cv2.DRAW_MATCHES_FLAGS_DRAW_RICH_KEYPOINTS)
plt.subplot(121), plt.imshow(img),
plt.title('Destination'), plt.axis('off')
plt.subplot(122), plt.imshow(img1),
plt.title('Destination'), plt.axis('off')
plt.show()
opencv-python 获取 sift 特征值
最新推荐文章于 2024-06-06 12:14:18 发布