如何使用匈牙利算法解决多维度的约束条件问题

news2024/11/22 17:26:18

🍿*★,°*:.☆欢迎您/$:*.°★* 🍿


 

正文


假设 一个项目 有三个  维度的参数 A B C 都要 组合后最小
分别求解 a b c 三个维度的最优组合
如果三个组合方案刚好 重叠 那么说明有一个使得三个方案最优的 解
如果没有 那么若选择某个方案 其他维度的参数 的值 是 最后得到 选择每种方案的 所有维度参数 按照 到 0点 的欧式距离排序 选择最小的
一般的项目维度 是可穷举的
选择a 维度参数 的方案 a 的值
选择a 维度参数 的方案 b 的值
选择a 维度参数 的方案 c 的值
选择b 维度参数 的方案 a 的值
选择b 维度参数 的方案 b 的值
选择b 维度参数 的方案 c 的值
选择c 维度参数 的方案 a 的值
选择c 维度参数 的方案 b 的值
选择c 维度参数 的方案 c 的值
如果是有填充值得那么 还需要计算每个方案的有效组合数 最后 同时 排序 方可
在没有 组合有效数 的情况下 a b 方案均可  优化 方案 是将 所有方案参数归一化
假设 每个方案 有效组合是 [1,2,3]
当考虑到有效组合方案的时候要使用 多个参数一起排序  在前面的优先级最高 False 是降序 True 是升序

import numpy as np
import pandas as pd
from scipy.optimize import linear_sum_assignment


acost = np.array([[4, 1, 3], [2, 0, 5], [3, 2, 2]])
bcost = np.array([[6, 2, 7], [2, 1, 5], [7, 3, 2]])
ccost = np.array([[6, 3, 4], [2, 1, 8], [9, 3, 6]])
arow_ind, acol_ind = linear_sum_assignment(acost)
brow_ind, bcol_ind = linear_sum_assignment(bcost)
crow_ind, ccol_ind = linear_sum_assignment(ccost)

if np.sum((acol_ind == bcol_ind) & (arow_ind == ccol_ind) & (arow_ind == brow_ind) & (
        arow_ind == crow_ind)) == ccol_ind.size:
    print("选择一种方案即可")

a_acost_value = acost[arow_ind, acol_ind].sum()

a_bcost_value = bcost[arow_ind, acol_ind].sum()

a_ccost_value = bcost[arow_ind, acol_ind].sum()
a_cost_value = [a_acost_value, a_bcost_value, a_ccost_value]

b_acost_value = acost[brow_ind, bcol_ind].sum()

b_bcost_value = bcost[brow_ind, bcol_ind].sum()

b_ccost_value = bcost[brow_ind, bcol_ind].sum()
b_cost_value = [b_acost_value, b_bcost_value, b_ccost_value]

c_acost_value = acost[crow_ind, ccol_ind].sum()

c_bcost_value = bcost[crow_ind, ccol_ind].sum()

c_ccost_value = bcost[crow_ind, ccol_ind].sum()
c_cost_value = [c_acost_value, c_bcost_value, c_ccost_value]
total_cost_value = [np.array(a_cost_value) / max(a_cost_value), np.array(b_cost_value) / max(b_cost_value),
                    np.array(c_cost_value) / max(c_cost_value)]
total_cost_value = np.vstack(total_cost_value)
dis = np.std(total_cost_value - np.zeros(total_cost_value.shape), -1)
print(np.argmin(dis))
effective_combination_value = [1, 2, 3]
ef_dis_data = pd.DataFrame({"ef_count": effective_combination_value, "dis": dis})
print(ef_dis_data.sort_values(["ef_count","dis"],ascending=[False,True]).index.values[0])


总结

        简单的应用


  • 📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正!
  • 📢本文由东方佑原创,首发于 CSDN博客🙉
  • 📢停下休息的时候不要忘了别人还在奔跑,希望大家抓紧时间学习,全力奔赴更美好的生活✨


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/87375.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

直播倒计时 2 天 | SOFAChannel#31 RPC 框架设计的考和量

SOFARPC 是蚂蚁集团开源的一款基于 Java 实现的 RPC 服务框架,为应用之间提供远程服务调用能力,具有高可伸缩性,高容错性,目前蚂蚁集团所有的业务的相互间的 RPC 调用都是采用 SOFARPC。SOFARPC 为用户提供了负载均衡,…

Android -- 每日一问:回调函数和观察者模式的区别?

知识点 观察者模式 网上很容易查到观察者模式的定义: 观察者模式定义了对象间的一种一对多依赖关系,使得每当一个对象改变状态,则所有依赖于它的对象都会得到通知并被自动更新。 Android中大量的使用了观察者模式。你可能已经用过ListView…

基于51单片机的舞蹈机器人步进机仿真设计

程序运行图: 仿真原理图: 部分程序: #include "reg51.h" #include "intrins.H" //8步式步进电机脉冲序列 //unsigned char steps[8] {0x77,0x33,0xbb,0x99,0xdd,0xcc,0xee,0x66}; unsigned char steps[8] {0x2,0x…

Vue2快速入门

Vue 介绍 Vue 是一套构建用户界面的渐进式前端框架只关注视图层,并且非常容易学习,还可以很方便的与其它库或已有项目整合通过尽可能简单的API来实现响应数据的绑定和组合的视图组件特点易用:在有HTML CSS JavaScript的基础上,快速…

拓扑排序(数据结构之图的应用)

我们先搞清楚一个概念: 什么是出度与入度? 在有向图中,箭头是具有方向的,从一个顶点指向另一个顶点,这样一来,每个顶点被指向的箭头个数,就是它的入度。从这个顶点指出去的箭头个数&#xff0c…

不锈钢风淋室的使用需要注意哪些事项

风淋室的使用需要注意哪些事项 一、风淋室的操作说明: 1) 接通380V,50HZ电源(L1、L2、L3-火线,N-零线,E-接地线),打开工作、照明开关,确认风机与照明工作正常,此时,风/货淋室处于初…

原创 | Attention is all you need 论文解析(附代码)

作者:杨金珊审校:陈之炎本文约4300字,建议阅读8分钟“Attention is all you need”一文在注意力机制的使用方面取得了很大的进步,对Transformer模型做出了重大改进。目前NLP任务中的最著名模型(例如GPT-2或BERT&#x…

【数集项目之 MCDF】(四) 整形器 formatter

根据上一章的arbiter结构图,结合设计文档中MCDF的整体结构图,可以发现formatter整形器模块是arbiter的上级,负责最终的数据输出,与外界数据接收端相连。 第一节 fromatter文档理解 设计文档formatter的部分时序介绍如下 如图所示…

钡铼技术S274数据遥测终端机

钡铼技术S274数据遥测终端机功能特点: 内置 2 路 DC 直流电源输出,无需单独额外增加变送器的电源适配器,节省布线成本;  采用完备的防掉线机制,保证数据终端永远在线,掉线重发数据以及掉线短信通知用户…

第38篇 网络(八)TCP(二)

导语 在上一节里我们使用TCP服务器发送一个字符串,然后在TCP客户端进行接收。在这一节将重新写一个客户端程序和一个服务器程序,这次实现客户端进行文件的发送,服务器进行文件的接收。有了上一节的基础,这一节的内容就很好理解了…

postgresql_internals-14 学习笔记(三)冻结、rebuild

一、 Freezing 冻结 1. 引入原因 简单说来就是目前pg事务id只有32位,大业务量下很可能用完,触发事务id回卷(循环使用)。而pg是根据事务id大小判断可见性的,如果新事务却使用了小id,旧事务将可以看到新事务…

win下 conda 虚拟环境没有名字怎么进入

本文主要介绍windows下,在conda 虚拟环境名字消失后的解决办法。主要介绍两种解决方案。 文章目录前言解决方案一:往.condarc文件中添加envs_dirs1. 设置envs_dirs2. 重新查看虚拟环境解决方案二:直接通过path 激活虚拟环境总结前言 我们都知…

Grafana 监控大屏可视化图表

Grafana 系列文章,版本:OOS v9.3.1 Grafana 的介绍和安装Grafana监控大屏配置参数介绍(一)Grafana监控大屏配置参数介绍(二)Grafana监控大屏可视化图表 前面我们以Time series 图表为例,学习了面…

每天投递一两个公司,我连续投了三个月

作者:阿秀校招八股文学习网站:https://interviewguide.cn你好,我是阿秀。阿秀以前在秋招的时候投递过八九十份简历,当时还没有简历一键上传功能,很多时候都需要自己去那些公司注册账号,然后找到校园招聘模块…

手机备忘录误删恢复的操作方法

手机备忘录在使用的过程中,会有多种不同的操作,通过不同的操作来实现不同的效果。对于有的内容来说,是可以过期删除的,但是在删除这个操作的过程当中,如果不小心把有用的东西误删了,那么恢复误删内容的操作…

行内块元素因换行带来的间隔问题及解决方法

行内块元素因换行带来的间隔问题 先看一个案例所展示的行内块元素因换行带来的间隔问题,俺直接上截图 再来一张截图可以更加清楚地看见行内块元素之间因换行而带来的间隔 从上方所有图片可以看出,行内块元素之间一行并排放置时编译器中的换行操作会在浏览器渲染时带来行内块元…

鸡汤来了

这几天,网上铺天盖地都是各种感染新冠的消息,连我一直关注的和菜头也感染上了,关键是连怎么感染的都不知道。他写道:我也很委屈。自从北京开始比拼首阳之后,我的确是缩在家里,想着越晚感染越好。为了达到这…

基于STM32单片机和RFID的智能考勤系统设计

提示:记录2022年4月做的毕设 文章目录前言一、任务书1.1设计(研究)目标:1.2设计(研究)内容:二、思路三、硬件3.1RFID模块3.2 时钟模块四、联系我五、代码以及框图等资料喜欢请点赞哦!前言 基于STM32的考勤系统,主控使用STM32F103ZET6&#x…

代码随想录算法训练营第四十八天|198.打家劫舍、213.打家劫舍II、337.打家劫舍 III

198.打家劫舍 当前房屋偷与不偷取决于 前一个房屋和前两个房屋是否被偷了。 所以这里就更感觉到,当前状态和前面状态会有一种依赖关系,那么这种依赖关系都是动规的递推公式。 动规五部曲分析如下: 确定dp数组以及下标的含义 dp[i]&#xf…

华为的 HCIE 和 HCIP 的发展趋势如何

华为认证: 华为认证是华为基于“平台生态”战略,围绕“云-管-端”协同的新ICT技术架构,打造的业界覆盖ICT领域最广的认证体系,华为认证覆盖ICT领域,致力于提供领先的人才培养体系和认证标准,培养数字化时代…