- 在线时间
- 1630 小时
- 最后登录
- 2024-1-29
- 注册时间
- 2017-5-16
- 听众数
- 82
- 收听数
- 1
- 能力
- 120 分
- 体力
- 564668 点
- 威望
- 12 点
- 阅读权限
- 255
- 积分
- 174623
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 5313
- 主题
- 5273
- 精华
- 3
- 分享
- 0
- 好友
- 163
TA的每日心情 | 开心 2021-8-11 17:59 |
|---|
签到天数: 17 天 [LV.4]偶尔看看III 网络挑战赛参赛者 网络挑战赛参赛者 - 自我介绍
- 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
 群组: 2018美赛大象算法课程 群组: 2018美赛护航培训课程 群组: 2019年 数学中国站长建 群组: 2019年数据分析师课程 群组: 2018年大象老师国赛优 |
2-7、规划问题的Lingo解法
6 p* Y, G" R$ U3 E H/ G一、 从规划问题引入# @% X+ }, e4 y
8 A8 D0 @4 W9 d 在我们学习探索的各个领域,规划问题都是无处不在的。通过列出约束条件及目标函数,再画出约束条件所表示的可行域,就能在可行域内求得目标函数的最优解以及最优值。当然我们在高中就已经学习过线性规划的相关知识,对于理科同学来说,大多数同学应该感觉难度不大,或者说是送分考点。然而到了大学阶段,一些规划问题的求解已经不是人力可以轻松算出来的了,必须借助于计算机来进行计算。那么对于规划问题的软件选择,又应当如何进行呢?
+ Y# E9 P4 }/ _7 J# r" e
- r! `0 ~# B/ \+ O) T二、 软件分析与选择! N9 A( p1 k+ E% D
) [1 t" r$ J/ X Matlab相比之下是一个面面俱到的编程软件,也可用于求解规划问题。但是如果一定要去和某些“针对特定功能而开发的软件”去比的话,Matlab有时也会稍显逊色。就好比一款顶级的耳机能通吃高中低音,但是去和另一款顶级的为高音而设计的耳机去比较的话,也难免会被比下去。这也就是为什么在规划问题上,很多人会去使用Lingo进行求解。
2 K1 H( G4 }/ W9 D9 S) H
) y, @6 b1 n1 R/ N( A7 J 首先我们来区分一下Lindo和Lingo这两款软件。Lingo是在Lindo基础之上做成的软件,处理解线性规划问题之外还加了非线性的求解器,更关键的是还追加了集的概念。可以更方便的解决复杂的问题。所以本文只对Lingo进行讲解。
+ @7 k8 D7 i* i% {! o 而对于Matlab与Lingo的区别,就好比手动挡与自动挡的区别,有针对性的专业软件会对用户做很多的优化。这里引用知乎上大佬 花开花落 的回答 4 r4 D5 o4 C& C* @7 f; \& z" u) }
https://www.zhihu.com/question/49319704/answer/165923451
+ E4 p' e4 A, Y5 f2 z" O8 D, M8 l# D2 D( p0 g
用MATLAB求解线性规划和整数规划问题,需要先将问题转化成如下标准型,其中X只能是向量,也就是单下标变量,然后用向量和矩阵来表达目标函数和约束条件。 V9 } `0 k0 {- P8 f8 b
然而,许多问题(如指派问题和运输问题)由于参数和决策变量是双下标变量,必须在基本的数学模型的基础上进行变换才能求解,这样得到的等式约束和不等式约束的系数矩阵规模就非常庞大,当然由MATLAB计算问题不大,但转换工作完全要由人工完成,工作量大而且容易出错,因此在这一块效率不高。 4 c, c5 y3 b; t3 F' S% k
而LINGO有自己的建模语言,在建立了集合的基础上,能够高效表达目标函数和各种约束条件。所写的模型基本上可以看作是对数学模型的翻译,不需要太多的转换。
: a! _5 U$ H" w. ]
) M* f1 h' d/ T/ B( U; ~ 那么现在我们基本上对LINGO和MATLAB对规划问题的处理方面有了初步认识与了解,至于是执着于MATLAB还是选择开辟LINGO这片新的领域,取决于队伍自身了。
' C6 z% O- V( S! c' W+ V( N7 d& k% Y" L8 J
三、 如何上手Lingo4 i" e- s& q: j; B% d
9 ]! z/ g4 i' I8 W7 ]* P& y, b$ B 有很多人对于Lingo的评价都是,非常简单的软件,很好上手。
% H% T% ^1 Y) }0 D& V q “简单”一词我觉得还比较恰当。Lingo的各种版本几乎全部都是免安装版本的,界面很简单,功能用法很简单,处理问题的方式简单快捷。确实是跟“简单”一词挂钩的。但是任何一款软件想要精通,都是有一定难度的。如果你只需要用Lingo处理一些简单的线性问题,那么2个小时不到,0编程基础的朋友就能上手。如果你认准了Lingo就是你处理各类规划问题的御用软件,那么还是有很长一段路要走的。当然这也取决于用户的编程基础。如果学习过面向对象的程序设计课程的朋友,对于类与对象概念有所了解,那么对于集这一概念也能快速理解上手,学习起来更加轻松。
* ^& Y+ h+ U& a- ?( e* a; T$ i ~! d& p
1 n J7 W$ N; c四、 Lingo的基本语法规则
3 W# g9 j9 C8 D% k: n2 _( [, ~
' M3 z0 i! h; `! j; z; L3 G$ N$ w8 y1、求目标函数的最大最小值用 MAX=MAX= 和 MIN=MIN= 来表示;
) u$ G6 j" D& V. O+ F2、每个语句必须用分号“;”结束,每行可以有许多语句,一个语句可以跨行;
/ o' ^) C% y* Z; `% ]8 K; ]3、变量名必须以字母A-Z开头,由字母、数字0-9和下划线组成,长度不超过32个字符,不区分大小写;
; s- s& V1 v. Q4、可以给语句加上标号;
C& ]- T' A/ V" l5 [' @5、注释以“!”开头以“;”结束; 7 H J& Z; A4 K
6、默认所有的决策变量为非负数;
# d/ q- y. c7 @# t# X z1 q7、Lingo模型以“MODEL”开头以“END”结束。
, D# I: S2 |0 j' c) ]5 j* {; p% E8、Lingo把相联系的对象聚合成集,借助集,就能够用一个单一的长的简明的公式表示一系列相应的约束。 ' ]+ s$ L$ B0 t v
9、Lingo程序会包含集合段,数据输入段,优化目标和约束段,初始段和数据预处理部分。 $ _" y M+ z/ H6 y
10、Lingo函数包括有数学函数,金融函数,概率函数,变量界定义函数,集操作函数,集循环函数,输入输出函数,辅助函数等等。
5 [8 d" z; a$ A6 g' d& Z Z1 Q7 H) [* F7 i! G
五、 谈一谈例子* w x$ Z8 @% l( ?# D; ^
5 [4 Q; ?* J5 N7 A4 s) K4 R6 S
那么Lingo用起来到底有多简单呢,我们来看一个例子。% f' m; \# j: S3 s1 F, d8 I" z% z
. _& y- i" C/ c6 s, g6 {( l例1:某家公诉制造书桌、餐桌和椅子,所用的资源有三种:木料、木工和漆工。生产数据如下表所示:
7 q& b, ?# T0 ~- O7 i0 j) W
E# W7 U% S% h% w6 t2 T0 ?1 ` 每个书桌 每个餐桌 每个椅子 现有资源总数3 d( I5 R' c1 H2 j- K* M2 p. m
木料 8个单位 6个单位 1个单位 48个单位; m4 K- m" f) {8 d" Z
漆工 4个单位 2个单位 1.5个单位 20个单位
) t V, i: P) s/ Q- U) G% r; R木工 2个单位 1.5个单位 0.5个单位 8个单位5 o% C( @; g4 j6 F; Y* b/ o
成品单价 60个单位 30个单位 20个单位
- |( G9 V$ i' n! M" e0 ]8 j! i+ p 若要求桌子的生产量不超过5件,如何安排三种产品的生产可使利润最大?" y4 I( O$ b7 o0 R7 F, @
- |, U E, m- J) v% A
解:代码+ U. W# v/ e; W. ~3 ~
8 e! u/ Z% k4 o2 Z, Y
max = 60 * desks + 30 * tables + 20 * chairs;
" c* p! K3 B8 J1 f; k8 i/ v6 U3 U% i$ j 8 * desks + 6 * tables + chairs <= 48;
; a# _: a- T5 Y1 Q 4 * desks + 2 * tables + 1.5 * chairs <= 20; s* R$ p2 V4 b; F7 E" `+ L) t
2 * desks + 1.5 * tables + .5 * chairs <= 8;
8 N% Q/ n: @: [; N" E6 |: htables <= 5;
3 b/ m1 s& a, n1
3 ?' E9 Z) C6 a( y2
" O D# {! @" Q% |% @9 O, T0 X% o3( c6 p N, H9 i; D
4$ g! \" Z! e" R
58 B. _' I! W" V+ g5 H( B
可以得到结果: 9 g5 i" P) c7 J1 A& _! E5 W/ q, C, {8 L
8 g1 N! y3 c. I2 ]3 ^ 这里的 Total solver iteration 表示一共迭代2次得到最优解。 8 b0 E4 G, p& ?2 c
Objective value 表示最优值为280,而取280的时候各个变量取多少呢,底下的表格给出了答案。 % E, r) s1 E7 o( I* d9 T: L
可以看到,没有定义变量,简简单单一个函数一个约束条件,迅速计算出了答案。Lingo看上去就像是为了非编程人员量身定制的一样。9 G8 g1 A& {3 R5 q/ t+ [
& h0 j4 p" [9 e
例2:给定一个直角三角形,求包含该三角形的最小正方形。2 \. u ^* y8 P; I4 ^' h0 _$ I1 S
# j( ^; p- f; x( g我们可以作出如下正方形:
: H: T3 X3 A- [6 a; ^# j5 A! g5 I
$ x! n& e+ h, `! P ?& v$ ?4 T CE=asinx,AD=bcosx,DE=acosx+bsinxCE=asinx,AD=bcosx,DE=acosx+bsinx
2 [$ i) c1 o9 m3 ` 转化为了规划问题那么正方形面积最小的时候即为最优解。
* u6 D( T. c( w& R; T 代码:
) f+ B* I# G- v* B9 B/ r: E9 s6 k1 t: f; R
model:0 J4 h F% J2 k% R% z: c, a
sets:
4 a6 a2 [4 b3 y! o3 c. O+ W object/1..3/:f;
) M2 _7 b1 U' u* b# ?6 ^9 ]endsets
/ w6 v; G' ]8 n$ N9 edata:
6 c6 D) [0 _# ]. u# h& b8 c a, b = 3, 4;
1 P8 Z$ m1 G X' W, F4 I2 h0 @enddata M, ^6 Y' ]- V2 M! b# V& u3 P4 n
f(1) = a * @sin(x);
, L( t. w2 G% } f(2) = b * @cos(x);$ J* \5 x$ t$ y2 W: `/ E
f(3) = a * @cos(x) + b * @sin(x);
, r: m' w9 B5 D% |: P min = @smax(f(1), f(2), f(3));
" x: k2 Z0 f1 O9 H: Q" A @bnd(0, x, 1.57);: C/ o3 U, I, C! E8 B* P# U
end# x4 S: d- D; b5 `& x3 H
15 ]5 c' e4 y* `
2
- n( D( W# I5 j3 ]. E8 c* B/ [3
1 |/ t* k: P; Y; V4 U: ^) E) G, l- X( j2 E
5
; l0 Z k* H0 O1 y- [& w. m6: W6 E3 b: @1 L- J# I
7
2 D2 @# }' v# q% _7 i2 x: p/ d( K8
% K. |' z$ t: B0 l9
' Y* `! ]9 ], Z0 O6 ]10
/ Z9 K: F1 G# @% L11/ z- j& s" o Z& [1 L7 l/ w* _
12
+ S5 C4 @8 w* d2 o, F4 o13
3 d$ T9 Z9 w: v9 l; F+ F, C 得到结果: 4 d# c" p6 w' t/ T
M) O' L) d' _, ]3 m, x8 L4 W" `/ I7 E- c" M
这里需要注意,lingo中如果没有代码说明,是默认 xx 的值大于0的。代码中用 bndbnd 函数限制了 xx 的范围。 `& i3 ~9 X) u5 t0 a" h4 W( i
那么再进阶一下,Lingo在处理TSP问题的时候表现如何呢?4 h% b* u- N3 r
t, K2 k9 `" ~
例3: 现需在一台机器上加工 nn 个零件(如烧瓷器),这些零件可按任意先后顺序在机器上加工。我们希望加工完成所有零件的总时间尽可能少。由于加工工艺的要求,加工零件 jj 时机器必须处于相应状态 sjsj(如炉温)。设起始未加工任何零件时机器处于状态 s0s0 ,且当所有零件加工完成后需恢复到 s0s0 状态。已知从状态 sisi 调整到状态 sj(j≠i)sj(j≠i) 需要时间 cijcij 零件 jj 本身加工时间为 pjpj。为方便起见,引入一个虚零件 00,其加工时间为 00,要求状态为 s0s0,则 0,1,2,…,n0,1,2,…,n 的一个圈置换 ππ 就表示对所有零件的一个加工顺序,在此置换下,完成所有加工所需要的总时间为 & [1 G1 s7 O. h' q* O
∑i=0n(ciπ(i)+piπ(i))=∑i=0nciπ(i)+∑j=0npj
@0 y7 d% {/ ?) s" \& x. ^∑i=0n(ciπ(i)+piπ(i))=∑i=0nciπ(i)+∑j=0npj& X# P/ E. Y4 n
由于 ∑nj=0pj∑j=0npj 是一个常数,故该零件的加工顺序问题变成TSP。! w2 X% m4 \* d! e) C' R* T
+ y- o2 o+ k$ o# Q$ {9 C" [
代码:' \! a2 s9 o H7 k: L C% M
( Y+ J0 W7 d0 _: s!旅行商问题;
' p. P- p4 @# m) E: |7 N/ p! M+ xmodel:
$ f5 V7 {- K5 P7 ksets:
. @1 o- R4 U5 G' {4 P city / 1.. 5/: u;
7 @" V3 I8 N1 g% Q link(city, city):
) o/ H5 j4 V) q3 o8 c$ I dist, x; !距离矩阵;4 l' z9 ^5 e; i1 }. ~/ q$ r
endsets% {! Y8 h! A+ ~8 C. T1 l! A+ e
n = @size(city);
- X8 A0 j @; P8 ^3 r7 odata: !距离矩阵,它并不需要是对称的;
0 c7 v9 C+ M6 R T; T+ e dist = @qrand(1); !随机产生,这里可改为你要解决的问题的数据;
2 v5 p" o' k, Venddata
+ J0 U5 D" `( [4 K n, W6 q min = @sum(link:dist * x);5 ^( h4 P9 I8 S. Z9 j
@FOR(city(K):
# v1 ~" O1 v+ S( [' L- i @sum(city(I)|I #ne# K: x(I, K)) = 1;1 ]# x& a5 ~6 O! G0 V. M( s1 E
!进入城市K;
* C2 G+ [$ F8 j( g7 P% { @sum(city(J)|J #ne# K: x(K, J)) = 1;) ^8 a% ?$ [! O" q) a
);' R9 M8 r. Y" |: p1 k3 q
@for(city(I)|I #gt# 1:( M; K, u" V3 E' Q
@for(city( J)| J#gt#1 #and# I #ne# J:
4 i; _( z- M* M" O u(I) - u(J) + n * x(I,J) <= n - 1);
) \: p- {. ?9 ~3 W$ M9 ] \9 W8 g );- W$ Y! t0 Z) x B8 y" D" w
@for(city(I)|I #gt# 1: u(I) <= n - 2);" U3 b H( z! w! S3 j
@for(link: @bin(x));
7 y4 F6 G8 Q7 x/ f% [3 Aend2 r h, ~( Z. C3 @5 Q0 p( _
1' y" K9 o: }- s/ J }7 g
2
* J6 u1 E7 D1 g/ l32 A9 h; c) Z1 t4 Z
4
( w% l; c& k% m9 U [5 G" o1 k: n$ j) p$ P
6: K. a7 p/ Q5 W! e5 j+ z; c, Z" w
7
3 ? l( f% q& Q% J8 ^7 }3 x& K& @88 d5 e7 A/ }6 a( c1 N% q
9
1 `( o7 i5 |- g1 x; @10
3 @1 y, Q% Q1 O11, u& }1 o9 U3 o- z, p2 W: ?! X
12# }9 h6 s2 F \
13
8 \9 A0 K* g- _5 P; g14
/ x; w: c9 j0 ~9 X4 }/ g+ X151 L' J! `& F3 [# v; }1 v2 }
162 h7 g, [. e! ~6 B
17
, ?% L9 U, |7 p' K s9 y- [18
/ b9 H3 P& d$ e19 O9 L1 G: [! L# J
20& ]/ \/ T- n8 o+ F0 p/ i/ v
21
" ]" A) H1 F* i+ j' o# P22 I, j, I4 Z8 ^ q. s3 a
23
* D3 Y0 c& q# {/ p/ ]6 x24
# c t8 M$ m# T' s可以得到结果:
1 w$ J* N' x {, q8 E- {2 d$ L9 _, }0 D3 n# v0 H0 i4 }( n9 n
--------------------- * X1 I+ z% T9 t- [7 w6 @
5 b: Q" g7 h5 H2 @8 Z4 O% @( J. M( o |! E! o) P
" k# Y3 J' A) R9 T0 i* K% n- H- q: R9 ~4 A; u# o# H' k0 y
( \8 e" n3 y) P* I
|
zan
|