直方图
对于直方图,使用cv::calcHist函数可以求出。
原型
void calcHist(const Mat* arrays, int narrays, const int* channels, InputArray mask, OutputArray
hist, int dims, const int* histSize, const float** ranges, bool uniform=true, bool accumulate=
false );void calcHist(const Mat* arrays, int narrays, const int* channels, InputArray mask, SparseMat&
hist, int dims, const int* histSize, const float** ranges, bool uniform=true, bool accumulate=
false );
- arrays: 输入图像(或数组、数组集)
- narrays: 输入数组的个数
- channels: 需要统计的通道
- mask: 掩码( 0 表示忽略该像素), 如果未定义,则不使用掩码
- hist: 储存直方图的矩阵
- dims: 直方图维数
- histSize: 每个维度的bin数目
- ranges: 每个维度的取值范围
- uniform 和 accumulate: bin大小相同,清楚直方图痕迹
这里给出一个我封装好的计算直方图的方法
1 void GetGrayHist(cv::Mat& src, cv::Mat& grayHist, int histSize=255)
2 {
3 float range[] = { 0, 255 };
4 const float* histRange = { range };
5 bool uniform = true; bool accumulate = false;
6 (&src, 1, 0, cv::Mat(), grayHist, 1, &histSize, &histRange, uniform, accumulate);
7 }
平均值与方差
平均值与方差的计算使用cv::meanStdDev函数
该函数有四个输入参数
1Mat 图像
2Mat 平均值,计算后会变成Float64型(double)1*1。
3Mat 方差,计算后同样会变成Float64型1*1。
4掩膜
以下是一个计算图像平均灰度与灰度方差的程序:
1 void GetGrayAvgStdDev(cv::Mat& src, double& avg, double &stddev)
2 {
3 cv::Mat img;
4 if (src.channels() == 3)
5 cv::cvtColor(src, img, CV_BGR2GRAY);
6 else
7 img = src;
8 cv::mean(src);
9 cv::Mat mean;
10 cv::Mat stdDev;
11 cv::meanStdDev(img, mean, stdDev);
12
13 avg = mean.ptr<double>(0)[0];
14 stddev = stdDev.ptr<double>(0)[0];
15 }
分类:
OpenCV
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程
· .NET 10 首个预览版发布,跨平台开发与性能全面提升
· 《HelloGitHub》第 107 期
· 全程使用 AI 从 0 到 1 写了个小工具
· 从文本到图像:SSE 如何助力 AI 内容实时呈现?(Typescript篇)