QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 9827|回复: 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解法
    ) {$ D# }* h7 W1 _- n6 T  C% r8 Z& {( n一、 从规划问题引入
    6 k5 W! E2 w( U) [) p! R& I( v8 ?  f* ]
      在我们学习探索的各个领域,规划问题都是无处不在的。通过列出约束条件及目标函数,再画出约束条件所表示的可行域,就能在可行域内求得目标函数的最优解以及最优值。当然我们在高中就已经学习过线性规划的相关知识,对于理科同学来说,大多数同学应该感觉难度不大,或者说是送分考点。然而到了大学阶段,一些规划问题的求解已经不是人力可以轻松算出来的了,必须借助于计算机来进行计算。那么对于规划问题的软件选择,又应当如何进行呢?
    3 K$ n5 R7 @( m* z
    $ ]; C% |' I$ ~二、 软件分析与选择# k/ F5 h" ^9 t1 [& S
    & J8 b# A/ h) Z" P" [: x
      Matlab相比之下是一个面面俱到的编程软件,也可用于求解规划问题。但是如果一定要去和某些“针对特定功能而开发的软件”去比的话,Matlab有时也会稍显逊色。就好比一款顶级的耳机能通吃高中低音,但是去和另一款顶级的为高音而设计的耳机去比较的话,也难免会被比下去。这也就是为什么在规划问题上,很多人会去使用Lingo进行求解。
    / A# {1 C% j0 S% A9 M# o& L% q( O  A) d7 _; G2 x
      首先我们来区分一下Lindo和Lingo这两款软件。Lingo是在Lindo基础之上做成的软件,处理解线性规划问题之外还加了非线性的求解器,更关键的是还追加了集的概念。可以更方便的解决复杂的问题。所以本文只对Lingo进行讲解。
    ( z7 v0 m( r" S4 v  而对于Matlab与Lingo的区别,就好比手动挡与自动挡的区别,有针对性的专业软件会对用户做很多的优化。这里引用知乎上大佬 花开花落 的回答
    0 F  W2 |) P7 H0 w8 Thttps://www.zhihu.com/question/49319704/answer/165923451
    / Z' b" n) @7 g
    - D9 i& {! R- h- F$ S) I  用MATLAB求解线性规划和整数规划问题,需要先将问题转化成如下标准型,其中X只能是向量,也就是单下标变量,然后用向量和矩阵来表达目标函数和约束条件。
      T! A6 _7 F  X: Q$ v6 ^: t  然而,许多问题(如指派问题和运输问题)由于参数和决策变量是双下标变量,必须在基本的数学模型的基础上进行变换才能求解,这样得到的等式约束和不等式约束的系数矩阵规模就非常庞大,当然由MATLAB计算问题不大,但转换工作完全要由人工完成,工作量大而且容易出错,因此在这一块效率不高。
    * x" x7 D2 q, r4 A, p  而LINGO有自己的建模语言,在建立了集合的基础上,能够高效表达目标函数和各种约束条件。所写的模型基本上可以看作是对数学模型的翻译,不需要太多的转换。
    ' p2 |. t9 w$ I3 Y9 S
    ; B  ?& Y$ z" q" u+ G7 j  那么现在我们基本上对LINGO和MATLAB对规划问题的处理方面有了初步认识与了解,至于是执着于MATLAB还是选择开辟LINGO这片新的领域,取决于队伍自身了。! @* @/ t4 M- p  l% y

    3 C' K% ^# }- l& |4 p; S三、 如何上手Lingo
    % A- J1 c7 I% }) E3 o+ b& H8 J, H4 p0 h! K0 Q8 W" W9 @3 ?
      有很多人对于Lingo的评价都是,非常简单的软件,很好上手。 ! V! v- c1 `  }$ N3 c
      “简单”一词我觉得还比较恰当。Lingo的各种版本几乎全部都是免安装版本的,界面很简单,功能用法很简单,处理问题的方式简单快捷。确实是跟“简单”一词挂钩的。但是任何一款软件想要精通,都是有一定难度的。如果你只需要用Lingo处理一些简单的线性问题,那么2个小时不到,0编程基础的朋友就能上手。如果你认准了Lingo就是你处理各类规划问题的御用软件,那么还是有很长一段路要走的。当然这也取决于用户的编程基础。如果学习过面向对象的程序设计课程的朋友,对于类与对象概念有所了解,那么对于集这一概念也能快速理解上手,学习起来更加轻松。
    7 C% {$ X! w$ }# S' I& K/ n9 x+ q' K8 D0 \: T5 Q/ J% E6 l$ @
    四、 Lingo的基本语法规则; ~" \! Y/ h  \+ N4 |
    ; e  O; R  g7 V
    1、求目标函数的最大最小值用 MAX=MAX= 和 MIN=MIN= 来表示; 1 {: g& k: z6 }, G/ s
    2、每个语句必须用分号“;”结束,每行可以有许多语句,一个语句可以跨行;
    2 c4 i2 J0 }2 r! A* p. R+ A- t; O3、变量名必须以字母A-Z开头,由字母、数字0-9和下划线组成,长度不超过32个字符,不区分大小写;
    3 s5 z& ^9 y! x7 o2 A$ b4、可以给语句加上标号;
    ' Z# S: @9 E1 _% k9 K5 h6 D5、注释以“!”开头以“;”结束; ; Q' N6 |. g* z% X  V
    6、默认所有的决策变量为非负数; ! w/ }# _% Z8 d# s6 p4 r* n8 S7 M3 p
    7、Lingo模型以“MODEL”开头以“END”结束。
    - _! I$ @: s; `1 S8、Lingo把相联系的对象聚合成集,借助集,就能够用一个单一的长的简明的公式表示一系列相应的约束。
    1 {$ L, V: z) ?& i+ M% P3 K0 U9、Lingo程序会包含集合段,数据输入段,优化目标和约束段,初始段和数据预处理部分。 , ~5 R2 I. Z! p1 g; J
    10、Lingo函数包括有数学函数,金融函数,概率函数,变量界定义函数,集操作函数,集循环函数,输入输出函数,辅助函数等等。0 E; S5 h- u$ K6 A+ E( P5 ^: n( t  n) v
    1 f7 c" s5 H. E- P8 ]$ g: d
    五、 谈一谈例子6 C* V  u- Q6 v! V$ y
      y) E$ l2 `" C( E5 u* o9 r: z
      那么Lingo用起来到底有多简单呢,我们来看一个例子。6 f1 U1 _; W1 c$ g. f
    ( a5 X4 H2 w" \4 K/ `$ Z
    例1:某家公诉制造书桌、餐桌和椅子,所用的资源有三种:木料、木工和漆工。生产数据如下表所示:
    * _) P4 i9 P/ j! J9 ~$ `8 _& K# T8 k1 u" c
             每个书桌        每个餐桌        每个椅子        现有资源总数
    ' x5 u; T% R3 O8 Z5 \# v木料        8个单位        6个单位        1个单位        48个单位* @4 w" b4 N) l$ b, _$ a
    漆工        4个单位        2个单位        1.5个单位        20个单位/ a3 x9 f+ c" h3 F+ T3 \0 B+ N, k4 U
    木工        2个单位        1.5个单位        0.5个单位        8个单位5 V' n0 ~/ v& S# K' M+ b! Y
    成品单价        60个单位        30个单位        20个单位         
    - X* U3 X0 V" t, ^0 k/ `1 y3 V  若要求桌子的生产量不超过5件,如何安排三种产品的生产可使利润最大?
    3 y) b6 ]# x6 |3 V& O0 Z+ P* }/ e8 V& R  P; k
    解:代码3 n9 Q* v% D8 |9 g8 w- x
    ! U3 \1 M: x5 r! g: W
    max = 60 * desks + 30 * tables + 20 * chairs;7 Q0 m( W* V! y" j- `' k. @
          8 * desks + 6 * tables + chairs <= 48;
    ) h! y1 X% i. s, g/ D4 `$ G. D5 T; s      4 * desks + 2 * tables + 1.5 * chairs <= 20;  @% ]9 ?- m# ]5 n% T) M3 T
          2 * desks + 1.5 * tables + .5 * chairs <= 8;6 T& @! q: }" X5 e
    tables <= 5;
    - ]+ o# C9 O( f1
    % Y5 m3 H+ u0 c+ h) T, n2
    ' `& S& x) s8 T1 s' E# _3
    ( E/ d4 V7 q0 |" D  a4
    7 E  q8 e  `9 U; E5( `) e* j- C# w& W
    可以得到结果: / K8 H2 `# B7 y+ g* G# V

    + w) D0 g4 g. h5 n  这里的 Total solver iteration 表示一共迭代2次得到最优解。 # y( T# w* `/ `3 m
      Objective value 表示最优值为280,而取280的时候各个变量取多少呢,底下的表格给出了答案。
    ' a# m/ F0 {2 [1 D  ^) d  可以看到,没有定义变量,简简单单一个函数一个约束条件,迅速计算出了答案。Lingo看上去就像是为了非编程人员量身定制的一样。
    , W. N  P8 f  v, H; Q+ u' s% t- r: m/ q- x  U# Q" e, a1 b/ G
    例2:给定一个直角三角形,求包含该三角形的最小正方形。
    " M2 G( w; Z1 B0 L6 L8 P9 Y' T! e9 n# |
    我们可以作出如下正方形: * s: m' @, g! w1 n" [

    6 m# `9 Q0 I  T8 e; [
    1 K: Y; i& J' R0 V  CE=asinx,AD=bcosx,DE=acosx+bsinxCE=asinx,AD=bcosx,DE=acosx+bsinx% d% m  _4 C- x
      转化为了规划问题那么正方形面积最小的时候即为最优解。   g) f7 p: P- v- u2 y( U2 o
      代码:
    : y+ Q( F7 H/ Z$ c" A
    ' l9 C2 s+ X# ?: Z% r- Amodel:+ i' S7 d$ ~. c  ]: \) {: k
    sets:
    3 x' C9 p/ W+ r, q    object/1..3/:f;
    6 }# d% v* w2 Mendsets( [* `, H( P  g9 D8 t, \6 \
    data:% r: S7 R% Y  K( W
        a, b = 3, 4;
    . p# |3 L: m3 r7 F! l! z( q4 j3 genddata  B) H! ]: ~# x/ ^% n
        f(1) = a * @sin(x);
    & ?4 r3 b% W" x  i    f(2) = b * @cos(x);
    * L7 Q; k) X1 K0 Z$ N4 h! n    f(3) = a * @cos(x) + b * @sin(x);; N; t9 I0 X8 h1 v
        min = @smax(f(1), f(2), f(3));
    % R/ {2 u+ F1 \  l1 z8 Z: p4 q% h    @bnd(0, x, 1.57);' z$ E. m8 K. g  T5 T; t  Z7 }
    end
    3 m7 d9 H( N% }8 z( r' c  W1
    ) A; V! Z1 M  T, N( u0 g2
      L; k( I7 ~* s* \3
    3 e; w# o- w6 c$ I9 C- ]( U4( O7 `! z8 o' B1 A, z' l1 w
    58 v8 e4 v7 |$ r
    6- D; p4 v# \0 X, X. I0 _
    7
    / w5 H: }  C7 g$ d! W8
    . c/ E1 ?! |: i* i2 ~4 n0 Z9
    # Q$ _+ q0 w" r( E* ]/ x" `) z107 h+ i1 P% W9 m
    11
    7 v/ @* C5 x/ d& Q12
    ) ]! `  y- o1 Y! U13
    4 o) m1 M! a! W. T; C  得到结果:
    - F- `8 Y( z$ ]5 _$ ^
    ! @5 S7 ?$ o2 ]1 H. \7 R) b# m# P
    & L9 p6 e; D0 f4 p7 ^  这里需要注意,lingo中如果没有代码说明,是默认 xx 的值大于0的。代码中用 bndbnd 函数限制了 xx 的范围。
      Z$ T& p( W, Z+ ^# M  那么再进阶一下,Lingo在处理TSP问题的时候表现如何呢?3 i  ^+ E* C% K; U& ?; F+ g. p4 B( e
    # @; z3 }8 g) ?2 `+ p& |1 J
    例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 的一个圈置换 ππ 就表示对所有零件的一个加工顺序,在此置换下,完成所有加工所需要的总时间为 $ S8 i  ^# q. u
    ∑i=0n(ciπ(i)+piπ(i))=∑i=0nciπ(i)+∑j=0npj
    # g/ G5 f) J/ Y: e8 I2 X∑i=0n(ciπ(i)+piπ(i))=∑i=0nciπ(i)+∑j=0npj; l5 v; _' u  @
    由于 ∑nj=0pj∑j=0npj 是一个常数,故该零件的加工顺序问题变成TSP。% `1 v! ?9 V( h1 v6 X
    + R8 v1 Y+ ?* P: c! q
    代码:5 L: y+ ]! n5 V, O

    * W( x: {- }/ ^. P+ U! a9 A!旅行商问题;
    5 K$ n. L; a; w+ Omodel:
    # ^; u" `4 Y9 o+ Xsets:4 T+ Q+ i4 V8 o( }
        city / 1.. 5/: u;
    & A8 y' W$ H/ V- a; E" r5 _    link(city, city):
    . n. }$ x  ?3 Q' t% B& A8 G        dist, x; !距离矩阵;
    " ]6 I* ^$ b* O0 q/ r: E! V" L9 K* ^6 `endsets* w& F3 v. Q" U7 f, O( b. T  D
        n = @size(city);% Q9 W$ _8 [0 }. c4 z, f
    data: !距离矩阵,它并不需要是对称的;# h/ O( ^$ G, |7 [+ U
        dist = @qrand(1); !随机产生,这里可改为你要解决的问题的数据;7 O2 {( ^( I1 N
    enddata# x8 x, x- z% f1 n! C
        min = @sum(link:dist * x);
    ; I4 ~+ M& ~" s- M  _% \& D    @FOR(city(K):9 w4 {% u* n& o- a
            @sum(city(I)|I #ne# K: x(I, K)) = 1;1 }9 v0 l+ v. ?" K
            !进入城市K;; r" {3 r, a  M, E
            @sum(city(J)|J #ne# K: x(K, J)) = 1;
      K- r) N0 r+ {9 T6 B: `    );" ~! k, m! B8 E. i: b0 J# {" C
        @for(city(I)|I #gt# 1:
    + j% g3 d5 U! j. ?' Q! w0 j4 c# c        @for(city( J)| J#gt#1 #and# I #ne# J:
    / p0 g5 n2 p! {! _, o             u(I) - u(J) + n * x(I,J) <= n - 1);
    * x1 m) y  s0 T8 f5 a    );
    & E% Z. K* ?# V3 g2 j@for(city(I)|I #gt# 1: u(I) <= n - 2);
    ; Q0 ?7 P  x9 F/ A$ L@for(link: @bin(x));5 K6 b  n2 p+ d( \
    end8 u2 U7 t& Z' p% k( ~. L5 i5 x2 G
    1
    , E' H. f2 g* c: a# v; [" q2
    1 y) r4 P2 Q" }" K* G% m+ R3  W* S7 o6 r: F4 T- O: _; r" _
    4: l% u4 g$ {# U! n( V
    5
    & @$ Z# [  p: K3 b. ]6 W6* u3 B4 T5 u. I0 v+ K. Q
    76 W) B! ~- F5 x6 u1 G8 R. u: I. Y
    8! }; f+ S: p6 T- q7 i
    9
    1 m+ F2 Y& d$ g1 [10
    " E" N' |, I4 i; S* o& y11$ r! u. [5 ^7 c5 t6 Y6 e: Q7 w
    12
    , k- T( n* |; D% B0 q  R1 ]. z+ X/ P  V13
    8 j4 h& U2 x) K14; o- d* @6 U" d7 O# i
    15
    : l; ]% w2 `' f; L* E1 r) K16
    7 U! B5 U" ?5 l6 W0 x" M177 |1 W7 R* V; s. M9 I. p$ T1 b
    180 q5 h: z$ Z  H% N3 c
    19% s' L: a% L( f" q
    20
    ! j' Y  I) T% q( g21
    & B7 U- H" f$ A% `' C22
    ! x/ i3 m) {. q' z* p23: j; G0 h6 w2 X' l% k
    24
    7 S0 }7 a' L' O  ^可以得到结果: . V: u, p4 t& L8 E& F5 b! P

    " c6 t- x3 D! V( Q- H" d+ d- F+ d& K--------------------- # L" N) }: y9 Y+ t
    + W* y% @" K+ E
    : B9 C6 p' M$ X. ?+ o  f# o

    , d$ S$ t; @+ A% f! V, R
    % w$ x( \- @1 r4 c; G  f7 z2 D8 V3 @' H4 s" P8 H5 ^
    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, 2025-10-17 03:35 , Processed in 0.412583 second(s), 51 queries .

    回顶部