土方工程的Python代码';s距离

土方工程的Python代码';s距离,python,image,Python,Image,我正在寻找python中的地球移动器距离(或快速EMD)实现。 任何关于在哪里找到它的线索,我在网上已经查够了。 我想在我正在做的一个图像检索项目中使用它。 谢谢 编辑: 我发现了一个非常好的解决方案使用。 此页面还包含设置它所需的说明。for Python中有一个很好的实现。函数名为,比较两幅图像直方图的简单代码如下: #Import OpenCv library from cv2 import * ### HISTOGRAM FUNCTION #######################

我正在寻找python中的地球移动器距离(或快速EMD)实现。 任何关于在哪里找到它的线索,我在网上已经查够了。 我想在我正在做的一个图像检索项目中使用它。 谢谢

编辑: 我发现了一个非常好的解决方案使用。
此页面还包含设置它所需的说明。

for Python中有一个很好的实现。函数名为,比较两幅图像直方图的简单代码如下:

#Import OpenCv library
from cv2 import *

### HISTOGRAM FUNCTION #########################################################
def calcHistogram(src):
    # Convert to HSV
    hsv = cv.CreateImage(cv.GetSize(src), 8, 3)
    cv.CvtColor(src, hsv, cv.CV_BGR2HSV)

    # Extract the H and S planes
    size = cv.GetSize(src)
    h_plane = cv.CreateMat(size[1], size[0], cv.CV_8UC1)
    s_plane = cv.CreateMat(size[1], size[0], cv.CV_8UC1)
    cv.Split(hsv, h_plane, s_plane, None, None)
    planes = [h_plane, s_plane]

    #Define numer of bins
    h_bins = 30
    s_bins = 32

    #Define histogram size
    hist_size = [h_bins, s_bins]

    # hue varies from 0 (~0 deg red) to 180 (~360 deg red again */
    h_ranges = [0, 180]

    # saturation varies from 0 (black-gray-white) to 255 (pure spectrum color)
    s_ranges = [0, 255]

    ranges = [h_ranges, s_ranges]

    #Create histogram
    hist = cv.CreateHist([h_bins, s_bins], cv.CV_HIST_ARRAY, ranges, 1)

    #Calc histogram
    cv.CalcHist([cv.GetImage(i) for i in planes], hist)

    cv.NormalizeHist(hist, 1.0)

    #Return histogram
    return hist

### EARTH MOVERS ############################################################
def calcEM(hist1,hist2,h_bins,s_bins):

    #Define number of rows
    numRows = h_bins*s_bins

    sig1 = cv.CreateMat(numRows, 3, cv.CV_32FC1)
    sig2 = cv.CreateMat(numRows, 3, cv.CV_32FC1)    

    for h in range(h_bins):
        for s in range(s_bins): 
            bin_val = cv.QueryHistValue_2D(hist1, h, s)
            cv.Set2D(sig1, h*s_bins+s, 0, cv.Scalar(bin_val))
            cv.Set2D(sig1, h*s_bins+s, 1, cv.Scalar(h))
            cv.Set2D(sig1, h*s_bins+s, 2, cv.Scalar(s))

            bin_val = cv.QueryHistValue_2D(hist2, h, s)
            cv.Set2D(sig2, h*s_bins+s, 0, cv.Scalar(bin_val))
            cv.Set2D(sig2, h*s_bins+s, 1, cv.Scalar(h))
            cv.Set2D(sig2, h*s_bins+s, 2, cv.Scalar(s))

    #This is the important line were the OpenCV EM algorithm is called
    return cv.CalcEMD2(sig1,sig2,cv.CV_DIST_L2)

### MAIN ########################################################################
if __name__=="__main__":
    #Load image 1
    src1 = cv.LoadImage("image1.jpg")

    #Load image 1
    src2 = cv.LoadImage("image2.jpg")

    # Get histograms
    histSrc1= calcHistogram(src1)
    histSrc2= calcHistogram(src2)

    # Compare histograms using earth mover's
    histComp = calcEM(histSrc1,histSrc2,30,32)

    #Print solution
    print(histComp)

我使用Python2.7和Python(x,y)测试了与前面代码非常相似的代码。如果你想了解更多关于地球运动的知识,你想看到使用OpenCV和C++的实现,你可以阅读加里Brdask& AdRun-KaBulr的书“学习OpenCV”的“第7章:直方图”。< P> > Python代码:计算等长

两个一维分布之间的推土机距离的Python代码。
def emd (a,b):
earth = 0
earth1 = 0
diff = 0
s= len(a)
su = []
diff_array = []
for i in range (0,s):
    diff = a[i]-b[i]
    diff_array.append(diff)
    diff = 0
for j in range (0,s):
    earth = (earth + diff_array[j])
    earth1= abs(earth)
    su.append(earth1)
emd_output = sum(su)/(s-1)
print(emd_output)

也许如果你包含一个指向这个术语定义的链接,你就可以省去潜在的回答者去谷歌的旅程。如果它存在于C语言中,你可以从Python中使用它。你认为你可以尝试详细说明你找到的解决方案吗?我也遇到了同样的问题:)@Will您是否成功地从我在编辑中提到的链接安装了纸浆库?地球移动器的距离(EMD)也被称为Wasserstein度量,您可以从
scipy.stats
获取Python实现: