您必须根据权重和坐标定义数组。如果您有两个表示一维直方图的数组 a = [1,1,0,0,1] 和 b = [0,1,0,1],那么 numpy 数组应该如下所示:
a = [[1 1]
[1 2]
[0 3]
[0 4]
[1 5]]
b = [[0 1]
[1 2]
[0 3]
[1 4]]
请注意,行数可以不同。列数应该是维度 + 1。第一列包含权重,第二列包含坐标。
下一步是在将 numpy 数组作为签名输入到 CalcEMD2 函数之前,将数组转换为 CV_32FC1 Mat。代码如下所示:
from cv2 import *
import numpy as np
# Initialize a and b numpy arrays with coordinates and weights
a = np.zeros((5,2))
for i in range(0,5):
a[i][1] = i+1
a[0][0] = 1
a[1][0] = 1
a[2][0] = 0
a[3][0] = 0
a[4][0] = 1
b = np.zeros((4,2))
for i in range(0,4):
b[i][1] = i+1
b[0][0] = 0
b[1][0] = 1
b[2][0] = 0
b[3][0] = 1
# Convert from numpy array to CV_32FC1 Mat
a64 = cv.fromarray(a)
a32 = cv.CreateMat(a64.rows, a64.cols, cv.CV_32FC1)
cv.Convert(a64, a32)
b64 = cv.fromarray(b)
b32 = cv.CreateMat(b64.rows, b64.cols, cv.CV_32FC1)
cv.Convert(b64, b32)
# Calculate Earth Mover's
print cv.CalcEMD2(a32,b32,cv.CV_DIST_L2)
# Wait for key
cv.WaitKey(0)
请注意,CalcEMD2 的第三个参数是欧几里得距离 CV_DIST_L2。第三个参数的另一个选项是曼哈顿距离 CV_DIST_L1。
我还想提一下,我编写了代码来计算 Python 中两个 2D 直方图的 Earth Mover 距离。您可以在此处找到此代码。