OpenCV 图像像素值统计

一、知识点
1、像素值统计

(1)、最小(min)

(2)、最大(max)

(3)、均值(mean)

(4)、标准差(standard deviation)

方差是一组数据与其平均值之差的平方的平均值。

标准差是方差的平方根。

它们衡量了数据的离散程度。 值越大,数据点之间的差异越大,集中趋势差; 反之,数据分布越集中。

2、void minMaxLoc(InputArray src, CV_OUT double * minVal, CV_OUT double * maxVal = 0, CV_OUT Point * minLoc = 0, CV_OUT Point * maxLoc = 0, InputArray mask = noArray());

(1)、查找数组(图像)中的最小值和最大值,以及它们的位置。

(2)、参数说明:

src: 输入数组(图像),需要单通道的。

minVal: 输出参数,指向最小值的指针,若不需要,则置NULL。

maxVal: 输出参数,指向最大值的指针,若不需要,则置NULL。

minLoc: 输出参数,指向最小值位置(x, y坐标)的指针,若不需要,则置NULL。

maxLoc: 输出参数,指向最大值位置(x, y坐标)的指针,若不需要,则置NULL。

mask: 可选掩码,若不为空,则在指定数组中(非零掩码对应)搜索最小最大值; 若为空,则在整个数组中搜索。

3、void meanStdDev(InputArray src, OutputArray mean, OutputArray stddev, InputArray mask = noArray());

(1)、计算数组(图像)的均值和标准差。

(2)、参数说明:

src: 输入数组(图像),可以是单通道,也可以是多通道。

mean: 输出数组,用于存储每个通道的均值。

stddev: 输出数组,用于存储每个通道的标准差值。

mask: 可选掩码,若不为空,则在指定数组中(非零掩码对应)计算; 若为空,则在整个数组中计算。

二、示例代码

cpp 复制代码
#include <iostream>
#include <opencv2/opencv.hpp>


int main()
{
    cv::Mat src1 = cv::imread("../images/6.png");
    if (src1.empty())
    {
        std::cout << "load src image error..." << std::endl;
        return -1;
    }

    //求最小最大值时,输入图像需是单通道的
    std::vector<cv::Mat> vecM;
    cv::split(src1, vecM);
    for (int i = 0; i < vecM.size(); i++)
    {
        double minV, maxV;
        cv::Point minLoc, maxLoc;
        cv::minMaxLoc(vecM[i], &minV, &maxV, &minLoc, &maxLoc, cv::Mat());
        std::cout << "Image1 i = " << i << ", minValue = " << minV << ", maxValue = " << maxV << std::endl;
    }
    
    //求均值和方差
    cv::Mat mean, stddev;
    cv::meanStdDev(src1, mean, stddev);
    std::cout << "mean:" << std::endl << mean << std::endl << "stddev:" << std::endl << stddev << std::endl;

    cv::Mat src2 = cv::Mat::zeros(4, 3, CV_8UC3);
    src2 = cv::Scalar(42, 89, 105);

    //求最小最大值
    std::vector<cv::Mat> vecM2;
    cv::split(src2, vecM2);
    for (int i = 0; i < vecM2.size(); i++)
    {
        double minV, maxV;
        cv::Point minLoc, maxLoc;
        cv::minMaxLoc(vecM2[i], &minV, &maxV, &minLoc, &maxLoc, cv::Mat());
        std::cout << "Image2 i = " << i << ", minValue = " << minV << ", maxValue = " << maxV << std::endl;
    }

    //求均值和方差
    cv::Mat mean2, stddev2;
    cv::meanStdDev(src2, mean2, stddev2);
    std::cout << "mean2:" << std::endl << mean2 << std::endl << "stddev2:" << std::endl << stddev2 << std::endl;

    system("pause");

    return 0;
}

输出结果:

Image1 i = 0, minValue = 0, maxValue = 255

Image1 i = 1, minValue = 0, maxValue = 255

Image1 i = 2, minValue = 0, maxValue = 255

mean:

117.4247741699219; 99.5269775390625; 103.0511779785156

stddev:

109.9909118460736; 99.60692477866574; 111.1995801429959

Image2 i = 0, minValue = 42, maxValue = 42

Image2 i = 1, minValue = 89, maxValue = 89

Image2 i = 2, minValue = 105, maxValue = 105

mean2:

42; 89; 105

stddev2:

0; 0; 0

相关推荐
weixin_446260851 小时前
LocalAI:一个免费开源的AI替代方案,让创意更自由!
人工智能·开源
CAE3202 小时前
基于机器学习的智能垃圾短信检测超强系统
人工智能·python·机器学习·自然语言处理·垃圾短信拦截
骄傲的心别枯萎2 小时前
RV1126 NO.37:OPENCV的图像叠加功能
人工智能·opencv·计算机视觉·音视频·视频编解码·rv1126
HyperAI超神经2 小时前
解决蛋白质构象异质性的原子级建模挑战!David Baker团队PLACER框架解析
人工智能·深度学习·ai·ai4s·蛋白质结构
TG:@yunlaoda360 云老大4 小时前
腾讯WAIC发布“1+3+N”AI全景图:混元3D世界模型开源,具身智能平台Tairos亮相
人工智能·3d·开源·腾讯云
这张生成的图像能检测吗5 小时前
(论文速读)Fast3R:在一个向前通道中实现1000+图像的3D重建
人工智能·深度学习·计算机视觉·3d重建
心 爱心 爱5 小时前
Shape-Guided Dual-Memory Learning for 3D Anomaly Detection 论文精读
计算机视觉·3d·异常检测·工业异常检测·三维异常检测·多模态工业异常检测·二维异常检测
兴趣使然黄小黄8 小时前
【AI-agent】LangChain开发智能体工具流程
人工智能·microsoft·langchain
出门吃三碗饭8 小时前
Transformer前世今生——使用pytorch实现多头注意力(八)
人工智能·深度学习·transformer
l1t8 小时前
利用DeepSeek改写SQLite版本的二进制位数独求解SQL
数据库·人工智能·sql·sqlite