运筹学软件(LINGO)简介
(运筹学)Lindo软件
模型求解
用鼠标点击工具栏中的图标 , 或从菜单中选择Solve|Solve(Ctrl+S)命令 或从菜单中选择 命令
LINDO首先开始编译 首先开始编译 这个模型, 编译没有 这个模型 , 错误则开始求解; 错误则开始求解; 求解时会首先显示如 右 图 所 示 的 LINDO “求解器运行状态窗 口 ”。
显示整数规划当前的最佳目标值: 显示整数规划当前的最佳目标值:“N/A” (No Best IP Answer或Not Applicable)表示无答案或无意义, 表示无答案或无意义, 或 表示无答案或无意义 (整数规划当前的最佳 整数规划当前的最佳 因为这个模型中没有整数变量,不是整数规划(IP) 因为这个模型中没有整数变量,不是整数规划 目标值) 目标值 。
保存文件
选择File|Save(F5)命令把 结果报告”保存在一个文件中 选择 命令把“结果报告 保存在一个文件中 命令把 结果报告 (缺省的后缀名为 缺省的后缀名为LTX,即LINDO文本文件 文本文件) 缺省的后缀名为 即 文本文件 类似地,回到模型窗口, 类似地,回到模型窗口,可以把输入的模型保存在一个 文件中。保存的文件将来可以用File |Open(F3)和File | 文件中。保存的文件将来可以用 和 View(F4)重新打开,用前者打开的程序可以进行修改, 重新打开,用前者打开的程序可以进行修改, 重新打开 而后者只能浏览。 而后者只能浏览。 如果模型有错误,运行时会弹出出错信息报告窗口 (LINDO Error Message),则需要修改模型。 ,则需要修改模型。
一个简单的LINDO程序 一个简单的LINDO程序
例1:简单的线性规划 (LP)问题 简单的线性规划 问题
Max s .t .
2024年度LINGO软件
结果分析
对求解结果进行分析,验证模型的有 效性和可行性。
模型调整
根据结果分析,对模型进行调整和优 化,提高模型的实用性和准确性。
24
05 LINGO软件在各 个领域的应用案 例
2024/3/23
25
生产计划与调度问题
2024/3/23
生产线平衡
LINGO可以用于解决生产线平衡问题,通过优化生产线上 各个工位的任务分配,提高生产效率和资源利用率。
一些学术机构和研究团队也会分享他们的 LINGO使用经验和案例,为学习者提供更多 的学习资源和合作机会。
37
THANKS
感谢观看
2024/3/23
38
LINGO可用于金融市场预测和决策分析,通过建立预测模型和分析工具
,揭示金融市场的运行规律和趋势,为投资决策提供支持。
29
06 LINGO软件与其 他工具的集成与 应用
2024/3/23
30
与Excel的集成与应用
2024/3/23
数据交换
LINGO可以直接从Excel中导入数据,也可以将结果导出到Excel ,实现数据的无缝对接。
2024/3/23
28
金融工程与投资组合优化问题
01
投资组合优化
LINGO可以用于解决投资组合优化问题,通过优化投资组合中各个资产
的配置比例,实现风险和收益的平衡。
02
期权定价与风险管理
利用LINGO建立期权定价模型,可以准确计算期权的价值,为风险管理
提供决策依据。
2024/3/23
03
金融市场预测与决策分析
2024/3/23
整数规划算法
分支定界法、割平面法等适用于整数规划问 题的求解。
运筹学___的LINGO软件
当你在 windows 下开始运行 LINGO 系统时,会得到一个窗口: 外层是主框架窗口,包含了所有菜单命令和工具条,其它所有的窗口将被包含在主 窗口之下。在主窗口内的标题为 LINGO Model – LINGO1 的窗口是 LINGO 的默认模型窗 口,建立的模型都都要在该窗口内编码实现。下面举两个例子。 例 2.1 如何在 LINGO 中求解如下的 LP 问题:
§3 LINGO 中的集
对实际问题建模的时候,总会遇到一群或多群相联系的对象,比如工厂、消费者群 体、交通工具和雇工等等。LINGO 允许把这些相联系的对象聚合成集(sets)。一旦把 对象聚合成集,就可以利用集来最大限度的发挥 LINGO 建模语言的优势。
-316-
3.1 什么是集 集是一群相联系的对象,这些对象也称为集的成员。一个集可能是一系列产品、卡 车或雇员。每个集成员可能有一个或多个与之有关联的特征,我们把这些特征称为属性。 属性值可以预先给定,也可以是未知的,有待于 LINGO 求解。例如,产品集中的每个产 品可以有一个价格属性;卡车集中的每辆卡车可以有一个牵引力属性;雇员集中的每位 雇员可以有一个薪水属性,也可以有一个生日属性等等。 LINGO 有两种类型的集:原始集(primitive set)和派生集(derived set)。 一个原始集是由一些最基本的对象组成的。 一个派生集是用一个或多个其它集来定义的,也就是说,它的成员来自于其它已存 在的集。
(iii)LINGO 可以用来求解线性,非线性和整数规划问题。 (iv)LINGO NL (LINGO2) 可以用来求解线性,非线性和整数规划问题。 与 LINDO 和 GINO 不同的是,LINGO 和 LINGO NL (LINGO2) 包含了內置的建模 语言,允许以简练,直观的方式描述较大规模的优化问题,模型中所需的数据可以以一 定格式保存在独立的文件中。 (v)“what’s best!” 组件主要用于数据文件是由电子表格软件(如 LUTOS1-2-3 和 MS OFFICE 等)生成的情形。 LINDO 软件包有多种版本,但其软件內核和使用方法基本上是类似的。下面介绍 LINGO 组件的基本使用方法。
Lingo简介
6. “ltx”:Lindo格式的模型文件;
7. “mps”:MPS(数学规划系统) Lingo软件模型一般由5部分组成: 1. 集合段(SETS):“SETS:”开始,“ENDSETS”结束; 2. 目标与约束段; 3. 数据段(DATA):“DATA:”开始,“ENDDATA”结束; 4. 初始化段(INIT):“INIT:”开始,“ENDINIT”结束;
无限
800 3200
无限
4000 16000
无限
Lindo/Lingo 软件简介
Lindo是英文Linear INteractive and Discrete Optimizer 字母的缩写,可求解线性规划(LP)和二次规划(QP)。
Lingo是英文Linear INteractive and General Optimizer 字母的缩写,除了具有Lindo所有功能之外,还可以用于求 解非线性规划(NLP),也可用于一些线性和非线性方程 的求解等。
Lindo/Lingo 软件简介
Lindo/Lingo内部求解器: 1. 直接求解程序(Direct Solver)
2. 线性优化求解程序(Linear Solver)
3. 非线性优化求解程序(Nonlinear Solver) 4. 分支定界管理程序(Branch and Bound Manager)
Lindo/Lingo 软件简介
美国芝加哥大学 Linus Schrage 教授于1980年前后开发 的一套专门用于求解最优化问题的软件包。 软件包括:Lindo、Lingo、Lindo API以及What’sBest! 这四款软件分为演示版(试用版)和正式版,两者的区别 在于求解问题的规模不同。正式版又可以分为求解包 (Solver Suite)、高级版(Super)、超级版(Hyper)、 工业版(Industrial)、扩展版(Extended)。
LINGO软件介绍
LINGO 程序设计介绍在运筹学中中会遇到如规划类的题型,在这种模型中总存在着一个目标,并希望这个目标的取值尽可能的大或小,同时与这个目标有关的一系列变量之间存在一些约束。
在构造出目标函数和约束条件的表达式后,我们需要对求出这个最值和各变量的取值。
一般我们用LINGO 来对模型进行求解,本文将通过举一个简单的例子,围绕这个例子逐步学习LINGO 的使用。
LINGO 只是一个求解工具,我们主要的任务还是模型的建立!当你在windows 下开始运行LINGO 系统时,会得到类似下面的一个窗口:外层是主框架窗口,包含了所有菜单命令和工具条,其它所有的窗口将被包含在主窗口之下。
在主窗口内的标题为LINGO Model – LINGO1的窗口是LINGO 的默认模型窗口,建立的模型都都要在该窗口内编码实现。
一.变量、常量定义在lingo 中变量在使用前是无需定义也可以使用的。
在描述类似ij i a x ,带有下标的变量时,我们可以在使用时一一例举,即,x1,x2,x3….x8, 但这样显然很麻烦(刚接触LINGO 的时候大部分是这样使用的)。
Lingo 中可以使用sets 来预先定义这些变量,然后就可以在loop 语句方便地访问这一组变量,也可以用小x(2), a(2,3)的形式访问个别变量,这和C 语言中的数组是类似的。
1.SETS 的使用:为了定义ij i a x ,那么首先要确定下标i 和j 的取值范围。
在lingo 中用sets 来表示。
代码:SETS :Xb1 /1..8/ ;Xb2 /1..6/ ;ENDSETS其中xb1、xb2分别为下标1..8 ,1..6的名字(sets_name),这些名字在loop语句中要使用。
对于sets_name一般将它命名为有意义的名称,这个sets_name必须以字母或下划线(_)开始。
二维下标是在两个一维下标定义的基础上给定的,定义a(i,j)下标的代码如下:SETS :Xb1 /1..8/;Xb2 /1..6/ ;Xb3 (xb1,xb2);ENDSETS现在下标已经定义完成了,定义数组变量时则需在下标后加上冒号再写上变量名,代码如下:SETS :Xb1 /1..8/:x,c,b ;Xb2 /1..6/ ;Xb3 (xb1,xb2):a;ENDSETS2.DATA的使用(常量定义):在lingo中把常量理解为已经被给定某常数的变量,在DATA 中对一些变量赋值,使之成为常量。
运筹学lingo实验报告(一)
运筹学lingo实验报告(一)运筹学lingo实验报告介绍•运筹学是一门研究在给定资源约束下优化决策的学科,广泛应用于管理、工程、金融等领域。
•LINGO是一种常用的运筹学建模和求解软件,具有丰富的功能和高效的求解算法。
实验目的•了解运筹学的基本原理和应用。
•掌握LINGO软件的使用方法。
•运用LINGO进行优化建模和求解实际问题。
实验内容1.使用LINGO进行线性规划的建模和求解。
2.使用LINGO进行整数规划的建模和求解。
3.使用LINGO进行非线性规划的建模和求解。
4.使用LINGO进行多目标规划的建模和求解。
实验步骤1. 线性规划•确定决策变量、目标函数和约束条件。
•使用LINGO进行建模,设定目标函数和约束条件。
•运行LINGO求解线性规划问题。
2. 整数规划•在线性规划的基础上,将决策变量的取值限制为整数。
•使用LINGO进行整数规划的建模和求解。
3. 非线性规划•确定决策变量、目标函数和约束条件。
•使用LINGO进行非线性规划的建模和求解。
4. 多目标规划•确定多个目标函数和相应的权重。
•使用LINGO进行多目标规划的建模和求解。
实验结果•列举各个实验的结果,包括最优解、最优目标函数值等。
结论•运筹学lingo实验是一种有效的学习运筹学和应用LINGO的方法。
•通过本实验能够提高对运筹学概念和方法的理解,并掌握运用LINGO进行优化建模和求解的技能。
讨论与建议•实验过程中是否遇到困难或问题,可以进行讨论和解决。
•提出对于实验内容或方法的建议和改进方案。
参考资料•提供参考书目、文献、教材、网站等资料,以便学生深入学习和研究。
致谢•对与实验指导、帮助或支持的人员表示感谢,如老师、助教或同学等。
以上为运筹学lingo实验报告的基本框架,根据实际情况进行适当调整和补充。
实验报告应简洁明了,清晰表达实验目的、内容、步骤、结果和结论,同时可以加入必要的讨论和建议,以及参考资料和致谢等信息。
lingo在运筹学中的运用
lingo在运筹学中的运用
Lingo在运筹学中是一类特别有用的工具,它是一种针对非线性优
化问题的建模语言。
它提供了一种实现复杂求解过程的有效方法,可
以帮助企业创建可衡量的、可控的模型,本质上提高解决难题的能力。
Lingo在运筹学中的应用如下:
一、数据建模
Lingo可以帮助企业更好地利用数据分析,通过数据可视化,实时监测,以及建立超级等式和复合对象,更好地实现数据建模。
这样可以提高
数据管理能力,让企业能够更好地组织、管理、分析及设计数据模型。
二、决策模型
Lingo可以帮助企业构建复杂的决策模型,允许运筹学家在多变量制约
条件下建立决策模型。
Lingo可以在多种应用场景中使用,从传统的精
确方程求解到组合优化多目标问题,从分布式系统的模拟到深度学习
的应用模型,Lingo都有着重要的用途。
三、数学优化
Lingo可以帮助企业有效地实现数学优化目标,在模型本身的表述上,Lingo具有更快的执行速度,并且可以处理大量的数量和变量,可以表
示复杂的最优化目标函数,从而提供最佳的运行数值。
四、机器学习
Lingo在运筹学中也可以应用于机器学习领域,可以用来构建收敛性更
强的机器学习模型,比如基于复杂决策树的模型,或者用Lingo设计的模型来处理视觉捕获和多机实时分析的问题。
总结:Lingo在运筹学中具有重要的作用,它可以帮助企业更加有效地实现数据建模、决策模型、数学优化和机器学习等方面的目标,进而提高企业的解决问题的能力。
LINGO软件简介
LINGO 软件简介LINGO 软件是一个处理优化问题的专门软件,它尤其擅长求解线性规划、非线性规划、整数规划等问题.一个简单示例有如下一个混合非线性规划问题:⎪⎩⎪⎨⎧≥≤≤+++---+为整数2132121321322212121,;0,,210022..15023.027798max x x x x x x x x x x t s x x x x x x x .LINGO 程序模型:max =98x1+277x2-x1^2-0.3x1x2-2x2^2+150x3; x1+2x2+2x3<=100; x1<=2x2;gin x1;gin x2; Lingo 默认变量非负注意:binx 表示x 是0-1变量;ginx 表示x 是整数变量;bndL,x,U表示限制LxU ;freex 表示取消对x 的符号限制,即可正、可负.结果:Global optimal solution found.Objective value: 9561.200 Extended solver steps: 0 Total solver iterations: 45 Variable Value Reduced CostX1 6.000000 -76.70000X2 31.00000 -151.2000X3 16.00000 -150.0000Row Slack or Surplus Dual Price1 9561.200 1.0000002 0.000000 0.0000003 56.00000 0.000000———————— 非常简单在LINGO 中使用集合为了方便地表示大规模的规划问题,减少模型、数据表示的复杂程度,LINGO 引进了“集合”的用法,实现了变量、系数的数组化下标表示.例如:对⎪⎪⎩⎪⎪⎨⎧==-++-==≤++∑=.,,;10)0(;4,3,2,1),()())()1()(;4,3,2,1,20)(..)}(20)(450)(400{min4,3,2,1均非负INV OP RP INV I I DEM I OP I RP I INV I INV I I RP t s I INV I OP I RP I求解程序:model :sets :mark/1,2,3,4/:dem,rp,op,inv;也可以vmark/1..4/:dem,rp,op,inv;endsetsmin=sum mark:400rp+450op+20inv;也可以markI:400rpI+450opI+20invI;for markI: rpI<40;for markI|Igt1: invI=invI-1+rpI+opI-demI;inv1=10+rp1+op1-dem1;data:dem=40,60,75,35;enddataend上面程序在model…end之间有1集合定义、2数据输入和3其他三部分内容.集合定义部分从sets:到endsets:定义了一个指标集合mark可以理解为数组下标及其范围和其4个属性dem、rp、op、inv用此向量的数组变量.数据输入部分从data:到enddata依次给出常量dem的值.其他部分:给出优化目标及约束.一般而言,LINGO中建立优化模型的程序可以由五部分组成,或称为五段section:1集合段SETS:这部分以“SETS:”开始,以“ENDSETS”结束,作用在于定义必要的集合变量SET及其元素member,含义类似于数组的下标和属性attribute,含义类似于数组.2目标与约束段:这部分实际上定义了目标函数、约束条件等,但这部分没有段的开始和结束标记;该段一般常用到LINGO内部函数,尤其是和集合相关的求和函数SUM和循环函数FOR等.3数据段DATA:这部分以“DATA:”开始,以“ENDDATA”结束,作用在于对集合的属性数组输入必要的常数数据.格式为:attribute属性=value_list常数列表;常数列表中的数据之间可以用逗号、空格或回车符分隔.如果想要在运行时才对参数赋值,可以在数据段使用输入语句,其格式为“变量名=;”,但仅限对单个变量赋值,而不能用于属性变量数组的单个元素.4初始段INIT:这部分以“INIT:”开始,以“ENDINIT”结束,作用在于对集合的属性数组定义初值因为求解算法一般是迭代算法,提供一个较好的初值,能提高计算效果.定义初值的语句格式为:attribute属性=value_list常数列表;这与数据段中的用法类似.5计算段CALC:这部分以“CALC:”开始,以“ENDCALC”结束,作用在于对一些原始数据进行预处理加工,使其成为模型直接需要的数据.该段中通常是计算赋值语句.基本集合与派生集合为了处理二维数组变量等有多个下标的问题,LINGO引入了“派生集”的概念.我们把直接列出元素的指标集合叫“基本集合”,而基于其他集合派生出来的二维或多维指标集合称为“派生集”.派生集的定义格式为:派生集名原始集合1,原始集合2,…,原始集合n:属性变量列表;实际上就是笛卡儿积的意思,即:派生集={i1,i2, (i)n| i1集合1, i2集合2,…, in集合n}.1一个应用例子布局问题:某些建筑工地的位置用平面坐标a,b表示及水泥日用量d已知.现有A、B两临时料场位于P5,1、Q2,7,日储量20.问A、B两料场分别向各工地运输多少吨水泥,使总吨公里数最小若重新安排两料场的位置,应怎样安排才能使总吨公里数最小这样安排可节省多少吨公里设工地位置ai ,bi,水泥日用量为dii=1,2,…,6;料场位置xi,yi,日储量ej,j=1,2;从料场j向工地i运送量为cij.该问题的数学模型为:LINGO求解程序为:MODEL:sets:Imark/1..6/:a,b,d;Jmark/1,2/:x,y,e;IJmarkImark,Jmark:c;endsetsdata:Location for demand需求点位置;a=1.25,8.75,0.5,5.75,3,7.25;b=1.25,0.75,4.75,5,6.5,7.75;Quantities of the demand and supply供需量;d=3,5,4,7,6,11;e=20,20;enddatainit:Initial location for the supply初始点;x,y=5,1,2,7;endinitObjective function目标;OBJ min=sum IJmarki,j: ci,jxj-ai^2+yj-bi^2^1/2; demand contraints需求约束;for Imarki:DEMAND_CON SUM Jmarkj:ci,j=di;; supply constrains供给约束;for Jmarkj:SUPPLY_CON SUM Imarki:ci,j<=ej;;for Jmark: free x;free y;;2一个动态规划的例子:最短路问题从S城市到T城市之间找一条最短路径,道路情况如下:数学模型为:LINGO求解程序:model:sets:cities/s,a1,a2,a3,b1,b2,c1,c2,t/:L; 属性Li表示城市S到城市i的最优行驶路线的里程;roadscities,cities/ 派生集合roads表示的是网络中的道路;s,a1 s,a2 s,a3 由于并非所有城市间都有道路直接连接,所以将路具体列出;a1,b1 a1,b2 a2,b1 a2,b2 a3,b1 a3,b2b1,c1 b1,c2 b2,c1 b2,c2 属性Di,j是城市i到城市j的直接距离已知;c1,t c2,t/:D;endsetsD= 6 3 36 5 8 67 46 7 8 95 6;L=0,,,,,,,,; 因为Ls=0;enddatafor citiesi|igt index s: 这行中"indexs"可以直接写成"1";Li=min roadsj,i:Lj+Dj,i;; 这就是最短路关系式;endVariable ValueL S0.000000L A16.000000L A23.000000L A33.000000L B110.00000L B27.000000L C115.00000L C216.00000L T20.00000最短路径为: S-〉A3-〉B2-〉C1-〉T3指派问题设有6个人做6件事.其中cij表示第i人做第j事的收益;设第i人做第j事时xij =1,否则xij=0.该问题的规划模型:说明:其中“-”表示某人无法做该事.可令其为-表示绝对不行或0领薪不用干活LINGO求解程序:MODEL:sets:Imark/1..6/:i;Jmark/1..6/:j;IJmarkImark,Jmark:c,x;endsetsdata:第i人做第j事的收益;c=20,15,16,5,4,717,15,33,12,8,69,12,18,16,30,1312,8,11,27,19,14-99,7,10,21,10,32-99,-99,-99,6,11,13;enddataOBJ max=sum IJmarki,j: cx;每人做一项工作;for Imarki: SUM Jmarkj:xi,j=1;;每事一人做;for Jmarkj: SUM Imarki:xi,j=1;;for IJmark: bin x;本约束可以不要,因为有解时必为0或1; END4生产与销售计划问题某公司用两种原油A 和B 混合加工成两种汽油甲和乙.甲、乙两种汽油含原油A 的最低比例分别为50%和60%,每吨售价分别是4800元和5600元.该公司现有原油A 和B 的库存量分别为500吨和1000吨,还可以从市场上买到不超过1500吨的原油A.原油A 的市场价为:购买量不超500吨时单价为10000元/吨;购买量超过500吨但不超1000吨时,超过500吨部分单价为8000元/吨;购买量超过1000吨部分的单价是6000元/吨.该公司应如何安排原油的采购和加工以获得最大利润数学模型: 设原油A 用于生产甲、乙两种汽油的数量分别是x11和x12,原油B 用于生产甲、乙两种汽油的数量分别是x21和x22;购买原油A 的数量是x 吨,采购支出为cx 千元/吨.为了处理分段函数cx,将原油采购量x 分解为对应价格10千元/吨的采购量x1、对应对应价格8千元/吨的采购量x2和对应价格6千元/吨的采购量x3,它们应满足:0)500(21=-x x 表示要么x1=500要么x2=0,即x1的量不达到500时x2=00)500(32=-x x 表示要么x2=500要么x3=0,即x2的量不达到500时x3=0此时采购支出3216810)(x x x x c ++=模型改变为:LINGO 求解程序:model :init:x1=500;x2=500;x3=0;x12=1500;x22=1000;x11=0;x21=0;endinitmax=4.8x11+4.8x21+5.6x12+5.6x22-10x1-8x2-6x3; x11+x12<=x+500;x21+x22<=1000;0.5x11-0.5x21>=0;0.4x12-0.6x22>=0;x=x1+x2+x3;x1-500x2=0;x2-500x3=0;bnd0,x1,500;bnd0,x2,500;bnd0,x3,500;。
《LINGO简介》课件
某些复杂的数学表达可能无法直接在 LINGO中表示。用户可以通过混合编 程或使用其他建模语言(如GAMS) 来解决这一问题。
对于特定行业或领域的定制化需求, LINGO可能无法直接提供相应的功能 。在这种情况下,用户可以通过扩展 LINGO的API或与其他软件的集成来 实现定制化需求。
感谢您的观看
目标函数的设置
目标函数定义
在LINGO中,需要定义一个目标函数来描述决策变量 的优化目标。
目标函数类型
目标函数可以是最大化或最小化形式,根据实际问题 的需求进行选择。
目标函数编辑器
LINGO提供了一个目标函数编辑器,用户可以在其中 方便地定义和编辑目标函数。
求解操作
求解器选择
在LINGO中,可以选择不同的求解器 来求解模型,根据模型的规模和复杂
LINGO软件广泛应用于生产计划、资源分配 、工艺流程优化等方面。
物流运输
LINGO软件用于运输路线规划、车辆调度、 仓储优化等问题求解。
金融投资
LINGO软件用于投资组合优化、风险管理、 信贷决策等问题求解。
科研领域
LINGO软件在数学建模、统计分析、机器学 习等领域有广泛应用。
02
LINGO软件的基本操作
物流配送问题
总结词
物流配送问题是一个复杂的优化问题,LINGO软件能够通过建立有效的数学模型,优化配送路线和成本。
详细描述
物流配送问题涉及到如何合理规划配送路线、分配运输资源,以最小化运输成本并确保及时送达。LINGO软件通 过构建配送问题的数学模型,帮助企业找到最优的配送方案,降低运输成本、提高运输效率。
LINGO软件与其他软件的比较与选择
MATLAB
MATLAB在科学计算和数据分析领域具有广泛的应用,但 相比之下,LINGO在求解优化问题方面更加专业和高效。
LINGO软件介绍
例:邮局一周中每天需要不同数目的雇员,设周一 至少20人,周二至少16人,13,16,19,14,12人,又 规定应聘者需连续工作5天,问邮局每天聘多少雇 员才能既满足需求,又使聘用总人数最少。 min =s1+s2+s3+s4+s5+s6+s7; s1+s4+s5+s6+s7>=20; !周1雇员数; s1+s2+s5+s6+s7>=16; !周2雇员数; s1+s2+s3+s6+s7>=13; !周3雇员数; s1+s2+s3+s4+s7>=16; !周4雇员数; s1+s2+s3+s4+s5>=19; !周5雇员数; s2+s3+s4+s5+s6>=14; !周6雇员数; s3+s4+s5+s6+s7>=12; !周7雇员数;
五个基本的组成部分: 1.变量定义; 2.数据输入; 3.目标函数; 4.约束; 5.变量取值范围。
结束。 (1) 每条语句后必须使用分号“;”结束。问题 ) 每条语句后必须使用分号“ 模型必须由MODEL命令开始,END结束。 命令开始, 结束。 模型必须由 命令开始 结束 命令来作为输入问题模型的开始, (2) 用MODEL命令来作为输入问题模型的开始, ) 命令来作为输入问题模型的开始 格式为MODEL:statement (语句)。 语句)。 格式为 : (3) 目标函数必须由“min =”或“max =”开头。 开头。 ) 目标函数必须由“ 或 开头 (4) 数字与变量之间 变量与变量之间要使用运 ) 数字与变量之间,变量与变量之间要使用运 算符。 如 号等 号等) 算符。(如*号等
LINGO软件介绍
(1) LINGO 软件介绍LINGO 是一种专门用于求解数学规划问题的软件包。
LINGO 主要用于求解线性规划、非线性规划、二次规划、动态规划和整数规划等问题,也可以用于求解一些线性和非线性方程组及代数方程求根等。
LINGO 中包含了一种建模语言和大量的常用函数,可供使用者在建立数学规划问题的模型时调用。
(2) 示例例如,用LINGO 求解线性规划问题:⎪⎪⎪⎪⎩⎪⎪⎪⎪⎨⎧==≥≥+≥+≥+≥+≥+++≥++++++++++=4,3,2,1;2,1,01002001100170010002000..153751511572521min 241423132212211124232221141312112423222114131211j i x x x xx x x x x x x x x x x x x t s x x x x x x x x z ij只需要打开LINGO ,然后按照下面的操作进行即可。
1、 模型的输入当打开LINGO 后,屏幕将出现如图1所示的窗口。
标题为“LINGO ”的窗口是主窗口,它包含所有的其他窗口以及所有命令菜单和工具栏。
里面的空白窗口用于输入LINGO 的程序代码,代码格式如下:MODEL:图1min=21*x11+25*x12+7*x13+15*x14+51*x21+51*x22+37*x23+15*x24; x11+x12+x13+x14>=2000; x21+x22+x23+x24>=1000; x11+x21>=1700;x12+x22>=1100;x13+x23>=200; x14+x24>=100; END2、 执行从Solve 菜单选择Solve 命令,或者在窗口顶部的工具栏里按Solve 按钮,LINGO 就会先对模型进行编译,检查模型是否具有数学意义以及是否符合语法要求。
如果模型不能通过这一步检查,会看到报错信息,并指出出错的语句。
lingo-lindo简介
Lingo、lindo简介一、软件概述 (1)二、快速入门 (4)三、Mathematica函数大全--运算符及特殊符号 (11)参见网址: /一、软件概述(一)简介LINGO软件是由美国LINDO系统公司研发的主要产品。
LINGO是Linear Interactive and General Optimizer的缩写,即交互式的线性和通用优化求解器。
LINGO可以用于求解非线性规划,也可以用于一些线性和非线性方程组的求解等,功能十分强大,是求解优化模型的最佳选择。
其特色在于内置建模语言,提供十几个内部函数,可以允许决策变量是整数(即整数规划,包括 0-1 整数规划),方便灵活,而且执行速度非常快。
能方便与EXCEL,数据库等其他软件交换数据。
LINGO实际上还是最优化问题的一种建模语言,包括许多常用的函数可供使用者建立优化模型时调用,并提供与其他数据文件(如文本文件、Excel 电子表格文件、数据库文件等)的接口,易于方便地输入、求解和分析大规模最优化问题。
(二)LINGO的主要特点:Lingo 是使建立和求解线性、非线性和整数最佳化模型更快更简单更有效率的综合工具。
Lingo 提供强大的语言和快速的求解引擎来阐述和求解最佳化模型。
1 简单的模型表示LINGO 可以将线性、非线性和整数问题迅速得予以公式表示,并且容易阅读、了解和修改。
LINGO的建模语言允许您使用汇总和下标变量以一种易懂的直观的方式来表达模型,非常类似您在使用纸和笔。
模型更加容易构建,更容易理解,因此也更容易维护。
2 方便的数据输入和输出选择LINGO 建立的模型可以直接从数据库或工作表获取资料。
同样地,LINGO 可以将求解结果直接输出到数据库或工作表。
使得您能够在您选择的应用程序中生成报告。
3 强大的求解器LINGO拥有一整套快速的,内建的求解器用来求解线性的,非线性的(球面&非球面的),二次的,二次约束的,和整数优化问题。
用LINGO解决非线性规划问题
注意比较:
当去掉第二个约束条件y<=0.5时,最小值 为-3 当x=0, y=1时;
当去掉所有约束条件无条件最值时,最小
值为-5 当x=1, y=2时;
15
三、用LINGO解决非线性规划问题
例3 求解非线性规划问题:
16
三、用LINGO解决非线性规划问题
17
三、用LINGO解决非线性规划问题
18
X1+ 3X2<=18;
X1,X2为决策变量;
2X1+ X2<=16;
4X2<=20; 第二到四行均为约束条件
8
二、用LINGO解决基本的线性规划问题
我们编辑程序并求解后,得到LINGO Model窗口、 Solution report窗口和Solver status窗口如下:
9
二、用LINGO解决基本的线性规划问题
6
二、用LINGO解决基本的线性规划问题
例1 求解如下的线性规划模型:
m ax z 50 x1 70 x2 ,
x1 3 x2 1 8,
2 x 1 x 2 1 6 ,
4x2 20,
x 1 , x 2 0
7
二、用LINGO解决基本的线性规划问题
我们编辑一个LINGO程序:
MAX=50X1+70X2; 目标函数;
三、用LINGO解决非线性规划问题
例4 求解二次规划问题:
直接使用LINGO最大化过程:
max=98x1+277x2-x1^2-0.3x1x2-2x2^2; x1 + x2 <= 100; x1 <= 2x2; ginx1;ginx2;
19
三、用LINGO解决非线性规划问题
1.6.1 LINGO 简介[共14页]
图 1.9 LINGO 演示版的相关信息
图 1.10 LINGO 程序主窗口
35
(一)LINGO 软件的安装
LINGO 软件目前最新版本为 13.0,分为 Demo(演示版)、Solve Suite(求解包)、Super
(高级版)、Hyper(超级版)、Industrial(工业版)和 Extended(扩展版)6 类不同版本,不同
的版本对模型的变量总数、非线性变量数量、整型变量数量和约束条件的数量有不同的限
ID File”,然后得到程序窗口(见图 1.10),可以在该窗口编写 LINGO 程序。
图 1.8 系统弹出的对话框
(二)LINGO 软件的基本操作
启动 LINGO 后,弹出主窗口和模型窗口(见图 1.10),可以在模型窗口输入具体的模型 程序,若模型是小型的数学规划模型,则可直接按照数学公式形式输入,若模型是大型的数 学规划模型,则需要使用复杂的 LINGO 语言来编写程序。
制,其中只有 Demo 版是免费的,其他版本则需要向 LINDO 系统公司购买。
34
LINGO 13.0 有针对 Win32 操作系统和 Win64 操作系统两种,安装程序大小均为 35M 左
第
右,开始安装后,选择接受安装协议,选择安装目录,系统会自动完成安装过程。安装过程
成功后,即可在 Windows 操作系统下运行 LINGO 软件。
1章
第一次运行 LINGO 软件时,系统会弹出一个对话框(见图 1.8),要求输入许可证密码,若安
线 性
装的是正版软件,则在密码框中直接输入密码,然后单击“OK”即可,否则只能使用演示版(也
规 划
就是试用版),即单击“Demo”,出现演示版 LINGO 的相关信息以及相关要求(见图 1.9),单击
LINGO软件的简介与使用
LINGO软件的使用
运算符的优先级: 优先级 运算符 最高 #NOT# —(负号) ^ * / + —(减法) #EQ# #NE# #GT# #GE# #LT# #LE# #AND# #OR# <(=) = >(=) 最低
LINGO软件的使用
常用函数: ABS(X) 绝对值函数 COS(X) 余弦函数 EXP(X) 指数函数 FLOOR(X) 取整函数 LOG(X) 自然对数函数 MOD(X,Y) 模函数 POW(X,Y) 指数函数 SIGN(X) 符号函数 SIN(X) 正弦函数 SQR(X) 平方函数 SQRT(X) 平方根函数 TAN(X) 正切函数 BIN(X) 限定0-1变量 FREE(X) 取消符号限制 GIN(X) 限制整数 等等还有很多~
absx绝对值函数cosx余弦函数expx指数函数floorx取整函数logx自然对数函数modxy模函数powxy指数函数signx符号函数sinx正弦函数sqrx平方函数sqrtx平方根函数tanx正切函数binx限定01变量freex取消符号限制ginx限制整数等等还有很多lingosolverstatus求解程序状态框
LINGO软件的使用
Solver Status 求解程 序状态框: Model 模型类型 State 解的状态 Objective 最优值 Infeasibility 不满足约 束总数 Iterations 迭代次数
பைடு நூலகம்
LINGO软件的使用
Solution Report 解答报告: 解的状态 Objective value 最优值 Extended solver steps 特 殊求解程序运行步数 Total solver iterations 迭 代次数
什么是Lingo
LINGO目录简介步骤LINGO 综述编辑本段简介LINGO是Linear Interactive and General Optimizer的缩写,即“交互式的线性和通用优化求解器”,由美国LINDO系统公司(Lindo System Inc.)推出的,可以用于求解非线性规划,也可以用于一些线性和非线性方程组的求解等,功能十分强大,是求解优化模型的最佳选择。
其特色在于内置建模语言,提供十几个内部函数,可以允许决策变量是整数(即整数规划,包括0-1 整数规划),方便灵活,而且执行速度非常快。
能方便与EXCEL,数据库等其他软件交换数据。
编辑本段步骤一般地,使用LINGO 求解运筹学问题可以分为以下两个步骤来完成:1)根据实际问题,建立数学模型,即使用数学建模的方法建立优化模型;2)根据优化模型,利用LINGO 来求解模型。
主要是根据LINGO 软件,把数学模型转译成计算机语言,借助于计算机来求解。
例题:在线性规划中的应用max Z =5 X1+3 X2+6X3,s.t. X1 +2 X2 + X3 ≤182 X1 + X2 +3 X3 =16X1 + X2 + X3 =10X1 ,X2 ≥0 , X3 为自由变量应用LINGO 来求解该模型,只需要在lingo窗口中输入以下信息即可:max=5•x1 +3•x2 +6•x3 ;x1 +2•x2 + x3 <=18 ;2•x1 + x2+3•x3 =16 ;x1 + x2 + x3 =10 ;@free( x3) ;然后按运行按钮,得到模型最优解,具体如下:Objective value: 46.00000Variable Value Reduced Costx1 14.00000 0.000000x2 0.000000 1.000000x3 -4 .000000 0.000000由此可知,当x1 =14 , x2 =0 , x3 =-4 时,模型得到最优值,且最优值为46。
运筹软件简介
LINGO
• LINGO是Linear Interactive and General
Optimizer的缩写,即“交互式的线性和通用
优化求解器”,由美国LINDO系统公司
(Lindo System Inc.)推出的,可以用于求
解非线性规划,也可以用于一些线性和非 线性方程组的求解等,功能十分强大,是 求解优化模型的常用选择。
但并意味着必须限制该软件包仅只用于处理经济方面的时间序
列。EViews处理非时间序列数据照样得心应手。
• • • • • •
Objective value: 46.00000 Variable Value Reduced Cost x1 14.00000 0.000000 x2 0.000000 1.000000 x3 -4 .000000 0.000000 由此可知,当 x1 =14,x2 =0,x3 =-4 时,模型得到最优值, 且最优值为 46。 • 说明:在利用LINGO 求解线性规划时,如自变量都为非 负的话,在LINGO 中输入的信息和模型基本相同;如自 变量为自由变量,可以使用函数 @free来把系统默认的 非负变量定义自由变量,如实例一中的 x3。
题。其正式版(标准版)则可求解的变量和约
束在1量级以上。
•
LINDO是一个解决二次线性整数规划问题的方便
而强大的工具。这些问题主要出现在商业、工业、
研究和政府等领域。已被证实LINDO能在其中发挥
巨大作用的具体事务包括:产品分销、成分混合、 生产与个人事务安排、存货管理......在这里不一一 列举,但可以肯定的是,LINDO可以大展拳脚的领 域是多不胜数的。LINDO的主要设计原则是,如果
SAS/OR协调问题,产品组合上的最低成本与标准。 SAS/OR时间规划问题。时间规划问题模型是将重复结构作为时间的函数。生
运筹学软件介绍
Liujinghua 2008.5.14
ቤተ መጻሕፍቲ ባይዱ
运筹学软件介绍(5种)
1.LINDO软件 软件 2.LINGO软件 软件 3.Excel 4.MATLAB 5.GAMS
介绍框架
用途 适用 应用领域 具体事务 设计原则 不同版本 网站
1.LINDO软件
用途:LINDO (Linear, Interactive, and Discrete 用途 Optimizer)是一个解决二次线性整数规划问题的方便 是一个解决二次线性整数规划问题的方便 而强大的工具。 而强大的工具。 适用:一些拥有超过50,000个约束条件和 个约束条件和200,000万个 适用:一些拥有超过 个约束条件和 万个 变量的大规模复杂问题。 变量的大规模复杂问题。 应用领域:商业、工业、研究和政府等领域。 应用领域:商业、工业、研究和政府等领域。 具体事务:产品分销、成分混合、 具体事务:产品分销、成分混合、生产与个人事务安 存货管理。 排、存货管理。 设计原则:如果一个用户只是想解决一个简单的问题, 设计原则:如果一个用户只是想解决一个简单的问题, 就不应该在学习LINDO的基本特性上花费太多的准备 就不应该在学习 的基本特性上花费太多的准备 成本。 成本。 不同版本: 学生版至多可求解多达300个 不同版本:LINDO 6 .1 学生版至多可求解多达 个 变量和150个约束的规划问题。其正式版(标准版) 个约束的规划问题。 变量和 个约束的规划问题 其正式版(标准版) 则可求解的变量和约束在1量级以上 量级以上。 则可求解的变量和约束在 量级以上。
LINDO软件LP的注意事项
1.目标函数及各约束条件之间一定要有 目标函数及各约束条件之间一定要有 "Subject to (ST) "分开 分开. 分开 2.变量名不能超过8个字符 变量名不能超过8 变量名不能超过 个字符. 3.变量与其系数间可以有空格,单不能有任何 变量与其系数间可以有空格, 变量与其系数间可以有空格 运算符号(如乘号 如乘号"*"等 运算符号 如乘号 等). 4. 要输入 或>=约束,相应以 或>代替即可 要输入<=或 约束 相应以<或 代替即可 约束, 代替即可. 5.一般 一般LINDO 中不能接受括号 中不能接受括号"()"和逗号 和逗号",", 一般 和逗号 需写成400X1+400X2;10,000 例:400(X1+X2) 需写成 需写成10000. 需写成 6.表达式应当已经过简化。不能出现 表达式应当已经过简化。 表达式应当已经过简化 2X1+3X2-4X1,而应写成 而应写成-2X1+3X2. 而应写成
Lingo软件介绍
当前解的状态 Infeasible(不可行)、Unbounded(无界)、
Interrupted(中断)、undetermined(未确定)
Objective
当前解的目标函 数值
实数
Infeasibility
当前约束不满足 的量
实数
Iterations
目前为止迭代的 次数
非负实数
域名
Lingo状态窗口中关于扩展的求解器各项的含义
Lingo软件介绍
➢变量定界函数对变量的取值范围附加限制,共有以 下四种:
变 @BND(L,X,U):限制L < = X < = U.
量 定
@BIN(X):限制X为0或1。
界 @FREE(X) :取消对X的符号限制(即可取
函 数
负数,0或正数).
@GIN(X):限制X为整数.
➢ 算术运算符 ➢ 逻辑运算符 ➢ 关系运算符
Lingo软件求解的优化模型类型见下图:
优化模型
连续模型
整数模型
线性规划
二次规划
非线性规划ຫໍສະໝຸດ Lingo软件介绍➢解决一个简单的线性规划(LP)问题
Max 5x 2 y; 4x 2 y 10
s.t. 6x 7 y 12
点击图标 运行,屏幕上显示运行状态窗口如下:
变量数目:变量总数 (Total)、非线型变量数 (Nonlinear)、整数变量数 (Integer) 约束变量:约束总数 ( Total )、非线性约束个数 (Nonlinear) 非线性系数数量:总数 ( Total )、非线性项的系数 个数(Nonlinear) 内存使用量:单位为千字节
➢ Lingo最大特色在于可以允许决策变量是整数, 而且执行速度很快;Lingo实际上还是一种建模 语言,即使对优化方面的专业知识了解不多的
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
目标与约束段
对于产品数量的平衡方程而言, 由于下标I=1时的约束关系 与I=2,3,4时有所区别(因为定义的变量INV是不包含INV(0)), 因 此把I=1的约束关系单独写出“INV(1)=10+RP(1)+OP(1)-DEM(1);”, 而对I=2,3,4对应的约束, 增加了一个逻辑表达式来刻划: @FOR(QUARTERS(I)|I#GT#1: INV(I)=INV(I-1)+RP(I)+OP(I)-DEM(I););
② 变量定界函数 @GIN(X): @BIN(X): @FREE(X): 限制X为整数. 限制X为0或1. 取消对X的符号限制.
@BND(L,X,U): 限制 L ≤ X ≤ U .
注: 有关其它函数的介绍, 请参考LINGO的帮助文件.
4、运算符说明 ① 运算符 算数运算符: +(加法), -(减法或负号), *(乘法), /(除法), ^(求幂). 关系运算符: <(即<=,小于等于), >(即>=,大于等于). 注:优化模型中的约束一般没有严格小于、严格大于关系. =(等于),
逻辑运算符: #AND#(与), #EQ#(等于), #OR#(或), #NE#(不等于), #NOT#(非); #GT#(大于).
#GE#(大于等于), #LT#(小于),#LE#(小于等于).
注: 逻辑运算的结果为“真”(TRUE)和“假”(FALSE), LINGO 中用数字1代表TRUE, 其它值都是FALSE.
2、状态窗口说明(例1)
Variables(变量数量) Total(变量总数) Nonlinear(非线性变量) Integer(整数数量)
注:由于LINGO对中文操作系 统的兼容性不好, 所以有些 显示字符和单词被截掉了.
状态窗口说明
Constraints(约束数量) Nonzeros(非零系数数量) 内存使用量 求解花费的时间
软件简介
一、集合的基本用法 二、基本集合与派生集合 三、集合的使用小结
一、集合的基本用法
例2: 某帆船公司需要决定下四个季度的帆船生产量. 下四个季度的帆船需求量分别是40条,60条,75条,25条, 这些需求必须按时满足. 每个季度正常的生产能力是40 条帆船, 每条船的生产费用为400美元. 如果加班生产, 每条船的生产费用为450美元. 每个季度末, 每条船的库 存费用为20美元. 假定生产提前期为0, 初始库存为10条 帆船. 如何安排生产可使总费用最小?
LINGO: Linear INteractive and General Optimizer 即“交互式的线性和通用优化求解器”, 它是一种专门用 于求解最优化问题的软件,由美国芝加哥大学的 Linus Schrage 教授于1980年开发, 其公司(LINDO系统公司) 的网址为: 线性规划(LP) LINGO软件能求解的优化模型: 非线性规划(NLP) 二次规划(QP)
例1的运算结果:
主 窗 口 模型窗口 报告窗口 状态窗口
1、主窗口与模型窗口说明
定 位 某 行
模 型 求 解
模 型 图 示
查 找
匹 配 括 号
显 示 解 答
选 项 设 置
文件类型
*.lg4:LINGO格式的模型文件 *.lng:文本格式的模型文件 *.ldt: LINGO数据文件 *.ltf: LINGO命令脚本文件 *.lgr: LINGO报告文件 *.ltx: LINGO格式的文本文件 *.mps: 数学规划系统格式的模型文件
⑥ 在LINGO中, 以@开头的 都是函数的调用. ⑦ LINGO已假定所有变量 非负, 可用限定变量取值 范围的函数@BIN、@GIN、@FREE 、@BND改变变 量的非负假定.
2、关键字说明 MODEL: END TITLE 主要关键字:
(多为蓝色字符)
模型的开始 模型的结束 对模型命名 目标最大化 集合段开始 集合段结束 数据段开始 数据段结束
分析: 该问题考虑的是4个季度, 求解过程中需要设16 个变量(需求量、正常生产的产量、加班生产的产量、库 存量等), 若考虑的是更多季度(如1000个)的时候, 则问 题比较麻烦. 下面利用集合的概念, 可简化问题的求解. 解: 用DEM,RP,OP,INV分别表示需求量、正常生产的产 量、加班生产的产量、库存量, 则DEM,RP,OP,INV对每 个季度都应该有一个对应的值, 即它们都是由4个元素组 成的数组.
,6; j = 1,2 .
目标函数: 总吨公里数最小
min f = ∑∑ cij ( x j − ai ) 2 + ( y j − bi ) 2
j =1 i =1 2 6
约束条件:①各工地的日用量必需满足
∑c
j =1
2
ij
= di , i = 1,
,6
约束条件:②各料场的运送量不能超过日储量
∑c
i =1
集合QUARTERS的属性
DEM
RP
OP
INV
1
集合QUARTERS
2
3
4
该模型的LINGO程序为:
集 合 段 数 据 段
目标与约束段
①集合段
语句“QUARTERS/1,2,3,4/:DEM,RP,OP,INV;”就是定 义了集合QUARTERS={1,2,3,4},以及对应于该集合的属性 DEM,RP,OP,INV,其结果正是定义了16个变量名DEM(1), DEM(2), DEM(3), ‥‥‥.
状态窗口说明
求解器状态框 模型的类型 解的状态
Objective(解的目标函数值) Infeasibility(约束不满足总量)
到目前为止的迭代次数 扩展的求解器状态框
3、报告窗口说明(例1)
得到局部最优解 变量的检验数
扩展求解步骤数
松弛或剩余变量的值
对偶价格的值
第二节 在LINGO中使用集合
② 运算符的优先级 优先级
最高
运算符
#NOT#,-(负号) ^ *,/ +,-(减法) #EQ#, #NE#, #GT#, #GE#, #LT#, #LE# #AND#,#OR#
最低
<,=,>
二、LINGO的窗口介绍
LINGO的主窗口 LINGO模型窗口 LINGO的窗口: LINGO状态窗口 LINGO报告窗口
一、LINGO的基本特征
例1: 用LINGO求解二次规划问题:
目标函数
2 max 98 x1 + 277 x2 − x12 − 0.3 x1 x2 − 2 x2
100 ⎪ ⎨ x1 ≤ 2 x2 ⎪ x , x ≥ 0 为整数 ⎩ 1 2
解: 直接在LINGO的模型窗口中输入程序:
MAX SETS: ENDSETS DATA: ENDDATA
3、LINGO函数说明 基本的数学函数 变量定界函数 文件输入输出函数 LINGO主要函数: 集合循环函数 集合操作函数 概率中的函数 结果报告函数
① 基本的数学函数 @ABS(X): @COS(X): @EXP(X): @LOG(X): 绝对值函数, 返回X的绝对值. 余弦函数,返回X的余弦值(X为弧度). 指数函数, 返回 e X 的值. 自然对数函数, 返回X的自然对数值.
目标函数是所有费用的和:
min ∑ [400 RP( I ) + 450OP ( I ) + 20 INV ( I )]
I =1
4
约束条件有:
⑴能力限制 RP ( I ) ≤ 40, I = 1, ⑵产品数量的平衡方程
,4
INV (0) = 10
INV ( I ) = INV ( I − 1) + RP ( I ) + OP ( I ) − DEM ( I ) I = 1,
运行该LINGO程序得到解答报告: 全局最优解: RP=(40,40,40,25) OP=( 0,10,35,0 ) 最小成本=78450
二、基本集合与派生集合
例3: 建筑工地的位置(用平面坐标a,b表示,距离单 位: km)及水泥日用量d(单位:t)由表2-1给出. (1)目前有两个临时料场位于P(5,1),Q(2,7), 日储量 各有20t. 求从P,Q两料场分别向各工地运送多少吨水泥, 使总的吨公里数最小. (2)为进一步减少吨公里数, 打算改建两个日储量仍各 为20t的新料场, 两个新的料场应建在何处, 节省的吨公 里数有多大?
1、程序语言说明
① LINGO程序以“MODEL”开始,以“END”结束. 它们之间由 语句组成, 且每个语句都以分号“;”结尾. ② 一行中感叹号“!”后面的文字将被认为是注释语句, 不参与模型的建立(内容为绿色字符).
③ LINGO中的语句顺序 是不重要的,因为LINGO 总是根据“Max=”或“Min=” 语句寻找目标函数,其它语句都是约束条件. ④ LINGO程序中不区分大小写字母.(实际上任何小写字 符将被转换为大写字符) ⑤ LINGO中的变量必须以字母开头,且最多不能超过32个 字符.
6
ij
≤ e j , j = 1,2
当使用临时料场时(问题(1)),决策变量只有 cij ,所以 此时的优化模型为线性规划模型; 当为新建料场选址时 (问题(2)), 决策变量为 cij 和 x j , y j ,所以在新建料场时的 优化模型是非线性规划模型(NLP).
2 6 下面先用集合的概念求解NLP模型(问题(2)), 而把现 min f = ∑∑ cij ( x j − ai ) 2 + ( y j − bi ) 2 j =1 i =1 有临时料场的位置作为初始解告诉LINGO.
大学数学建模竞赛系列讲座
主讲人:薛 震
中北大学数学系
E-mail:xuezhen@
主要内容: