匈牙利算法实现(from scipy.optimize import linear_sum_assignment)

ops/2024/10/11 7:36:00/

linear_sum_assignmentSciPy 库中 scipy.optimize 模块提供的一个函数,专门用于解决线性分配问题,也被称为匈牙利算法。这个问题通常出现在任务分配中,例如将一组工人分配给一组任务,以最小化总成本或最大化总收益。

代码解释

from scipy.optimize import linear_sum_assignment

这行代码导入了 linear_sum_assignment 函数。

什么是线性分配问题?

假设有一个矩阵 cost_matrix,其中 cost_matrix[i, j] 表示将第 i 个工人分配给第 j 个任务的成本(或收益的负值)。目标是找到一种分配方式,使得所有工人的总分配成本最小。

示例

假设有以下成本矩阵:

import numpy as np
from scipy.optimize import linear_sum_assignmentcost_matrix = np.array([[4, 2, 8],[2, 3, 7],[3, 6, 9]
])row_ind, col_ind = linear_sum_assignment(cost_matrix)

如何使用 linear_sum_assignment

  1. 输入linear_sum_assignment(cost_matrix) 函数的输入是一个二维数组或矩阵 cost_matrix,其中每个元素表示将某个任务分配给某个工人的成本。

  2. 输出:该函数返回两个数组 row_indcol_ind,分别表示最优分配中行和列的索引。例如,在上面的代码中,row_ind 对应于工人,col_ind 对应于任务。

结果说明

如果你打印出 row_indcol_ind,你会得到:

print(row_ind)  # [0 1 2]
print(col_ind)  # [1 0 2]

这意味着:

  • 第 0 个工人应被分配给第 1 个任务。
  • 第 1 个工人应被分配给第 0 个任务。
  • 第 2 个工人应被分配给第 2 个任务。

这是一种最小化总成本的分配方式。

总结

linear_sum_assignment 是解决任务分配优化问题的一个强大工具,特别适用于需要在二维代价矩阵中找到最低成本的分配方案的场景。


http://www.ppmy.cn/ops/107247.html

相关文章

UDP广播、 组播通信

广播接收 #include <netinet/in.h> #include <netinet/ip.h> #include <stdio.h> #include <stdlib.h> #include <sys/socket.h> #include <sys/types.h> /* See NOTES */ #include <unistd.h> #include <arpa/inet.h>// 定义…

内网隧道:端口转发

目录 LCX端口转发 场景一 场景二 SSH的端口转发 一、本地转发&#xff08;正向访问A&#xff09;&#xff1a; 二、远程转发&#xff08;反向访问A&#xff09; 三.NETSH端口转发 端口转发和端口映射 端口转发,有时被称为做隧道,是安全壳( SSH)为网络安全通信使用的一种方…

Python 数据分析— Pandas 基本操作(中)

文章目录 学习内容&#xff1a;一、 创建数据透视表二、表格合并操作三、表格分组操作四、Series 值映射五、替换 DataFrame 或 Series 中的值 学习内容&#xff1a; 一、 创建数据透视表 pivot_table(values需聚合的列名默认所有数值列, index行分组键(数组) [, columns列上…

C++ | Leetcode C++题解之第355题设计推特

题目&#xff1a; 题解&#xff1a; class Twitter {struct Node {// 哈希表存储关注人的 Idunordered_set<int> followee;// 用链表存储 tweetIdlist<int> tweet;};// getNewsFeed 检索的推文的上限以及 tweetId 的时间戳int recentMax, time;// tweetId 对应发送…

SQL进阶技巧:如何取时间序列最新完成状态的前一个状态并将完成状态的过程进行合并?

目录 0 问题描述 1 数据准备 2 问题分析 问题1:取最新完成状态的前一个状态 方法1:分析函数求解 方法2:关联求解 问题2:如何将完成状态的过程合并 方法1:分析函数作为辅助变量 方法2:自关联形式获取全量结果集 3 小结 0 问题描述 表status 字段及内容如下:…

【Linux入门】shell基础篇——免交互脚本以及配置实例

文章目录 免交互交互与免交互Here Document 免交互总结 expect工具1. 介绍2. 安装3. 基本概念4. 基本命令4.1 脚本解释器4.2 spawn4.3 expect4.4 send4.5 结束符4.6 set4.7 exp_continue4.8 send_user4.9 接收参数 5. 示例脚本 免交互配置示例修改用户密码脚本 passwd.shsu 切换…

ARM32开发——GD32F4 DMA功能查询

&#x1f3ac; 秋野酱&#xff1a;《个人主页》 &#x1f525; 个人专栏:《Java专栏》《Python专栏》 ⛺️心若有所向往,何惧道阻且长 文章目录 DMA0DMA1 DMA0 DMA1

传统CV算法——基于Opencv的图像绘制

直线绘制 参数解析&#xff1a; &#xff08;图像矩阵&#xff0c;直线起始坐标&#xff0c; 直线终止坐标、颜色、线条厚度&#xff09; cv2.line()是OpenCV中用于绘制直线的函数。 参数说明&#xff1a;img&#xff1a;要绘制直线的图像矩阵。(100,30)&#xff1a;直线的起…