实验1用LINGO求解线性规划问题

合集下载

实验一_线性规划求解、运输问题、整数规划求解

实验一_线性规划求解、运输问题、整数规划求解

一、实验目的1、掌握线性规划求解的基本方法,熟悉灵敏度分析的步骤和内容;2、掌握运输问题的模型,概念,求解方法;3、掌握整数规划的算法。

4、熟悉lingo软件基本功能,并能熟练操作,正确完成模型求解过程及分析过程。

二、实验内容或设计思想1、lingo软件和运筹学实验软件的安装及菜单熟悉了解。

2、lingo软件和运筹学实验软件应用:任选几种不同类型的LP输入计算程序,运行求解;完成产销平衡的运输问题求解;求解任一整数规划。

三、实验环境与工具计算机,lingo软件,运筹学软件四、实验过程或实验数据1、用lingo软件求解线性规划【例题1】某家具公司制造书桌、餐桌和椅子,所用的资源有三种:木料、木工和漆工。

生产数据如下表所示:解:(1)用DESKS、TABLES和CHAIRS分别表示三种产品的生产量,建立LP模型。

max=60*desks+30*tables+20*chairs;8*desks+6*tables+chairs<=48;4*desks+2*tables+1.5*chairs<=20;2*desks+1.5*tables+.5*chairs<=8;tables<=5;(2)求解这个模型,得如下结果:Global optimal solution found.Objective value: 280.0000Infeasibilities: 0.000000Total solver iterations: 2Variable Value Reduced CostDESKS 2.000000 0.000000TABLES 0.000000 5.000000CHAIRS 8.000000 0.000000Row Slack or Surplus Dual Price1 280.0000 1.0000002 24.00000 0.0000003 0.000000 10.000004 0.000000 10.000005 5.000000 0.000000(3)结论:2、用LINGO软件求解运输问题【例题1】6个发点8个收点的最小费用运输问题。

应用lingo软件实现线性规划和整数规划

应用lingo软件实现线性规划和整数规划

一、 实验目的应用lingo 软件实现线性规划和整数规划。

二、 实验内容:1.线性规划方法的lingo 软件实现。

2.整数规划方法的Lingo 软件实现三、 实验环境:1 硬件要求:计算机一台2 操作系统:WindowsXP3 软件要求:lingo10四、实验步骤及程序编写:1.线性规划模型。

某战略轰炸机群奉命摧毁敌人军事目标。

已知该目标有四个要害部位,只要摧毁其中之一即可达到目的。

为完成此项任务的汽油消耗量限制为48000升、重型炸弹48枚、轻型炸弹32枚。

飞机携带重型炸弹时每升汽油可飞行2千米,带轻型炸弹时每升汽油可飞行3千米。

又知每架飞机每次只能装载一枚炸弹,每出发轰炸一次除来回路程汽为了使摧毁敌方军事目标的可能性最大,应如何确定飞机轰炸的方案。

解:设用了x 枚重型炸弹,用了y 枚轻型炸弹,攻击的是第i 个部位,再设一标志变量f 定义如下: ⎩⎨⎧=个部位不攻击第个部位攻击第i i f i 01目标函数为: ()[]∑=⨯⨯+⨯=41max i i li ih f p y px()()480002004/3/2004/2/≤++⨯+++⨯i i i i d d y d d x48≤x ,32≤y141=∑=i if2、整数规划模型。

某厂生产甲、乙两种产品,生产甲种产品每件要消耗煤9t ,电力4kw ,使用劳动力3个,获利70元;生产乙种产品每件消耗煤4t ,电力5kw ,使用劳动力10个,获利120元。

有一个生产日,这个厂可动用的煤是360t ,电力是200kw ,劳动力是300个,问应该如何安排甲、乙两种产品的生产,才能使工厂在当日的获利最大,并问该厂当日的最大获利是多少? 解:模型建立:⎪⎪⎩⎪⎪⎨⎧<+<+<++=取整x x x x x x x x x x t s f 2121212121,3001032005436049..12070max五、程序调试及实验总结1.线性规划模型。

运筹学lingo实验报告

运筹学lingo实验报告

运筹学lingo实验报告
运筹学lingo实验报告
一、引言
实验目的
本次实验旨在探索运筹学lingo在解决实际问题中的应用,了解lingo的基本使用方法和解题思路。

实验背景
运筹学是一门研究决策和规划的学科,其能够帮助我们优化资源分配、解决最优化问题等。

lingo是一种常用的运筹学工具,具有强大的求解能力和用户友好的界面,被广泛应用于各个领域。

二、实验步骤
准备工作
•安装lingo软件并激活
•熟悉lingo界面和基本功能
确定问题
•选择一个运筹学问题作为实验对象,例如线性规划、整数规划、网络流等问题
•根据实际问题,使用lingo的建模语言描述问题,并设置变量、约束条件和目标函数
运行模型
•利用lingo的求解器,运行模型得到结果
结果分析
•分析模型求解结果的合理性和优劣,对于不符合要求的结果进行调整和优化
结论
•根据实验结果,总结lingo在解决该问题中的应用效果和局限性,对于其他类似问题的解决提出建议和改进方案
三、实验总结
实验收获
•通过本次实验,我熟悉了lingo软件的基本使用方法和建模语言,增加了运筹学领域的知识和实践经验。

实验不足
•由于时间和条件的限制,本次实验仅涉及了基本的lingo应用,对于一些复杂问题的解决还需要进一步学习和实践。

•在以后的学习中,我将继续深入研究lingo的高级功能和应用场景,以提升运筹学问题的求解能力。

以上就是本次实验的相关报告内容,通过实验的实践和总结,我对lingo在运筹学中的应用有了更深入的理解,为今后的学习和研究奠定了基础。

用Lingo软件编程求解规划问题

用Lingo软件编程求解规划问题

x2桶牛奶生产A2 获利 16×4 x2
Max z 72 x1 64 x2
x1 x2 50
12 x1 8x2 480 3x1 100
x1, x2 0
线性规 划模型 (LP)
例1——加工奶制品的生产计划
x1 x2 50
12
x1 8x2 480 3x1 100
Lingo软件——基本集合元素的列举
一个原始集是由一些最基本的对象组成的。 setname [/member_list/] [: attribute_list];
sets: students/John Jill, Rose Mike/: sex, age;
endsets
集、集成员和集属性
• 集成员无论用何种字符标记,它的索引都是 从1开始连续计数。

ij
8
j 1
N Nij

V
i
i 1, ,6,j 1, ,8, i 1, ,6,


N 6
i1 ij
d
j
j 1, ,8.
结果
Lingo软件
Lingo 是一个可以简洁地阐述、解决和分析复杂问题的简便工具。
其特点是程序执行速度很快,易于输入、修改、求解和分析一个数 学规划问题。


N 6
i1 ij
d
j
j 1, ,8.
corps
需求量 35 37 22 32 41 32 43 38
拥有量
60 55 51 depot 43 41 52
B1 B2 B3 B4 B5 B6 B7 B8
A1
62674259
A2
49538582

讲义:用LINGO解线性规划和整数规划

讲义:用LINGO解线性规划和整数规划

用LINGO 解线性规划和整数规划在工程技术、经济管理、科学研究和日常生活等许多领域中,人们经常遇到的一类决策问题是:在一系列客观或主观限制条件下,寻求使关注的某个或多个指标达到最大(或最小)的决策。

例如:★ 结构设计要在满足强度要求条件下选择材料的尺寸,使其总重量最轻; ★ 资源分配要在有限资源约束下制定各用户的分配数量,使资源产生的总效益最大;★ 运输方案要在满足物资需求和装载条件下安排从各供应点到各需求点的运量和路线,使运输总费用最低;★ 生产计划要按照产品工艺流程和顾客需求,制定原料、零件、部件等订购、投产的日程和数量,尽量降低成本使利润最高。

上述这种决策问题通常称为优化问题。

人们解决这些优化问题的手段大致有以下几种:1.依赖过去的经验判断面临的问题。

这似乎切实可行,并且没有太大的风险,但是其处理过程会融入决策者太多的主观因素,难以客观地加以描述,从而无法确认结果的最优性。

2.做大量的试验反复比较。

这固然比较真实可靠,但是常要花费太多的资金和人力,而且得到的最优结果基本上离不开开始设计的试验范围。

3.用数学建模的方法建立数学规划模型求解最优决策。

虽然由于建模时要作适当的简化,可能使得结果不一定完全可行或达到实际上的最优,但是它基于客观规律和数据,又不需要多大的费用,具有前两种手段无可比拟的优点。

如果在此基础上再辅之以适当的经验和试验,就可以期望得到实际问题的一个比较圆满的回答,是解决这种问题最有效、最常用的方法之一。

1.1.1 数学规划模型数学规划模型一般有三个要素:一是决策变量,通常是该问题要求解的那些未知量,不妨用n 维向量12n x (x ,x ,,x )'= 表示;二是目标函数,通常是该问题要优化(最小或最大)的那个目标的数学表达式,它是决策变量x的函数,这里抽象地记作f(x);三是约束条件,由该问题对决策变量的限制条件给出,即x允许取值的范围x∈Ω,Ω称可行域,常用一组关于x的不等式(也可是等式)g i(x)≤0(I=1,2,…,m)来界定。

运筹学实验报告(三)线性规划问题的编程求解

运筹学实验报告(三)线性规划问题的编程求解

a=1 2 4 0 0 4; end data end
求解可得Solution Report
Global optimal solution found. Objective value: Total solver iterations: Variable B( 1) B( 2) B( 3) C( 1) C( 2) X( 1) X( 2) A( 1, 1) A( 1, 2) A( 2, 1) A( 2, 2) A( 3, 1) A( 3, 2) Row 1 2 3 4 Value 8.000000 16.00000 12.00000 2.000000 3.000000 4.000000 2.000000 1.000000 2.000000 4.000000 0.000000 0.000000 4.000000 Slack or Surplus 14.00000 0.000000 0.000000 4.000000 14.00000 1 Reduced Cost 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 0.000000 Dual Price 1.000000 1.500000 0.1250000 0.000000
3 人力资源分配问题 某昼夜服务的公交线路每天各时间段内所需司机和乘务人员人数如表 1 所示。 班次 1 2 3 时间 6:00~10:00 10:00~14:00 14:00~18:00 所需人数 60 70 60 班次 4 5 6 时间 18:00~22:00 22:00~2:00 2:00~6:00 所需人数 50 20 30

运用Lingo进行线性规划求解(实例)

!注:集表达式:名称/成员/:属性 名称(初始集):属性
♂返回
定 义 数 据
data:!定义数据 c=3 5 4; b=1500 800 2000; a=2 3 0 0 2 4 3 2 5; Enddata
!注:数据的大小与集合定义中一致, 分量中间用空格或逗号分开,数据 结束后用分号;
♂返回
调 用 函 数
♂返回
结 果
Global optimal solution found at iteration: 3 Objective value: 2675.000 Variable Value Reduced Cost C( 1) 3.000000 0.000000 C( 2) 5.000000 0.000000 C( 3) 4.000000 0.000000 X( 1) 375.0000 0.000000 X( 2) 250.0000 0.000000 X( 3) 75.00000 0.000000
LinDo/LinGo软件
LinDo
输入模型 求解 点击求解按钮 结果

即可
♂返回
输 入 模 型
!注释内容,可用中文 !目标函数:最大-max,最小-min,大小写不分 max 3 x1+5 x2+4 x3 !约束,以subject to开始 subject to 2 x1+3 x2<=1500 2 x2+4 x3<=800 3 x1+2 x2 +5 x3<=2000 end
注意与LinDo的区别
目标函数中加ຫໍສະໝຸດ 号变量与系数之间用“*” Model:-end可省略


♂返回
LinGo 模 式

LINGO软件在线性规划中的运用

Southwestuniversityofscienceandtechnology实验报告LINGO软件在线性规划中的运用学院名称环境与资源学院专业名称采矿工程学生姓名学号指导教师二〇一五年十一月实验LINGO软件在线性规划中的运用1.实验目的掌握LINGO软件求解线性规划问题的基本步骤,了解LINGO软件解决线性规划问题的基本原理,熟悉常用的线性规划计算代码,理解线性规划问题的迭代关系。

2.实验仪器、设备或软件电脑,LINGO软件3.实验内容(1)LINGO软件求解线性规划问题的基本原理;(2)编写并调试LINGO软件求解线性规划问题的计算代码;4.实验步骤(1)使用LINGO计算并求解线性规划问题;(2)写出实验报告,并浅谈学习心得体会(线性规划的基本求解思路与方法及求解过程中出现的问题及解决方法)。

5.题目有一艘货轮,分前、中、后三个舱位,它们的容积与最大允许载重量如表1所示。

现有三种货物待运,已知有关数据列于表2中。

又为了航运安全,要求前、中、后舱在实际载重量上大体保持各舱最大允许载重量的比例关系。

具体要求前、后舱分别与中舱之间载重量比例上偏差不超过15%,前、后舱之间不超过10%。

问该货轮应装载A、B、C各多少件,运费收入为最大?要求写出建模分析,数学模型建立,并分别用lingo和matlab编写程序代码,并计算出结果和分析结果。

前舱中舱后舱最大允许载重量(t) 2000 3000 1500容积(m3) 4000 5400 1500商品数量(件) 每件体积(m3/件) 每件重量(t/件) 运价(元/件)A 600 10 8 1000B 1000 5 6 700C 800 7 5 6006.实验过程!设前舱运A为x11,运B:x12,运C:x13;!设中舱运A为x21,运B:x22,运C:x23;!设后舱运A为x31,运B:x32,运C:x33;!单位:件;!目标函数;max=1000*(x11+x21+x31)+700*(x12+x22+x32)+600*(x13+x23+x33);!数量约束;x11+x21+x31<=600;x12+x22+x32<=1000;x13+x23+x33<=800;!容量约束;x11*10+x12*5+x13*7<=4000;x21*10+x22*5+x23*7<=5400;x31*10+x32*5+x33*7<=1500;!重量约束;x11*8+x12*6+x13*5<=2000;x21*8+x22*6+x23*5<=3000;x31*8+x32*6+x33*5<=1500;!平衡约束;x11*8+x12*6+x13*5<=1.15*(x21*8+x22*6+x23*5);x21*8+x22*6+x23*5<=1.15*(x11*8+x12*6+x13*5);x31*8+x32*6+x33*5<=1.15*(x21*8+x22*6+x23*5);x21*8+x22*6+x23*5<=1.15*(x31*8+x32*6+x33*5);x11*8+x12*6+x13*5<=1.1*(x21*8+x22*6+x23*5);x21*8+x22*6+x23*5<=1.1*(x11*8+x12*6+x13*5);!整数约束;@gin(x11);@gin(x12);@gin(x13);@gin(x21);@gin(x22);@gin(x23);@gin(x31);@gin(x32);@gin(x33);7.心得体会运筹学是近几十年发展起来的一门新兴学科。

用Lingo软件编程求解规划问题解决方案

sets: students/John Jill, Rose Mike/: sex, age;
endsets
集成员不放在集定义中,而在随后的数据部分来定义。 sets: students:sex,age; endsets
data: students,sex,age= John 1 16 Jill 0 14 Rose 0 17 Mike 1 13;
x 1 x 2 50
12
x1 8 x2 3 x 1 100
480
x1 0
x2 0
求 z7x216x42的最大值?
70
x2
60
50
40
30
20
10
0
O
-10 -10 0
Linear program 3x1=100
12x1+8x2=480
z=72x1+64x2=720
x1+x2=50 x1
集合
setname [/member_list/] [: attribute_list];
派生集合 基本集合 稀疏集合 稠密集合
元素列表法 元素过滤法 直接列举法 隐式列举法
Lingo软件——基本集合元素的列举
一个原始集是由一些最基本的对象组成的。 setname [/member_list/] [: attribute_list];
决策变量 目标函数
约束条件
x1桶牛奶生产A1 获利 24×3x1 每天获利 原料供应 劳动时间 加工能力 非负约束
x2桶牛奶生产A2
获利 16×4 x2
Mz a7 xx1 26x4 2
x1x2 50
12x18x2 480 3x1 100
x1,x2 0

附1:用LINGO求解线性规划的例子 一奶制品加工厂用牛奶生产A1、A2

附1:用LINGO求解线性规划的例子一奶制品加工厂用牛奶生产A1、A2附1:用LINGO求解线性规划的例子一奶制品加工厂用牛奶生产A、A两种奶制品,1桶牛奶可以在设备甲上用12小时加工成3公斤A,121或者在设备乙上用8小时加工成4公斤A。

根据市场需求,生产的A、A能全部售出,且每公斤A获利212124元,每公斤A获利16元。

现在加工厂每天能得到50桶牛奶的供应,每天正式工人总的劳动时间为4802 小时,并且设备甲每天至多能加工100公斤A,设备乙的加工能力没有限制。

试为该厂制定一个生产计划,1使每天获利最大,并进一步讨论以下3个附加问题:1)若用35元可以购买到1桶牛奶,应否作这项投资,若投资,每天最多购买多少桶牛奶,2)若可以聘用临时工人以增加劳动时间,付给临时工人的工资最多是每小时几元,3)由于市场需求变化,每公斤A的获利增加到30元,应否改变生产计划, 1数学模型:设每天用x桶牛奶生产A1 ,用x桶牛奶生产A2 12目标函数:设每天获利为z元。

x桶牛奶可生产3x公斤A1,获利24*3x,x桶牛奶可生产4*x公11122斤A2,获利16*4x,故z=72x+64x212约束条件:原料供应:生产A、A的原料(牛奶)总量不超过每天的供应50桶,即 12x+x?50 12劳动时间:生产A、A的总加工时间不超过每天正式工人总的劳动时间480小时,即 1212x+8x?480 12设备能力:A的产量不得超过设备甲每天的加工能力100小时,即 13x?100 1非负约束:x、x均不能为负值,即x?0,x?0 2121综上所述可得max z=72x+64x 12s.t.x+x?50 1212x+8x?480 123x?100 1x?0,x?0 21显然,目标函数和约束条件都是线性的,这是一个线性规划(LP),求出的最优解将给出使净利润最大的生产计划,要讨论的问题需要考虑参数的变化对最优解和影响,一般称为敏感性(或灵敏度)分析。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验用LINDO或LINGO求解线性规划问题
实验目的
1.对于给定的实际应用问题,正确的建立线性规划问题数学模型,并用LINDO或LINGO 求解;
2.掌握灵敏度分析以及资源的影子价格的相关分析方法.
问题1某工厂在计划期内要安排生产A、B两种产品,已知生产单位产品所需设备台时及对甲、乙两种原材料的消耗,有关数据如表1.1.问:应如何安排生产计划,使工厂获利最大?
.
LINDO输入语句:
max 2x1+3x2
st
x1+2x2<=8
4x1<=16
4x2<=12
end
在LINGO的MODEL窗口内输入如下模型:
model:
max=2*x1+3*x2;
x1+2*x2<=8;
4*x1<=16;
4*x2<=12;
end
选菜单Lingo|Solve(或按Ctrl+S),或用鼠标点击“求解”按纽,如果模型有语法错误,则弹出一个标题为“LINGO Error Message”(错误信息)的窗口,指出在哪一行有怎样的错误,每一种错误都有一个编号(具体含义可查阅相关文献或LINGO的Help).改正错误以后再求解,如果语法通过,LINGO用内部所带的求解程序求出模型的解,然后弹出一个标题为“LINGO Solver Status”(求解状态)的窗口,其内容为变量个数、约束条件个数、优化状态、耗费内存、所花时间等信息,点击Close关闭窗口,屏幕上出现标题为“Solution Report”(解的报告)的信息窗口,显示优化计算(线性规划中换基迭代)的步数、优化后的目标函
数值、列出各变量的计算结果.求解结果:
Global optimal solution found at iteration: 5 Objective value: 14.00000
Variable Value Reduced Cost X1 4.000000 0.000000 X2 2.000000 0.000000 Row Slack or Surplus Dual Price 1 14.00000 1.000000 2 0.000000 1.500000 3 0.000000 0.1250000 4 4.000000 0.000000
该报告说明:运行5步找到全局最优解,目标函数值为14,变量值分别为124,2==x x .“Reduced Cost ”的含义是需缩减成本系数或需增加利润系数(最优解中取值非零的决策变量的Reduced Cost 值等于零).“Row ”是输入模型中的行号,目标函数是第一行;“Slack or Surplus ”的意思是松弛或剩余,即约束条件左边与右边的差值,对于“≤”的不等式,右边减左边的差值为Slack (松弛),对于“≥”的不等式,左边减的右边差值为Surplus (剩余),当约束条件两边相等时,松弛或剩余的值等于零.“Dual Price ”的意思是对偶价格(或称为影子价格),上述报告中Row2的松弛值为0,表明生产甲产品4单位、乙产品2单位,所需设备8台时已经饱和,对偶价格1.5的含义是:如果设备增加1台时,能使目标函数值增加1.5.报告中Row4的松弛值为4,表明生产甲产品4单位、乙产品2单位,所需原材料乙8公斤还剩余4公斤,因此增加原材料乙不会使目标函数值增加,所以对偶价格为0.
对于目标函数系数和约束条件右端常数项的灵敏度分析,可以通过LINGO 软件求解的灵敏度分析给出.如果要看灵敏度分析结果,必须激活灵敏度计算功能才会在求解时给出灵敏度分析结果,默认情况下这项功能是关闭的.想要激活它,必须运行LINGO|Options …命令,选择Gengral Solver ,在Dual Computation 列表框中,选择Prices and Ranges 选项并确定. 法一:打开command window ,输入range ;
法二:LINGO ——options ——General Solver ——DualComputations ——Prices&Ranges , 运行一遍,然后关掉,然后lingo-----range
问题2 某公司饲养实验用的动物以供出售,已知这些动物的生长对饲料中3种营养成分(蛋白质、矿物质和维生素)特别敏感,每个动物每周至少需要蛋白质60g ,矿物质3g ,维生素8mg ,该公司能买到5种不同的饲料,每种饲料1kg 所含各种营养成分和成本如表1.2所示,如果每个小动物每周食用饲料不超过52kg ,求既能满足动物生长需要,又使总成本最低的饲料配方.
问题3 设有四个化肥厂供应四个地区的农用化肥,假定等量的化肥在这些地区使用效果相同.已知各化肥厂年产量(单位:吨)、各地区年需要量以及从各化肥厂到各地区单位化肥的运价如表3.2.1所示(表中运价中“—”表示不适合).试决定总的运费最节省的化肥调运方案.
表3.2.1 化肥供应的平衡表与运价表
问题4 某公司计划在东、西、南、北四个市区建立销售门市部,拟议中有10个位置
(1,2,
,10)j A j =可供选择,考虑到各地区居民的消费水平及居民居住密集度,在东区由
123,,A A A 三个点至多选择两个;在西区由45,A A 两个点中至少选一个;在南区由67,A A 两个
点中至少选一个;在北区由8910,,A A A 三个点中至少选两个.j A 各点的设备投资及每年可获利润情况见表3.2.2所示 (单位:万元).但投资总额不能超过72万元,问应选择哪几个销售点,可使年利润为最大?建立整数规划问题的数学模型,并用LINGO 求解.
表3.2.2 四个市区的10个位置设备投资及每年利润表
问题5 求解整数线性规划问题 12
121212
max 2535
..436
,0,379z x x x x s t x x x x =≤≤≥++⎧⎪
+⎨⎪⎩全部为整数 思考题
1.(1988年美国大学生数学建模竞赛试题)有七种规格的包装箱要装到两辆铁路平板车上去.包装箱的宽和高是一样的,但厚度(t,以厘米计)及重量(w ,以公斤计)是不同的.表3.
2.4给出了每种包装箱的厚度、重量以及数量.每辆平板车有10.2米长的地方可用来装包装箱(像面包片那样),载重为40吨.由于当地货运的限制,对567,,C C C 类的包装箱的总数有一个特别的限制:这类箱子在两辆平板车上所占的总空间(厚度)不能超过302.7厘米.
试把包装箱(见表3.2.4)装到平板车上去使得浪费的空间最小.。

相关文档
最新文档