您的位置:首页 > 产品设计 > UI/UE

【练习7.1】cvCreateHist创建直方图、cvCalcHist计算直方图、cvQueryHistValue_1D访问直方图及右左法则

2015-05-06 22:11 465 查看
提纲

题目要求
程序代码
结果图片
要言妙道
题目要求:

在0~1之间生成1000个随机值,定义bin的大小为10,并建立一个直方图

a、输出每个bin中的数据

程序代码:

// OpenCVExerciseTesting.cpp : 定义控制台应用程序的入口点。
//
//D:\\Work\\Work_Programming\\Source\\Image\\lena.jpg

#include "stdafx.h"
#include <cv.h>
#include <highgui.h>
#include <iostream>

#include <opencv2/legacy/legacy.hpp>
//#pragma comment(lib, "opencv_legacy2411.lib")

using namespace cv;
using namespace std;

//函数声明-->--->-->--->-->--->-->--->//

//<--<--<--<--<--<--<--<--<--函数声明//

int _tmain(int argc, _TCHAR* argv[])
{
CvRNG rng;
rng = cvRNG(cvGetTickCount());
IplImage* src = cvCreateImage(cvSize(10, 100), IPL_DEPTH_32F, 1);

for (int i = 0; i < 1000; ++i)
{
double value = cvRandReal(&rng);
cvSetReal1D(src, i, value);
}

int dims = 1;
int sizes[1] = { 10 };
int type = CV_HIST_ARRAY;
float arr[] = { 0.0f, 1.0f };
float * rangs[] = { arr };

CvHistogram *histogram = cvCreateHist(dims, sizes, type, rangs, 1);
cvCalcHist(&src, histogram);

float sum = 0.0f;
for (int i = 0; i < 10; ++i)
{
float value = cvQueryHistValue_1D(histogram, i);
cout << value << endl;
}

system("pause");

cvWaitKey();
cvReleaseImage(&src);
cvDestroyAllWindows();
rangs = NULL;

return 0;
}

void DrawHistogram(IplImage * image_hist, const CvHistogram * histogram)
{

}


结果图片:


要言妙道:

① cvWaitKey(); 只有在之前调用该cvShowImage后才会等待,如果之前的代码没调过,则必须用 system("pause"); 才能暂停下来。但是,如果代码中有cvShowImage的操作,在 cvWaitKey(); 前一定不能使用 system("pause"); ,不然程序一直会暂停那里,鼠标一直转圈,显示不出图片

②cvCreateHist的参数sizes即直方图的大小,相当于直方图包含元素的个数,如果是二维直方图,即直方图大小为2,包含两个一维直方图。sizes必须为整型数组,数组长度等于直方图的维数,数组中每一个整数表示分配给对应维数的bin的个数,例如直方图为一维,sizes必须为只包含一个整型元素的数组,该元素的值即为直方图bin的个数

③cvCreateHist的参数ranges是指向指针的指针,即二维数组,第一维的长度应等于bin的个数,第二维代表各个bin的的范围或分段情况,对于均匀直方图,第二维便是最小值和最大值组成的两个元素的数组;对于有N个bin的非均匀直方图,第二维是由N+1个元素组成的分段情况,例如本题如果使用非均匀可以是{0.0,0.14,0.25,0.31,0.29,0.55,0.60,0.66,0.79,0.82,1.0},这第二维工11个数,相邻的两个数代表一个bin的范围,这样若干个一维数组合成一个二维数组,本题的若干个=1个

④根据右左法则以 float * rangs[] 为例,rangs是一个数组,数组元素的类型为指针,指针式指向float的指针,其实这一点使用 float rangs[] 更容易理解,rangs是一个数组,数组元素是float型。

⑤cvCalcHist计算直方图即根据直方图的参数,算出落在每个bin中数量

⑥cvQueryHistValue_1D等函数即获取各个bin中元素的数量
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: