0

我使用了一个map<CString, vector<double>>结构来存储文件名到其 HSV 颜色直方图的映射。这个映射中有 100 个元素作为图像 DB。如果现在有一个图像,我已经得到了输入图像的直方图,我该怎么做比较?

我知道一种叫做“二次距离”的方法,但我不明白。

4

1 回答 1

1

一种简单的方法是使用这样的距离计算器:

double dist(vector<double> *histogram1, vector<double> *histogram2) {
    double result = 0.0;
    for (vector<double>::iterator val1=histogram1->begin(), val2=histogram2->begin();
         val1<histogram1->end();
         val1++, val2++) {
        result += (*val1 - *val2) * (*val1 - *val2);
    }
    result = sqrt(result);
    return result;
}

然后确定哪个直方图的距离最小。请注意,这仅用于演示目的,您必须添加矢量大小检查等。

于 2012-07-04T06:10:55.747 回答