QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 10093|回复: 0
打印 上一主题 下一主题

2-7、规划问题的Lingo解法

[复制链接]
字体大小: 正常 放大
杨利霞        

5273

主题

82

听众

17万

积分

  • TA的每日心情
    开心
    2021-8-11 17:59
  • 签到天数: 17 天

    [LV.4]偶尔看看III

    网络挑战赛参赛者

    网络挑战赛参赛者

    自我介绍
    本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。

    群组2018美赛大象算法课程

    群组2018美赛护航培训课程

    群组2019年 数学中国站长建

    群组2019年数据分析师课程

    群组2018年大象老师国赛优

    跳转到指定楼层
    1#
    发表于 2019-4-25 16:16 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    2-7、规划问题的Lingo解法) k, q2 V% M' s0 P" i
    一、 从规划问题引入+ }4 r* K4 s9 k  }; ?, ^
    1 J( F3 P( {6 B
      在我们学习探索的各个领域,规划问题都是无处不在的。通过列出约束条件及目标函数,再画出约束条件所表示的可行域,就能在可行域内求得目标函数的最优解以及最优值。当然我们在高中就已经学习过线性规划的相关知识,对于理科同学来说,大多数同学应该感觉难度不大,或者说是送分考点。然而到了大学阶段,一些规划问题的求解已经不是人力可以轻松算出来的了,必须借助于计算机来进行计算。那么对于规划问题的软件选择,又应当如何进行呢?- R, E2 }- Y+ d& n
    8 y% ]4 H8 S6 B: h: j( N2 J4 x
    二、 软件分析与选择3 I  m% S' u5 Q/ b2 ?
    4 J- A" x$ h* n0 J# B% u3 c
      Matlab相比之下是一个面面俱到的编程软件,也可用于求解规划问题。但是如果一定要去和某些“针对特定功能而开发的软件”去比的话,Matlab有时也会稍显逊色。就好比一款顶级的耳机能通吃高中低音,但是去和另一款顶级的为高音而设计的耳机去比较的话,也难免会被比下去。这也就是为什么在规划问题上,很多人会去使用Lingo进行求解。
    . e! y# m& P+ H: x4 P! V" B$ ^! @2 y1 {0 I/ M9 b- P, H: v
      首先我们来区分一下Lindo和Lingo这两款软件。Lingo是在Lindo基础之上做成的软件,处理解线性规划问题之外还加了非线性的求解器,更关键的是还追加了集的概念。可以更方便的解决复杂的问题。所以本文只对Lingo进行讲解。 % @8 F8 ^0 y/ Y& L  o4 w9 _6 [# t2 q, J
      而对于Matlab与Lingo的区别,就好比手动挡与自动挡的区别,有针对性的专业软件会对用户做很多的优化。这里引用知乎上大佬 花开花落 的回答 % |3 W# I. @1 r# c# X! a6 r+ V/ M
    https://www.zhihu.com/question/49319704/answer/165923451  f/ i$ Q! H+ w! C
    9 \: m7 }: m( a0 E$ L- `
      用MATLAB求解线性规划和整数规划问题,需要先将问题转化成如下标准型,其中X只能是向量,也就是单下标变量,然后用向量和矩阵来表达目标函数和约束条件。 : j6 r2 N" y/ k; P
      然而,许多问题(如指派问题和运输问题)由于参数和决策变量是双下标变量,必须在基本的数学模型的基础上进行变换才能求解,这样得到的等式约束和不等式约束的系数矩阵规模就非常庞大,当然由MATLAB计算问题不大,但转换工作完全要由人工完成,工作量大而且容易出错,因此在这一块效率不高。
    & }' s( [% K$ X  而LINGO有自己的建模语言,在建立了集合的基础上,能够高效表达目标函数和各种约束条件。所写的模型基本上可以看作是对数学模型的翻译,不需要太多的转换。
    * }& [7 [% s0 k7 S/ I1 R9 p( l. h: T. X+ r. H
      那么现在我们基本上对LINGO和MATLAB对规划问题的处理方面有了初步认识与了解,至于是执着于MATLAB还是选择开辟LINGO这片新的领域,取决于队伍自身了。; D# K; l+ j* i9 ~% R0 L

    - n. s. _4 p) _6 t, y6 d三、 如何上手Lingo
    ; h; W6 q6 J! s; O+ S: W) J- i" [3 n; h$ ~% n+ Z
      有很多人对于Lingo的评价都是,非常简单的软件,很好上手。
    & w) I7 ]! h% A% O* ~' o  “简单”一词我觉得还比较恰当。Lingo的各种版本几乎全部都是免安装版本的,界面很简单,功能用法很简单,处理问题的方式简单快捷。确实是跟“简单”一词挂钩的。但是任何一款软件想要精通,都是有一定难度的。如果你只需要用Lingo处理一些简单的线性问题,那么2个小时不到,0编程基础的朋友就能上手。如果你认准了Lingo就是你处理各类规划问题的御用软件,那么还是有很长一段路要走的。当然这也取决于用户的编程基础。如果学习过面向对象的程序设计课程的朋友,对于类与对象概念有所了解,那么对于集这一概念也能快速理解上手,学习起来更加轻松。
    " P; K6 _" u' m, Z" R0 y. b' y% j% n- g, b1 e
    四、 Lingo的基本语法规则
    ' T, }5 w/ i# y/ N+ N3 R8 }, |. O( G6 S. K
    1、求目标函数的最大最小值用 MAX=MAX= 和 MIN=MIN= 来表示; , }$ V! A; a9 M' ~+ \
    2、每个语句必须用分号“;”结束,每行可以有许多语句,一个语句可以跨行;
    ' n( r- s2 \/ X9 [7 z3 P! U9 u3、变量名必须以字母A-Z开头,由字母、数字0-9和下划线组成,长度不超过32个字符,不区分大小写;
    9 C1 O. Q2 V+ g) M* ~( s/ A4、可以给语句加上标号;
    & A4 ~7 l2 @- o! Y5 r& D5、注释以“!”开头以“;”结束; , `; G% i2 l; j: f+ e$ S
    6、默认所有的决策变量为非负数;
    2 J: @# M7 G5 n  A+ a; `7、Lingo模型以“MODEL”开头以“END”结束。 * _% g. X' D+ l
    8、Lingo把相联系的对象聚合成集,借助集,就能够用一个单一的长的简明的公式表示一系列相应的约束。 . j1 Z- D/ X2 [7 b+ u
    9、Lingo程序会包含集合段,数据输入段,优化目标和约束段,初始段和数据预处理部分。
    2 o% C3 @) T3 ?8 [- M10、Lingo函数包括有数学函数,金融函数,概率函数,变量界定义函数,集操作函数,集循环函数,输入输出函数,辅助函数等等。
    + `( G2 D& w/ Y* V" ?9 w% _. R: B. Z, S- c
    五、 谈一谈例子' J  ~" ], J4 r" o" Z

    ' r' L7 `* k2 `" N( J7 o3 l  那么Lingo用起来到底有多简单呢,我们来看一个例子。0 `$ S/ K/ h+ r! E; C

    " n$ k8 `% O% ~3 Y例1:某家公诉制造书桌、餐桌和椅子,所用的资源有三种:木料、木工和漆工。生产数据如下表所示:
    2 \$ u* k- h/ }1 p, n8 v; Z/ e0 c, Z0 |$ ^
             每个书桌        每个餐桌        每个椅子        现有资源总数7 b* L/ \6 W9 U9 z
    木料        8个单位        6个单位        1个单位        48个单位
    ) p; y# \$ D- |4 i" }0 u漆工        4个单位        2个单位        1.5个单位        20个单位! R2 A6 Q9 ?/ a/ U2 G
    木工        2个单位        1.5个单位        0.5个单位        8个单位
    $ N" \$ Y, f* `# W) h成品单价        60个单位        30个单位        20个单位         
    * D. G6 a0 e0 S3 |' o2 s9 w# q# q# {  若要求桌子的生产量不超过5件,如何安排三种产品的生产可使利润最大?8 \9 C: Z2 N  K" ?5 G( i( X
    0 |# B9 `+ v) ?7 @# N* Y9 P7 K
    解:代码
    6 o- F: n- I2 U  C, ^/ K* }1 U+ y' S, o) Z7 t' ]
    max = 60 * desks + 30 * tables + 20 * chairs;; Z& B& `2 N1 o
          8 * desks + 6 * tables + chairs <= 48;0 b: P' D' v3 [7 J7 v7 A
          4 * desks + 2 * tables + 1.5 * chairs <= 20;
    5 E0 y. f, m' D. P8 x: j# L      2 * desks + 1.5 * tables + .5 * chairs <= 8;6 `3 V+ t1 C, V
    tables <= 5;' W) \5 C4 d# F$ t7 U  ]/ r) {8 d
    1
    + u. _+ i& X) x) U2. C6 [, F2 r- [/ t1 `% `
    3: c, D4 h. m9 _1 I* B6 h0 [; y
    4
    1 M' F# n0 X# R4 b  C5
    ; ~- v2 y- {1 o' {2 b5 H  l可以得到结果: - \8 I* L, l$ Y' d
    : a% A& k7 N8 i5 R7 b
      这里的 Total solver iteration 表示一共迭代2次得到最优解。 7 M7 V8 Z1 l; ]8 r' h$ r
      Objective value 表示最优值为280,而取280的时候各个变量取多少呢,底下的表格给出了答案。
    % Q) I/ E5 H# `2 {. M* a" {  可以看到,没有定义变量,简简单单一个函数一个约束条件,迅速计算出了答案。Lingo看上去就像是为了非编程人员量身定制的一样。& f5 Q. B+ _/ w" T8 |3 s

    + V) T& \4 K  c( u. G例2:给定一个直角三角形,求包含该三角形的最小正方形。" |. r6 x8 c! E7 b# ?$ B0 i4 f' W
    2 q% Q. b# d" h% G: ^6 p
    我们可以作出如下正方形: 7 M% Q9 m/ U( j/ A; U3 ?

    ' s6 Q8 s1 a; b$ a. k& `5 g" m  m' @. ^5 D
      CE=asinx,AD=bcosx,DE=acosx+bsinxCE=asinx,AD=bcosx,DE=acosx+bsinx
    ' T. |; n$ }1 ^9 I1 E0 y( @  转化为了规划问题那么正方形面积最小的时候即为最优解。 8 D$ e; ^* X# e# a9 A5 M& |- a$ b
      代码:
    6 L# L" G  e# y; v
    # m' S( L9 B% P% r& imodel:
    8 L, @+ B# [/ f2 X8 gsets:
    / _0 R7 \0 N/ h& u: R    object/1..3/:f;
    8 s7 i8 i! d8 ?. y- H9 E+ {endsets4 w5 R/ v# R0 ]- J, o1 m  S+ _5 L
    data:  J- \" r2 ?0 N/ u! k. W) ?
        a, b = 3, 4;
    ' X+ n+ X8 U( E. k% tenddata. x  y0 C; \5 |, B
        f(1) = a * @sin(x);2 u: h, W; C; g) l) f9 _
        f(2) = b * @cos(x);
    : U, Q7 U& k1 a$ w1 K$ {; ~. w    f(3) = a * @cos(x) + b * @sin(x);
    " }% F& I1 N& a* L    min = @smax(f(1), f(2), f(3));) V/ n. f$ Y3 j  u7 M
        @bnd(0, x, 1.57);
    0 X& `, A* I% f' i; t2 Kend
    & S; e; i! B8 z& ^1 y  e10 M: a* j$ J& Z9 l" T& D
    2
      t4 X6 k# F) K8 _( s. E3
    4 Q: ?# _' m; ~0 \3 H. n# n5 n49 r3 @. f; _0 G$ U
    5
    & X( q: g/ B4 Z5 {4 h- e( H6 R6
    9 V# S1 y5 X; F# d( q: T; @7
    ) ?+ I! g& E- W8
    5 a2 f- P. m4 M& A; @" _9) ]& A9 d& V0 Y8 e! C; d  q2 q
    10
    / T& q( r' x+ ~$ i! r1 n7 {' g11
    $ b( R' |/ z5 Y, u+ Z" N12% x, w( ^8 @2 o: }2 s
    13
    0 D& P% `8 v$ s6 c; U" f. w6 ]  得到结果:
    0 Q$ x2 c  f) f9 {2 M6 h" e# u, P# E3 Y3 u! c
    $ S+ B% W3 U  E5 t
      这里需要注意,lingo中如果没有代码说明,是默认 xx 的值大于0的。代码中用 bndbnd 函数限制了 xx 的范围。" `. I4 @& w$ h+ }, D
      那么再进阶一下,Lingo在处理TSP问题的时候表现如何呢?; E8 b0 {3 \7 A) {: }. F: M
    $ ^' e$ p9 L2 t
    例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 的一个圈置换 ππ 就表示对所有零件的一个加工顺序,在此置换下,完成所有加工所需要的总时间为
    ( B. O, R% T7 G3 K, o, D9 S- {3 o∑i=0n(ciπ(i)+piπ(i))=∑i=0nciπ(i)+∑j=0npj- ?% S# d6 y' ~8 m9 _6 X
    ∑i=0n(ciπ(i)+piπ(i))=∑i=0nciπ(i)+∑j=0npj
    0 x; C7 `$ W8 f! v. P# _5 O: B7 }由于 ∑nj=0pj∑j=0npj 是一个常数,故该零件的加工顺序问题变成TSP。: O# {# ?2 s* J3 W& z: I( ?1 }* m( C

    3 B2 [' H, C* M, o代码:
      y' Q7 W" @" h' m, d6 Q1 G( k
    ! u8 v) ^6 w' i. U!旅行商问题;
    0 Y+ X: S) G4 `; E, j! U/ Dmodel:: W/ Y4 I9 S+ o1 [- [
    sets:
    ) E% N  B# ~% G( x' P" j$ j    city / 1.. 5/: u;
    3 J0 i( q- w3 E8 P    link(city, city):
    3 c8 K& P0 ]% Z, `( T        dist, x; !距离矩阵;
    0 ?. J) W' _- G: ]& j2 p" nendsets" x8 }7 g* G6 S3 L
        n = @size(city);
    ' a$ M+ w, k  p, Rdata: !距离矩阵,它并不需要是对称的;7 O% ]* }' t4 I
        dist = @qrand(1); !随机产生,这里可改为你要解决的问题的数据;0 P2 t2 T4 h$ x% z2 J: j
    enddata
      t& Q: V" R: ]- z2 s4 L    min = @sum(link:dist * x);
    ( s& c8 g! w$ O2 O/ U- T# Z    @FOR(city(K):
    . [* [, d6 v) ]- h+ o        @sum(city(I)|I #ne# K: x(I, K)) = 1;
    4 C5 O& Y( U( x& D1 N        !进入城市K;
    * }2 h5 @; u$ w+ P4 b+ w0 e        @sum(city(J)|J #ne# K: x(K, J)) = 1;
    ; U: i+ u0 D' x' ~    );
    0 \1 T/ P7 d3 K    @for(city(I)|I #gt# 1:
    $ h7 N" L7 {+ A8 F; v        @for(city( J)| J#gt#1 #and# I #ne# J:
    5 ^4 L) m, f, Z! S+ x' v4 v             u(I) - u(J) + n * x(I,J) <= n - 1);
    ! b1 p2 X. S4 A2 U& u7 k    );1 b9 r- l4 l+ C( h- u; J& ~! Q
    @for(city(I)|I #gt# 1: u(I) <= n - 2);" ^& i6 e4 V6 W( B% W3 A
    @for(link: @bin(x));
    ; m" i6 n  y7 v6 h, `5 Oend
    0 X. Z2 B. F! j1 w/ I% H; M16 p, U$ v  d# n! R. C% J
    2
    5 F: g3 S  ~. B8 O  T32 z/ X. ?6 L- z0 i9 Q
    4/ a/ {: m# ~4 E8 `1 ]
    5
    1 p. w) W& V. B7 x6 h6
    , M3 B5 ?2 @2 p8 ^- M, {$ ]7" v4 W( B# j4 h0 F! R  g# `
    8, s* \* k9 r2 s4 K! ]" H3 r/ t
    9
    $ c+ e9 l3 F; z9 X1 u  u' K5 D10& C# W& k# b& [3 A* c! w3 b' p
    11
    : i3 s5 X* ^. y9 `+ T% Y" R; G7 k12
    & V+ T6 O& W8 l1 a13( A/ ?! ]* T9 |4 w
    142 a* [9 m$ F4 \7 {, u% L5 C
    15: ?* |+ G4 U, }
    16
    7 c/ }( q( y( j  y6 \2 _2 M17
    - V  z, Z9 d5 K( ~' v$ J# f18
    0 X* B8 @% H+ u4 I: z1 c$ }19
    ) D. n+ |) \8 W: M- ]+ N# U20' V- `# m, P$ R0 f' C7 Q: k" I4 g
    21, z( u5 S* t7 w) D1 H
    22) {; c4 c" O1 x: [# A
    23; I. _9 `6 A+ F% ^  r# v
    24
    " T4 ]% f2 Z6 U& J* ?6 q可以得到结果:
    - T3 {8 I3 g+ j6 u, J8 C5 L$ {3 I8 ^! ~2 K3 }. c% g  G/ B
    ---------------------
    0 W9 c, t3 o* Q  j6 `% f2 V& a6 F" i
    6 Z2 A( |- E/ h) Y7 c: X0 ]

    ' c) X! Y1 Z, ]9 L. J. H1 o/ Y$ t$ H6 y" a
    5 L% P1 Y3 ?; U1 w! L9 n
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-6-10 18:39 , Processed in 0.361175 second(s), 50 queries .

    回顶部