当前位置:首页 > 影视动漫 >

运筹学模型的三个基本要素(运筹学建模中的基本步骤)

来源:原点资讯(m.360kss.com)时间:2023-10-28 17:04:34作者:YD166手机阅读>>

运筹学模型的三个基本要素,运筹学建模中的基本步骤(1)

运筹学

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

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

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

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

建模步骤

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

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

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

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

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

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

运筹学模型的三个基本要素,运筹学建模中的基本步骤(2)

让我们看一下Python代码:

# Import required libraries import numpy as np from 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 vector b = np.array([-1000, 0, -340, 0, 0, 0]) # Set the coefficients of the linear objective function vector c = np.array([10, 15, 25]) # Solve linear programming problem res = linprog(c, A_ub=A, b_ub=b) # Print results print('Optimal value:', round(res.fun, ndigits=2), '\nx values:', res.x, '\nNumber of iterations performed:', res.nit, '\nStatus:', 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(即通过改变其符号),可以将最小化问题转化为一个最大化问题。

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

运筹学模型的三个基本要素,运筹学建模中的基本步骤(3)

让我们看一下Python的实现:

# Import required libraries import numpy as np from 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 vector b = 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 coefficient c = np.array([-5, -7]) # Solve linear programming problem res = linprog(c, A_ub=A, b_ub=b) # Print results print('Optimal value:', round(res.fun*-1, ndigits=2), '\nx values:', res.x, '\nNumber of iterations performed:', res.nit, '\nStatus:', 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函数可以节省大量时间。

栏目热文

运筹学模型和方法答案(运筹学模型与方法答案)

运筹学模型和方法答案(运筹学模型与方法答案)

运筹学第三版教材课后习题答案 高等教育出版社,...

2023-10-28 17:10:08查看全文 >>

运筹学数学规划模型分为哪两种(运筹学模型总结)

运筹学数学规划模型分为哪两种(运筹学模型总结)

前言每一个程序员或开发者都会面临着如何提升系统吞吐量、如何减少系统访问耗时尖刺、如何机器CPU利用率、如何降低系统响应时...

2023-10-28 17:09:50查看全文 >>

运筹学模型建立的七个步骤(运筹学模型应用的基本流程)

运筹学模型建立的七个步骤(运筹学模型应用的基本流程)

以下文章来源于生产系统仿真软件 ,作者ZHP导读在建模仿真之前,首先要明确仿真的目标,即为什么要进行仿真,要分析哪些指标...

2023-10-28 16:39:39查看全文 >>

运筹学决策问题的三种类型(简述运筹学方法论的主要过程)

运筹学决策问题的三种类型(简述运筹学方法论的主要过程)

点击上方“科学人文在线”可关注人生有许多路口,常常不知向左还是右……懂点运筹学,在遇到问题的时候或许就不难找到更好的解决...

2023-10-28 16:59:43查看全文 >>

运筹学五种经典模型(三种数学模型运筹学)

运筹学五种经典模型(三种数学模型运筹学)

本文介绍了五个经典管理学模型:桶队模型、牛鞭模型、报童模型、巴斯模型、里特模型,真是好玩有趣又有用,快来学习一下吧。(1...

2023-10-28 16:45:31查看全文 >>

运筹学中所使用的模型是(运筹学模型应用的基本流程)

运筹学中所使用的模型是(运筹学模型应用的基本流程)

最受欢迎的机器学习模型的直观解释。在上一篇文章中,我解释了什么是回归并展示了如何在应用中使用它。 本周,我将介绍实践中使...

2023-10-28 16:36:49查看全文 >>

运筹学建立的模型的步骤(运筹学方法与模型要点内容摘录)

运筹学建立的模型的步骤(运筹学方法与模型要点内容摘录)

主讲人:W学长- Columbia University:PhD in Industrial Engineering &...

2023-10-28 16:59:22查看全文 >>

举例运筹学模型方面的应用(运筹学中的建模步骤)

举例运筹学模型方面的应用(运筹学中的建模步骤)

『运筹OR帷幄』原创作者:覃含章 留德华叫兽编者按关于这个问题,本公号之前整理过一次。这次重新整理该问题主要从应用和就业...

2023-10-28 17:10:00查看全文 >>

运筹学的模型通常有哪些(运筹学模型及方法)

运筹学的模型通常有哪些(运筹学模型及方法)

查理芒格提出跨学科知识以及多元思维模型,在《穷查理宝典》中提到了有100多个思维模型,我们将会以学习思维模型的方式对查理...

2023-10-28 17:06:43查看全文 >>

已退款又收到货且签收了怎么办(已经退款的商品签收了怎么处理)

已退款又收到货且签收了怎么办(已经退款的商品签收了怎么处理)

昨日,淘宝网在规则中心内发布了“关于《淘宝平台争议处理规则》新增买家未收到货退款的争议规则”公示通知。公告内称:此次的规...

2023-10-28 16:55:18查看全文 >>

文档排行