【优化数学模型】1. 基于Python的线性规划问题求解

在这里插入图片描述

【优化数学模型】1. 基于Python的线性规划问题求解

  • 一、线性规划问题
    • 1.概述
    • 2.三要素
  • 二、示例:药厂生产问题
  • 三、使用 Python 绘图求解线性规划问题
    • 1.绘制约束条件
    • 2.绘制可行域
    • 3.绘制目标函数
    • 4.绘制最优解
  • 四、使用 scipy.optimize 软件包求解线性规划问题
    • 1.导入库
    • 2.输入目标函数参数和约束条件
    • 3.求解
  • 参考文献


一、线性规划问题

1.概述

线性规划(Linear Programming, LP) 是解决最优化问题的工具之一,也是运筹学的重要分支。

运筹学(Operations Research) 是一门研究人类对各种广义资源的运用及筹划活动的新兴学科,其目的在于了解和发现这种运用及筹划活动的基本规律,以便更有效发挥有限资源的效益,从而达到总体或全局有效或平衡的目标。

1947年,美国数学家G.B.Dantzig及其同事提出了求解线性规划的单纯形法及其有关理论,为线性规划这一学科的建立奠定了理论基础。1979年苏联数学家哈奇扬的椭球算法和1984年美籍印度数学家H.Karmarkar算法的相继问世,使得线性规划的理论更加完备、成熟,实用领域更加宽广。

线性规划涉及的实际问题多种多样,包括生产计划问题、物资运输问题、合理下料问题、库存问题、劳动力问题、最优设计问题等,这些问题虽然出自不同的行业,有着不同的实际背景,但都是属于如何计划、安排、调度的问题,即如何物尽其用、人尽其才的问题。

2.三要素

最优化问题往往具有三个基本要素,即决策变量、目标函数和约束条件,也被称为优化模型的三要素。

  1. 决策变量:是决策者可以控制的因素,在规划模型中,用一组决策变量来表示某一方案或措施,即描述所要做出的决策,可由决策者决定和控制。例如根据不同的实际问题,决策变量可以选为药品或器械的产量、医疗物资的运量及工作的天数等。
  2. 目标函数:是以函数形式来表示决策者追求的目标,表示决策者希望实现的目标。按问题的不同,要求目标函数实现最大化或最小化,在前面加上max或min来表示,目标函数也是衡量方案优劣的标准。例如目标可以是利润最大或成本最小等。对于线性规划,目标函数要求是线性的。
  3. 约束条件:是决策变量需要满足的限定条件,通常表示为一组含有决策变量的等式或不等式,是决策方案可行的保障。对于线性规划,约束条件是一组线性等式或不等式。

二、示例:药厂生产问题

假设一家药厂可以生产两种药品,称为“药品A”和“药品B”。

生产每种药品都需要材料和劳动力。销售每种药品都会产生收入。

所需单位材料和劳动力投入,以及收入如下表所示:

药品A药品B
材料25
劳动42
收入34

一家药厂药构建一个生产计划,使用 30 个单位的材料和 20 个单位的劳动力,以使其收入最大化。该问题可以表述为:

  max ⁡ x 1 , x 2 z = 3 x 1 + 4 x 2  subject to  2 x 1 + 5 x 2 ≤ 30 4 x 1 + 2 x 2 ≤ 20 x 1 , x 2 ≥ 0 \begin{array}{cl}\ \max _{x_1, x_2} & z=3 x_1+4 x_2 \\ \text { subject to } & 2 x_1+5 x_2 \leq 30 \\ & 4 x_1+2 x_2 \leq 20 \\ & x_1, x_2 \geq 0\end{array}  maxx1,x2 subject to z=3x1+4x22x1+5x2304x1+2x220x1,x20

三、使用 Python 绘图求解线性规划问题

1.绘制约束条件

fig, ax = plt.subplots(figsize=(8, 6))
ax.grid()

ax.hlines(0, -1, 17.5)
ax.vlines(0, -1, 12)
ax.plot(np.linspace(-1, 17.5, 100), 6-0.4*np.linspace(-1, 17.5, 100), color="c")
ax.plot(np.linspace(-1, 5.5, 100), 10-2*np.linspace(-1, 5.5, 100), color="c")
ax.text(1.5, 8, "$2x_1 + 5x_2 \leq 30$", size=12)
ax.text(10, 2.5, "$4x_1 + 2x_2 \leq 20$", size=12)
ax.text(-2, 2, "$x_2 \geq 0$", size=12)
ax.text(2.5, -0.7, "$x_1 \geq 0$", size=12)

2.绘制可行域

feasible_set = Polygon(np.array([[0, 0],
                                 [0, 6],
                                 [2.5, 5],
                                 [5, 0]]),
                       color="cyan")
ax.add_patch(feasible_set)

3.绘制目标函数

ax.plot(np.linspace(-1, 5.5, 100), 3.875-0.75*np.linspace(-1, 5.5, 100), color="orange")
ax.plot(np.linspace(-1, 5.5, 100), 5.375-0.75*np.linspace(-1, 5.5, 100), color="orange")
ax.plot(np.linspace(-1, 5.5, 100), 6.875-0.75*np.linspace(-1, 5.5, 100), color="orange")
ax.arrow(-1.6, 5, 0, 2, width = 0.05, head_width=0.2, head_length=0.5, color="orange")
ax.text(5.7, 1, "$z = 3x_1 + 4x_2$", size=12)

4.绘制最优解

ax.plot(2.5, 5, "*", color="black")
ax.text(2.7, 5.2, "Optimal Solution", size=12)

plt.show()

绘制图像如下:

在这里插入图片描述

  • 其中,蓝色区域是满足所有约束条件的可行域。
  • 平行的橙色线是收入线。
  • 药厂的目标即找到平行的橙色线以达到可行域的上边界。
  • 可行域与最高橙色线的交点就是最优集合。在此示例中,最优集合是点 。

四、使用 scipy.optimize 软件包求解线性规划问题

scipy.optimize 软件包提供了 linprog 函数来求解线性规划问题,形式如下:

min ⁡ x c ′ x  subject to  A u b x ≤ b u b A e q x = b e q l ≤ x ≤ u \begin{array}{cl} \min _x & c^{\prime} x \\ \text { subject to } & A_{u b} x \leq b_{u b} \\ & A_{e q} x=b_{e q} \\ & l \leq x \leq u \end{array} minx subject to cxAubxbubAeqx=beqlxu

原示例可转化为以下等同的标准形式:

min ⁡ x 1 , x 2 − ( 3 x 1 + 4 x 2 )  subject to  2 x 1 + 5 x 2 + s 1 = 30 4 x 1 + 2 x 2 + s 2 = 20 x 1 , x 2 , s 1 , s 2 ≥ 0 \begin{aligned} \min _{x_1, x_2} & -\left(3 x_1+4 x_2\right) \\ \text { subject to } & 2 x_1+5 x_2+s_1=30 \\ & 4 x_1+2 x_2+s_2=20 \\ & x_1, x_2, s_1, s_2 \geq 0 \end{aligned} x1,x2min subject to (3x1+4x2)2x1+5x2+s1=304x1+2x2+s2=20x1,x2,s1,s20

1.导入库

import numpy as np
from scipy.optimize import linprog
import matplotlib.pyplot as plt
from matplotlib.patches import Polygon

2.输入目标函数参数和约束条件

  • 对于每个不等式约束,生成一个松弛变量。
  • 松弛变量的向量是一个二维 NumPy 数组。
# 目标函数参数
c_ex1 = np.array([3, 4])

# 约束条件
A_ex1 = np.array([[2, 5],
                  [4, 2]])
b_ex1 = np.array([30,20])

3.求解

# 求解
res_ex1 = linprog(-c_ex1, A_ub=A_ex1, b_ub=b_ex1)

res_ex1

输出结果如下:

        message: Optimization terminated successfully. (HiGHS Status 7: Optimal)
        success: True
         status: 0
            fun: -27.5
              x: [ 2.500e+00  5.000e+00]
            nit: 2
          lower:  residual: [ 2.500e+00  5.000e+00]
                 marginals: [ 0.000e+00  0.000e+00]
          upper:  residual: [       inf        inf]
                 marginals: [ 0.000e+00  0.000e+00]
          eqlin:  residual: []
                 marginals: []
        ineqlin:  residual: [ 0.000e+00  0.000e+00]
                 marginals: [-6.250e-01 -4.375e-01]
 mip_node_count: 0
 mip_dual_bound: 0.0
        mip_gap: 0.0

最优方案为:药厂生产 2.5 个单位的药品A 和 5 个单位的药品B,这产生了 27.5 的最大收入值。


参考文献

  1. https://scipy.org/
  2. J. N. Bertsimas, D. & Tsitsiklis. Introduction to linear optimization. Athena Scientific, 1997.

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

springboot742餐厅点餐系统

springboot742餐厅点餐系统 获取源码——》公主号:计算机专业毕设大全

面试前的准备

面试前的准备 Java程序员校招与社招的区别 校招和社招都是企业招聘形式的一种,只是面向的对象不同。校招 只允许在校生参加,社招理论上是任何人都能参加的(包括在校生)。 但是,无论是社招还是校招,它的难度都取决于你的水平高低。…

【Win10 触摸板】在插入鼠标时禁用触摸板,并在没有鼠标时自动启用触摸板。取消勾选连接鼠标时让触摸板保持打开状态,但拔掉鼠标后触摸板依旧不能使用

出现这种问题我的第一反应就是触摸板坏了,但是无意间我换了一个账户发现触摸板可以用,因此推断触摸板没有坏,是之前的账户问题,跟系统也没有关系,不需要重装系统。 解决办法:与鼠标虚拟设备有关 然后又从知…

Redis笔记

Redis(Remote Dictionary Server)是一种非关系型数据库 Redis 与其他 key - value 缓存产品有以下三个特点: Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。Redis不仅仅…

C# Winform .net6自绘的圆形进度条

using System; using System.Drawing; using System.Drawing.Drawing2D; using System.Windows.Forms;namespace Net6_GeneralUiWinFrm {public class CircularProgressBar : Control{private int progress 0;private int borderWidth 20; // 增加的边框宽度public int Progr…

Qt:槽函数的五种写法

一、Qt4写法(不推荐) connect(ui.btnOpen,SIGNAL(clicked),this,SLOT( open() ) );因为是以宏定义的方式展开,所以如果SIGNAL写错,或者信号名字、槽函数写错、编译器是无法检验出来的,导致出现隐性BUG,不容…

SpringBoot+Vue3 完成小红书项目

简介 该项目采用微服务架构,实现了前后端分离的系统设计。在前端,我们选择了 Vue3 配合 TypeScript 和 ElementUi 框架,以提升开发效率和用户体验。而在后端,则是运用 SpringBoot 和 Mybatis-plus 进行开发,保证了系统…

JVM(2)实战篇

1 内存调优 1.1 内存溢出和内存泄漏 内存泄漏(memory leak):在Java中如果不再使用一个对象,但是该对象依然在GC ROOT的引用链上,这个对象就不会被垃圾回收器回收,这种情况就称之为内存泄漏。 内存泄漏绝…

从汇编角度解释线程间互斥-mutex互斥锁与lock_guard的使用

多线程并发的竞态问题 我们创建三个线程同时进行购票&#xff0c;代码如下 #include<iostream> #include<thread> #include<list> using namespace std; //总票数 int ticketCount100; //售票线程 void sellTicket(int idx) {while(ticketCount>0){cou…

Pycharm里如何设置多Python文件并行运行

点击上方“Python爬虫与数据挖掘”&#xff0c;进行关注 回复“书籍”即可获赠Python从入门到进阶共10本电子书 今 日 鸡 汤 夕阳何事近黄昏&#xff0c;不道人间犹有未招魂。 大家好&#xff0c;我是皮皮。 一、前言 相信使用Pycharm的粉丝们肯定有和我一样的想法&#xff0c;…

Matplotlib自定义辅助函数 (一):让你的图表大放异彩!

Matplotlib美化秘诀&#xff1a;自定义辅助函数&#xff0c;让你的图表大放异彩&#xff01; 利用Matplotlib进行数据可视化示例 &#x1f335;文章目录&#x1f335; &#x1f333;一、创建自定义样式函数&#x1f333;&#x1f333;二、创建自定义颜色映射&#x1f333;&…

预处理详解(下)

1.#运算符 #运算符将宏的一个参数转换为字符串字面量。它仅允许出现在带参数的宏的替换列表中。 #运算符所执行的操作可以理解为”字符串化“。 例如&#xff1a; 我们将打印的字符串中的n改为参数n,这样在传参的时候就也会随着变化。假如我们不将其改为参数n的话会发生什么呢…

黑马Java——异常、File、综合案例

一、异常 误区&#xff1a;不是让我们以后不出异常&#xff0c;而是出现异常了之后&#xff0c;如何去处理 1、异常的分类 1.1、Error 1.2、Exception 1.3、小结 2、编译时异常和运行时异常 2.1、编译时异常 2.2、运行时异常 2.3、为什么异常要分成编译时异常和运行时异常&…

随机过程及应用学习笔记(三)几种重要的随机过程

介绍独立过程和独立增量过程。重点介绍两种独立增量过程-—维纳过程和泊松过程。 目录 前言 一、独立过程和独立增量过程 1、独立过程&#xff08;Independent Process&#xff09; 2、独立增量过程&#xff08;Independent Increment Process&#xff09; 二、正态过程&am…

【c++】构造函数(上)

Hello everybody!今天我们来聊一聊构造函数的用法和一些基本性质。内容比较多&#xff0c;我打算分两篇文章讲完&#xff01; 希望大家在看完我的文章后能够有所收获&#xff01; 1.构造函数的定义 构造函数是特殊的成员函数&#xff0c;需要注意的是&#xff0c;构造函数虽然…

Editable Scene Simulation for Autonomous Driving via Collaborative LLM-Agents

ChatSim&#xff1a;首个通过大语言模型实现可编辑逼真3D驾驶场景的仿真 论文链接&#xff1a;https://arxiv.org/pdf/2402.05746.pdf 代码链接&#xff1a;https://github.com/yifanlu0227/ChatSim 1. 摘要&#xff08;Abstract&#xff09; 自动驾驶中的场景仿真因其生成定制…

【前端高频面试题--git篇】

&#x1f680; 作者 &#xff1a;“码上有前” &#x1f680; 文章简介 &#xff1a;前端高频面试题 &#x1f680; 欢迎小伙伴们 点赞&#x1f44d;、收藏⭐、留言&#x1f4ac; 前端高频面试题--git篇 常用命令git add 和 git stage 有什么区别怎么使用git连接到远程仓库git…

.target勒索病毒解密方法|勒索病毒解决|勒索病毒恢复|数据库修复

导言&#xff1a; 网络安全威胁如勒索病毒已经成为企业和个人数据安全的重大挑战之一。.target勒索病毒作为其中的一种&#xff0c;以其高度复杂的加密算法和迅速变化的攻击手法备受关注。本文将深入介绍.target勒索病毒的特点&#xff0c;探讨如何有效地恢复被加密的数据文件…

【复现】某某ERP 信息泄露漏洞_49

目录 一.概述 二 .漏洞影响 三.漏洞复现 1. 漏洞一&#xff1a; 四.修复建议&#xff1a; 五. 搜索语法&#xff1a; 六.免责声明 一.概述 该ERP基于SpringBoot框架和SaaS模式&#xff0c;立志为中小企业提供开源好用的ERP软件&#xff0c;目前专注进销存财务生产功能。…

模拟电子技术——基本放大电路

文章目录 前言一、三极管输入输出特性三极管放大作用三极管电流放大关系三极管的特性曲线 二、基本放大电路-电路结构与工作原理基本放大电路的构成基本放大电路放大原理三种基本放大电路比较 三、基本放大电路静态工作点什么是静态工作点&#xff1f;静态工作点的作用估算法分…