opencv 3.0 求均值 标准差 mean MeanStdDev

均值 mean 标准差 MeanStdDev

opencv 中mean,MeanStdDev

以下是一个计算单通道矩阵所有元素均值和标准差的例子。

首先是将图像转化为灰度图。

void meanStdDev_test()
{
    const char* imagename = "E:/1.jpg";   
    //产生灰度图
    Mat img = imread(imagename);
    Mat gray,color;
    cvtColor(img, gray, CV_RGB2GRAY);
    cout << "Channel: " << gray.channels() << endl;

    Mat tmp_m, tmp_sd;
    double m = 0, sd = 0;

    m = mean(gray)[0];
    cout << "Mean: " << m << endl;

    meanStdDev(gray, tmp_m, tmp_sd);
    m = tmp_m.at(0,0);
    sd = tmp_sd.at(0,0);
    cout << "Mean: " << m << " , StdDev: " << sd << endl;
}

mean, meanStdDev计算结果是double类型的。
mean返回的值是Scalar,就是vector类型的数组。所以当要Scalar的元素,要用[n]方式访问。
meanStdDev计算的均值和标准差都以Mat形式返回,这里返回的是1X1的矩阵。所以访问结果,要访问Mat的元素。

 

输出界面:
opencv 3.0 求均值 标准差 mean MeanStdDev_第1张图片

你可能感兴趣的:(OpenCV)