IT评测·应用市场-qidao123.com

标题: Opencv中的直方图(5)计算EMD间隔的函数EMD()的使用 [打印本页]

作者: 魏晓东    时间: 2024-9-5 20:53
标题: Opencv中的直方图(5)计算EMD间隔的函数EMD()的使用
算法形貌

计算两个加权点配置之间的“最小工作量”间隔。
该函数计算地球搬运工间隔(Earth Mover’s Distance)和/或两个加权点配置之间间隔的下界。其中一个应用如文献 225和 226中所述,是在图像检索中举行多维直方图比力。EMD 是一个运输问题,使用某种修改的单纯形算法来求解,因此最坏情况下的复杂度是指数级的,不外均匀而言它要快得多。在真实度量的情况下,下界甚至可以用线性时间算法更快地计算出来,而且它可以用来大抵确定两个签名是否足够远,以至于它们不大概关联到同一个对象。
函数原型

  1. float cv::EMD
  2. (
  3.         InputArray         signature1,
  4.         InputArray         signature2,       
  5.         int         distType,
  6.         InputArray         cost = noArray(),
  7.         float *         lowerBound = 0,
  8.         OutputArray         flow = noArray()
  9. )               
复制代码
参数


代码示例

  1. #include <iostream>
  2. #include <opencv2/opencv.hpp>
  3. int main()
  4. {
  5.     // 创建两个加权点配置
  6.     cv::Mat signature1 = ( cv::Mat_< float >( 3, 2 ) << 100, 23, 12,13, 13, 11 );  // 权重和坐标
  7.     cv::Mat signature2 = ( cv::Mat_< float >( 3, 2 ) << 3, 12, 12, 1, 21, 3 );  // 权重和坐标
  8.     // 初始化参数
  9.     int distType = cv::DIST_L2;  // 使用 L2 距离
  10.     cv::Mat flow;                // 流矩阵
  11.     float lowerBound = 0;        // 下界
  12.     // 计算 EMD
  13.     float distance = cv::EMD( signature1, signature2, distType, cv::Mat(), &lowerBound, flow );
  14.     std::cout << "The EMD distance between the two signatures is: " << distance << std::endl;
  15.     std::cout << "The lower bound of the EMD distance is: " << lowerBound << std::endl;
  16.     std::cout << "The flow matrix is: " << std::endl << flow << std::endl;
  17.     return 0;
  18. }
复制代码
运行结果



免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 IT评测·应用市场-qidao123.com (https://dis.qidao123.com/) Powered by Discuz! X3.4