当前位置: 首页 > article >正文

C++:opencv获取矩阵中的最大最小值--cv::minMaxLoc

cv::minMaxLoc 是 OpenCV 中一个用于计算图像或矩阵中最小值和最大值的函数。它可以用来查找数组中的最小值和最大值及其位置,这在图像处理和计算机视觉任务中非常有用。

函数原型

void cv::minMaxLoc(
    const cv::InputArray& src,
    double* minVal = nullptr,
    double* maxVal = nullptr,
    cv::Point* minLoc = nullptr,
    cv::Point* maxLoc = nullptr,
    const cv::InputArray& mask = cv::noArray()
);

参数解释

  1. src:

    • 类型: cv::InputArray
    • 描述: 输入图像或矩阵。该参数表示需要计算最小值和最大值的源数据。可以是 cv::Mat 类型的图像或矩阵。
  2. minVal:

    • 类型: double*(可选)
    • 描述: 指向存储最小值的变量的指针。如果传递了这个指针,函数将把最小值存储到这个变量中。如果不需要最小值,可以传递 nullptr
  3. maxVal:

    • 类型: double*(可选)
    • 描述: 指向存储最大值的变量的指针。如果传递了这个指针,函数将把最大值存储到这个变量中。如果不需要最大值,可以传递 nullptr
  4. minLoc:

    • 类型: cv::Point*(可选)
    • 描述: 指向存储最小值位置的变量的指针。如果传递了这个指针,函数将把最小值的位置(坐标)存储到这个变量中。如果不需要最小值的位置,可以传递 nullptr
  5. maxLoc:

    • 类型: cv::Point*(可选)
    • 描述: 指向存储最大值位置的变量的指针。如果传递了这个指针,函数将把最大值的位置(坐标)存储到这个变量中。如果不需要最大值的位置,可以传递 nullptr
  6. mask:

    • 类型: cv::InputArray(可选)
    • 描述: 可选的掩模图像,用于指定在计算最小值和最大值时要考虑的区域。掩模图像是一个与源图像相同尺寸的二值图像,其中白色(255)的位置表示要考虑的区域,黑色(0)的位置表示忽略的区域。如果不使用掩模,可以将其设置为 cv::noArray()

函数功能

cv::minMaxLoc 函数计算给定图像或矩阵中的最小值和最大值,并可以选定地返回它们的位置(坐标)。它的主要功能是:

  • 查找最小值和最大值: 计算输入图像或矩阵中像素值的最小和最大值。
  • 确定位置: 计算这些最小值和最大值的位置(坐标),有助于进一步的分析和处理。

示例代码

以下是一个示例,展示如何使用 cv::minMaxLoc 查找图像中的最小值和最大值及其位置:

#include <opencv2/opencv.hpp>
#include <iostream>

int main() {
    // 创建一个示例图像
    cv::Mat img = (cv::Mat_<uchar>(3, 3) << 10, 20, 30, 40, 50, 60, 70, 80, 90);

    // 定义变量存储结果
    double minVal, maxVal;
    cv::Point minLoc, maxLoc;

    // 计算最小值、最大值及其位置
    cv::minMaxLoc(img, &minVal, &maxVal, &minLoc, &maxLoc);

    // 输出结果
    std::cout << "Minimum Value: " << minVal << std::endl;
    std::cout << "Maximum Value: " << maxVal << std::endl;
    std::cout << "Minimum Location: (" << minLoc.x << ", " << minLoc.y << ")" << std::endl;
    std::cout << "Maximum Location: (" << maxLoc.x << ", " << maxLoc.y << ")" << std::endl;

    return 0;
}

解释

  1. 创建图像:

    • 使用 cv::Mat 创建一个简单的 3x3 矩阵,作为示例图像。
  2. 计算最小值和最大值:

    • 调用 cv::minMaxLoc 计算图像中的最小值和最大值,并获取它们的位置。
  3. 输出结果:

    • 打印最小值、最大值及其位置。

总结

  • 功能: cv::minMaxLoc 用于计算图像或矩阵中的最小值和最大值,并返回它们的位置。
  • 参数: 输入图像、最小值和最大值的存储变量、最小值和最大值的位置的存储变量、可选掩模。
  • 应用: 用于图像分析、数据统计和处理等任务,特别是在需要了解图像中像素值的范围和分布时。

http://www.kler.cn/a/304972.html

相关文章:

  • Unity3D实现WEBGL打开Window文件对话框打开/上传文件
  • C++实现设计模式---备忘录模式 (Memento)
  • MYSQL5.7 全文检索中文无返回数据
  • CAPL如何设置TCP/IP传输层动态端口范围
  • Bundlephobia前端强大的包分析工具
  • 数据存储与信息技术领域 - 磁带技术:企业用磁带与音乐磁带
  • R语言进行无序多分类Logistic回归
  • 五星级可视化页面(24):管线管路流程图可视化大屏。
  • 文档智能:OCR+Rocketqa+layoutxlm
  • Maven下载安装
  • 如何将镜像推送到docker hub
  • 【C++ 设计模式】单例模式的两种懒汉式和饿汉式
  • 使用transform对html的video播放器窗口放大
  • 基于51单片机的电饭锅控制系统proteus仿真
  • DroidBot: A Lightweight UI-Guided Test InputGenerator for Android论文学习
  • Apache SeaTunnel Zeta 引擎源码解析(二) Client端的任务提交流程
  • 【Prompt Engineering:思维树 (ToT)、检索增强生成 (RAG)、自动推理并使用工具 (ART)】
  • Nginx的使用场景:构建高效、可扩展的Web架构
  • 77-java 装饰器模式和适配器模式区别
  • PDF扫描版文字识别OCR
  • docker+docker-compose+gitlab
  • CentOS 入门
  • 深度解析:云原生环境下Docker部署Doris数据库
  • XMOJ3376 结界
  • 深度神经网络
  • Django REST framework 实现缓存机制以优化性能