广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Python+PuLP怎么实现线性规划
  • 759
分享到

Python+PuLP怎么实现线性规划

2023-06-30 10:06:08 759人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

今天小编给大家分享一下python+PuLP怎么实现线性规划的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1.PuLP 库的

今天小编给大家分享一下python+PuLP怎么实现线性规划的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

1.PuLP 库的安装

如果您使用的是 Anaconda的话(事实上我也更推荐这样做),需要先激活你想要安装的虚拟环境,之后在 Prompt 输入

pip install pulp

不出意外的话等一会就安装完毕。

2.线性规划简介

想必大家能点开这篇文章一定都知道线性规划是什么意思吧……那么我用两个例子再简单说一下。

2.1 线性规划

2.1.1 题目描述

若变量x,y 满足约束条件:

Python+PuLP怎么实现线性规划

求z=3x+y 的最大值。

2.1.2 基本概念

首先,我们要认清在这道题中,x和y是可以变的,所以把它们叫做决策变量。三个不等式叫做约束条件,即x和y必须同时满足这三个不等式。我们若画出图来:

Python+PuLP怎么实现线性规划

其中不满足约束条件的区域被我标上了颜色,所以x,y 可以取得值只能在纯白区域内,这一片区域称作可行域

再看最后的我们的目标:求z=x+3y 的最大值。

于是z=x+3y 就被称作目标函数,我们的工作就是求这个目标函数的最大值。

整个问题描述为:

Python+PuLP怎么实现线性规划

然后怎么算?别急我们再看一个例子。

2.2 整数规划

2.2.1 题目描述

汽车厂生产小、中、大三种类型的汽车,已知各类型每辆车对钢材、劳动时间的需求以及利润如下表所示。要求每月的钢材消耗不超过 600 t,总劳动时间不超过 60 000 h。试指定生产计划使得工厂每月的利润最大。

 小型车中型车大型车
钢材 / t1.535
劳动时间 / h280250400
利润 / 万元234

2.2.2 解题思路

首先,设三个决策变量,用x1,x2,x3 分别表示生产小型车、中型车、大型车的数量,但是注意要满足:

  • 车的数量只能是整数

  • 车的数量大于等于 0。

其他约束条件看题直接列:

Python+PuLP怎么实现线性规划

最后写出目标函数

z=2x1+3x2+4x3

综合起来整个问题描述为:

Python+PuLP怎么实现线性规划

另外可以看出这个题由于涉及到三个决策变量,可行域是相当抽象的,这里就不画了 hhh~

3.求解过程

首先在最前面引入所需的pulp工具库:

import pulp as pl

这句话是引入 pulp 库并简写为 pl,一个 Python 库只有在开始 import 了之后才能在后面使用。这样后面凡是用到 pulp 的功能都要写成 pl.xxx

接下来是以下几个步骤:

  • 定义模型

  • 定义决策变量

  • 添加约束条件

  • 添加目标函数

  • 模型求解

  • 打印结果

3.1 定义模型

# Define the modelmodel = pl.LpProblem(name="My-Model", sense=pl.LpMaximize)

这个操作是使用 pl.LpProblem 创建了一个模型并赋值给变量 model,接收两个参数:

  • name:模型的名字,随便起一个;

  • sense:模型的类型,pl.LpMinimize是求目标函数的最小值,pl.LpMaximize 是求最大值

3.2 定义决策变量

# Define the decision variablesx = pl.LpVariable(name='x')y = pl.LpVariable(name='y')

如果你的变量比较少的话可以简单这么写。这个意思是定义了两个浮点数变量,取值范围是整个实数域。注意等号左边的变量才是你在之后的计算式中使用的符号,而参数 name 只有在最后打印结果的时候才会被打印出来。另外如果你对变量有其他要求的话可以添加以下参数:

  • lowBound:变量的最小取值(不写的话默认负无穷);

  • upBound:变量的最大取值(默认正无穷);

  • cat:变量的类型,有 pl.Binary 逻辑变量、pl.Integer 整数、pl.Continuous 实数(默认值);

如果你的变量比较多而不得不用 1, 2, 3…… 来编号,可以采用类似这样的写法:

# Define the decision variablesx = {i: pl.LpVariable(name=f"x{i}", lowBound=0, cat=pl.LpInteger) for i in range(1, 9)}

这是一次定义 8 个变量并保存在一个类似数组的结构中,变量都是正整数,分别用 x[1],x[2], ..., x[8] 表示,依次命名为 x1, x2,..., x8。

注意 range(left, right) 表示的区间是左闭右开。

3.3 添加约束条件

# Add constraintsmodel += (2 * x + 3 * y - 6 >= 0, "constrain_1")model += (x + 3 * y - 3 == 0, "constrain_2")

没错!如你所见就是这么简单,括号里第一个变量就是你的约束不等式等式,第二个变量是你的自定义的约束名(可以起一个有意义的名字,当然也可以省略)。

由于一些比较数学的原因,约束条件里是不能使用大于号“>”或小于号“<”的。

如果你像前面一样把变量定义在了数组中,那么可以直接用方括号调用:

model += (2 * x[1] + 3 * x[2] - 6 >= 0)

3.4 添加目标函数

# Set the objectivemodel += x + 3 * y

与前面添加约束条件不同,添加目标函数这一步不用加最外层的括号。

3.5 模型求解

# Solve the optimization problemstatus = model.solve()

就写这一句话,调用 model 的 solve() 方法,并把结果保存在 status 中。

3.6 打印结果

# Get the resultsprint(f"status: {model.status}, {pl.LpStatus[model.status]}")print(f"objective: {model.objective.value()}")for var in model.variables():    print(f"{var.name}: {var.value()}")for name, constraint in model.constraints.items():    print(f"{name}: {constraint.value()}")

然后你就能看到模型求解的结果了。

4.示例代码

4.1 高考题代码

首先解决一下 3.1 的高考题:

import pulp as pl# 定义一个模型,命名为 "Model_3.1",求最大值model = pl.LpProblem(name="Model_3.1", sense=pl.LpMaximize)# 定义两个决策变量,取值为整个实数域x = pl.LpVariable(name='x')y = pl.LpVariable(name='y')# 添加三个约束条件model += (2 * x + 3 * y - 6 >= 0)model += (x + y - 3 <= 0)model += (y - 2 <= 0)# 目标函数model += x + 3 * y# 求解status = model.solve()# 打印结果print(f"status: {model.status}, {pl.LpStatus[model.status]}")print(f"objective: {model.objective.value()}")for var in model.variables():    print(f"{var.name}: {var.value()}")for name, constraint in model.constraints.items():    print(f"{name}: {constraint.value()}")

查看结果的最后几行:

status: 1, Optimal
objective: 7.0
x: 1.0
y: 2.0
_C1: 2.0
_C2: 0.0
_C3: 0.0

最大值是7.0,在x=1.0,y=2.0 时取到。

4.2 汽车厂代码

import pulp as pl# 定义一个模型,命名为 "Model_3.2",求最大值model = pl.LpProblem(name="Model_3.2", sense=pl.LpMaximize)# 定义三个决策变量,取值正整数x = {i: pl.LpVariable(name=f"x{i}", lowBound=0, cat=pl.LpInteger) for i in range(1, 4)}# 添加约束条件model += (1.5 * x[1] + 3 * x[2] + 5 * x[3] <= 600)model += (280 * x[1] + 250 * x[2] + 400 * x[3] <= 60000)# 目标函数model += 2 * x[1] + 3 * x[2] + 4 * x[3]# 求解status = model.solve()# 打印结果print(f"status: {model.status}, {pl.LpStatus[model.status]}")print(f"objective: {model.objective.value()}")for var in model.variables():    print(f"{var.name}: {var.value()}")for name, constraint in model.constraints.items():    print(f"{name}: {constraint.value()}")

查看结果的最后几行:

status: 1, Optimal
objective: 632.0
x1: 64.0
x2: 168.0
x3: 0.0
_C1: 0.0
_C2: -80.0

三种车的产量分别取 64、168、0,最大收益 632 万元。

以上就是“Python+PuLP怎么实现线性规划”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网Python频道。

--结束END--

本文标题: Python+PuLP怎么实现线性规划

本文链接: https://www.lsjlt.com/news/328259.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Python+PuLP怎么实现线性规划
    今天小编给大家分享一下Python+PuLP怎么实现线性规划的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1.PuLP 库的...
    99+
    2023-06-30
  • Python+PuLP实现线性规划的求解
    目录1.PuLP 库的安装2.线性规划简介2.1 线性规划2.2 整数规划3.求解过程3.1 定义模型3.2 定义决策变量3.3 添加约束条件3.4 添加目标函数3.5 模型求解3....
    99+
    2022-11-10
  • Python中怎么实现线性规划
    这篇文章给大家介绍Python中怎么实现线性规划,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 运筹学运筹学是一种科学的决策方法,它通常是在需要分配稀缺资源的条件下,寻求系统的优秀设计。科学的决策方法需要使用...
    99+
    2023-06-16
  • Python数学建模PuLP库线性规划实际案例编程详解
    目录1、问题描述2、用PuLP 库求解线性规划2.1 问题 1(1)数学建模(2)Python 编程(3)运行结果2.2 问题 2(1)数学建模(2)Python 编程(3)运行结果...
    99+
    2022-11-12
  • Python数学建模PuLP库线性规划入门示例详解
    目录1、什么是线性规划2、PuLP 库求解线性规划-(0)导入 PuLP库函数-(1)定义一个规划问题-(2)定义决策变量-(3)添加目标函数-(4)添加约束条件-(5)求解3、Py...
    99+
    2022-11-12
  • Python实现线性规划求解
    线性规划标准形式:MATLAB-------------线性规划求解主要分  两个部分,目标函数(max,min)和约束条件(s.t.),求解时一般要化为MATLAB标准形式:求解用到的模块(scipy 和  numpy...
    99+
    2023-06-02
  • Python数学建模PuLP库线性规划进阶基于字典详解
    目录1、基于字典的创建规划问题2、线性规划问题案例3、建立模型(1)决策变量(2)目标函数(3)约束条件(4)变量取值范围4、PuLP 程序1:使用 LpVariable 逐一定义变...
    99+
    2022-11-12
  • python中如何实现线性规划
    python中如何实现线性规划,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。说明图解法,用几何绘图的方法,求出最优解。中学就讲过这种方法,在经济学研究中非常常用...
    99+
    2023-06-20
  • python四种出行路线规划的实现
    目录一、简介思路高德地图API二、获取经纬度三、路线规划(四种方式)获取出行路线数据处理四、演示效果五、结尾一、简介 路径规划中包括步行、公交、驾车、骑行等不同方式,今天借助高德地图web服务api,实现出行路线规...
    99+
    2022-06-02
    python 出行路线规划 python路线规划图
  • python中求解线性规划的包是什么
    这篇文章主要介绍python中求解线性规划的包是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!说明Scipy库提供简单的线性或非线性规划问题。但不能解决背包问题的0-1规划问题,或者整数规划问题,混合整数规划问题...
    99+
    2023-06-20
  • 【自动驾驶】路径规划——ReedsShepp 曲线总结(python实现 | c++实现)
    文章目录 参考资料1. Reeds-Shepp 曲线1.1 基本概念1.2 字段组合1.3 时间翻转(timeflip)、反射(reflect)和向后变换(backwards)1.3.1 时间...
    99+
    2023-10-07
    自动驾驶 人工智能 路径规划 reeds-shepp曲线
  • Python怎么实现最大连续区间和动态规划
    本篇内容介绍了“Python怎么实现最大连续区间和动态规划”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!问题描述:给定一段长度为N的整数序列...
    99+
    2023-06-26
  • 怎么在CSS3中利用transition属性实现下划线
    怎么在CSS3中利用transition属性实现下划线?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。transition属性transition: 简写属性,用于在一个属性中设...
    99+
    2023-06-08
  • Python怎么实现线性回归
    Python怎么实现线性回归,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1、概述(1)人工智能学习        &n...
    99+
    2023-06-26
  • java驼峰转下划线怎么实现
    要将驼峰命名法转换为下划线命名法,可以使用以下方法:1. 使用正则表达式:```javaString input = "camelC...
    99+
    2023-09-11
    java
  • div css怎么实现文字中划线
    这篇文章主要介绍了div css怎么实现文字中划线的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇div css怎么实现文字中划线文章都会有所收获,下面我们一起来看看吧。代码&l...
    99+
    2022-10-19
  • css文字划线效果怎么实现
    这篇文章主要介绍“css文字划线效果怎么实现”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“css文字划线效果怎么实现”文章能帮助大家解决问题。 一、文字中划线CS...
    99+
    2022-10-19
  • python一元线性回归怎么实现
    在Python中,可以使用NumPy和Scikit-learn库来实现一元线性回归。以下是一元线性回归的实现步骤:1. 导入所需的库...
    99+
    2023-08-18
    python
  • python多元线性回归怎么实现
    在Python中,可以使用`scikit-learn`库来实现多元线性回归。首先,需要导入所需的库和模块:```pythonfrom...
    99+
    2023-08-18
    python
  • python多线程及多线程有序性怎么实现
    这篇文章主要介绍了python多线程及多线程有序性怎么实现的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇python多线程及多线程有序性怎么实现文章都会有所收获,下面我们一起来看看吧。前言多线程一般用于同时调用...
    99+
    2023-07-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作