QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 10096|回复: 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* z+ S) z  K+ Q/ k8 ~9 J1 K
    一、 从规划问题引入
    ) Y* _$ Q7 {. R6 m4 c1 \: M" Y/ `0 d- j1 [7 d# r7 H
      在我们学习探索的各个领域,规划问题都是无处不在的。通过列出约束条件及目标函数,再画出约束条件所表示的可行域,就能在可行域内求得目标函数的最优解以及最优值。当然我们在高中就已经学习过线性规划的相关知识,对于理科同学来说,大多数同学应该感觉难度不大,或者说是送分考点。然而到了大学阶段,一些规划问题的求解已经不是人力可以轻松算出来的了,必须借助于计算机来进行计算。那么对于规划问题的软件选择,又应当如何进行呢?
    $ u" i4 }; d" I/ k9 e4 p1 V" @9 C8 s' W8 k0 `# A
    二、 软件分析与选择& N0 t2 Y) X, F9 @) z  F
    ) V3 c5 J+ a8 e! H8 ^8 U: n
      Matlab相比之下是一个面面俱到的编程软件,也可用于求解规划问题。但是如果一定要去和某些“针对特定功能而开发的软件”去比的话,Matlab有时也会稍显逊色。就好比一款顶级的耳机能通吃高中低音,但是去和另一款顶级的为高音而设计的耳机去比较的话,也难免会被比下去。这也就是为什么在规划问题上,很多人会去使用Lingo进行求解。
    ) W4 e( T0 M6 r' O; Z3 l9 Q+ y; Q9 W7 O! x
      首先我们来区分一下Lindo和Lingo这两款软件。Lingo是在Lindo基础之上做成的软件,处理解线性规划问题之外还加了非线性的求解器,更关键的是还追加了集的概念。可以更方便的解决复杂的问题。所以本文只对Lingo进行讲解。
    5 t7 h% p+ C! B6 R  而对于Matlab与Lingo的区别,就好比手动挡与自动挡的区别,有针对性的专业软件会对用户做很多的优化。这里引用知乎上大佬 花开花落 的回答
    0 J+ X* y/ A4 E+ ahttps://www.zhihu.com/question/49319704/answer/165923451
    & U0 q$ U! d& z+ r' w" D6 d2 K" H& T7 H& C6 m& w7 g, A
      用MATLAB求解线性规划和整数规划问题,需要先将问题转化成如下标准型,其中X只能是向量,也就是单下标变量,然后用向量和矩阵来表达目标函数和约束条件。 : }) _3 K4 ~# }1 \: ^2 R& w; c
      然而,许多问题(如指派问题和运输问题)由于参数和决策变量是双下标变量,必须在基本的数学模型的基础上进行变换才能求解,这样得到的等式约束和不等式约束的系数矩阵规模就非常庞大,当然由MATLAB计算问题不大,但转换工作完全要由人工完成,工作量大而且容易出错,因此在这一块效率不高。
    5 G6 \$ B" N8 ?+ W  而LINGO有自己的建模语言,在建立了集合的基础上,能够高效表达目标函数和各种约束条件。所写的模型基本上可以看作是对数学模型的翻译,不需要太多的转换。* L: _1 [+ h% \6 g  ~. z

    # M+ u, M2 i: o7 X6 I  那么现在我们基本上对LINGO和MATLAB对规划问题的处理方面有了初步认识与了解,至于是执着于MATLAB还是选择开辟LINGO这片新的领域,取决于队伍自身了。
    0 Q$ t6 l: |, m# n% I: W# S- \0 [+ `
    三、 如何上手Lingo' D8 S3 v" R& l

    # Q4 N$ n. @) p8 j, K  有很多人对于Lingo的评价都是,非常简单的软件,很好上手。 , I1 \! g" R# A$ P* a* O! y" }
      “简单”一词我觉得还比较恰当。Lingo的各种版本几乎全部都是免安装版本的,界面很简单,功能用法很简单,处理问题的方式简单快捷。确实是跟“简单”一词挂钩的。但是任何一款软件想要精通,都是有一定难度的。如果你只需要用Lingo处理一些简单的线性问题,那么2个小时不到,0编程基础的朋友就能上手。如果你认准了Lingo就是你处理各类规划问题的御用软件,那么还是有很长一段路要走的。当然这也取决于用户的编程基础。如果学习过面向对象的程序设计课程的朋友,对于类与对象概念有所了解,那么对于集这一概念也能快速理解上手,学习起来更加轻松。
    # U# P" A3 z' G0 s& }4 y8 j. p# i. f( p
    四、 Lingo的基本语法规则
    ( U/ m7 u0 q! [4 H  O! j  R6 y  {: N; f' x$ T( T
    1、求目标函数的最大最小值用 MAX=MAX= 和 MIN=MIN= 来表示;
      Y% a1 w& a! _' ]6 e- i2、每个语句必须用分号“;”结束,每行可以有许多语句,一个语句可以跨行;
    3 g5 |$ h6 Q" k- [# s- t/ \! r3、变量名必须以字母A-Z开头,由字母、数字0-9和下划线组成,长度不超过32个字符,不区分大小写;
    0 g) k/ ~4 i2 u7 y6 |4、可以给语句加上标号; ( \8 Z; K/ _% P' e
    5、注释以“!”开头以“;”结束; 2 C& b% o" U! y$ F$ `3 C
    6、默认所有的决策变量为非负数; . J+ e0 `* z. u- t3 [
    7、Lingo模型以“MODEL”开头以“END”结束。 4 m0 o  V( O6 V" Q
    8、Lingo把相联系的对象聚合成集,借助集,就能够用一个单一的长的简明的公式表示一系列相应的约束。 2 M+ f# `' L$ X. A2 G
    9、Lingo程序会包含集合段,数据输入段,优化目标和约束段,初始段和数据预处理部分。 8 e4 L% Z/ L% }% Q0 W0 f- q, w
    10、Lingo函数包括有数学函数,金融函数,概率函数,变量界定义函数,集操作函数,集循环函数,输入输出函数,辅助函数等等。0 |; |" L1 u- G, d& p- I

    0 U5 j! L! K4 y% q: G五、 谈一谈例子
    + _4 j* R& `+ m8 L4 ]) z
    $ ~% `; k2 G" Y! C: i. W# [  那么Lingo用起来到底有多简单呢,我们来看一个例子。
    + n  v* _& D( f4 K: d, t9 s) c+ ~
    例1:某家公诉制造书桌、餐桌和椅子,所用的资源有三种:木料、木工和漆工。生产数据如下表所示:- h' d2 a: Y/ L. g& C/ P

    ; l. z9 K$ n2 `: ], r         每个书桌        每个餐桌        每个椅子        现有资源总数
    + ?. U4 ]4 J- ]5 t9 |& ?  H  H木料        8个单位        6个单位        1个单位        48个单位5 o' z: C3 o5 W5 ~
    漆工        4个单位        2个单位        1.5个单位        20个单位
    + @# ~2 b0 F' {木工        2个单位        1.5个单位        0.5个单位        8个单位
    2 t) q$ u9 D+ ]成品单价        60个单位        30个单位        20个单位         
    , f- x. C, ], ^- u" ]) n  若要求桌子的生产量不超过5件,如何安排三种产品的生产可使利润最大?0 Z2 D* _* D7 ]
    ; o8 p, Z7 g4 O& v2 M, {
    解:代码
    1 j, x* @2 _7 l: T7 F3 M8 [% H" E# [3 o1 l
    max = 60 * desks + 30 * tables + 20 * chairs;
    7 O; a7 C. X! W2 w- L      8 * desks + 6 * tables + chairs <= 48;
    * \4 T: q1 w/ m; Q3 O$ y      4 * desks + 2 * tables + 1.5 * chairs <= 20;
    ' a! ]/ J8 K2 q5 o4 Y7 c* L" Z      2 * desks + 1.5 * tables + .5 * chairs <= 8;& Z: y' `$ c  w1 T
    tables <= 5;
    & z( L" b5 g7 A$ ?" j! E/ [- H; |1
      i& }( y# K$ d2; _5 Q+ ]0 Z( M' N/ {; g
    38 _8 z# `- q4 H" ?( j/ S
    45 o6 t" N) {. B
    5
    ' A# G# M" Q2 ~- z/ X+ S可以得到结果:
    1 N" n# S7 r2 C& X! g0 q
    1 p5 }/ c  k9 N  ~  这里的 Total solver iteration 表示一共迭代2次得到最优解。 ! R4 h2 D. e' r$ U" f
      Objective value 表示最优值为280,而取280的时候各个变量取多少呢,底下的表格给出了答案。
    8 b$ t3 ^7 a4 N! s) w  可以看到,没有定义变量,简简单单一个函数一个约束条件,迅速计算出了答案。Lingo看上去就像是为了非编程人员量身定制的一样。
    . Y# o8 t, M- U; B
    3 F, K* @2 I6 s& W; m: Z2 @# a例2:给定一个直角三角形,求包含该三角形的最小正方形。$ Q: V, K/ n6 o3 l5 u7 i; E6 d

    2 `* u+ ]" [- d; K3 s我们可以作出如下正方形:
    ! Y4 u* n5 c; r" l  q0 k# |$ {, K8 \  ], Q

    0 H4 M7 y: i% H( J7 m  Y7 |  CE=asinx,AD=bcosx,DE=acosx+bsinxCE=asinx,AD=bcosx,DE=acosx+bsinx
    * j) z* r/ k7 C& D  转化为了规划问题那么正方形面积最小的时候即为最优解。
    / o6 ~: C7 ?  {7 b! D4 z, r  代码:, y9 _* `" a+ y/ j/ v* N
    ! N3 q  W# Y# D" L
    model:! v; Z% n4 ?' k7 s8 C
    sets:
    # e: w7 Q' O. X- r9 L  s" ~    object/1..3/:f;
    : d: k) T9 R% ~endsets
    " ]3 t' M" F2 i. Kdata:" P6 @" u- }& S
        a, b = 3, 4;
    % T7 @$ c! W! H6 T8 I; `enddata8 s1 \" V! q* X4 P, j+ B
        f(1) = a * @sin(x);
    - k1 Q6 s6 X! F" A6 i, l    f(2) = b * @cos(x);
    2 g$ C, j. p# I    f(3) = a * @cos(x) + b * @sin(x);
    & d4 d4 `. [- Y8 S    min = @smax(f(1), f(2), f(3));
    - Y* M+ Y5 h8 S9 X& J! s% @6 @    @bnd(0, x, 1.57);& ]" l. t' }9 G: T
    end! x+ r6 w! `! x& C! k& `
    11 }) H2 U5 y* m1 Z$ K& x
    2
    ) n1 v8 F9 j+ \& U- l1 x9 f3& O, |6 n$ s& m( X8 K& [+ f+ M% I
    4
    . k( |  j/ c- K% t& i5
    2 T! G+ o4 b7 g3 v% J! a' _4 }62 k7 O% ?, ], O) M8 \
    7
    0 c8 C8 k9 W# i- I& a1 T6 ^8
    # ^; C7 n: K# F1 h. e% h9
    , r4 X8 B, y: X3 T2 e10" K/ Z* v' v% m, @; }
    11& T# Z+ H1 G; _! s1 m2 K4 F' S
    12
      y  F0 e& y4 f& c13( I+ C, R6 U. F) X1 M$ o2 \8 _% r
      得到结果:
    # h+ r4 `7 n+ x& G' x2 j
    7 U3 U, u& T9 e! t
    : r1 O! p. b- v& d  这里需要注意,lingo中如果没有代码说明,是默认 xx 的值大于0的。代码中用 bndbnd 函数限制了 xx 的范围。
      [3 T, M7 M, g  那么再进阶一下,Lingo在处理TSP问题的时候表现如何呢?6 g9 \: K- d" i* _
    ; V; z7 Y& l' x$ B; @
    例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 的一个圈置换 ππ 就表示对所有零件的一个加工顺序,在此置换下,完成所有加工所需要的总时间为
    - ?' X. i% Y( l3 L∑i=0n(ciπ(i)+piπ(i))=∑i=0nciπ(i)+∑j=0npj
    & N( g1 W/ F% E6 v8 I∑i=0n(ciπ(i)+piπ(i))=∑i=0nciπ(i)+∑j=0npj
    ' y: E: T" y& x! Z7 Y6 p* i由于 ∑nj=0pj∑j=0npj 是一个常数,故该零件的加工顺序问题变成TSP。
    9 m" o( J6 `, C; V, l  f- z5 K, t3 _
    0 T6 m0 S4 [9 R3 U代码:
    , o- J# O  P6 Q' O) j! o9 ~8 D2 p; y* m0 ]
    !旅行商问题;
    $ V) W9 M% S" G" [model:8 p) G: x) L. ~9 n+ p! @
    sets:. D1 u- o+ U6 N1 C% t$ p4 j
        city / 1.. 5/: u;
    2 v* g9 Z7 s% [, f7 G9 q    link(city, city):/ e0 H7 [# A0 V& {' }8 |
            dist, x; !距离矩阵;
    ( S) V* @$ Y$ hendsets/ c+ m6 N4 X0 z# J6 P/ W
        n = @size(city);! _* x, W2 [! P
    data: !距离矩阵,它并不需要是对称的;
    " p) K! F2 w# Y5 f2 z; v    dist = @qrand(1); !随机产生,这里可改为你要解决的问题的数据;
    ; h) x( b5 e: c9 cenddata3 O$ R7 S  M/ i- W' w
        min = @sum(link:dist * x);
    # E. @3 u- B, I" L: ]* L9 F, {7 }    @FOR(city(K):. Y" _& h, B0 T" ]
            @sum(city(I)|I #ne# K: x(I, K)) = 1;
    . \0 |2 l, y# Z' U) Q        !进入城市K;4 E, w( M+ ?: |% e
            @sum(city(J)|J #ne# K: x(K, J)) = 1;
    * M: @/ r$ i9 L$ S! [: y    );, E7 t' `5 I$ M" r( N' A$ @
        @for(city(I)|I #gt# 1:& \. k. w+ P- I6 v
            @for(city( J)| J#gt#1 #and# I #ne# J:
    ' T) q( v0 f) n$ E( m9 Q1 q             u(I) - u(J) + n * x(I,J) <= n - 1);
    8 |9 s! [' w* C0 f' q    );, v. f3 t& Q8 |( y1 O
    @for(city(I)|I #gt# 1: u(I) <= n - 2);
    ; s& L7 r# y4 q3 I2 G@for(link: @bin(x));- ?8 ]* L6 U7 P  y& T
    end
    ( A- u; k  e. \& L1/ J$ J( w: j$ F' {, X. ~4 _9 \
    2
    / H6 B+ n; y& L0 p* e( [0 `5 a! ^3 o3  ~. E% D% K4 N% I3 N. t5 Y
    40 i- j+ m& ?1 ]; _
    5! u5 b- a& X( q
    6
    & F6 X3 W2 Q* b. ~/ R* V; U- a7
    ; T7 E" c  E/ h5 B8 x6 ~# t8. I, B9 W0 z4 k1 Y0 p  y- d# F
    98 `' g: ^; ]! k7 `- [
    10( d6 }0 E# `: ]8 ]- A0 c$ x: `
    11# s) V) g9 \5 C1 T2 ^
    12) O+ x3 b' b% C; V+ H4 a# G' j
    13
    2 S3 g' j7 N$ ~1 d7 R" k$ H149 w5 g7 g* p/ q) D3 }  i1 Y' T3 y
    156 q( g( p+ r; n, B6 X
    16" ^# K/ U8 @6 j5 \9 }3 ?
    17# ?1 ]: l5 p" @9 k! {7 Q6 S
    183 T7 A! k4 _' Z% a- @
    19) ^& D8 r( O+ g2 a0 C1 W! F
    20
    7 `3 _& I; g' g7 v# E21: }) {: N! g* D8 B$ O/ X$ s
    22
    0 X( ^" r) ?( P+ n6 z; Z2 O/ z23; x2 ^2 P# L: g' h8 x5 z% F
    24
    5 R+ o3 Z9 W3 o; x) Q可以得到结果: 4 W! c$ F% t2 g6 b* I

    4 p( F8 V% H! ?9 m$ y0 B8 f---------------------
    0 O! `) C0 r3 X* [
    9 Z. e. e7 n! F( w: o+ w: i# X% o) E6 ]' g7 u- R7 J

    & ]$ c2 F' A+ N- ]2 A, C* I' L0 g! M) Z& S
    5 w2 V9 p; a! e
    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 13:32 , Processed in 0.342876 second(s), 50 queries .

    回顶部