opencv各个模块介绍(2)

news2025/1/10 20:45:47

Features2D 模块:特征检测和描述子计算模块,包括SIFT、SURF等算法。

Features2D 模块提供了许多用于特征检测和描述子匹配的函数和类,这些函数和类可用于图像特征的提取、匹配和跟踪。

  1. FeatureDetector:特征检测器的基类,包括常用的特征检测算法,如ORB、SIFT、SURF、FAST 等。

  2. DescriptorExtractor:描述子提取器的基类,用于从图像中提取特征点周围的描述子,包括常用的描述子算法,如ORB、SIFT、SURF 等。

  3. Feature2D:特征检测器和描述子提取器的统一接口类,可以方便地使用各种特征检测和描述子提取算法。

  4. DescriptorMatcher:描述子匹配器的基类,用于对提取出的描述子进行匹配,包括常用的匹配算法,如BruteForce、FlannBased 等。

  5. drawKeypoints:用于在图像上绘制特征点的函数,可以将检测到的特征点可视化显示在图像上。

  6. drawMatches:用于在两幅图像上绘制特征点匹配的函数,可以将两幅图像中匹配的特征点对可视化显示出来。

  7. compute:用于计算图像中的特征点和描述子的函数,可以对输入的图像进行特征点检测和描述子提取。

  8. match:用于对输入的两组描述子进行匹配的函数,可以对提取出的描述子进行匹配操作。

这些函数和类提供了在图像中进行特征检测、描述子提取和匹配的基本工具,通过使用它们,我们可以提取图像中的关键特征点和描述子,进行特征匹配和跟踪,从而实现诸如目标识别、图像拼接、运动跟踪等应用。

Calib3d 模块:相机标定和三维重建模块

OpenCV Calib3d 模块函数和类:

  1. calibrateCamera:用于对相机进行内参和畸变参数的标定,通过捕获多个图像中的棋盘格等模板,并提取角点位置来进行相机标定。

  2. stereoCalibrate:用于立体相机的标定,通过匹配两个相机的图像中的对应点,求解两个相机之间的外参和内参关系。

  3. stereoRectify:用于校正立体相机的图像,使得两个相机的光学轴平行,方便后续的立体匹配。

  4. stereoMatch:用于立体匹配,通过匹配左右两个相机的图像,得到对应点的深度信息。

  5. solvePnP:用于从图像中的二维点和三维点之间求解相机的姿态(旋转和平移矩阵)。

  6. findHomography:用于寻找两幅图像之间的单应性矩阵,通常用于图像配准和目标跟踪。

  7. triangulatePoints:用于三角化立体视觉中的对应点,求解三维空间中的点坐标。

  8. undistort:用于去畸变,将畸变图像转换为无畸变的图像。

这些函数和类在摄像机标定、立体视觉和三维重构等领域具有广泛的应用,可以帮助我们理解场景的三维结构、测量物体的尺寸、进行虚拟现实等任务。通过使用这些函数和类,我们可以实现各种基于摄像机的视觉任务,并提高图像处理和计算机视觉的效果和准确性。

Videoio 模块:视频输入/输出模块,用于读取和写入视频文件

  1. VideoCapture:用于从视频文件或摄像头捕获视频帧的类,可以通过该类实例来读取视频文件或捕获摄像头视频流。

  2. VideoWriter:用于将视频帧写入视频文件的类,可以通过该类实例将视频帧写入到视频文件中。

  3. cv::CAP_PROP_ 参数*:一系列用于设置视频流参数的常量,如帧率、分辨率、亮度、对比度等

  4. isOpened:用于检查 VideoCapture 或 VideoWriter 是否成功打开视频文件或捕获设备。

  5. read:用于从 VideoCapture 实例中读取下一帧视频。

  6. write:用于将视频帧写入到 VideoWriter 实例中。

  7. set:用于设置 VideoCapture 或 VideoWriter 的参数,如帧率、分辨率等。

  8. get:用于获取 VideoCapture 或 VideoWriter 的参数,如帧率、分辨率等。

通过使用 Videoio 模块提供的函数和类,我们可以方便地读取视频文件、捕获摄像头视频流,并进行视频数据的处理和分析。这些函数和类为我们在计算机视觉和图像处理领域中处理视频数据提供了便捷的工具,可以帮助我们实现视频内容的处理、分析和应用。

Dnn 模块:深度学习模块,支持使用深度学习模型进行图像处理任务

  1. readNet:用于加载深度学习模型的函数,支持多种深度学习框架(如 TensorFlow、Caffe、Darknet 等)的模型格式。

  2. Net:代表一个深度学习模型的类,可以用于进行前向推断、获取输出等操作。

  3. setInput:用于设置输入数据到深度学习模型中,例如设置图像作为模型的输入。

  4. forward:执行前向推断,获取模型的输出。

  5. getUnconnectedOutLayers:获取模型中未连接到其他层的输出层索引。

  6. getLayerNames:获取模型中所有层的名称。

  7. blobFromImage:将图像转换为网络模型的输入 blob 格式。

  8. NMSBoxes:执行非最大抑制(Non-Maximum Suppression),用于目标检测中去除重叠的边界框。

通过使用 Dnn 模块提供的函数和类,我们可以方便地加载和使用深度学习模型,进行图像识别、目标检测、人脸识别等任务。这些函数和类为我们在计算机视觉领域应用深度学习模型提供了强大的工具,可以帮助我们实现各种复杂的视觉任务,并提高处理效率和准确性。

备注:

NMS(Non-Maximum Suppression,非最大抑制)是一种常用的目标检测算法,用于在目标检测任务中去除重叠的边界框,保留最相关的目标框。NMS 算法通常应用于神经网络输出的边界框预测中。

NMS 的原理如下:

  1. 得分排序:首先,对所有的候选边界框按照其置信度得分进行排序,通常情况下,得分越高的边界框越可能包含真实目标。

  2. 选择最高得分框:从得分最高的边界框开始,将该边界框加入最终输出的目标框列表中。

  3. 计算重叠区域:对于剩余的边界框,计算它们与已选边界框的重叠区域的面积,通常采用交并比(IoU)来衡量两个边界框的重叠程度。

  4. 去除重叠边界框:对于与已选边界框有较大重叠的边界框,根据设定的阈值(通常为 0.5 或 0.7)来决定是否将其丢弃,只保留得分最高的边界框。

  5. 重复步骤:重复上述步骤,直到处理完所有的候选边界框。

NMS 算法可以在目标检测结果中去除大量重叠的边界框,保留最具代表性和置信度最高的目标框,从而提高目标检测算法的准确性和鲁棒性。

NMS 算法在许多目标检测器(如 Faster R-CNN、YOLO 等)中被广泛应用,是提高目标检测性能的重要组成部分。

Machine Learning(ML)模块:机器学习模块,提供了一些常见的机器学习算法实现

  1. cv::ml::SVM:支持向量机(SVM)模型的实现类,用于二分类、多分类和回归任务。

  2. cv::ml::KNearest:k-最近邻(KNN)模型的实现类,用于基于最近邻的分类和回归。

  3. cv::ml::RTrees:随机森林(Random Forest)模型的实现类,用于决策树集成学习。

  4. cv::ml::Boost:Boosting 模型的实现类,用于集成多个弱分类器以提高性能。

  5. cv::ml::ANN_MLP:人工神经网络(MLP)模型的实现类,用于深度神经网络的训练和预测。

  6. cv::ml::EM:期望最大化(Expectation-Maximization)算法的实现类,用于高斯混合模型的聚类。

  7. cv::ml::TrainData:用于加载和处理训练数据集的类,方便机器学习模型的训练。

  8. cv::ml::ParamGrid:用于定义参数网格搜索的类,帮助进行模型参数调优。

  9. cv::ml::StatModel:所有机器学习模型的基类,包括了训练和预测等通用方法。

这些函数和类提供了丰富的功能和工具,可以帮助我们在 OpenCV 中应用各种机器学习算法,并实现图像分类、目标检测、特征提取等复杂任务。通过熟练掌握这些函数和类的用法,我们可以更好地利用机器学习技术来解决计算机视觉和图像处理领域的挑战。

Stitching 模块:图像拼接模块,用于将多幅图片拼接成全景图像

  1. cv::Stitcher::create():静态方法,用于创建 Stitcher 类的实例。

  2. cv::Stitcher::stitch():拼接多幅图像,生成全景图像。可以通过该方法传入图像集合进行拼接,并获取拼接后的全景图像。

  3. cv::Stitcher::estimateTransform():估计图像间的转换矩阵,用于拼接图像时的配准。

  4. cv::Stitcher::composePanorama():对拼接后的全景图像进行优化和融合,消除拼接过程中的接缝。

  5. cv::Stitcher::registrationResol():设置拼接的分辨率,影响最终拼接结果的清晰度和质量。

  6. cv::Stitcher::blendImages():对拼接的图像进行融合处理,使得拼接后的全景图像看起来更加自然。

Photo 模块:图像编辑和修复模块,包括图像去噪、颜色校正等功能

Photo 模块提供了许多图像处理和修复的函数和类,用于实现图像增强、去噪、颜色校正等功能。以下是一些常用的 OpenCV Photo 模块函数和类:

  1. cv::fastNlMeansDenoising():使用非局部均值去噪算法对图像进行去噪处理。

  2. cv::colorChange():将图像的颜色转换为目标颜色。

  3. cv::seamlessClone():无缝克隆算法,将源图像的一部分融合到目标图像中,使得融合后的图像看起来自然。

  4. cv::illuminationChange():调整图像的光照条件。

  5. cv::textureFlattening():纹理平滑算法,用于减少图像中的纹理细节。

  6. cv::rollMinEigenVal():计算图像的最小特征值,用于角点检测和特征匹配。

  7. cv::edgePreservingFilter():边缘保留滤波器,用于保留图像中的细节信息而抑制噪声。

  8. cv::detailEnhance():增强图像的细节和结构。

  9. cv::decolor():将彩色图像转换为灰度图像,但保留图像的结构信息。

  10. cv::colorChange():改变图像的颜色。

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

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

相关文章

java数据结构与算法刷题-----LeetCode452. 用最少数量的箭引爆气球

java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完):https://blog.csdn.net/grd_java/article/details/123063846 文章目录 解题思路:贪心算法,时间复杂度O( n ∗ l …

【计算机】——51单片机——持续更新

单片机是一种内部包含CPU、存储器和输入/输出接口等电路的集成电路(IC芯片) 单片机是单片微型计算机(Single Chip Microcomputer)的简称,用于控制领域,所以又称为微型控制器(Microcontroller U…

AI+软件工程:10倍提效!用ChatGPT编写系统功能文档

系统功能文档是一种描述软件系统功能和操作方式的文档。它让开发团队、测试人员、项目管理者、客户和最终用户对系统行为有清晰、全面的了解。 通过ChatGPT,我们能让编写系统功能文档的效率提升10倍以上。 ​《Leetcode算法刷题宝典》一位阿里P8大佬总结的刷题笔记…

一文看懂,高端及大流量停车场如何选择合适的道闸管理系统?

在当今快速发展的城市环境中,停车场的管理和运营已成为城市基础设施建设的重要组成部分。不同类型的停车场,如大流量停车场和高端停车场,面临着各自独特的挑战和需求。为了确保停车场的高效运营和良好的用户体验,选择合适的道闸管…

在ubuntu22.04系统上用pycharm编写第一个ros2程序

1.打开终端(快捷键altctrlt),创建工作空间,工作空间就是文件夹 2.创建一个功能包 打开pycharm的终端(altf12) 3.创建节点文件 在village_li文件夹右键新建li4.py 4.在li4.py编写代码 5.在setup.py里面添加…

Ubuntu Desktop 安装谷歌拼音输入法

Ubuntu Desktop 安装谷歌拼音输入法 1. Installation1.1. 汉语语言包​1.2. 谷歌拼音输入法1.3. 安装语言包1.4. 键盘输入方式系统1.5. 重启电脑1.6. 输入法配置 2. configuration2.1. Text Entry Settings… 3. ExecutionReferences 1. Installation 1.1. 汉语语言包 strong…

淘宝海外获取tglobal跨境商品原数据 API 返回值说明

一、应用场景 宝海外获取TGlobal跨境商品原数据API的应用场景相当广泛,涵盖了多个领域和行业。以下是一些主要的应用场景: 跨境电商平台:跨境电商平台可以通过此API获取全球范围内的商品信息,从而丰富平台上的商品种类&#xff…

边缘计算基础介绍及AKamai-linode产品分析

1、背景 随着互联网的发展,我们进入了大数据时代,这个时代也是移动互联网的时代,而且这个时代,大量的线下服务走到线上,随之而来的,比如外卖、叫车……于是,有各种各样的 App 和设备在收集你的…

如何打破SAST代码审计工具的局限性?

关键词:白盒测试;代码分析工具;代码扫描工具;静态代码检测工具; 在代码的世界里,安全问题如同潜伏的暗礁,随时可能让航行中的软件项目触礁沉没。SAST代码审计工具如同雷达一样,以其独…

Python - 深度学习系列30 - 使用LLaMA-Factory微调模型

说明 最实用的一种利用大语言模型的方式是进行微调。预训练模型与我们的使用场景一定会存在一些差异,而我们又不可能重头训练。 微调的原理并不复杂,载入模型,灌新的数据,然后运行再训练,保留checkpoints。但是不同项…

Cobalt Strike -- 各种beacon

今天来讲一下cs里面的beacon 其实cs真的功能很强大,自带代理创建,自带beacon通信!!! 一张图,就能说明beacon的工作原理 1.Beacon 每当有一台机器上线之后,我们都会选择sleep时间,…

PCI产业概述和产业发展动态分享

atsec白海蔚 2024年3月底 关键词:支付卡产业、PCI DSS、数据安全、支付交易 本文为atsec和作者技术共享类文章,旨在共同探讨信息安全的相关话题。转载请注明:atsec和作者名称。 *如有兴趣了解早期产业信息请参见作者于2021年4月发布信息&a…

数据在内存里面的存储

学习流程 ————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————…

SOC子模块---RTC and watchdog

RTC RTC大致执行过程: 对SOC 中的锁相环或者外部晶振的时钟进行计数;产生时,分,秒的中断;送给中断控制器;中断控制器进行优先权选择后送给cpu;Cpu执行中断服务程序;在中断服务程序…

吴恩达深度学习笔记:神经网络的编程基础2.15-2.17

目录 第一门课:神经网络和深度学习 (Neural Networks and Deep Learning)第二周:神经网络的编程基础 (Basics of Neural Network programming)2.15 Python 中的广播(Broadcasting in Python)2.16 关于 python _ numpy 向量的说明&…

Java中的代理模式(动态代理和静态代理)

代理模式 我们先了解一下代理模式: 在开发中,当我们要访问目标类时,不是直接访问目标类,而是访问器代理类。通过代理类调用目标类完成操作。简单来说就是:把直接访问变为间接访问。 这样做的最大好处就是&#xff1a…

UE5 LiveLink 自动连接数据源,以及打包后不能收到udp消息的解决办法

为什么要自动连接数据源,因为方便打包后接收数据,这里我是写在了Game Instance,也可以写在其他地方,自行替换成Beginplay和Endplay 关于编辑器模式下能收到udp消息,打包后不能收到消息的问题有两点需要排查,启动打包后…

数据结构·排序

1. 排序的概念及运用 1.1 排序的概念 排序:排序是将一组“无序”的记录序列,按照某个或某些关键字的大小,递增或递减归零调整为“有序”的记录序列的操作 稳定性:假定在待排序的记录序列中,存在多个具有相同关键字的记…

大数据技术原理与应用 01.大数据概述

不可以垂头丧气,会显矮 —— 24.3.24 参考学习:厦门大学 林子雨老师 大数据技术原理与应用 一、大数据时代 大数据概念、影响、应用、关键技术 大数据与云计算、物联网的关系 ①三次信息化浪潮时代 ②第三次信息化浪潮的技术支撑 1>存储设备容量不断…

PWM实现电机的正反转和调速以及TIM定时器

pwm.c #include "pwm.h"/* PWM --- PA2 --TIM2_CH3 //将电机信号控制一根接GND,一根接在PA2(TIM2_CH3), 输出PWM控制电机快慢 TIM2挂在APB1 定时器频率:84MHZ*/ void Pwm_Init(void) {GPIO_InitTypeDef GPIO_InitStruct;TIM_TimeBaseInitT…