4

我正在使用一个 CBIR(基于内容的图像检索)项目,该项目将绘制图像的 RGB 直方图,并计算其他图像与查询图像之间的距离。

我正在使用 VS 2008 - MFC 和 OpenCV 库。我想用来计算距离的方法是欧几里得距离(ED),但不知何故我没能解决。

我找到了一个函数 - cvCalcEMD2() 可以帮助我计算两个直方图之间的距离。要使用此功能,我需要为我的直方图创建签名。

这是我找到的创建签名的示例

在 For 循环中,有一行我需要在直方图中传递:

浮动 bin_val = cvQueryHistValue_2D( hist1, h, s );

在我的直方图函数中没有变量 h_bins 和 s_bins

在我的程序中,我将直方图计算/绘制成 R、G 和 B。意思是,每张图像我都有 3 个直方图。例如:CvHistogram *hist_red、*hist_green、*hist_blue;

如何使用直方图创建签名?

*我的drawHistogram函数的链接在我下面的评论中

4

1 回答 1

0

这是我在项目中创建 RGB hist 签名的代码:在我的情况下,我需要签名 tu 是浮点数组。

void makeColorSign(const IplImage* img,float** colorSign) {
    unsigned int* N = Params::colorSignSize;
    float* sign = (float*)malloc(N[0]*N[1]*3*sizeof(float));
    IplImage* s = cvCreateImage(cvSize(N[0],N[1]),img->depth,img->nChannels);
    cvResize(img,s,CV_INTER_NN);
    RgbImage rgb(s);
    for(unsigned int y=0; y<N[1]; ++y) {
        for(unsigned int x=0; x<N[0]; ++x) {
            unsigned int coord = (y*N[1]+x)*3;
            sign[coord] = rgb[y][x].r;
            sign[coord+1] = rgb[y][x].g;
            sign[coord+2] = rgb[y][x].b;
        }
    }
    *colorSign = sign;
    cvReleaseImage(&s);
}
于 2011-01-27T09:38:13.127 回答