第1讲 Lingo软件入门
lingo入门教程(共55张)
3 3
A2
8 67
A3 4
7
B2
8 9
5 C2 6
T
第18页,共55页。
分析
(fēnxī)
6 A1 5 6
B1 6 C1
S
3 3
A2
8 67
A3 4
7
B2
8 9
5 C2 6
T
假设从S到T的最优行驶路线 P 经过城市C1, 则P中从S到C1的子路也一定 是从S到C1的最优行驶路线; 假设 P 经过城市C2, 则P中从S到C2的子路也一定是从S到C2的最优行驶路线. 因此, 为得到从S到T的最优行驶路线, 只需要先求出从S到Ck(k=1,2)的最 优行驶路线, 就可以方便地得到从S到T的最优行驶路线.
第19页,共55页。
分析
(fēnxī)
6 A1 5 6
B1 6 C1
S
3 3
A2
8 67
A3 4
7
B2
8 9
5 C2 6
T
此例中可把从S到T的行驶过程分成4个阶段,即 S→Ai (i=1,2 或3), Ai → Bj(j=1或2), Bj → Ck(k=1或2), Ck → T. 记d(Y,X)为城 市Y与城市X之间的直接距离(若这两个城市之间没有道路直 接相连,则可以认为直接距离为∞),用L(X)表示城市S到城市
L B2 minL A1 5, L A2 6, L A3 4 7 L A3 4; L C1 minL B1 6, L B2 8 15 L B2 8;
略2去),最小运量136.2275(吨公里)。
1
3
5
0
0
1
2
3
4
5
6
之一(Lingo初步)
Lindo /Lingo 软件初步Lindo/Lingo 软件是美国Lindo 系统公司开发的一套专门用于求解优化模型的软件。
Lindo 系统公司面向全社会免费提供该软件的“演示版”,我们现在使用的就是这个演示版。
占领硬盘空间大约50MB .一.Lingo 入门1.编写简单的Lingo 程序Lingo 程序:在“模型窗口”中,按Lingo 语法格式,输入一个完整的优化模型。
(注意:一个程序就是一个优化模型)例1 要求解线性规划问题 .0,,1253,1034..,32max ≥≤+≤++=y x y x y x t s y x z输入程序:max=2*x+3*y;4*x+3*y<=10;3*x+5*y<=12;例2 求解 .,0,,2,100..,23.027798max 21212122212121且都是整数≥≤≤+---+x x x x x x t s x x x x x x输入程序:max=98*x1+277*x2-x1^2-0.3*x1*x2-2*x2^2;x1<=2*x2;x1+x2<=100;@gin(x1); @gin(x2);2.语法格式(1)目标函数 max= 或 min=(2)每个语句的结尾要有“;”(3)程序中,各个语句的先后次序无关(4)自动默认各个变量均为大于等于零的实数(5)不区分大写、小写(6)程序中的“<=”、“<”等同于原模型中的“≤”程序中的“>=”、“>”等同于原模型中的“≥”(7)对一个特定的变量 x ,进行限制:@free(x) :把x 放宽为任意实数@gin(x) :限制x 为整数@bin(x) :限制x 只能取0或1@bnd(-6,x,18) :限制x 为闭区间[-6,18]上的任意实数3.练习题题1:求解“整数规划”问题.,,,,10..,432max 43214321432124232221+∈≥+++++++----Z x x x x x x x x t s x x x x x x x x题2:求解“0----1规划”问题.}1,0{,,,,2..,432max 43214321432124232221∈≥+++++++----x x x x x x x x t s x x x x x x x x题3:某学校游泳队要从5名队员中选4名参加4乘100米混合泳接力赛。
培训教案——LINGO(一)
培训教案——LINGO(一)LINGO是一款常用的线性规划软件,它能够方便地解决复杂问题。
培训LINGO,需要深入了解软件的使用方法和解决实际问题的能力。
下面就LINGO培训的内容进行分点介绍。
一、LINGO的基础知识LINGO的基础知识包括软件的基本功能和操作。
需要讲解LINGO的界面、工具栏、菜单栏等。
初次接触LINGO的学员需要掌握LINGO的一些基本用法,比如如何输入数据、如何设定优化目标,如何设置约束等,这些都是LINGO的基本操作。
二、LINGO求解模型了解LINGO的基本操作之后,需要讲解LINGO的求解模型。
LINGO的数学模型是LINGO软件解决问题必需的部分。
对于LINGO求解模型的学习,需要学员掌握数学模型的建立方法和标准的数学模型。
培训学员掌握LINGO的求解模型知识是LINGO培训的核心。
三、LINGO的高级应用LINGO的高级应用需要讲授如何利用LINGO解决实际问题,需要讲解如何构建多约束模型来描述现实中的问题,如何设置变量、常数和目标函数等。
高级应用的讲授需要结合实例,让学员深入了解LINGO的实际应用场景,提高解决实际问题的能力。
四、LINGO的调试LINGO的调试是LINGO培训的重要组成部分。
在LINGO求解过程中,有时会出现错误,导致模型不能正常求解。
因此,需要讲解LINGO调试的方法和技巧,使得学员具备调试LINGO模型的能力。
五、LINGO应用举例为了让学员进一步巩固LINGO的知识,需要讲解一些LINGO的应用举例。
举例的内容包括:产品组合问题、生产调度问题、财务规划问题、运输规划问题等。
通过这些示例,让学员对LINGO的应用有更加深刻的理解。
六、LINGO的作业练习培训LINGO需要进行实际操作,软件操作的熟练程度可以通过作业考核来体现。
作业练习的难度需要逐渐增加,从简单到复杂地设置模型,巩固培训成果。
LINGO培训需要根据学员的水平进行分类管理,加强培训的个性化和针对性。
第1讲Lingo软件基础学习(2014)
第1讲Lingo软件入门司守奎烟台市,海军航空工程学院数学教研室Email:sishoukui@1 Lingo软件的基本语法1.1 集合集合部分的语法为sets:集合名称1/成员列表1/:属性1_1,属性1_2,…,属性1_n1;集合名称2/成员列表2/:属性2_1,属性2_2,…,属性2_n2;派生集合名称(集合名称1,集合名称2):属性3_1,…,属性3_n3;endsets例26sets:product/A B/;machine/M N/;week/1..2/;allowed(product,machine,week):x;endsets1.2 数据数据部分的语法为data:属性1=数据列表;属性2=数据列表;enddata1.3 计算计算段部分不能含有变量,必须是已知数据的运算。
calc:b=0;a=a+1;endcalc1.4 模型的目标函数和约束条件这里就不具体给出了,下面通过具体例子给出。
1.5 子模型在LINGO 9.0 及更早的版本中,在每个LINGO 模型窗口中只允许有一个优化模型,可以称为主模型(MAIN MODEL)。
在LINGO 10.0 中,每个LINGO 模型窗口中除了主模型外,用户还可以定义子模型(SUBMODEL)。
子模型可以在主模型的计算段中被调用,这就进一步增强了LINGO 的编程能力。
子模型必须包含在主模型之内,即必须位于以“MODEL:”开头、以“END”结束的模块内。
同一个主模型中,允许定义多个子模型,所以每个子模型本身必须命名,其基本语法是:SUBMODEL mymodel:可执行语句(约束+目标函数);ENDSUBMODEL其中mymodel 是该子模型的名字,可执行语句一般是一些约束语句,也可能包含目标函数,但不可以有自身单独的集合段、数据段、初始段和计算段。
也就是说,同一个主模型内的变量都是全局变量,这些变量对主模型和所有子模型同样有效。
如果已经定义了子模型mymodel,则在计算段中可以用语句“@SOLVE( mymodel);”求解这个子模型。
第一讲 初识LINGO
Best Obj Obj Bound Steps
目前为止找到的可行解的最佳 实数 目标函数值 目标函数值的界 实数
特殊求解程序当前运行步数: 非负整数 分枝数(对B-and-B程序); 子问题数(对Global程序); 初始点数(对Multistart程序) 有效步数 非负整数
13
Active
⑶“Variables” 表示变量数量(其中包括变量总数、非线性 变量数、整数变量数) ⑷“Constraints” 表示约束数量(约束总数、非线性约束个数) ⑸“Nonzeros” 表示非零系数数量(总数、非线性项的个数) ⑹“Generator Memory Used(K)”
2
LINDO和LINGO软件能求解的优化模型
优化模型
连续优化
整数规划(IP)
线性规划 (LP)
二次规划 (QP)
非线性规划 (NLP) LINGO
3
LINDO
LINDO/LINGO 软件的求解过程
LINDO/LINGO预处理程序 1、确定常数 2、识别类型 IP 全局优化(选) LP NLP 分枝定界管理程序
113求解状态窗口的参数解释求解扩展求解变量数量约束数量非零系数数量内存使用量求解花费的时间12solverstatus为求解器状态框各子项的含义及状态表域名含义可能的显示modelclass当前模型的类型lpqpilpiqppilpnlpinlppinlp以i开头表示ip以pi开头表示pipstate当前解的状态globaloptimumlocaloptimumfeasibleinfeasibleunboundedinterruptedundeterminedobjective目标函数值实数infeasibility当前约束不满足的总量实数即使该值为0当前解也可能不可行因为这个量中没有考虑用上下界形式给出的约束iterations目前为止的迭代次数非负整数13extendedsolverstatus
LINGO使用教程
LINGO 使用教程LINGO 是用来求解线性和非线性优化问题的简易工具。
LINGO 内置了一种建立最优化模型的语言,可以简便地表达大规模问题,利用LINGO 高效的求解器可快速求解并分析结果。
§1 LINGO 快速入门当你在windows 下开始运行LINGO 系统时,会得到类似下面的一个窗口:外层是主框架窗口,包含了所有菜单命令和工具条,其它所有的窗口将被包含在主窗口之下。
在主窗口内的标题为LINGO Model – LINGO1的窗口是LINGO 的默认模型窗口,建立的模型都都要在该窗口内编码实现。
下面举两个例子。
例 如何在LINGO 中求解如下的LP 问题: ⎪⎪⎩⎪⎪⎨⎧≥≤+≥≥++0,6002100350..32min212112121x x x x x x x t s x x 在模型窗口中输入如下代码:min =2*x1+3*x2; x1+x2>=350; x1>=100; 2*x1+x2<=600;然后点击工具条上的按钮即可。
例使用LINGO软件计算6个发点8个收点的最小费用运输问题。
产销单位运价如下表。
使用LINGO软件,编制程序如下:model:!6发点8收点运输问题;sets:warehouses/wh1..wh6/: capacity;vendors/v1..v8/: demand;links(warehouses,vendors): cost, volume;endsets!目标函数;min=@sum(links: cost*volume);!需求约束;@for(vendors(J):@sum(warehouses(I): volume(I,J))=demand(J));!产量约束;@for(warehouses(I):@sum(vendors(J): volume(I,J))<=capacity(I));!这里是数据;data:capacity=60 55 51 43 41 52;demand=35 37 22 32 41 32 43 38;cost=6 2 6 7 4 2 9 54 95 3 8 5 8 25 2 1 9 7 4 3 37 6 7 3 9 2 7 12 3 9 5 7 2 6 55 5 2 2 8 1 4 3;enddataend然后点击工具条上的按钮即可。
第1讲 Lingo软件入门
1.3 LINGO 软件的基本语法
1.3.1 集合 集合部分的语法为 sets: 集合名称 1/成员列表 1/:属性 1_1,属性 1_2,…,属性 1_n1; 集合名称 2/成员列表 2/:属性 2_1,属性 2_2,…,属性 2_n2; 派生集合名称(集合名称 1,集合名称 2) :属性 3_1,…,属性 3_n3; endsets
1.2
1.2.1 LINGO 的模型窗口
LINGO 软件的界面介绍
求解按钮
图 1.1 LINGO 的模型窗口
模型窗口输入格式要求: (1)LINGO 的数学规划模型包含目标函数、决策变量、约束条件三个要素。 (2)在 LINGO 程序中,每一个语句都必须要用一个英文状态下的分号结束,一个语 句可以分几行输入。 (3)LINGO 的注释以英文状态的!开始,必须以英文状态下的分号结束; (4)LINGO 的变量不区分字母的大小写,必须以字母开头,可以包含数字和下划线,
4
图 1.4 LINGO Options 设置
勾选了 Prices 选项后,运行 LINGO 程序,输出结果窗口中包含灵敏度分析,如图 1.5 所示。
最优目标函数值
第一个约束条件 第三个约束条件
图 1.5 灵敏度分析
目标函数
从结果可知,目标函数的最优值为 3360,决策变量 x1 20, x2 30 。 (1)reduced cost 值对应于单纯形法计算过程中各变量的检验数。 (2)图 1.5 中红色方框表示第二个约束条件,Slack or Surplus 值为 0 表示该约束松弛 变量为 0,约束等号成立,为紧约束或有效约束。蓝色方框表示第三个约束松弛变量为 40, 不等号成立,有剩余。 (3) Dual Price 对应影子价格, 红色方框表示当第一个约束条件右端常数项增加 1 个单 位,即由 50 变为 51 时,目标函数值增加 48,即约束条件 1 所代表的资源的影子价格。蓝 色方框表示,第三个约束条件右端常数项增加 1 个单位时,目标函数值不变。 2.确保最优基不变的系数变化范围 如果想要研究目标函数的系数和约束右端常数项系数在什么范围变化 (假定其他系数保 持不变)时,最优基保持不变。此时需要首先勾选图 1.6 所示的选项。
LINGO基本教程(完整版)pdf
LINGO基本教程(完整版)pdf一、教学内容本节课我们使用的教材是《LINGO基本教程》,我们将学习第14章的内容。
第1章介绍LINGO软件的基本操作,包括界面的熟悉、模型的建立等;第2章学习线性规划模型的建立与求解;第3章讲解非线性规划模型的建立与求解;第4章介绍整数规划模型的建立与求解。
二、教学目标1. 学生能够熟练操作LINGO软件,建立和求解线性、非线性以及整数规划模型。
2. 学生能够理解线性、非线性以及整数规划的基本概念,并能够运用到实际问题中。
3. 学生通过学习LINGO基本教程,提高自己的逻辑思维能力和解决实际问题的能力。
三、教学难点与重点重点:熟练操作LINGO软件,建立和求解线性、非线性以及整数规划模型。
难点:理解线性、非线性以及整数规划的基本概念,以及如何将这些概念运用到实际问题中。
四、教具与学具准备教具:多媒体教学设备、投影仪、计算机。
学具:学生计算机、LINGO软件、教材《LINGO基本教程》。
五、教学过程1. 实践情景引入:以一个简单的线性规划问题为切入点,引导学生思考如何利用LINGO软件求解。
2. 讲解教材内容:分别讲解第14章的内容,包括LINGO软件的基本操作、线性规划模型的建立与求解、非线性规划模型的建立与求解以及整数规划模型的建立与求解。
3. 例题讲解:针对每个章节的内容,选择合适的例题进行讲解,让学生通过例题理解并掌握相关知识点。
4. 随堂练习:在每个章节讲解结束后,安排随堂练习,让学生通过练习巩固所学知识。
5. 课堂互动:鼓励学生提问,解答学生在学习过程中遇到的问题。
6. 板书设计:每个章节的重要知识点和操作步骤进行板书设计,方便学生复习。
7. 作业布置:布置与本节课内容相关的作业,巩固所学知识。
六、作业设计1. 作业题目:最大化问题:目标函数:Z = 2x1 + 3x2约束条件:x1 + x2 ≤ 62x1 + x2 ≤ 8x1, x2 ≥ 0最大化问题:目标函数:Z = x1^2 + x2^2约束条件:x1 + x2 ≤ 5x1^2 + x2^2 ≤ 10x1, x2 ≥ 0最大化问题:目标函数:Z = 3x1 + 2x2约束条件:x1 + x2 ≤ 42x1 + x2 ≤ 6x1, x2 均为整数2. 答案:(1)线性规划问题的解为:x1 = 2, x2 = 4(2)非线性规划问题的解为:x1 = 3, x2 = 2(3)整数规划问题的解为:x1 = 2, x2 = 2七、板书设计1. 第1章:LINGO软件的基本操作(1)界面的熟悉(2)模型的建立2. 第2章:线性规划模型的建立与求解(1)目标函数的定义(2)约束条件的设置(3)求解线性规划问题3. 第3章:非线性规划模型的建立与求解(1)目标函数的定义(2)约束条件的设置(3)求解非线性规划问题4. 第4章:整数规划模型的建立与求解(1)目标函数的定义(2)约束条件的设置(3)求解整数规划问题八、课后反思及拓展延伸本节课通过实践情景引入,使学生能够快速融入学习状态。
lingo入门教程
运送量为cij 。
2 6
2
2
MIN f
cij x j ai y j bi
1
j1 i1
2
s.t.
cij di , i 1, 2,L , 6
2
j 1
6
cij ej , j 1, 2
3
i 1
使用现有临时料场时,决策变量只有 c(ij 非负),所以这是LP模型;当为新
建料场选址时决策变量为
c ij
和
x j , y j,由于目标函数
f对
x ,y
j
j
是非线性的,
所以在新建料场时是NLP模型。先解NLP模型,而把现有临时料场的位置作
为初始解告诉LINGO。
本例中集合的概念
利用集合的概念,可以定义需求点DEMAND和供应点 SUPPLY两个集合,分别有6个和2个元素(下标)。但决 策变量(运送量) cij 与集合DEMAND和集合SUPPLY都 有关系的。该如何定义这样的属性?
输出结果: 运行菜单命令“LINGO|Solve”
最大利润=11077.5
最优整数解 X=(35,65)
一个简单的LINGO程序
LINGO的基本用法的几点注意事项
•LINGO中不区分大小写字母;变量和行名可以超过8个字符,但 不能超过32个字符,且必须以字母开头。 •用LINGO解优化模型时已假定所有变量非负(除非用限定变量取 值范围的函数@free或@sub或@slb另行说明)。 •变量可以放在约束条件的右端(同时数字也可放在约束条件的左 端)。但为了提高LINGO求解时的效率,应尽可能采用线性表达 式定义目标和约束(如果可能的话)。 •语句是组成LINGO模型的基本单位,每个语句都以分号结尾,编 写程序时应注意模型的可读性。例如:一行只写一个语句,按照 语句之间的嵌套关系对语句安排适当的缩进,增强层次感。 •以感叹号开始的是说明语句(说明语句也需要以分号结束))。
12 Lingo软件基础1
练习
EX1 解线性规划
max z = − x1 + x 2 2 x1 − x 2 ≥ − 2 x − 2x ≤ 2 1 2 s .t . x1 + x 2 ≤ 5 x1 ≥ 0
EX2 求解问题
min z = − x 2 + 2 x 3 x1 x 2 s .t . x2 x j − 2 x2 + x3 = 2 − 3x3 + x4 = 1 − x3 + x5 = 2 ≥ 0 ; j = 1, 2 ,..., 5
• 当前时间
外层是主框架窗口, 外层是主框架窗口,包含了所有菜单命令和工 具条,其它所有的窗口将被包含在主窗口之下。 具条,其它所有的窗口将被包含在主窗口之下。 在主窗口内的标题为LINGO LINGO1的窗 在主窗口内的标题为LINGO Model – LINGO1的窗 口是LINGO的默认模型窗口, LINGO的默认模型窗口 口是LINGO的默认模型窗口,建立的模型都都要 在该窗口内编码实现。 在该窗口内编码实现。 例 如何在LINGO中求解如下的LP问题: 在模型窗口中输入如下代码: min=2*x1+3*x2; x1+x2>=350; x1>=100; 2*x1+x2<=600; 然后点击工具条上的按钮 即可。
LINGO软件的求解过程
1. 确定常数 2. 识别类型 LINDO/LINGO预处理程序 预处理程序 LP QP NLP IP 全局优化(选 全局优化 选)
分枝定界管理程序 ILP 线性优化求解程序 1. 单纯形算法 2. 内点算法 选) 内点算法(选 IQP INLP
非线性优化求解程序 1、顺序线性规划法(SLP) 、顺序线性规划法 2、广义既约梯度法 选 、广义既约梯度法(GRG) (选) 3、多点搜索 、多点搜索(Multistart) (选) 选
LINGO的基本用法
试确定各货栈到各客户处的货物调运数量, 使总的运输费用 最小
返回X的整数部分(向最靠近0的方向取整)
@LGM(X)
返回X的gamma函数的自然对数值
@MOD(X,Y)
运算对象是两个数
#GT# #GE#
左边大于右边时为真,否则为假 左边大于或等于右边时为真,否则为假
#LT#
左边小于右边时为真,否则为假
#LE#
左边小于或等于右边时为真,否则为假
预算对象是逻辑值 或逻辑表达式
#NOT# #AND# #OR#
单目运算符,表示对运算对象取反(即真变假,假变真) 两个运算对象都真时为真,否则为假 两个运算对象都假时为假,否则为真
◆生成图形
由模型生成图形,以矩阵形式显示 模型的系数.
◆调试
调试结果,找到充分行(Sufficient Rows)和必要行 (Necessary Rows). ◆模型统计资料
◆查看(以为本方式显示模型内容)
13
LINGO 教 程
◆命令行窗口
主要是为用户交互地测试命令脚本 而设计.(通常不用)
◆状态窗口
@FOR(VD(J): @SUM(WH(I): X(I, J)) =DJ(J));
21
§1.4 LINGO的运算符和函数
一、 LINGO的常用运算符. 1. 算术运算符.
LINGO 教 程
^* / + -
lingo入门
lingo入门lingo入门教程之一--- 初识lingoingo对于一些线性或者非线性的规划,优化问题非常有效首先介绍一下,在lingo中运行程序时出现的页面(在工具栏点击类似靶子一样的图标便可运行)Solver status:求解器(求解程序)状态框Model Class:当前模型的类型:LP,QP,ILP,IQP,PILP,PIQP,NLP,INLP,PINLP(以I开头表示IP,以PI 开头表示PIP)State:当前解的状态:"Global Optimum", "LocalOptimum", "Feasible", "Infeasible“(不可行), "Unbounded “(无界), "Interrupted“(中断), "Undetermined“(未确定)Object:解的目标函数值Infeasibility:当前约束不满足的总量(不是不满足的约束的个数):实数(即使该值=0,当前解也可能不可行,因为这个量中没有考虑用上下界命令形式给出的约束)Iteration:目前为止的迭代次数Extend solverstatus:扩展的求解器(求解程序)状态框Solver type:使用的特殊求解程序:Bestobj :目前为止找到的可行解的最佳目标函数值Objbound:目标函数值的界Steps:特殊求解程序当前运行步数:Active:有效步数Variables(变量数量):变量总数(T otal)、非线性变量数(Nonlinear)、整数变量数(Integer)。
Constraints(约束数量):约束总数(T otal)、非线性约束个数(Nonlinear)。
Nonzeros(非零系数数量):总数(Total)、非线性项系数个数(Nonlinear)。
GeneratorMemory Used (K) (内存使用量)ElapsedRuntime (hh:mm:ss)(求解花费的时间)运行之后页面介绍(这里的运行界面并不是与上面的运行过程中出现界面一致,即并非来自于同一个程序运行出现)第一行表示在经过457次迭代后得到局部最优解第二行给出该局部最优解的具体值下面给出取局部最优值时,x1 x2的具体取值这里求解的是局部最优解,如果想求出全局最优解,可以进行页面设置:lingo --> option --> global solver --> 勾选use globalsolver对于运行结果也可以另存为,格式一般为ldt,因为有时候对于求解一个问题,或许需要运行很久才可以得出结果,所以没必要每次为了看结果都运行,而是运行成功一次后便把结果保存下来注意事项LINGO总是根据“MAX=”或“MIN=”寻找目标函数;程序语句的顺序一般不重要,既可以随意调换;程序运用函数时都是以@开头;程序中的变量默认为非负数,想要改变变量类型必须有相应函数调整程序中变量不区分大小写;语句必须以分号结尾;注释以!开始,且注释语句后面必须也有分号,注释默认注释到第一个分号处,意思是分号前面会全部被注释掉。
Lingo教程(一)
NLP
IP
分枝定界管理程序
ILPBiblioteka INLPIQP线性优化求解程序
非线性优化求解程序
图 3-2 LINDO/LINGO 软件的求解过程
第 38 页 共 112 页
谢金星:MATLAB 优化工具箱和 LINDO/LINGO 优化软件
第 39 页 共 112 页
2、识别优化模型的类型:对等式约束的预处理完成后,预处理程序能自动识别优化模型 的类型,从而决定下一步采用什么求解程序。如果模型是连续线性规划,下一步直接调用线 性优化求解程序;如果模型是连续非线性规划,下一步直接调用非线性优化求解程序;如果 模型是整数规划,则下一步直接调用分枝定界管理程序。
优化模型
连续优化
整数规划
线性规划
二次规划
非线性规划
LINDO
LINGO
图 3-1 LINDO 和 LINGO 软件能求解的优化模型
第 37 页 共 112 页
谢金星:MATLAB 优化工具箱和 LINDO/LINGO 优化软件
第 38 页 共 112 页
此外,LINDO 系统公司还提供了 LINDO/LINGO 软件与其它开发工具(如 C++和 Java 等语言)的接口软件 LINDO API(Application Program Interface),因此使 LINDO 和 LINGO 软件还能方便地融入到用户应用软件的开发中去。
线性优化求解程序通常使用单纯形算法,对高级版本的 LINDO/LINGO 软件,为了能解 大规模问题,也可以使用内点算法。非线性优化求解程序采用的是顺序线性规划法(Sequential Linear Programming, 简称 SLP),即通过迭代求解一系列线性规划来达到求解非线性规划的 目的。非线性优化求解程序也可以使用其他算法,如广义既约梯度法(Generalized Reduced Gradient, 简称 GRG),并可以自动选用多个初始点开始进行迭代,以便增加找到全局最优解 的可能性。分枝定界管理程序用于管理整数规划问题的分枝定界算法,在运行中还要不断调 用线性优化求解程序和非线性优化求解程序进行定界处理。
1.LINGO软件的基本使用方法
• 运行状态窗口
当前模型的类型 :LP,QP,ILP,IQP,PILP, , , , , , PIQP,NLP,INLP,PINLP (以I开头表示 , , , 开头表示 IP,以PI开头表示 开头表示PIP) , 开头表示 当前解的状态 : "Global Optimum", "Local Optimum", "Feasible", "Infeasible“(不可行 不可行), 不可行 "Unbounded“(无界 无界), 无界 "Interrupted“(中断 中断), 中断 "Undetermined“(未确定 未确定) 未确定 当前约束不满足的总量(不是不 当前约束不满足的总量 不是不 满足的约束的个数):实数 实数( 满足的约束的个数 实数(即使 该值=0,当前解也可能不可行, 该值 ,当前解也可能不可行, 因为这个量中没有考虑用上下界 命令形式给出的约束) 命令形式给出的约束)
第一次运行时提示输入授权密码,如图: 第一次运行时提示输入授权密码,如图:
LINGO软件的主要特色 软件的主要特色
两种命令模式 Windows模式: 通过下拉式菜单命令驱动 模式: 通过下拉式菜单命令驱动LINGO运 模式 运 多数菜单命令有快捷键, 行(多数菜单命令有快捷键,常用的菜单命令有快捷 按钮),图形界面,使用方便; 按钮),图形界面,使用方便; ),图形界面
(这里主要介绍这种模式 这里主要介绍这种模式) 这里主要介绍这种模式
命令行 模式:仅在命令窗口(Command Window)下操 模式:仅在命令窗口 下操 通过输入行命令驱动LINGO运行 。 作,通过输入行命令驱动 运行
LINGO界面简介 界面简介
lingo教程
LINGO 是用来求解线性和非线性优化问题的简易工具。
LINGO 内置了一种建立最优化模型的语言,可以简便地表达大规模问题,利用LINGO 高效的求解器可快速求解并分析结果。
§1 LINGO 快速入门当你在windows 下开始运行LINGO 系统时,会得到类似下面的一个窗口:外层是主框架窗口,包含了所有菜单命令和工具条,其它所有的窗口将被包含在主窗口之下。
在主窗口内的标题为LINGO Model – LINGO1的窗口是LINGO 的默认模型窗口,建立的模型都都要在该窗口内编码实现。
下面举两个例子。
例1.1 如何在LINGO 中求解如下的LP 问题:0,6002100350..32min 212112121≥≤+≥≥++x x x x x x x t s x x在模型窗口中输入如下代码: min =2*x1+3*x2; x1+x2>=350; x1>=100;2*x1+x2<=600;然后点击工具条上的按钮 即可。
例1.2 使用LINGO 软件计算6个发点8个收点的最小费用运输问题。
产销model :!6发点8收点运输问题; sets :warehouses/wh1..wh6/: capacity; vendors/v1..v8/: demand;links(warehouses,vendors): cost, volume; endsets !目标函数;min =@sum (links: cost*volume); !需求约束;@for (vendors(J):@sum (warehouses(I): volume(I,J))=demand(J)); !产量约束;@for (warehouses(I):@sum (vendors(J): volume(I,J))<=capacity(I));!这里是数据; data :capacity=60 55 51 43 41 52;demand=35 37 22 32 41 32 43 38; cost=6 2 6 7 4 2 9 5 4 9 5 3 8 5 8 2 5 2 1 9 7 4 3 3 7 6 7 3 9 2 7 1 2 3 9 5 7 2 6 5 5 5 2 2 8 1 4 3; enddata end然后点击工具条上的按钮 即可。
LINGO教程
§1 LINGO 快速入门当你在windows 下开始运行LINGO 系统时,会得到类似下面的一个窗口:外层是主框架窗口,包含了所有菜单命令和工具条,其它所有的窗口将被包含在主窗口之下。
在主窗口内的标题为LINGO Model – LINGO1的窗口是LINGO 的默认模型窗口,建立的模型都都要在该窗口内编码实现。
下面举两个例子。
例1.1 如何在LINGO 中求解如下的LP 问题:,6002100350..32min 212112121≥≤+≥≥++x x x x x x x t s x x在模型窗口中输入如下代码: min =2*x1+3*x2; x1+x2>=350; x1>=100;2*x1+x2<=600;然后点击工具条上的按钮 即可。
例1.2 使用LINGO 软件计算6个发点8个收点的最小费用运输问题。
产销单位运价如model:!6发点8收点运输问题;sets:warehouses/wh1..wh6/: capacity;vendors/v1..v8/: demand;links(warehouses,vendors): cost, volume;endsets!目标函数;min=@sum(links: cost*volume);!需求约束;@for(vendors(J):@sum(warehouses(I): volume(I,J))=demand(J));!产量约束;@for(warehouses(I):@sum(vendors(J): volume(I,J))<=capacity(I));!这里是数据;data:capacity=60 55 51 43 41 52;demand=35 37 22 32 41 32 43 38;cost=6 2 6 7 4 2 9 54 95 3 8 5 8 25 2 1 9 7 4 3 37 6 7 3 9 2 7 12 3 9 5 7 2 6 55 5 2 2 8 1 4 3;enddataend然后点击工具条上的按钮即可。
(完整版)lingo初级入门手册
LINGO软件使用
LINGO是美国LINDO系统公司开发的一套专门用 于求解最优化问题的软件.它为求解最优化问题提供 了一个平台,主要用于求解线性规划、非线性规划、 整数规划、二次规划、线性及非线性方程组等问 题.它是最优化问题的一种建模语言,包含有许多常 用的函数供使用者编写程序时调用,并提供了与其他 数据文件的接口,易于方便地输入,求解和分析大规 模最优化问题,且执行速度快.由于它的功能较强, 所以在教学、科研、工业、商业、服务等许多领域得 到了广泛的应用.
STUDENTS/1..5/:NAME,AGE; ENDSETS
数学建模及其实验
数学建模及其实验
数学建模及其实验
数学建模及其实验
派生集:
Setname(parent_set_list(源集列表))[/member_list/][:attribute_list];
图1.1中最外层的窗口是LINGO软件的主窗口(LINGO软件的用户界 面),所有其他窗口都在这个窗口之内.主窗口有:标题栏、菜单栏、工 具栏和状态栏.目前,状态栏最左边显示的是“Ready”,表示准备就绪, 右下角显示的是当前时间,时间前面是当前光标的位置“Ln 1,Col 1” (即1行1列).将来用户可以用选项命令(LINGO|Options|Interface菜单 命令)决定是否需要显示工具栏和状态栏.
LINGO|Solution(Ctrl-O)(解答)命令显示当前解
• LINGO|Range(Ctrl-R)
LINGO|Range(Ctrl-R)(灵敏度分析)命令显示当前解的灵敏度分析结 果.(你必须在此之前求解过当前模型)
数学建模及其实验
• LINGO|Options(Ctrl-I)
Lingo软件简单教程
派生集是由其它的集来创建。这些集被称为该派生集的父集(原始 集或其它的派生集)。一个派生集既可以是稀疏的,也可以是稠密 的。稠密集包含了父集成员的所有组合(有时也称为父集的笛卡尔 乘积)。稀疏集仅包含了父集的笛卡尔乘积的一个子集,可通过显 式罗列和成员资格过滤器这两种方式来定义。显式罗列方法就是逐 个罗列稀疏集的成员。成员资格过滤器方法通过使用稀疏集成员必 须满足的逻辑条件从稠密集成员中过滤出稀疏集的成员。
4
LP问题在lindo和lingo中不同的输入形式:
Lindo: min 2x1+3x2 st x1+y2>=250 x1>=100 end
Lingo: min=2*x1+3*x2; x1+x2>=350; x1>=100; 2*x1+x2<=600; 这是LINGO 模型的最基本特征
(1)将目标函数的表示方式从“min”变成 了“min=” (2)“ST”在LINGO 模型中不再需要,所 以被删除了 (3)每个系数与变量间增加了运算符“*” (即乘号不能省略) (4)每行(目标、约束和说明语句)后面 均增加了一个分号“;” (5)模型结束标志“END”也被删除了 (LINGO 中只有当模型以“MODEL:”开 始时才能以“END”结束)。
3
例1 在LINGO中求解如下的LP问题:
min 2 x1 3x 2 s.t. x1 x 2 350 x1 100 2 x1 x 2 600 x1 , x 2 0
然后点击工具条上的按钮 即可。
在模型窗口中输入如下代码: min=2*x1+3*x2; x1+x2>=350; x1>=100; 2*x1+x2<=600;
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
max z 72 x1 64 x2 x1 x2 50, 12 x 8 x 480, 2 s.t. 1 3 x 100, 1 x1 , x2 0
LINGO 求解程序如下 max=72*x1+64*x2; x1+x2<=50; 12*x1+8*x2<=480; 3*x1<=100; 说明:LINGO 中默认所有的变量都是非负的,在 LINGO 中就不需写出对应的约束。
2
不超过 32 个字符。 (5)LINGO 程序中,只要定义好集合后,其他语句的顺序是任意的。 (6)LINGO 中的函数以“@”开头。 (7)LINGO 程序默认所有的变量都是非负的。 (8)LINGO 程序中“>或<”号与“ 或 ”号功能相同。 2.LINGO 建模时需要注意的几个基本问题 (1)尽量使用实数变量,减少整数约束和整数变量。 (2)模型中使用的参数数量级要适当,否则会给出警告信息,可以选择适当的单位改 变相对尺度。 (3)尽量使用线性模型,减少非线性约束和非线性变量的个数,同时尽量少使用绝对值、 符号函数、多变量求最大最小值、取整函数等非线性函数。 (4)合理设定变量上下界,尽可能给出初始值。 2.2.2 LINGO 的求解器运行状态窗口
1.4
LINGO 函数
1.4.1 算术运算符 ^ 乘方 ﹡ 乘 / 除 ﹢ 加 ﹣ 减 1.4.2 逻辑运算符 在 LINGO 中,逻辑运算符主要用于集循环函数的条件表达式中,来控制在函数中哪些 集成员被包含,哪些被排斥。在创建稀疏集时用在成员资格过滤器中。 LINGO 具有9种逻辑运算符 #not# 否定该操作数的逻辑值,#not#是一个一元运算符。 #eq# 若两个运算数相等,则为 true;否则为 false。 #ne# 若两个运算符不相等,则为 true;否则为 false。 #gt# 若左边的运算符严格大于右边的运算符,则为 true;否则为 false。 #ge# 若左边的运算符大于或等于右边的运算符,则为 true;否则为 false。 #lt# 若左边的运算符严格小于右边的运算符,则为 true;否则为 false。 #le# 若左边的运算符小于或等于右边的运算符,则为 true;否则为 false。 #and# 仅当两个参数都为 true 时,结果为 true;否则为 false。 #or# 仅当两个参数都为 false 时,结果为 false;否则为 true。 1.4.3 关系运算符 在 LINGO 中,关系运算符主要是被用在模型中来指定一个表达式的左边是否等于、小 于等于、 或者大于等于右边, 形成模型的一个约束条件。 关系运算符与逻辑运算符#eq#、 #le#、 #ge#截然不同,逻辑运算符仅仅判断一个关系是否被满足,满足为真,不满足为假。 LINGO 有三种关系运算符: “=”、 “<=”和“>=”。 LINGO 中还能用“<”表示小于等于关系, “>”表示大于等于关系。LINGO 并不支持严格小于和严格大于关系运算符。 1.4.4 数学函数 LINGO 提供了大量的标准数学函数 @abs(x)返回 x 的绝对值。 @sin(x)返回 x 的正弦值,x 采用弧度制。 @cos(x)返回 x 的余弦值。 @tan(x)返回 x 的正切值。
当前模型类型 当前解的状态 当前目标函数值 当前约束不满足的总量 目前为止迭代次数 使用的特殊求解程序 目前可行解的最佳目标函数值 目标函数值的界 特殊求解程序当前运行步数 有效步数
求解器状态
变量数量
约束数量 非零系数数量
变量总数 非线性变量数 整数变量数 约束总数 非线性约束个数 总数 非线性系数个数 内存的使用量 求解花费的时间
(2)Righthand Side Ranges 一栏反映了约束条件右端代表资源系数的常数项,可见第一个 约束右端常数项在 43.333333,60 变化时,最优基不变,但是最优解发生变化,目标函数值也相
应地发生变化。由于第三个约束松弛变量为 40,有剩余,可见无论再如何增加该资源,只会使 剩得更多,对解没有影响,但是如果减少量超过 40,就会产生影响。
max z 72 x1 64 x2 x1 x2 50, 12 x 8 x 480, 2 s.t. 1 3 x 100, 1 x1 , x2 0
1.影子价格 要进行灵敏度分析,必须选择如图 1.4 所示的画圈的选项,依次选择下列菜单 LINGO →Options…„General Solver 下 Dual Computations 选择 Prices。
4
图 1.4 LINGO Options 设置
勾选了 Prices 选项后,运行 LINGO 程序,输出结果窗口中包含灵敏度分析,如图 1.5 所示。
最优目标函数值
第一个约束条件 第三个约束条件
图 1.5 灵敏度分析
目标函数
从结果可知,目标函数的最优值为 3360,决策变量 x1 20, x2 30 。 (1)reduced cost 值对应于单纯形法计算过程中各变量的检验数。 (2)图 1.5 中红色方框表示第二个约束条件,Slack or Surplus 值为 0 表示该约束松弛 变量为 0,约束等号成立,为紧约束或有效约束。蓝色方框表示第三个约束松弛变量为 40, 不等号成立,有剩余。 (3) Dual Price 对应影子价格, 红色方框表示当第一个约束条件右端常数项增加 1 个单 位,即由 50 变为 51 时,目标函数值增加 48,即约束条件 1 所代表的资源的影子价格。蓝 色方框表示,第三个约束条件右端常数项增加 1 个单位时,目标函数值不变。 2.确保最优基不变的系数变化范围 如果想要研究目标函数的系数和约束右端常数项系数在什么范围变化 (假定其他系数保 持不变)时,最优基保持不变。此时需要首先勾选图 1.6 所示的选项。
第 1 讲 LINGO 软件入门
司守奎 烟台市,海军航空大学 Email:sishoukui@
1.1 初识 LINGO 程序
LINGO 程序书写实际上特别简捷,数学模型怎样描述,LINGO 语言就对应地怎样表达。 首先介绍两个简单的 LINGO 程序。 例 1.1 求解如下的线性规划问题:
1.3 LINGO 软件的基本语法
1.3.1 集合 集合部分的语法为 sets: 集合名称 1/成员列表 1/:属性 1_1,属性 1_2,…,属性 1_n1; 集合名称 2/成员列表 2/:属性 2_1,属性 2_2,…,属性 2_n2; 派生集合名称(集合名称 1,集合名称 2) :属性 3_1,…,属性 3_n3; endsets
例 1.2
抛物面 z x y 被平面 x y z 1 截成一椭圆,求原点到这椭圆的最短距
2 2
离。 该问题可以用拉格朗日乘子法求解。下面我们把问题归结为数学规划模型,用 LINGO 软件求解。 设原点到椭圆上点 ( x, y, z ) 的距离最短,建立如下的数学规划模型:
min
x2 y2 z 2
例 1.4 sets: product/A B/;
6
machine/M N/; week/1..2/; allowed(product,machine,week):x; endsets
1.3.2 数据 数据部分的语法为 data: 属性 1=数据列表; 属性 2=数据列表; enddata 在数据段中,=右侧不能出现运算,故不能出现分数,如 3/8,这里的/表示除法运算。 1.3.3 计算段 计算段部分不能含有变量,必须是已知数据的运算。 calc: b=0; a=a+1; endcalc 1.3.4 目标函数、约束条件 目标函数和约束条件这里就不具体给出了,下面通过具体例子给出。
x y z 1, s.t. 2 2 z x y .
LINGO 求解程序如下: min=(x^2+y^2+z^2)^(1/2); x+y+z=1; z=x^2+y^2; @free(x); @free(y); 说明:LINGO 中默认所有变量都是非负的,这里 x, y 的取值是可正可负的,所以使用 LINGO 函数 free。
扩展求解器状态
图 1.2 LINGO 的求解器状态窗口
1.求解器状态框 “当前解的状态”有如下几种: Global Optimum 全局最优解 Local Optimum 局部最优解 Feasible 可行解 Infeasible 不可行解 Unbounded 无界解 Interrupted 中断 Undetermined 未确定 2.扩展求解器状态 “使用的特殊求解程序”有如下几种: B-and-B 分支定界算法 Global 全局最优求解程序 Multistart 用多个初始点求解的程序 3.LINGO 求解的参数设置
1.2
1.2.1 LINGO 的模型窗口
LINGO 软件的界面介绍
求解按钮
图 1.1 LINGO 的模型窗口
模型窗口输入格式要求: (1)LINGO 的数学规划模型包含目标函数、决策变量、约束条件三个要素。 (2)在 LINGO 程序中,每一个语句都必须要用一个英文状态下的分号结束,一个语 句可以分几行输入。 (3)LINGO 的注释以英文状态的!开始,必须以英文状态下的分号结束; (4)LINGO 的变量不区分字母的大小写,必须以字母开头,可以包含数字和下划线,
例 1.3
求解如下的数学规划模型:
1
min
x
i 1 100
100
2 i
xi 1, i 1 s.t. 99 x x 2 . 100 i i 1