OpenCV输出均值、标准差、协方差

1、概述

  案例:使用OpenCV输出图片的均值和标准差以及协方差矩阵

  相关定义:

  1.均值:平均值,指讲一个数据集合中的值相加再除以数据集中数据的个数得出的值

  2.方差:数据集中每个样本值与全体样本值的平均数之差的平方值的平均数

  3.标准差:标准差是方差的算数平方根(ps:定义参考方差)

  4.协方差:在概率论和统计学中用于衡量两个变量的总体误差

  函数定义:

均值及标准差:
void meanStdDev(InputArray src, OutputArray mean, OutputArray stddev,
                             InputArray mask=noArray());
1.src:输入图像
2.mean:输出参数--->均值
3.stddev:输出参数--->标准差
协方差矩阵、均值矩阵
void calcCovarMatrix( InputArray samples, OutputArray covar, InputOutputArray mean, int flags, int ctype = CV_64F);
samples:输入数据,一般channgle==1
covar:输出参数表示协方差矩阵
mean:输出参数表示,均值矩阵
flags:操作标志:CV_COVAR_SCRAMBLED,CV_COVAR_NORMAL,CV_COVAR_USE_AVG,CV_COVAR_SCALE,CV_COVAR_ROWS,CV_COVAR_COLS.

2、代码演示

QT开发交流+赀料君羊:714620761

Face_Means_Covar::Face_Means_Covar(QWidget *parent)
    : MyGraphicsView{parent}
{
    this->setWindowTitle("计算Mat均值、标准差、及协方差");
    QLabel *labelTitle = new QLabel(this);
    labelTitle->setText("输出结果如下:");
    //均值
    QLabel *labelMeansTitle = new QLabel(this);
    labelMeansTitle->setText("均值:");
    labelMeansTitle->move(0,labelTitle->y()+labelTitle->height()+10);
    labelMeansValue = new QLabel(this);
    labelMeansValue->setFixedWidth(150);
    labelMeansValue->move(labelMeansTitle->x()+labelMeansTitle->width()+10,labelMeansTitle->y());
    //标准差
    QLabel *labelStddevTitle = new QLabel(this);
    labelStddevTitle->setText("标准差:");
    labelStddevTitle->move(0,labelMeansTitle->y()+labelMeansTitle->height()+10);
    labelStddevValue = new QLabel(this);
    labelStddevValue->setFixedWidth(150);
    labelStddevValue->move(labelStddevTitle->x()+labelStddevTitle->width()+10,labelStddevTitle->y());
    //协方差
    QLabel *labelCovarTitle = new QLabel(this);
    labelCovarTitle->setText("协方差:");
    labelCovarTitle->move(0,labelStddevTitle->y()+labelStddevTitle->height()+10);
    labelCovarValue = new QLabel(this);
    labelCovarValue->setFixedWidth(150);
    labelCovarValue->move(labelCovarTitle->x()+labelCovarTitle->width()+10,labelCovarTitle->y());

}

void Face_Means_Covar::dropEvent(QDropEvent *event){
    path = event->mimeData()->urls().at(0).toLocalFile();
    qDebug()<<"文件路径:"<(i);
         qDebug()<<"均值:"<< means.at(i);
    }
    QString rMeans=QString("%1").arg(resultMeans/3);
    labelMeansValue->setText(rMeans);


    //计算所有通道的标准差
    double resultStddev=0.0;
    for(int i=0;i(i);
        qDebug()<<"标准差:"<(i);
    }
    QString rStddev=QString("%1").arg(resultStddev/3);
    labelStddevValue->setText(rStddev);


    //计算协方差
    Mat covar,means2;
    cvtColor(src,src,COLOR_BGR2GRAY);
    //这里的输入需要是单通道的channgle==1
    calcCovarMatrix(src,covar,means2,COVAR_NORMAL|cv::COVAR_ROWS);
    qDebug()<<"以下是协方差矩阵";
    //一定要搞一个小一点的图测试
    cout << covar<

3、示例图片

页面更新:2024-03-03

标签:协方差   平方根   标准差   方差   平均数   矩阵   样本   定义   参数   数据

1 2 3 4 5

上滑加载更多 ↓
更多:

本站资料均由网友自行发布提供,仅用于学习交流。如有版权问题,请与我联系,QQ:4156828  

© CopyRight 2020-2024 All Rights Reserved. Powered By 71396.com 闽ICP备11008920号-4
闽公网安备35020302034903号

Top