利用【Python】【线性规划】优化工厂生产:实现智能资源配置与利润最大化的现代解决方案
目录
1. 问题背景和描述
1.1 问题背景
1.2 问题描述
2. 数学模型的建立
2.1决策变量
2.2 目标函数
2.3 约束条件
2.4 数学模型总结
3. 使用Python解决线性规划问题
3.1 导入必要的库
3.2 定义目标函数系数
3.3 定义不等式约束矩阵和向量
3.4 定义变量的边界
非负约束
变量边界在SciPy中的表示
3.5 求解线性规划问题
调用linprog函数
3.6 输出结果
获取和解释最优解
4. 结果解释和应用
4.1 结果解释
4.2 应用
4.3 验证结果
5. 扩展阅读
5.1 扩展阅读
5.2 线性规划的其他类型
编辑
代码
结果
总结
专栏:数学建模学习笔记
1. 问题背景和描述
1.1 问题背景
在现代制造业和商业运作中,资源的有效利用和利润的最大化是企业追求的重要目标。企业面临的常见问题是如何在有限的资源条件下,通过合理分配和优化使用资源,来实现利润的最大化。线性规划(Linear Programming,LP)是一种数学优化技术,能够在这些情况下发挥重要作用。它通过建立数学模型,帮助企业在众多可能的选择中找到最优解,进而指导实际操作。
假设有一家工厂,生产两种产品:产品A和产品B。每种产品的生产都需要消耗特定的资源。每天,每种资源的使用时间是有限的,这使得资源分配问题变得复杂。工厂的目标是通过合理分配资源,确定每天应该生产多少单位的产品A和产品B,以实现总利润的最大化。
具体数据如下:
- 资源1:每天最多可用60个小时
- 资源2:每天最多可用40个小时
- 产品A:每单位需要资源1的2个小时和资源2的1个小时
- 产品B:每单位需要资源1的1个小时和资源2的2个小时
- 产品A:每单位的利润为30美元
- 产品B:每单位的利润为20美元
通过对这些数据进行分析和建模,我们可以利用线性规划技术来制定一个优化的生产计划,确保在资源限制条件下实现利润的最大化。
1.2 问题描述
我们需要建立一个线性规划模型来描述上述问题,并使用该模型找到每天应该生产的产品A和产品B的最优数量,从而实现总利润的最大化。同时,生产过程中必须满足资源的限制条件,即不能超过每天可用的资源时间。
在这个问题中,我们的目标是构建一个数学模型,通过这个模型可以:
- 确定每天生产的产品A和产品B的数量。
- 满足资源的限制条件。
- 实现总利润的最大化。
2. 数学模型的建立
建立数学模型是解决线性规划问题的基础。我们将根据问题背景中的具体数据,定义决策变量,构建目标函数和约束条件。
2.1决策变量
决策变量是我们希望通过优化确定的数量。在这个问题中,决策变量是每天生产的产品A和产品B的数量。我们定义两个决策变量:
- x1:每天生产的产品A的单位数量
- x2:每天生产的产品B的单位数量
这些决策变量将用于构建目标函数和约束条件。
2.2 目标函数
目标函数是我们希望优化的表达式。在这个问题中,目标是最大化总利润。总利润可以表示为生产的产品A和产品B的利润之和。具体来说:
- 产品A每单位的利润为30美元
- 产品B每单位的利润为20美元
因此,总利润可以表示为: 利润=30x1+20x2
我们的目标是最大化总利润,因此目标函数可以表示为: 最大化 z=30x1+20x2
2.3 约束条件
约束条件是模型中必须满足的限制。在这个问题中,约束条件包括资源的限制和生产数量的非负性。
资源1的限制: 2*x1+x2≤60
资源2的限制:x1+2*x2≤40
非负约束:x1≥0 ,x2≥0
这些约束条件确保生产计划不会超过可用的资源,并且生产的数量是非负的,即实际可行的。
2.4 数学模型总结
综合以上信息,我们可以建立一个完整的线性规划模型来描述这个问题。模型的形式如下:
3. 使用Python解决线性规划问题
在建立了数学模型之后,我们可以使用Python中的SciPy库来求解这个线性规划问题。SciPy库提供了许多优化算法,其中linprog
函数可以用于求解线性规划问题。
3.1 导入必要的库
首先,我们需要导入必要的库:
import numpy as np
from scipy.optimize import linprog
3.2 定义目标函数系数
在求解问题时,SciPy的linprog
函数默认是用于最小化问题的。因此,我们需要将最大化问题转换为最小化问题。具体来说,我们可以将目标函数的系数取负。
目标函数的系数为:c=[−30,−20]
在Python中定义目标函数系数:
c = [-30, -20]
3.3 定义不等式约束矩阵和向量
在Python中,我们可以定义约束矩阵和向量如下:
A = [[2, 1], [1, 2]]
b = [60, 40]
这里,A
是一个二维数组,表示约束条件的系数矩阵,每一行对应一个不等式约束条件,每一列对应一个决策变量。b
是一个一维数组,表示每个约束条件的右端常数项。
- 矩阵 A:每一行代表一个约束条件,每一列代表一个决策变量。在我们的例子中,第一行 [2, 1] 表示第一个约束条件 2x1+x2≤60,第二行 [1, 2] 表示第二个约束条件x1+2x2≤40。
- 向量 b:每个元素表示一个约束条件的右端常数项。对于我们的例子,向量 b 中的元素分别是 60 和 40,对应两个约束条件的右端值。
3.4 定义变量的边界
在实际的生产问题中,变量的取值范围通常是有限制的。对于我们的例子,每天生产的产品数量不能为负,因此我们需要设置变量的边界条件。
非负约束
线性规划问题中的非负约束是指决策变量必须是非负数,即:
x1≥0 x2≥0
这些非负约束条件确保了我们的生产数量是合理的(即,不能生产负数的产品)。
变量边界在SciPy中的表示
在SciPy的linprog
函数中,变量的边界可以通过bounds
参数来指定。每个决策变量的边界条件可以用一个元组表示,元组的第一个元素是变量的下界,第二个元素是变量的上界。如果变量没有上界,可以用None
表示。
x_bounds = [(0, None), (0, None)]
这里,(0, None)
表示变量的下界是0,上界没有限制,即变量必须是非负的。
- 变量边界定义:我们用一个列表来表示每个变量的边界。列表中的每个元素是一个元组,元组的第一个元素表示变量的下界,第二个元素表示变量的上界。在我们的例子中,我们定义了两个变量 x1 和 x2,它们的边界条件都是非负的,因此我们用
(0, None)
来表示它们的边界。- 意义和应用:非负约束条件确保了我们的生产计划是现实可行的,因为生产的数量不能为负数。这在实际应用中是非常重要的,可以防止在优化过程中出现不合理的解。
3.5 求解线性规划问题
在定义了目标函数的系数、约束条件和变量的边界之后,我们可以使用SciPy的linprog
函数来求解这个线性规划问题。linprog
函数是SciPy库中用于求解线性规划问题的主要函数。
调用linprog函数
linprog
函数的基本调用方式如下:
res = linprog(c, A_ub=A, b_ub=b, bounds=x_bounds, method='highs')
其中:
c
:目标函数的系数向量A_ub
:不等式约束条件的系数矩阵b_ub
:不等式约束条件的右端常数项向量bounds
:变量的边界条件method
:求解方法,这里我们使用highs
方法,这是SciPy推荐的高效求解方法之一
- 目标函数的系数向量
c
:之前定义的目标函数的系数向量[-30, -20]
。注意这里我们将最大化问题转换为最小化问题,因此系数取负。- 不等式约束条件的系数矩阵
A_ub
:定义了每个约束条件的系数矩阵[[2, 1], [1, 2]]
。- 不等式约束条件的右端常数项向量
b_ub
:对应于不等式约束的右端常数项向量[60, 40]
。- 变量的边界条件
bounds
:定义了变量的取值范围,确保变量是非负的。- 求解方法
method
:指定使用highs
方法,这是SciPy中一个高效的线性规划求解器。
3.6 输出结果
在求解完成之后,我们需要输出结果。结果对象res
包含了优化的详细信息,包括最优解和最优目标函数值。
获取和解释最优解
最优解是指在满足所有约束条件的情况下,使目标函数达到最优值的决策变量值。在我们的例子中,最优解是每天应该生产的产品A和产品B的数量。
print('Optimal value:', round(res.fun * -1, ndigits=2)) # 恢复最大化问题的目标函数值
print('x:', res.x)
这里,res.fun
是最优目标函数值,因为我们最初将目标函数系数取了负,所以需要乘以-1来恢复最大化问题的目标函数值。res.x
是最优解,即最优的 x1 和 x2 的值。
4. 结果解释和应用
在得到线性规划问题的求解结果之后,我们需要对结果进行解释和应用。最优解和最优目标函数值对于实际的生产计划具有重要的指导意义。
4.1 结果解释
- 最优目标函数值:1400。这个值表示在满足所有资源约束的情况下,最大化的总利润为1400美元。
- 最优解:每天生产20个单位的产品A和10个单位的产品B。这是指在所有约束条件下能够使总利润最大化的最优生产计划。
4.2 应用
最优解对于工厂的生产计划具有重要的指导意义。通过按照最优解安排生产,工厂可以确保资源的有效利用,最大化利润。
具体来说,工厂应该每天生产20个单位的产品A和10个单位的产品B。这将使得总利润最大化,同时不超过每天可用的资源限制。通过这种方式,工厂可以实现资源的最佳配置,提高生产效率和经济效益。
4.3 验证结果
为了验证结果的正确性,我们可以检查最优解是否满足所有约束条件:
资源1的使用情况: 2×20+1×10=40+10=50≤60
资源2的使用情况: 1×20+2×10=20+20=40≤40
可以看到,最优解不仅最大化了总利润,而且满足所有约束条件。这表明我们的线性规划模型和求解过程是正确的,求解结果是合理的。
5. 扩展阅读
5.1 扩展阅读
线性规划问题在实际中有很多应用,如物流运输、生产计划、资源分配等。除了SciPy,其他常用的优化库还包括PuLP和Gurobi。
- PuLP:PuLP是一个开源的线性规划工具,可以与各种求解器结合使用。它提供了简单易用的接口,适合用于教学和简单的优化问题。
- Gurobi:Gurobi是一款高效的商业优化软件,支持求解线性规划、整数规划和其他优化问题。它具有强大的求解能力,适用于大规模和复杂的优化问题。
5.2 线性规划的其他类型
-
多目标优化:多目标优化考虑多个目标函数同时进行优化。例如,一个工厂可能希望在最大化利润的同时最小化污染物排放。多目标优化可以通过加权求和法或Pareto最优解来解决。
-
带有等式约束的线性规划:在约束条件中包含等式约束。例如,某些资源的使用量必须精确等于特定值。等式约束可以用于表示这些严格的资源限制或平衡条件。
-
混合整数线性规划:决策变量不仅包括连续变量,还包括整数变量。例如,在生产计划中,某些产品的生产数量必须为整数。混合整数线性规划可以通过将部分决策变量定义为整数来解决这些问题。
代码
import numpy as np
from scipy.optimize import linprog# 定义目标函数系数
# 我们希望最大化 30x1 + 20x2
# 在使用 linprog 时,我们需要将这个目标函数转化为最小化问题
# 因此我们取负,变为最小化 -30x1 - 20x2
c = [-30, -20]# 定义不等式约束矩阵和向量
# 不等式约束如下:
# 2x1 + x2 <= 60
# x1 + 2x2 <= 40
# 转化为矩阵形式 A @ x <= b
A = [[2, 1], [1, 2]]
b = [60, 40]# 定义变量的边界
# x1 >= 0
# x2 >= 0
x_bounds = [(0, None), (0, None)]# 使用 linprog 函数求解线性规划问题
res = linprog(c, A_ub=A, b_ub=b, bounds=x_bounds, method='highs')# 输出结果
print('Optimal value:', round(res.fun * -1, ndigits=2)) # 恢复最大化问题的目标函数值
print('x:', res.x)# 结果解释
# 最优目标函数值
optimal_value = round(res.fun * -1, ndigits=2)
# 最优解
optimal_solution = res.xprint(f"在满足资源约束的情况下,最大化的总利润为:{optimal_value} 美元")
print(f"每天生产 {optimal_solution[0]} 个单位的产品A 和 {optimal_solution[1]} 个单位的产品B")# 验证结果是否满足所有约束条件
# 资源1的使用情况
resource1_usage = 2 * optimal_solution[0] + optimal_solution[1]
# 资源2的使用情况
resource2_usage = optimal_solution[0] + 2 * optimal_solution[1]print(f"资源1的使用情况:{resource1_usage} 小时(<= 60 小时)")
print(f"资源2的使用情况:{resource2_usage} 小时(<= 40 小时)")# 验证是否满足所有约束条件
if resource1_usage <= 60 and resource2_usage <= 40:print("最优解满足所有约束条件。")
else:print("最优解不满足所有约束条件。")
结果
总结
建立线性规划模型,以解决生产优化问题。通过定义决策变量、目标函数和约束条件,使用Python的SciPy库中的linprog
函数求解模型,并验证结果的合理性。最终,确定了在资源限制条件下最大化利润的最优生产方案.
相关文章:

利用【Python】【线性规划】优化工厂生产:实现智能资源配置与利润最大化的现代解决方案
目录 1. 问题背景和描述 1.1 问题背景 1.2 问题描述 2. 数学模型的建立 2.1决策变量 2.2 目标函数 2.3 约束条件 2.4 数学模型总结 3. 使用Python解决线性规划问题 3.1 导入必要的库 3.2 定义目标函数系数 3.3 定义不等式约束矩阵和向量 3.4 定义变量的边界 非负…...

【spark】Exception in thread “main“ ExitCodeException exitCode=-1073741701
在window上运行spark程序写到本地文件的时候报错。 val rdd sc.sparkContext.parallelize(list)val arr rdd.collect()arr.foreach(println)rdd.saveAsTextFile("test1")sc.close()错误信息: zhangsan lisi wangwu Exception in thread "main" ExitCode…...

数学建模美赛经验小结
图片资料来自网络所听讲座,感谢分享!...
206. 反转链表 (Swift 版本)
题目 给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。 解题 /*** Definition for singly-linked list.* public class ListNode {* public var val: Int* public var next: ListNode?* public init() { self.val 0; self.…...

海狐外卖O2O商城系统:技术架构与运营模式的深度解析
摘要: 本文深入探讨了海狐外卖O2O商城系统的技术架构、功能特性以及运营模式。海狐外卖作为一款专注于细分市场领域的外卖餐饮解决方案,不仅拥有先进的技术栈支持,还通过丰富的系统插件和灵活的运营模式,为商户和用户提供高效、便…...

14-31 剑和诗人5 - 使用 AirLLM 和分层推理在单个 4GB GPU 上运行 LLama 3 70B
利用分层推理实现大模型语言(LLM) 大型语言模型 (LLM) 领域最近取得了显著进展,LLaMa 3 70B 等模型突破了之前认为可能实现的极限。然而,这些模型的庞大规模给其部署和实际使用带来了巨大挑战,尤其是在资源受限的设备上,例如内存…...
风景园林工程设计乙级资质业绩要求案例分析
项目数量与规模 数量要求:企业需要提供一定数量的已完成风景园林设计项目案例,这个数量可能依据具体政策而有所不同,但通常需要完成多个项目以展示设计团队的综合能力。 规模要求:项目规模需达到乙级资质标准所规定的级别&#…...

无人机之飞行规划与管理篇
无人机飞行规划与管理是确保无人机安全、高效且符合法规的运行的关键步骤。这一过程包括了对飞行任务的详细安排、航线的设定以及风险的评估和管理。下面简述这一过程的主要环节: 一、飞行目的和任务确定 在规划之初,必须明确无人机的飞行目的…...

realsense D435l+mid360标定
目录 一、安装realsense环境 二、获取realsense D450L相机内参 三、标定雷达和相机 1.下载livox_camera_calib 2.修改配置参数 3.使用fastlio生成点云 4.标定 一、安装realsense环境 git clone https://github.com/IntelRealSense/librealsense.git cd librealsense //更…...
深度学习中的正则化技术 - 数据集增强篇
序言 在机器学习与深度学习的广阔领域中,数据集的质量与规模往往是决定模型性能的关键因素之一。然而,现实世界中高质量、标注完善的数据集往往稀缺且获取成本高昂,这成为了制约算法进步的一大瓶颈。为了缓解这一问题,数据集增强…...

【Docker系列】Docker 镜像源:优化你的容器化开发流程
💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…...

【Linux】Windows环境下配置虚拟机静态IP
当前我们虚拟机的Linux操作系统,其IP地址是通过DHCP服务获取的。 DHCP:动态获取IP地址,即每闪重启设备后都会获取一次,可能导致IP地址频繁变更 原因1:办公电脑IP地址变化无所谓,但是我们要远程连接到Linux系统&#x…...

完美解决AttributeError: ‘list‘ object has no attribute ‘shape‘的正确解决方法,亲测有效!!!
完美解决AttributeError: ‘list‘ object has no attribute ‘shape‘的正确解决方法,亲测有效!!! 亲测有效 完美解决AttributeError: ‘list‘ object has no attribute ‘shape‘的正确解决方法,亲测有效࿰…...

链接服务器“XX”的OLEDB访问接口“MSOLEDBSQL”返回了消息“登录超时已过期” 解决方法
目录 1. 问题所示2. 原理分析3. 解决方法1. 问题所示 出现如下问题: 与链接服务器的测试连接失败。执行Transact-SQL 语句或批处理时发生了异常。命名管道提供程序:无法打开与SQL SERVER的链接[53]链接服务器“XX”的OLEDB访问接口“MSOLEDBSQL”返回了消息“登录超时已过期…...
【AI伦理与社会责任】讨论人工智能在隐私保护、偏见消除、自动化对就业的影响等伦理和社会问题。
人工智能(AI)作为第四次产业革命的核心技术,在推动社会进步和经济发展的同时,也引发了一系列伦理和社会问题。以下从隐私保护、偏见消除以及自动化对就业的影响三个方面进行详细讨论。 一、隐私保护 人工智能技术的广泛应用涉及…...
Qt编程技巧小知识点(1)TCP缓存区数据读取
文章目录 Qt编程技巧小知识点(1)TCP缓存区数据读取小结 Qt编程技巧小知识点(1)TCP缓存区数据读取 TCP的socket对内存进行读取(使用socket->readall())的时候输出的内容有时会进行局部倒置,其…...

vue 搭建 pinia
文章目录 环境设置存储读取数据【 storeToRefs】借助storeToRefs将store中的数据转为ref对象,方便在模板中使用【getters】当state中的数据,需要经过处理后再使用时,可以使用getters配置【$subscribe】通过 store 的 $subscribe() 方法侦听 s…...
什么是CLR
CLR,全称为Common Language Runtime,即公共语言运行时,是微软为.NET产品构建的运行环境,与Java的JVM(Java虚拟机)类似,可以看作是.NET的虚拟机。CLR的主要作用和特点如下: 主要作用…...
Spring MVC -01
Spring 的 MVC 框架 Spring的MVC框架是Spring框架的一部分,它提供了用于开发Web应用程序的一组组件和设计模式。MVC是Model-View-Controller的缩写,是一种设计模式,用于将应用程序的逻辑与用户界面分离。 在Spring的MVC框架中,Mo…...
山海鲸可视化——天地图画面和热力图
山海鲸引入天地图目前只有 iframe 的方式引入 首先我们创建一个文件夹 ——index.html ——index.js ——data.js 大家都是大佬,我就不详细介绍了,上代码都能看得懂 首先是index.html <!DOCTYPE html> <html lang"zh-CN"> <…...

Linux相关概念和易错知识点(42)(TCP的连接管理、可靠性、面临复杂网络的处理)
目录 1.TCP的连接管理机制(1)三次握手①握手过程②对握手过程的理解 (2)四次挥手(3)握手和挥手的触发(4)状态切换①挥手过程中状态的切换②握手过程中状态的切换 2.TCP的可靠性&…...

页面渲染流程与性能优化
页面渲染流程与性能优化详解(完整版) 一、现代浏览器渲染流程(详细说明) 1. 构建DOM树 浏览器接收到HTML文档后,会逐步解析并构建DOM(Document Object Model)树。具体过程如下: (…...

Mac软件卸载指南,简单易懂!
刚和Adobe分手,它却总在Library里给你写"回忆录"?卸载的Final Cut Pro像电子幽灵般阴魂不散?总是会有残留文件,别慌!这份Mac软件卸载指南,将用最硬核的方式教你"数字分手术"࿰…...
Linux云原生安全:零信任架构与机密计算
Linux云原生安全:零信任架构与机密计算 构建坚不可摧的云原生防御体系 引言:云原生安全的范式革命 随着云原生技术的普及,安全边界正在从传统的网络边界向工作负载内部转移。Gartner预测,到2025年,零信任架构将成为超…...

IT供电系统绝缘监测及故障定位解决方案
随着新能源的快速发展,光伏电站、储能系统及充电设备已广泛应用于现代能源网络。在光伏领域,IT供电系统凭借其持续供电性好、安全性高等优势成为光伏首选,但在长期运行中,例如老化、潮湿、隐裂、机械损伤等问题会影响光伏板绝缘层…...

Map相关知识
数据结构 二叉树 二叉树,顾名思义,每个节点最多有两个“叉”,也就是两个子节点,分别是左子 节点和右子节点。不过,二叉树并不要求每个节点都有两个子节点,有的节点只 有左子节点,有的节点只有…...

初学 pytest 记录
安装 pip install pytest用例可以是函数也可以是类中的方法 def test_func():print()class TestAdd: # def __init__(self): 在 pytest 中不可以使用__init__方法 # self.cc 12345 pytest.mark.api def test_str(self):res add(1, 2)assert res 12def test_int(self):r…...
Mysql8 忘记密码重置,以及问题解决
1.使用免密登录 找到配置MySQL文件,我的文件路径是/etc/mysql/my.cnf,有的人的是/etc/mysql/mysql.cnf 在里最后加入 skip-grant-tables重启MySQL服务 service mysql restartShutting down MySQL… SUCCESS! Starting MySQL… SUCCESS! 重启成功 2.登…...

DingDing机器人群消息推送
文章目录 1 新建机器人2 API文档说明3 代码编写 1 新建机器人 点击群设置 下滑到群管理的机器人,点击进入 添加机器人 选择自定义Webhook服务 点击添加 设置安全设置,详见说明文档 成功后,记录Webhook 2 API文档说明 点击设置说明 查看自…...

C# 表达式和运算符(求值顺序)
求值顺序 表达式可以由许多嵌套的子表达式构成。子表达式的求值顺序可以使表达式的最终值发生 变化。 例如,已知表达式3*52,依照子表达式的求值顺序,有两种可能的结果,如图9-3所示。 如果乘法先执行,结果是17。如果5…...