QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 9675|回复: 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解法
    2 l/ Z- B/ J1 m4 c一、 从规划问题引入
    9 n4 s7 c- r7 a! E
    ! W* |& a. X1 Z8 ]  在我们学习探索的各个领域,规划问题都是无处不在的。通过列出约束条件及目标函数,再画出约束条件所表示的可行域,就能在可行域内求得目标函数的最优解以及最优值。当然我们在高中就已经学习过线性规划的相关知识,对于理科同学来说,大多数同学应该感觉难度不大,或者说是送分考点。然而到了大学阶段,一些规划问题的求解已经不是人力可以轻松算出来的了,必须借助于计算机来进行计算。那么对于规划问题的软件选择,又应当如何进行呢?8 x8 W0 {) E2 z5 W

    3 a% X: S7 x" S3 p+ c2 j+ M二、 软件分析与选择" _# w" \1 ]! `+ S" B
    8 f% Z6 Q- k2 {) w9 o
      Matlab相比之下是一个面面俱到的编程软件,也可用于求解规划问题。但是如果一定要去和某些“针对特定功能而开发的软件”去比的话,Matlab有时也会稍显逊色。就好比一款顶级的耳机能通吃高中低音,但是去和另一款顶级的为高音而设计的耳机去比较的话,也难免会被比下去。这也就是为什么在规划问题上,很多人会去使用Lingo进行求解。( W! ]' m2 _* p

    ' r! \. P! l+ H2 v  首先我们来区分一下Lindo和Lingo这两款软件。Lingo是在Lindo基础之上做成的软件,处理解线性规划问题之外还加了非线性的求解器,更关键的是还追加了集的概念。可以更方便的解决复杂的问题。所以本文只对Lingo进行讲解。
    % L+ R- I  p" \0 o) h# m  而对于Matlab与Lingo的区别,就好比手动挡与自动挡的区别,有针对性的专业软件会对用户做很多的优化。这里引用知乎上大佬 花开花落 的回答
    0 N9 i" y1 h$ d; }https://www.zhihu.com/question/49319704/answer/1659234518 B. ~" @$ Q# p
    7 K4 K% m4 s2 [. S
      用MATLAB求解线性规划和整数规划问题,需要先将问题转化成如下标准型,其中X只能是向量,也就是单下标变量,然后用向量和矩阵来表达目标函数和约束条件。 ' E7 L4 o- G3 {9 R
      然而,许多问题(如指派问题和运输问题)由于参数和决策变量是双下标变量,必须在基本的数学模型的基础上进行变换才能求解,这样得到的等式约束和不等式约束的系数矩阵规模就非常庞大,当然由MATLAB计算问题不大,但转换工作完全要由人工完成,工作量大而且容易出错,因此在这一块效率不高。
    8 i. {- _( e9 Y7 |, y, N- q! c( y% l  而LINGO有自己的建模语言,在建立了集合的基础上,能够高效表达目标函数和各种约束条件。所写的模型基本上可以看作是对数学模型的翻译,不需要太多的转换。! s* I% {3 D3 D' {
    # r: B  g7 P! u- C& {0 b8 n
      那么现在我们基本上对LINGO和MATLAB对规划问题的处理方面有了初步认识与了解,至于是执着于MATLAB还是选择开辟LINGO这片新的领域,取决于队伍自身了。! D& R; X* \* ?! Q
    $ {2 A3 J' h# t; i3 l
    三、 如何上手Lingo& I8 @8 }2 t+ \+ R" s1 z
    $ v, E7 p4 q6 E
      有很多人对于Lingo的评价都是,非常简单的软件,很好上手。
    2 s* X0 ~8 F% T, S  “简单”一词我觉得还比较恰当。Lingo的各种版本几乎全部都是免安装版本的,界面很简单,功能用法很简单,处理问题的方式简单快捷。确实是跟“简单”一词挂钩的。但是任何一款软件想要精通,都是有一定难度的。如果你只需要用Lingo处理一些简单的线性问题,那么2个小时不到,0编程基础的朋友就能上手。如果你认准了Lingo就是你处理各类规划问题的御用软件,那么还是有很长一段路要走的。当然这也取决于用户的编程基础。如果学习过面向对象的程序设计课程的朋友,对于类与对象概念有所了解,那么对于集这一概念也能快速理解上手,学习起来更加轻松。
    8 f: a1 K. m: v# T$ D9 ?* w
    . a& d* \) w; f. j/ h/ [9 q四、 Lingo的基本语法规则
    7 e( Q/ f2 U6 z3 L: f1 Q
    4 E! ~8 `4 @9 a( [  M, m1、求目标函数的最大最小值用 MAX=MAX= 和 MIN=MIN= 来表示; ! p4 T; ]+ {. F; l7 y% ~. L$ u4 S" Q9 T
    2、每个语句必须用分号“;”结束,每行可以有许多语句,一个语句可以跨行; ) R3 w" o: @' Z9 Z/ ~8 J$ t
    3、变量名必须以字母A-Z开头,由字母、数字0-9和下划线组成,长度不超过32个字符,不区分大小写; , _- U$ y' N$ Q/ E: e
    4、可以给语句加上标号;
    # N) Y. ~/ v2 v8 U5、注释以“!”开头以“;”结束;
    # r5 k: {+ u5 F6、默认所有的决策变量为非负数;
    ' P& F* f; S5 o1 P7、Lingo模型以“MODEL”开头以“END”结束。 . H1 m: f( ^" B% \0 p) `
    8、Lingo把相联系的对象聚合成集,借助集,就能够用一个单一的长的简明的公式表示一系列相应的约束。 : q8 f7 y$ W: K8 [. s
    9、Lingo程序会包含集合段,数据输入段,优化目标和约束段,初始段和数据预处理部分。 " m* X6 o/ {% ]: ]% `2 r
    10、Lingo函数包括有数学函数,金融函数,概率函数,变量界定义函数,集操作函数,集循环函数,输入输出函数,辅助函数等等。
    ! e% J! v- z% k- Y
    , i  _+ I! f$ w& q% E5 k五、 谈一谈例子
    ) C! W1 d! R* n6 m8 Y# C1 ?7 o# n3 e: u# |+ K
      那么Lingo用起来到底有多简单呢,我们来看一个例子。! ?& x4 ?: a; X- x# }

    ! n: ]! N$ j: H5 {5 O5 j) @8 |9 U1 |0 b例1:某家公诉制造书桌、餐桌和椅子,所用的资源有三种:木料、木工和漆工。生产数据如下表所示:
    1 f, v! {1 @; \- A6 N7 {* w0 }4 P) `! F
             每个书桌        每个餐桌        每个椅子        现有资源总数
    . |& ]8 Q$ |; J+ ?. d木料        8个单位        6个单位        1个单位        48个单位: ?' C( A8 J  L) f
    漆工        4个单位        2个单位        1.5个单位        20个单位0 \5 d. c% S; s& T' r+ ^/ o& ]2 ]
    木工        2个单位        1.5个单位        0.5个单位        8个单位3 B2 v8 E, p' m1 ?- n# f
    成品单价        60个单位        30个单位        20个单位         / i; G' j  T; r: T$ K1 Z* ?$ A
      若要求桌子的生产量不超过5件,如何安排三种产品的生产可使利润最大?# H5 ]' d) o  \) v- j5 d

    1 h8 i; b& q. S% E& ~2 P解:代码' ~1 z7 |' _+ @

    / R) j3 Q+ X' G( e8 a/ ]max = 60 * desks + 30 * tables + 20 * chairs;
    . j( d' F7 R. \7 `& o9 S      8 * desks + 6 * tables + chairs <= 48;' p3 I7 C7 q9 R+ C2 J
          4 * desks + 2 * tables + 1.5 * chairs <= 20;. e1 ^# }3 ^0 E4 }
          2 * desks + 1.5 * tables + .5 * chairs <= 8;2 U, y, s/ }8 u$ N
    tables <= 5;  B4 \, i: c1 p* U/ Q2 K
    1$ l! F5 I0 q6 j: J3 S4 o& B& e
    2
    , O+ J! ^4 Y7 @: v( P) O6 _, X3
    . d1 j8 P' `, ^$ |2 t6 }. r3 [4 V* S4
    9 J  L7 h5 N8 R5
    1 ]! l8 G( l8 W: O& f1 k2 \7 W可以得到结果: : F& t4 k1 \, z& _5 l( Q  C
    7 Y" d6 X5 g% D4 b
      这里的 Total solver iteration 表示一共迭代2次得到最优解。
    % {6 e* v/ T/ r: i  Objective value 表示最优值为280,而取280的时候各个变量取多少呢,底下的表格给出了答案。
    & C. O% Z! A% P. e# M+ O  可以看到,没有定义变量,简简单单一个函数一个约束条件,迅速计算出了答案。Lingo看上去就像是为了非编程人员量身定制的一样。0 L4 c! g2 K! l1 {( ^0 L
    7 l# Q7 M) j0 _: F
    例2:给定一个直角三角形,求包含该三角形的最小正方形。
    " `4 `& N5 \* \+ b8 {; I% o6 E) r$ L* c  P. I6 E: [8 _
    我们可以作出如下正方形: * x$ L) X/ z5 b3 ^9 n3 {$ p
    / m3 c. E7 ?" z. L! r7 y3 h
    ) x  z" k2 T2 |6 I6 q
      CE=asinx,AD=bcosx,DE=acosx+bsinxCE=asinx,AD=bcosx,DE=acosx+bsinx
    5 Y" K" n9 Y. L! s  转化为了规划问题那么正方形面积最小的时候即为最优解。 / E, n4 n4 X4 n
      代码:
    : r# [. X& P6 n( m
    8 l/ c4 V- u! g- k" smodel:
    ( p/ s' Z# `2 W) B6 ksets:
    2 H8 a, s1 w, G0 q    object/1..3/:f;
    $ ^% z+ j/ ?$ V9 v. U+ _endsets
    " K. q* _. O2 l. K9 N. h$ ndata:
    ' N. I$ w4 f9 v1 B- x% M    a, b = 3, 4;1 n9 d0 `. w; C( ?. R3 b
    enddata  D; w1 B) D6 x' Y9 M2 u
        f(1) = a * @sin(x);% l" a* F  N) _1 W
        f(2) = b * @cos(x);
    " s1 h2 F- A) D2 ]    f(3) = a * @cos(x) + b * @sin(x);
    % s( `/ z; O: \) G; J: b    min = @smax(f(1), f(2), f(3));. d( W6 R9 ]" H4 s8 [
        @bnd(0, x, 1.57);9 [4 Z8 _% ^% a! q: t% c
    end
    ! ?7 O% U& V$ }0 a' `( O1+ V2 M$ X+ p9 v# A
    2+ K4 d3 o8 |- I* @$ X/ \, Q8 \
    3
    - A' |6 T  C% U: s4
    ! |  ~' [  {6 N5
    3 Y: u9 E" w: D% [6
      G- S- O1 f! J8 h; n# J" a7
    4 |, m4 B% J* R" v% n8
    4 j$ U( q6 S2 @+ j) Z" n9
    $ u! l" t$ ^, `2 k( W" y9 I* d10  p6 j- o/ M- a4 |5 l3 [9 j
    11
    2 x  |: H& H$ U0 Q/ N9 X5 C12# _3 U1 d: q8 O* y" x
    13) Z1 z1 w5 ]7 `0 Y+ C
      得到结果: 3 N- |) K" r$ F0 E! M, h/ B2 h
    , a; _  @5 x3 F1 B/ M

      e8 I( X1 i& n' V" c% w$ T! y; F  这里需要注意,lingo中如果没有代码说明,是默认 xx 的值大于0的。代码中用 bndbnd 函数限制了 xx 的范围。( M  ?2 x4 n+ d8 s( F3 n  m
      那么再进阶一下,Lingo在处理TSP问题的时候表现如何呢?9 u' @, u3 {5 K/ i

    ! V) }) o! w+ I% T0 V例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# S0 |2 ]: p  m) B∑i=0n(ciπ(i)+piπ(i))=∑i=0nciπ(i)+∑j=0npj1 D5 y6 x3 [/ f/ P3 ?
    ∑i=0n(ciπ(i)+piπ(i))=∑i=0nciπ(i)+∑j=0npj9 \% U5 H1 c6 y
    由于 ∑nj=0pj∑j=0npj 是一个常数,故该零件的加工顺序问题变成TSP。9 f. g& w$ u) P1 u2 s6 ?1 o
    . W" u% P  r6 `: v' e
    代码:
    & ^* ]- t( h; t# X% m+ K( ^! o6 W9 f, _) C& ^: n
    !旅行商问题;) {/ ]5 D1 U2 F* ]+ L
    model:: k7 a; _) p9 e) K; m1 m3 P% X0 C
    sets:9 {* v3 O2 n$ [7 @
        city / 1.. 5/: u;
    " {* o8 Q7 R" W8 ]8 @: X; Z6 T% H# L    link(city, city):: A6 I) }$ T/ v1 c; x8 O
            dist, x; !距离矩阵;
    ! {: X5 l0 L% Uendsets
    , @" g+ i0 Q& Y4 i9 `4 q( }    n = @size(city);! J9 B8 a. K2 l# H1 g' j: L
    data: !距离矩阵,它并不需要是对称的;. R6 A+ d+ F6 Z0 Z+ P" @
        dist = @qrand(1); !随机产生,这里可改为你要解决的问题的数据;
    & E1 X  ]; B2 V0 M; _2 wenddata
    + w! N! `- h$ T3 F( ~% e+ m    min = @sum(link:dist * x);* S+ Y% X- o1 D8 k
        @FOR(city(K):
    4 q; v) _  f- d4 z- [        @sum(city(I)|I #ne# K: x(I, K)) = 1;
    ) ?5 q6 N; }: J2 Y$ S        !进入城市K;
    4 ~1 M* ?5 \2 Z: U6 L5 B5 k3 R        @sum(city(J)|J #ne# K: x(K, J)) = 1;6 R  @6 ]; V3 {) g  J7 w
        );
    - [) r& m5 u6 _3 K, ]3 x9 @  c$ z    @for(city(I)|I #gt# 1:
    ! W  E8 B8 W! C+ A1 M0 A6 e        @for(city( J)| J#gt#1 #and# I #ne# J:
    / ]' H' U+ h* I             u(I) - u(J) + n * x(I,J) <= n - 1);! q6 I& p, c9 I2 J" [( s
        );3 [) F. n  B: ^& o
    @for(city(I)|I #gt# 1: u(I) <= n - 2);' Q6 k& |8 o3 D' X. g
    @for(link: @bin(x));3 z+ T5 l7 F9 p1 Z+ F2 H; B
    end, |. V* k! F! G1 O1 M9 |* n
    1. S: b' s! f, ?2 |
    2
    % ]9 i0 b" ]. W, i3
      k2 _2 q0 H1 W% M; u- R4 ?4
    7 M/ F. m% A# X# F3 ~0 O: G5
    $ D8 b+ m: v0 k/ ^% f6
    8 X9 J: O8 w* {4 A. L7
    2 U% d. z( S2 j! P+ s, E81 D0 p6 m) d" i$ z( Q1 b1 K6 S
    9
    # u, U) P& z9 m, {( _4 D. [- C10( q9 ^  I; |7 z2 S7 n5 v
    11& H6 M7 l! L5 g
    12) p2 v6 J* O& w9 D; P$ @
    13
    5 s% `% }5 E$ z8 ]/ k14/ A8 k- m$ \4 C3 O
    15
    0 v9 c. f+ W% c8 X5 U0 F  r. A/ b16% n% j3 ~0 _8 ^0 c$ h+ x+ \
    176 X9 @# D: w# P  [! Z9 H8 C' v, m; q
    18
    # l! Y# g2 n* O19
    ; Y* \* k# ~4 C* D) {5 f8 Y0 x7 ]20
    - K) f# O  p' {4 f# B( p21: u+ Z3 W" i: |6 F+ u' W
    228 v8 t) j7 Y- h# [1 m1 r0 \' [. d
    234 N5 n7 z+ a. ?6 ^: S7 K
    24
    " o: ~" f. O3 S! ^可以得到结果:
    ! p7 k( s$ \& J* f) X; I! B5 |" \
    ---------------------
    + U' h2 Q& ^, P3 }; ]7 k1 a" z' Y/ z, ?" V8 d
    1 M: k/ w- x% C. u0 c; `( v2 w

    + X; a# M7 W* w5 Z6 k5 }3 N7 o0 x* U" @" `

    , v+ K& R& Q7 k) X$ t4 `( o! \
    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-7-20 00:03 , Processed in 0.373409 second(s), 51 queries .

    回顶部