运筹学

运筹学是一种科学的决策方法,它通常是在需要分配稀缺资源的条件下,寻求系统的最佳设计。科学的决策方法需要使用一个或多个数学模型(优化模型)来做出最优决策。

优化模型试图在满足给定约束的决策变量的所有值的集合中,找到优化(最大化或最小化)目标函数的决策变量的值。 它的三个主要组成部分是:

  1. 目标函数:要优化的函数(最大化或最小化)。
  2. 决策变量:影响系统性能的可控变量。
  3. 约束:决策变量的一组约束(即线性不等式或等式)。非负性约束限制了决策变量取正值。

优化模型的解称为最优可行解。

建模步骤

对运筹学问题进行准确建模是最重要的任务,也是最困难的任务。错误的模型会导致错误的解决方案,从而不能解决原来的问题。团队成员应按照以下步骤进行建模:

  1. 问题定义:定义项目的范围,并确定三个要素:决策变量、目标和限制(即约束)。
  2. 模型构建:将问题定义转化为数学关系。
  3. 模型求解:使用标准优化算法。在获得解后,需要进行灵敏度分析,以找出由于某些参数的变化而导致的解的行为。
  4. 模型有效性:检查模型是否按预期工作。
  5. 实现:将模型和结果转换为解决方案。

线性规划

线性规划(Linear Programming,也称为LP)是一种运筹学技术,当当所有的目标和约束都是线性的(在变量中)并且当所有的决策变量都是连续的时使用。线性规划是最简单的运筹学方法。

Python的SciPy库包含用于解决线性编程问题的linprog函数。在使用linprog时,编写代码要考虑的两个注意事项:

  1. 这个问题必须表述为一个最小化问题。
  2. 不等式必须表示为≤。

最小化问题

让我们考虑以下要解决的最小化问题:

让我们看一下Python代码:

# Import required librariesimport numpy as npfrom scipy.optimize import linprog# Set the inequality constraints matrix# Note: the inequality constraints must be in the form of <=A = np.array([[-1, -1, -1], [-1, 2, 0], [0, 0, -1], [-1, 0, 0], [0, -1, 0], [0, 0, -1]])# Set the inequality constraints vectorb = np.array([-1000, 0, -340, 0, 0, 0])# Set the coefficients of the linear objective function vectorc = np.array([10, 15, 25])# Solve linear programming problemres = linprog(c, A_ub=A, b_ub=b)# Print resultsprint('Optimal value:', round(res.fun, ndigits=2),      'x values:', res.x,      'Number of iterations performed:', res.nit,      'Status:', res.message)

输出结果:

# Optimal value: 15100.0 # x values: [6.59999996e+02 1.00009440e-07 3.40000000e+02] # Number of iterations performed: 7 # Status: Optimization terminated successfully.

最大化问题

由于Python的SciPy库中的linprog函数是用来解决最小化问题的,因此有必要对原始目标函数进行转换。通过将目标函数的系数乘以-1(即通过改变其符号),可以将最小化问题转化为一个最大化问题。

让我们考虑下面需要解决的最大化问题:

让我们看一下Python的实现:

# Import required librariesimport numpy as npfrom scipy.optimize import linprog# Set the inequality constraints matrix# Note: the inequality constraints must be in the form of <=A = np.array([[1, 0], [2, 3], [1, 1], [-1, 0], [0, -1]])# Set the inequality constraints vectorb = np.array([16, 19, 8, 0, 0])# Set the coefficients of the linear objective function vector# Note: when maximizing, change the signs of the c vector coefficientc = np.array([-5, -7])# Solve linear programming problemres = linprog(c, A_ub=A, b_ub=b)# Print resultsprint('Optimal value:', round(res.fun*-1, ndigits=2),      'x values:', res.x,      'Number of iterations performed:', res.nit,      'Status:', res.message)

上述代码的输出结果为:

# Optimal value: 46.0 # x values: [5. 3.] # Number of iterations performed: 5 # Status: Optimization terminated successfully.

最后

线性规划为更好的决策提供了一种很好的优化技术。Python的SciPy库中的linprog函数允许只用几行代码就可以解决线性编程问题。虽然还有其他免费的优化软件(如GAMS、AMPL、TORA、LINDO),但使用linprog函数可以节省大量时间。

python 线性规划问题_使用Python进行线性规划示例相关推荐

  1. python 时间序列预测_使用Python进行动手时间序列预测

    python 时间序列预测 Time series analysis is the endeavor of extracting meaningful summary and statistical ...

  2. python 概率分布模型_使用python的概率模型进行公司估值

    python 概率分布模型 Note from Towards Data Science's editors: While we allow independent authors to publis ...

  3. 数学建模用python好吗_用 Python 做数学建模

    数学建模中,大多数人都在用MATLAB,但MATLAB不是一门正统的计算机编程语言,而且速度慢还收费,最不能忍受的就是MATLAB编辑器不支持代码自动补全.python对于数学建模来说,是个非常好的选 ...

  4. python集群_使用Python集群文档

    python集群 Natural Language Processing has made huge advancements in the last years. Currently, variou ...

  5. python 网页编程_通过Python编程检索网页

    python 网页编程 The internet and the World Wide Web (WWW), is probably the most prominent source of info ...

  6. python机器学习预测_使用Python和机器学习预测未来的股市趋势

    python机器学习预测 Note from Towards Data Science's editors: While we allow independent authors to publish ...

  7. python高斯求和_利用Python进行数据分析(3)- 列表、元组、字典、集合

    本文主要是对Python的数据结构进行了一个总结,常见的数据结构包含:列表list.元组tuple.字典dict和集合set. image 索引 左边0开始,右边-1开始 通过index()函数查看索 ...

  8. python 免费空间_用python做大数据

    不学Python迟早会被淘汰?Python真有这么好的前景? 最近几年Python编程语言在国内引起不小的轰动,有超越Java之势,本来在美国这个编程语言就是最火的,应用的非常非常的广泛,而Pytho ...

  9. python希腊字母字符串_#10 Python字符串

    前言 通过上一节可知,Python6个序列的内置类型中,最常见的是列表和元组,但在Python中,最常用的数据类型却不是列表和元组,而是字符串.要想深入了解字符串,必须先掌握字符编码问题.因此本篇博文 ...

  10. 使用python预测基金_使用python先知3 1创建预测

    使用python预测基金 This tutorial was created to democratize data science for business users (i.e., minimiz ...

最新文章

  1. CSP 201812-2 小明放学 Python实现+详解
  2. 使用.Net访问Office编程接口
  3. ABAP程序里设置外部断点,调试时断点怎么也触发不了,该怎么办
  4. sql取出某一列不重复数据的ID解决办法
  5. HTML浮动导致高度塌陷,HTML 文档流,设置元素浮动,导致父元素高度无法自适应的解决方法(高度欺骗)...
  6. 广东鸿图:搭建业务报表,摆脱人工计数,工作效率提升150%
  7. python I/O原理
  8. 你是农村人吗,小时候放过牛吗,都有哪些好玩的趣事?
  9. 搭建steam游戏服务器
  10. JS_原生js实现60秒倒计时
  11. Python 内置容器 之 字典 ( dict )超详细指南
  12. 数据模型及E-R模型
  13. “金三银四” 是找工作的最佳时期吗?
  14. Hadoop实例学习(八)全排序和区排序
  15. 如何提取matlab中某一行一列的数据
  16. python重启路由器_Python实现路由器的重启和查看实时流量
  17. java接口里面可以定义变量么?
  18. MCMC蒙特卡洛马尔可夫过程
  19. 基于pygame做的小游戏
  20. 微博话题下的数据爬取

热门文章

  1. final修饰符、抽象类、接口、多态、内部类的简单小结
  2. 页面点击提交跳转_一个入口一次提交!“六税合一”综合申报操作指南请收好~...
  3. Docker系列四~docker安装mysql
  4. Vue路由history模式踩坑记录:nginx配置解决404问题
  5. centos6.5 python2.6.6升级到python2.7.15
  6. 反思,今天总体感觉事情很简单,但项目比较多,没有掌握住很好的技巧,所以感觉很混乱
  7. Centos7重装系统保留数据(仅限于光盘和ISO镜像形式)
  8. 如何在Go中使用切片容量和长度
  9. Rand7()实现Rand10()
  10. 关于spring cloud的几个问题