OpenCV特征检测

1. 特征检测的基本概念

特征检测是计算机视觉和图像处理中的一个概念。它指的是使用计算机提取图像信息,决定每个图像的点是否属于一个图像特征。特征检测的结果是把图像上的点

分为不同的子集,这些子集往往属于孤立的点、连续的曲线或者连续的区域。

特征检测是指从图像或视频中自动检测出一些具有特定几何形状或特定的灰度分布等特征的局部区域。

  • 边缘检测
  • 角点检测
  • 区域检测
  • 脊检测

特征具有哪些特点:

  • 特征是唯一的
  • 特征是可追踪的
  • 特征是能比较的

也就是说,图像特征是指有意义的图像区域,具有独特性,易于识别性,比较角点,斑点以及高密度区域。

在图像特征中最重要的就是角点。

  • 灰度梯度的最大值对应的像素
  • 两条线的交点
  • 极点值(一阶导数最大,二阶导数为0)

2. lsd直线检测

cpp 复制代码
cv::Ptr<cv::LineSegmentDetector> lsd = cv::createLineSegmentDetector(cv::LSD_REFINE_NONE);  // 定义检测lsd对象
std::vector<cv::Vec4f> lines;       //存储检测的点
lsd->detect(grayImg, lines);        //进行直线检测
lsd->drawSegments(grayImg, lines);   //  将检测的直线绘制到图像中
cv::imshow("lsd_grayImg", grayImg);  // 显示对应的图像
cv::waitKey(0);                     //停留在显示界面,按空格键继续执行

3. harris角点检测

python 复制代码
import cv2
import numpy as np
 
img = cv2.imread('8.jpg')
 
# 变成灰度图片
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
 
# 角点检测
# blockSize没有要求必须是奇数
# 返回目标值(角点响应),每一个像素点都可以计算出一个角点响应
dst = cv2.cornerHarris(gray,blockSize=2,ksize=3,k=0.04)
 
#显示角点
# 设定阈值,dst.max()
img[dst > (0.01 * dst.max())] = [0,0,255]
 
cv2.imshow('img',img)
 
cv2.waitKey(0)
cv2.destroyAllWindows()

4. Shi-Tomasi角点检测

python 复制代码
import cv2
import numpy as np

img = cv2.imread('../my_work/01.png')

# 参数设置
maxCorners = 1000
q1 = 0.01
minDistance = 10

# 变成灰度图片
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)

corners = cv2.goodFeaturesToTrack(gray,maxCorners,q1,minDistance)
corners = np.int0(corners)

# 打印角点
for i in corners:
    x,y = i.ravel()
    cv2.circle(img,(x,y),3,(255,0,0),-1)

cv2.imshow('img',img)
cv2.waitKey()
cv2.destroyAllWindows()

参考文献

OpenCv之特征检测_opencv 特征点检测-CSDN博客

OpenCv-特征检测_opencv 特征-CSDN博客

相关推荐
jndingxin21 小时前
OpenCV图像注册模块
人工智能·opencv·计算机视觉
R-G-B21 小时前
【P14 3-6 】OpenCV Python——视频加载、摄像头调用、视频基本信息获取(宽、高、帧率、总帧数)
python·opencv·视频加载·摄像头调用·获取视频基本信息·获取视频帧率·获取视频帧数
荼蘼21 小时前
OpenCv(三)——图像平滑处理
人工智能·opencv·计算机视觉
R-G-B2 天前
OpenCV Python——报错AttributeError: module ‘cv2‘ has no attribute ‘bgsegm‘,解决办法
人工智能·python·opencv·opencv python·attributeerror·module ‘cv2‘·no attribute
似乎很简单2 天前
【opencv-Python学习笔记(5):几何变换】
笔记·opencv·学习
荼蘼2 天前
OpenCv(二)——边界填充、阈值处理
人工智能·opencv·计算机视觉
蜀中廖化2 天前
机器学习:基于OpenCV和Python的智能图像处理 实战
python·opencv·机器学习
R-G-B2 天前
【P27 4-8】OpenCV Python——Mat类、深拷贝(clone、copyTo、copy)、浅拷贝,原理讲解与示例代码
人工智能·python·opencv·浅拷贝·深拷贝·opencv python·mat类
星期天要睡觉2 天前
计算机视觉(opencv)实战三——图像运算、cv2.add()、cv2.addWeighted()
人工智能·opencv·计算机视觉
rhythmcc2 天前
【visual studio】visual studio配置环境opencv和onnxruntime
c++·人工智能·opencv