Opencv---计算图像直方图方差和均值

Abstrcat:本文主要讲解如何计算图像直方图的方差和均值

1.求解一个图像的直方图,原图需要为灰度图,代码如下:(首先需要申明通道和直方图的范围)

const int channels[1]={0};

const int histSize[1]={256};

float hranges[2]={0,255};

const float* ranges[1]={hranges};

MatND hist;

Mat img = imread("....",0); //读取图片

calcHist(&img,1,channels,Mat(),hist,1,histSize,ranges);

直方图的结果保存在hist里面。
我们对hist求取均值和方差,opencv有专门的函数可以求取均值和方差,如下所示:

Mat convr, Mean;

meanStdDev(hist.rowRange(0,255), convr, Mean); // 代表求取直方图0到255的均值和方差,我们也可以
求得0120的方差,函数里面的hist.rowRange(0,255)可以改为hist.rowRange(0,120)

结果保存在convr和Mean中,其中convr为方差,Mean为均值。

如果我们想求取整幅图的均值和方差,我们可以通过reshape函数把img,展开为一行,然后再调用meanStdDev函数即可以求出整张图片的方差和均值。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值