匈牙利算法解决两个坐标列表匹配问题

2023-05-16

匈牙利算法:

python线性规划(linear programming)与分配问题(assignment problem)—— linear_sum_assignment的使用
python数学建模之用optimize.linear_sum_assignment解决模型优化之指派问题

遇到一个问题,有一个坐标列表A:[[10,20],[20,30],[42,41],[45,41]], 和一个坐标列表B:[[14,24],[41,42],[20,31],[42,41]],需要看这两个坐标列表之间谁与谁更匹配,这时候就可以使用匈牙利算法来实现

其中分别使用欧几里得距离以及曼哈顿距离作为损失函数

## 遇到一个问题,有一个坐标列表A:[[10,20],[20,30],[42,41],[45,41]], 和一个坐标列表B:[[14,24],[41,42],[20,31],[42,41]],需要看这两个坐标列表之间谁与谁更匹配,这时候就可以使用匈牙利算法来实现

from scipy.optimize import linear_sum_assignment
import numpy as np

# 先前的坐标
position_a = [[10,20],[20,30],[42,41],[45,41]]

# 之后的坐标
position_b = [[14,24],[41,42],[20,31],[42,41]]

## 使用欧几里得距离作为损失

# 使用坐标计算代价矩阵
cost_martix = [[np.power((np.array(a)-np.array(b)),2).sum() for a in position_a] for b in position_b]

print(cost_martix)
# [[32, 72, 1073, 1250], [1445, 585, 2, 17], [221, 1, 584, 725], [1465, 605, 0, 9]]
# 进行匈牙利算法匹配

row_ind, col_ind = linear_sum_assignment(cost_martix)
print(row_ind)
print(col_ind)
# [0 1 2 3]
# [0 2 1 3]

for x,y in zip(row_ind, col_ind):
    print("列表B中的%s,应该与列表A中坐标%s匹配,距离消耗为%d"%(position_b[x],position_a[y],cost_martix[x][y]))
# 列表B中的[14, 24],应该与列表A中坐标[10, 20]匹配,距离消耗为32
# 列表B中的[41, 42],应该与列表A中坐标[42, 41]匹配,距离消耗为2
# 列表B中的[20, 31],应该与列表A中坐标[20, 30]匹配,距离消耗为1
# 列表B中的[42, 41],应该与列表A中坐标[45, 41]匹配,距离消耗为9

## 使用曼哈顿距离作为损失
cost_martix2 = [[np.abs((np.array(a)-np.array(b))).sum() for a in position_a] for b in position_b]

print(cost_martix2)
# [[8, 12, 45, 48], [53, 33, 2, 5], [21, 1, 32, 35], [53, 33, 0, 3]]

# 使用匈牙利算法匹配

row_ind2, col_ind2 = linear_sum_assignment(cost_martix2)
print(row_ind2)
print(col_ind2)
# [0 1 2 3]
# [0 2 1 3]

for x,y in zip(row_ind, col_ind):
    print("列表B中的%s,应该与列表A中坐标%s匹配,距离消耗为%d"%(position_b[x],position_a[y],cost_martix2[x][y]))
# 列表B中的[14, 24],应该与列表A中坐标[10, 20]匹配,距离消耗为8
# 列表B中的[41, 42],应该与列表A中坐标[42, 41]匹配,距离消耗为2
# 列表B中的[20, 31],应该与列表A中坐标[20, 30]匹配,距离消耗为1
# 列表B中的[42, 41],应该与列表A中坐标[45, 41]匹配,距离消耗为3
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

匈牙利算法解决两个坐标列表匹配问题 的相关文章

  • Nginx 使用 logrotate 进行日志滚动

    Nginx 日志滚动 xff08 官方 xff09 向 Nginx 主进程发送 USR1信号 USR1信号量被 Nginx 自定义了 xff0c 为重新打开日志 xff1b 当 kill 命令发送 USR1时 xff0c nginx 会重新
  • Softmax()函数的溢出问题笔记

    首先 xff0c 回顾softmax函数的定义 xff1a 按照这个定义 xff0c softmax 在Python解释器中可以这样实现 xff1a import numpy as np def softmax a exp a 61 np
  • 进公司一年,怎么跟老板提涨工资?

    网友提问 xff1a 进公司一年 xff0c 怎么跟老板提涨工资 xff1f 无忧专家 xff1a 薪资不是 你想加 xff0c 想加就能加的 xff0c 好多人鼓足勇气开口说出了加薪理由 xff0c 却被老板轻描淡写的一句话给噎住了喉咙
  • what is Cardinality?

    在数学意义上 xff0c cardinality 基数或者势 指集合内元素的个数 在数据库的相关资料中 xff0c 往往会看到cardinality这个术语 Base cardinality is the number of rows in
  • CAS单点登录开源框架解读(六)--CAS单点登录服务端认证之用户认证跳转

    用户认证之后如何执行后续跳转 在上一章节中 xff0c 我们知道了默认CAS服务端是如何通过配置文件实现用户登录名和密码的认证 xff0c 下面我们将继续对认证之后的动作处理进行分析 1 发送TGT之行为状态sendTicketGranti
  • cocos creator新缓动系统-cc.tween

    前言 一直对于cocos creator的action系统有着深深的埋怨 xff0c 原因是用起来太麻烦了 习惯了Unity的Tween插件的用法 xff0c 我也试着自己封装了下action系统 xff0c 用起来像Tween那样 xff
  • Direct UI

    有个坑爹的说法 xff1a 其实Direct UI只是一个思想 xff0c 要实现这个思 想 xff0c 还要靠自己 采用windows方式用api或gdi实现ui的绘制 DirectUI意为直接在父窗口上绘图 Paint on paren
  • 个人学习记录-AD2021

    有结点的一侧有电气属性 xff0c 用于连接导线 当捕捉格较大时 xff0c 更改捕捉栅格 视图 栅格 设置捕捉栅格 designator 位号 xff0c 一般用R U C T 代替 link 链接 填写元件名称及购买商 管脚name处
  • Linux Zram配置使用(特定平台&个人使用,maybe不具普适性)

    内核配置 xff1a CONFIG ZSMALLOC 61 y CONFIG ZRAM 61 y CONFIG SWAP 61 y swapon dev zram0 Function not implemented报错原因是CONFIG S
  • 2021-03-15

    float型变量占用32bit xff0c 即4个byte的内存空间 我们先来看下浮点数二进制表达的三个组成部分 三个主要成分是 xff1a Sign xff08 1bit xff09 xff1a 表示浮点数是正数还是负数 0表示正数 xf
  • 2021-03-18

    包络面与载波信号的确定
  • 2021-03-19

    输出 数字直角三角形 1 2 3 4 5 6 7 8 9 10 11 12 可根据需要增加行数 public class trangle 64 param args public static void main String args T
  • 2021-03-19

    switch语句实现成绩选择 注意强制转换 import java util Scanner public class Grade Switch 64 param args public static void main String ar
  • 2021-04-03

    Java代码 importjava util Scanner public classTest public static voidmain String args p br Scanner scan 61 newScanner Syste
  • 2021年寒假

    2022年1月4日 周二 雨雪 主要内容 xff1a 测试学校周雄短路的板子 xff0c 焊接新板子 上午11 00开始 xff0c 首先准备好电源 xff0c 热风枪 xff0c 前一天晚上已经改完的板子 第一次上电 测得最终输出5v 1
  • JavaScript 异步编程

    异步的概念 异步 xff08 Asynchronous async xff09 是与同步 xff08 Synchronous sync xff09 相对的概念 在我们学习的传统单线程编程中 xff0c 程序的运行是同步的 xff08 同步不
  • InnoDB引擎--存储结构与文件

    数据库是数据的集合 xff0c 数据库管理系统 xff08 DBMS xff09 是操作和管理数据库的应用程序 数据库应用主要有两类 xff1a OLAP xff08 联机分析处理 xff09 和OLTP xff08 联机事务处理 xff0
  • conda安装包出现CondaHTTPError: HTTP 000 CONNECTION FAILED for url问题

    win10本地利用conda install package时出现的问题 Fetching package metadata CondaHTTPError HTTP 000 CONNECTION FAILED for url lt http
  • NVM 切换Node版本不成功(nvm提示成功,实际Node版本未切换)

    一 背景 xff1a 因为接手了一个旧项目 xff0c node依赖版本对应不上 xff0c 于是想到用NVM切换下对应版本 xff0c 二 问题 xff1a xff08 先安装Node xff0c 后安装Nvm下 xff09 由于以前就安
  • STM32F103C8T6读取气压计MS5611,I2C读取模式

    笔者最近想用气压计模块来测一下相对高度 xff0c 使用的元器件如下图所示 所使用的最小系统板 所使用的气压计模块 其实读取还是蛮简单的 xff0c 根据核心板引脚图选择I2c接口 xff0c 然后借鉴正点原子的模拟i2c程序 xff0c

随机推荐