| cv.EMD - MATLAB File Help |
Computes the "minimal work" distance between two weighted point configurations
d = cv.EMD(signature1, signature2)
d = cv.EMD(signature1, signature2, 'OptionName', optionValue, ...)
[d, lowerBound, flow] = cv.EMD(...)
size1-by-(dims+1) floating-point
matrix. Each row stores the point weight followed by the point coordinates
[w,x1,x2,...,xn]. The matrix is allowed to have a single column (weights
only) if the user-defined Cost matrix is used. The weights must be
non-negative and have at least one non-zero value.size2-by-(dims+1) of the same format as
signature1, though the number of rows may be different. The total
weights may be different. In this case an extra "dummy" point is added to
either signature1 or signature2. The weights must be non-negative and
have at least one non-zero value.size1-by-size2 flow matrix of type single.
flow(i,j) is a flow from i-th point of signature1 to j-th point of
signature2.d = |x1-x2| + |y1-y2|d = sqrt((x1-x2)^2 + (y1-y2)^2)d = max(|x1-x2|,|y1-y2|)Cost is set.size1-by-size2 cost matrix. Also, if a cost matrix
is used, output lower boundary lowerBound cannot be calculated because
it needs a metric function. Not set by defaultLowerBound (it means that the signatures are far
enough), the function does not calculate EMD. In any case LowerBound is
set to the calculated distance between mass centers on return. Thus, if
you want to calculate both distance between mass centers and EMD,
LowerBound should be set to 0. default 0.The function computes the earth mover distance and/or a lower boundary of the distance between the two weighted point configurations. One of the applications described in [RubnerSept98], [Rubner2000] is multi-dimensional histogram comparison for image retrieval. EMD is a transportation problem that is solved using some modification of a simplex algorithm, thus the complexity is exponential in the worst case, though, on average it is much faster. In the case of a real metric the lower boundary can be calculated even faster (using linear-time algorithm) and it can be used to determine roughly whether the two signatures are far enough so that they cannot relate to the same object.
[RubnerSept98]:
Yossi Rubner, Carlo Tomasi, and Leonidas J Guibas. "The earth mover's distance as a metric for image retrieval". 1998.
[Rubner2000]:
Yossi Rubner, Carlo Tomasi, and Leonidas J Guibas. "The earth mover's distance as a metric for image retrieval". International Journal of Computer Vision, 40(2):99-121, 2000.