QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 10098|回复: 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解法- e: l9 w1 }* y
    一、 从规划问题引入
    : G$ d" Q1 {7 L0 I2 X' N
    0 u8 v8 e" U7 C2 a# o9 ~  在我们学习探索的各个领域,规划问题都是无处不在的。通过列出约束条件及目标函数,再画出约束条件所表示的可行域,就能在可行域内求得目标函数的最优解以及最优值。当然我们在高中就已经学习过线性规划的相关知识,对于理科同学来说,大多数同学应该感觉难度不大,或者说是送分考点。然而到了大学阶段,一些规划问题的求解已经不是人力可以轻松算出来的了,必须借助于计算机来进行计算。那么对于规划问题的软件选择,又应当如何进行呢?2 @4 p) l& v5 N' ]- Q$ G
    # L* K0 E" I) ~0 r, j0 Z$ i- R
    二、 软件分析与选择
    ) [5 z! q" M7 q" a5 m! Y) i8 h5 Q$ L9 D5 O$ }
      Matlab相比之下是一个面面俱到的编程软件,也可用于求解规划问题。但是如果一定要去和某些“针对特定功能而开发的软件”去比的话,Matlab有时也会稍显逊色。就好比一款顶级的耳机能通吃高中低音,但是去和另一款顶级的为高音而设计的耳机去比较的话,也难免会被比下去。这也就是为什么在规划问题上,很多人会去使用Lingo进行求解。; s% ?. V/ u/ J, T7 z% m0 ~, Q& ?
    % G  u# O7 g  n/ N/ g/ }
      首先我们来区分一下Lindo和Lingo这两款软件。Lingo是在Lindo基础之上做成的软件,处理解线性规划问题之外还加了非线性的求解器,更关键的是还追加了集的概念。可以更方便的解决复杂的问题。所以本文只对Lingo进行讲解。 ' g; C% A) B3 z2 N$ g
      而对于Matlab与Lingo的区别,就好比手动挡与自动挡的区别,有针对性的专业软件会对用户做很多的优化。这里引用知乎上大佬 花开花落 的回答 ) @: j6 T2 D" G, R
    https://www.zhihu.com/question/49319704/answer/1659234519 C( \1 @# [8 c6 ]4 Y
    - i$ b7 _# o2 s* L" f2 \
      用MATLAB求解线性规划和整数规划问题,需要先将问题转化成如下标准型,其中X只能是向量,也就是单下标变量,然后用向量和矩阵来表达目标函数和约束条件。
    ; O# D$ _: g4 V. H% w  Q; W  然而,许多问题(如指派问题和运输问题)由于参数和决策变量是双下标变量,必须在基本的数学模型的基础上进行变换才能求解,这样得到的等式约束和不等式约束的系数矩阵规模就非常庞大,当然由MATLAB计算问题不大,但转换工作完全要由人工完成,工作量大而且容易出错,因此在这一块效率不高。
    1 ~8 z/ c) R/ k; a, ~, N  而LINGO有自己的建模语言,在建立了集合的基础上,能够高效表达目标函数和各种约束条件。所写的模型基本上可以看作是对数学模型的翻译,不需要太多的转换。
    2 }6 p* }' \3 C, j! y8 E+ u9 i' b' h9 {8 }3 ^9 D$ q( a
      那么现在我们基本上对LINGO和MATLAB对规划问题的处理方面有了初步认识与了解,至于是执着于MATLAB还是选择开辟LINGO这片新的领域,取决于队伍自身了。
    . |/ |, ~$ N1 @9 N9 b8 }; `: |! O9 d" a
    三、 如何上手Lingo
    + e. `8 [7 ]3 x5 w8 L% g6 e9 s. C: q5 l. [3 g
      有很多人对于Lingo的评价都是,非常简单的软件,很好上手。 $ ]7 R9 e4 S, ^3 |% }7 x9 O
      “简单”一词我觉得还比较恰当。Lingo的各种版本几乎全部都是免安装版本的,界面很简单,功能用法很简单,处理问题的方式简单快捷。确实是跟“简单”一词挂钩的。但是任何一款软件想要精通,都是有一定难度的。如果你只需要用Lingo处理一些简单的线性问题,那么2个小时不到,0编程基础的朋友就能上手。如果你认准了Lingo就是你处理各类规划问题的御用软件,那么还是有很长一段路要走的。当然这也取决于用户的编程基础。如果学习过面向对象的程序设计课程的朋友,对于类与对象概念有所了解,那么对于集这一概念也能快速理解上手,学习起来更加轻松。
    2 y1 q7 @$ p& G" P
    6 H! g# n7 b9 C/ s四、 Lingo的基本语法规则
    8 o0 M1 K" e- J8 t4 b0 C3 t/ B. S9 w  b3 t
    1、求目标函数的最大最小值用 MAX=MAX= 和 MIN=MIN= 来表示;
    % C8 w) R6 L. D0 }; f3 S  x! ]2、每个语句必须用分号“;”结束,每行可以有许多语句,一个语句可以跨行;
    # T& g5 X' K( s" p6 o4 d; H" m5 w3、变量名必须以字母A-Z开头,由字母、数字0-9和下划线组成,长度不超过32个字符,不区分大小写; $ e' g% T; U! f4 `# d
    4、可以给语句加上标号;
    ! y. g. H' @* B3 f6 d% |5、注释以“!”开头以“;”结束; # P8 F+ H( P4 `0 e( q
    6、默认所有的决策变量为非负数;
    5 l$ s! K* N! e: J  \) \# S9 o2 q7、Lingo模型以“MODEL”开头以“END”结束。   p+ t  x; q% ^6 C0 O6 Z/ x2 p8 m
    8、Lingo把相联系的对象聚合成集,借助集,就能够用一个单一的长的简明的公式表示一系列相应的约束。 : N& Y# y, @$ _. I: x+ P4 u3 k" V' @
    9、Lingo程序会包含集合段,数据输入段,优化目标和约束段,初始段和数据预处理部分。
    ) I7 a, `" J; X$ V$ N10、Lingo函数包括有数学函数,金融函数,概率函数,变量界定义函数,集操作函数,集循环函数,输入输出函数,辅助函数等等。
    0 {, O0 e2 M+ U4 i  P+ Z7 _& [  N) S$ W
    五、 谈一谈例子. F/ s7 b- P$ v- n( Y6 W
    3 \/ P/ `4 {" Q" P0 Y
      那么Lingo用起来到底有多简单呢,我们来看一个例子。- x5 a: d+ ^& {8 L& `

    & |2 e; {/ w4 l! A: x3 [7 v例1:某家公诉制造书桌、餐桌和椅子,所用的资源有三种:木料、木工和漆工。生产数据如下表所示:% }2 P6 H# ~' J% m
    2 \2 n) q3 T, E% n
             每个书桌        每个餐桌        每个椅子        现有资源总数: X. \0 g$ r8 \" A9 y% }
    木料        8个单位        6个单位        1个单位        48个单位" q, X' Z* Y: d7 Q% @
    漆工        4个单位        2个单位        1.5个单位        20个单位7 k. V, e, F; p
    木工        2个单位        1.5个单位        0.5个单位        8个单位
    5 O) \8 q$ {: Y1 `. b# ]成品单价        60个单位        30个单位        20个单位         . W4 k) Z) K6 n( \3 e; q
      若要求桌子的生产量不超过5件,如何安排三种产品的生产可使利润最大?" K6 K( W# f4 r! |4 K+ e+ E5 x
    2 I2 x, y6 j& k8 e" |
    解:代码
    7 ^4 b9 V5 v% m* ^& I8 e( T2 j# n, o! @% ^8 }
    max = 60 * desks + 30 * tables + 20 * chairs;
    % L+ E1 u4 E. L/ H5 X9 }. |9 m      8 * desks + 6 * tables + chairs <= 48;7 K) O( t# P1 P( \1 H
          4 * desks + 2 * tables + 1.5 * chairs <= 20;$ _6 W" A# j' J0 `/ n- ~
          2 * desks + 1.5 * tables + .5 * chairs <= 8;
    : V" ~8 [! |- O2 I- ntables <= 5;5 v% q% c# f' P  ~6 {) k& z. S
    1. Y3 u6 m( m$ |' f
    2
    ! K- b5 b& G4 {( B; K/ D3
    : u1 T  c9 s( h1 Y( f1 L% x4
    8 X& |5 b+ j% r8 g' f5
    + U- ]2 ^- g/ Z( B3 I1 Y可以得到结果:
    # l0 i8 A: q6 s/ D# o; D; U4 \. ]) Q5 ]
      这里的 Total solver iteration 表示一共迭代2次得到最优解。 : C9 E) _4 D' e: l0 d9 A* a& i
      Objective value 表示最优值为280,而取280的时候各个变量取多少呢,底下的表格给出了答案。
    ! E6 V: y0 k; L( O  可以看到,没有定义变量,简简单单一个函数一个约束条件,迅速计算出了答案。Lingo看上去就像是为了非编程人员量身定制的一样。( v, v3 o  u0 ^! K' ~) R, _
    . ~/ \3 d9 o- Z1 `- C" {8 ~9 X2 E
    例2:给定一个直角三角形,求包含该三角形的最小正方形。' [2 ?5 X+ ~4 q4 T- x

    3 f9 u4 L0 v7 q6 ^% _8 O; R我们可以作出如下正方形:
    ; W( Z' K; O+ J% P" p% s
    0 W1 `' o" [3 t. q3 N' |3 x
    * A0 V* E( a  M- m5 Y; y  CE=asinx,AD=bcosx,DE=acosx+bsinxCE=asinx,AD=bcosx,DE=acosx+bsinx
    ' f0 G6 V6 o1 d& e' l1 o3 M4 V  转化为了规划问题那么正方形面积最小的时候即为最优解。
    ( U9 U- m, I" ^9 Z  代码:
    1 |. K$ y0 v* `. k
    , M# Q% H7 I1 rmodel:
    1 [7 D' m( T4 Q4 o& i$ Isets:6 p5 j3 i" z- ^
        object/1..3/:f;+ S" ]+ Y& B6 ^' ~2 r' J3 Q
    endsets! M6 |% u% A# I) U' w. J0 |  ?
    data:
    ( b) M  l. u# t. e! W: m! ]' H    a, b = 3, 4;
    . w' Q/ K" o" e( _) D6 j7 v7 o& tenddata' n8 _; T% ]& T
        f(1) = a * @sin(x);
    " U1 n- f% H4 w* d' j    f(2) = b * @cos(x);
    ; k1 k! z/ Y" k' n+ }7 n    f(3) = a * @cos(x) + b * @sin(x);
    3 `+ @' I' p& @4 |# Q1 b    min = @smax(f(1), f(2), f(3));
    * x- \' J5 o7 p" z6 E2 r  z# j6 s    @bnd(0, x, 1.57);
    3 [! n9 m  D! T) I+ S" Fend5 U# C4 N: C/ D5 L% r. |3 b
    1
    . P  j/ z& u  ], X& H23 a' ]/ @  ~* b$ n" x
    3* H9 {( ~& z: h+ `* [
    46 ~0 R  b" o5 O* g# C
    54 s+ v7 s% Y! g! Y2 i2 o2 ~, l
    6# I$ U! G" @7 A& B4 c
    7' e9 H  |# N* Y3 d1 i
    8
    ; j9 `- C- s1 M; s; }91 C: X5 m: [& ^
    10
    % e( ~) ]: O# ^* l1 _) W11
    % p! h8 u7 a& D. p# x128 ~) W4 Q6 s& A- }
    13& X8 R* `3 w" g" S$ J0 k
      得到结果:
    8 V# T7 a/ [0 {) @$ c; T* r& @3 c# u
    3 U4 v) `1 N# C* ^
      这里需要注意,lingo中如果没有代码说明,是默认 xx 的值大于0的。代码中用 bndbnd 函数限制了 xx 的范围。
    7 q# M8 Q% I* ^& F2 I  那么再进阶一下,Lingo在处理TSP问题的时候表现如何呢?. v# D5 d1 Q/ e& J
    ! X( P. x" ^) u
    例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 的一个圈置换 ππ 就表示对所有零件的一个加工顺序,在此置换下,完成所有加工所需要的总时间为   D; s7 o6 F* N) w! Z+ t
    ∑i=0n(ciπ(i)+piπ(i))=∑i=0nciπ(i)+∑j=0npj
    6 ^% e; y* {* s∑i=0n(ciπ(i)+piπ(i))=∑i=0nciπ(i)+∑j=0npj
    " X" D0 Z, l  N- a$ c9 H# l7 c由于 ∑nj=0pj∑j=0npj 是一个常数,故该零件的加工顺序问题变成TSP。" Z+ O  |2 A% J* b( F
    2 k. H2 g# g$ b! G
    代码:+ t7 ~, F" m) j' n, y0 r+ J
    1 ~$ i. l  I! w' }" K* O" c
    !旅行商问题;
    5 n* v: Y7 Z' dmodel:2 V, G; i1 v' ]! P, `6 W
    sets:# J6 ?% U6 r' W) i$ a
        city / 1.. 5/: u;! `- s( ?! C1 `8 A' C( U) z$ b
        link(city, city):
    1 U3 U" E8 D/ v& ?% z1 z, I        dist, x; !距离矩阵;# y$ P2 z/ i3 G) w; U6 |! t4 _
    endsets, Z, g+ N) s! Y# y* c& Y1 [3 w
        n = @size(city);
    4 X+ {( s/ `+ {2 g" Q; X' vdata: !距离矩阵,它并不需要是对称的;5 ^. S: O6 }; k6 q3 q4 U4 X
        dist = @qrand(1); !随机产生,这里可改为你要解决的问题的数据;
    . @( `. a" \2 P/ m$ \0 tenddata$ g+ r& E! P/ m5 B* \- X1 u
        min = @sum(link:dist * x);+ U+ O( H& Z6 ]# t
        @FOR(city(K):$ q8 t( S# ~( w: B' Z, z2 F" @1 A9 G. r
            @sum(city(I)|I #ne# K: x(I, K)) = 1;4 j/ N: z# w6 S  T8 D* J6 W
            !进入城市K;
    : ?& P% C+ c1 Q" }) X        @sum(city(J)|J #ne# K: x(K, J)) = 1;
    0 C; {5 W+ f8 ]) j    );
    5 [% E8 n- l) A: _. Z/ A8 D4 o; Y5 [    @for(city(I)|I #gt# 1:
      j2 X' @/ v' ^. o7 x8 K, W        @for(city( J)| J#gt#1 #and# I #ne# J:
    ! s' k9 G& m) N4 I             u(I) - u(J) + n * x(I,J) <= n - 1);5 ~" V  b* J" w# M) g
        );
    + x( w! a; k, Y0 k3 [+ t6 |! y@for(city(I)|I #gt# 1: u(I) <= n - 2);8 m& o5 A% q; O4 g
    @for(link: @bin(x));) {# s2 }" D5 J3 m( A+ F
    end2 P. U' v$ E2 l: f) Y- R  |
    16 k. Q" j& t7 y' D6 K/ ]5 E
    2
    * G9 d  @/ q: q& {1 A! o! C/ G7 ?7 w34 i, \3 I+ \1 m
    4# t' X( a2 H, ?# j; C. a0 v$ B, w5 e0 Y
    59 K9 G0 a9 R" i  \$ a$ G. S
    66 A5 k' G/ ^7 J9 M
    7
    - h8 }3 u) p. O' V4 @8
    " N- m2 f( [2 a2 b6 J+ v9
    " U! L1 i* M4 Y+ m2 l" t- k103 w% d' }$ Z9 {% g6 U
    11% f$ \2 K3 X: V4 {
    12
    ' R" o# N8 |) ]6 n13
    ; R5 h4 g; _2 ?3 v& U148 M) Z8 Z1 Q0 I3 X8 g9 \3 ^$ x, r
    15! i* A8 }5 Y" u
    16( ^; f4 E# F$ G- ]( c
    17& K+ ~' L. d" H1 I
    18
    + x4 Z. e4 Y5 R' V4 n6 H" _19
    & s! n6 D7 C' f) v5 E20
    & e. T: }6 p5 ^  H21, T& P5 |% `( D  R
    22& E  R/ ?- P+ q6 a6 P
    23
    & w  p* A9 J5 p9 a24
    ( ~: n5 G& w1 x2 @' P可以得到结果:
    ) G7 f1 r, P$ |+ x( U3 G1 w7 J0 W' k- p& I3 L3 `
    ---------------------
      C( i$ o8 @5 f" j; Y9 S" D) a8 {  W3 q0 e+ g! `1 Z$ u' y
    8 ~- M/ l* G5 r* E

    # |( W5 k. u& A+ A+ i, h. t; L( u- B  z4 ~) i- u

    ' n& ?6 y, G/ m" R. P
    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-12 16:31 , Processed in 0.422165 second(s), 50 queries .

    回顶部