opencv 图像直方图 calcHist
来源:互联网 发布:太极旗飘扬 知乎 编辑:程序博客网 时间:2024/04/30 08:30
图像直方图的概念
图像直方图是反映一个图像像素分布的统计表,其实横坐标代表了图像像素的种类,可以是灰度的,也可以是彩色的。纵坐标代表了每一种颜色值在图像中的像素总数或者占所有像素个数的百分比。
图像是由像素构成,因为反映像素分布的直方图往往可以作为图像一个很重要的特征。在实际工程中,图像直方图在特征提取、图像匹配等方面都有很好的应用。
利用OpenCV计算图像的直方图
OpenCV中计算图像直方图像函数是calcHist,它的参数比较多,下面分析一下它的接口和用法。
void calcHist(const Mat* images, int nimages, const int* channels, InputArray mask, OutputArray hist, int dims, const int* histSize, const float** ranges, booluniform=true, bool accumulate=false )
const Mat* images:为输入图像的指针。
int nimages:要计算直方图的图像的个数。此函数可以为多图像求直方图,我们通常情况下都只作用于单一图像,所以通常nimages=1。
const int* channels:图像的通道,它是一个数组,如果是灰度图像则channels[1]={0};如果是彩色图像则channels[3]={0,1,2};如果是只是求彩色图像第2个通道的直方图,则channels[1]={1};
IuputArray mask:是一个遮罩图像用于确定哪些点参与计算,实际应用中是个很好的参数,默认情况我们都设置为一个空图像,即:Mat()。
OutArray hist:计算得到的直方图
int dims:得到的直方图的维数,灰度图像为1维,彩色图像为3维。
const int* histSize:直方图横坐标的区间数。如果是10,则它会横坐标分为10份,然后统计每个区间的像素点总和。
const float** ranges:这是一个二维数组,用来指出每个区间的范围。
后面两个参数都有默认值,uniform参数表明直方图是否等距,最后一个参数与多图像下直方图的显示与存储有关。
OpenCV直方图例子
灰度直方图
int main(){ Mat Image=imread("../cat.png"); cvtColor(Image,Image,CV_BGR2GRAY); const int channels[1]={0}; const int histSize[1]={256}; float hranges[2]={0,255}; const float* ranges[1]={hranges}; MatND hist; calcHist(&Image,1,channels,Mat(),hist,1,histSize,ranges); return 0;}
彩色直方图
int main(){ Mat Image=imread("../cat.png"); const int channels[3]={0,1,2}; const int histSize[3]={256,256,256}; float hranges[2]={0,255}; const float* ranges[3]={hranges,hranges,hranges}; MatND hist; calcHist(&Image,1,channels,Mat(),hist,3,histSize,ranges); return 0;}
不均匀(自定义区间)直方图
int main(){ Mat Image=imread("../cat.png"); cvtColor(Image,Image,CV_BGR2GRAY); const int channels[1]={0}; int histSize[1]={5}; float hranges[6]={0,50,80,150,230,255}; const float* ranges[1]={hranges}; MatND hist; calcHist(&Image,1,channels,Mat(),hist,1,histSize,ranges,false); return 0;}
直方图的显示
Mat getHistImg(const MatND& hist){ double maxVal=0; double minVal=0; //找到直方图中的最大值和最小值 minMaxLoc(hist,&minVal,&maxVal,0,0); int histSize=hist.rows; Mat histImg(histSize,histSize,CV_8U,Scalar(255)); // 设置最大峰值为图像高度的90% int hpt=static_cast<int>(0.9*histSize); for(int h=0;h<histSize;h++) { float binVal=hist.at<float>(h); int intensity=static_cast<int>(binVal*hpt/maxVal); line(histImg,Point(h,histSize),Point(h,histSize-intensity),Scalar::all(0)); } return histImg;}
- opencv 图像直方图 calcHist
- calcHist()计算图像直方图opencv
- OpenCV【4】---calcHist 计算图像的直方图
- opencv 直方图calcHist
- opencv 计算直方图 calcHist()
- opencv学习(三十七)之图像直方图计算calcHist()
- 计算图像直方图方法,纠正calcHist调用错误(OpenCV)
- Opencv之直方图计算calcHist
- opencv 直方图 CV::calcHist使用
- OpenCv计算直方图cv::calcHist
- 【Opencv】【C++】 Opencv之calcHist() 计算直方图
- 【Opencv】【C++】 Opencv之calcHist() 计算直方图
- calcHist函数来计算图像直方图
- 【OpenCV】calcHist在直方图中的使用
- [OpenCV基础] 直方图之calcHist使用
- OpenCV直方图计算匹配方法详解calcHist
- OPENCV——直方图计算calcHist
- calcHist()直方图
- Android中Json的解析和构建
- [iOS开发]判断两个数组中数据是否相同
- 翻翻git之---史上最强的图片选择器 GalleryFinal(顺带附下麦麦,当当的近照)
- Tomcat内存设置详解
- js中this的指向
- opencv 图像直方图 calcHist
- OVS学习过程2
- HDFS之JAVA API
- 华为oj 密码强度等级
- wc统计程序行数
- ROS学习(二十)--tf/写broadcaster和listener
- iOS KVC和KVO
- FUEL8安装处理
- 79. Word Search&矩阵中的路径