QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 10097|回复: 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解法/ C! x% b5 t' N+ y
    一、 从规划问题引入) j. w3 ~; H; M: c& v0 s' Y, Q# K
    - w1 M, R" K8 |5 d3 J) x( }/ H
      在我们学习探索的各个领域,规划问题都是无处不在的。通过列出约束条件及目标函数,再画出约束条件所表示的可行域,就能在可行域内求得目标函数的最优解以及最优值。当然我们在高中就已经学习过线性规划的相关知识,对于理科同学来说,大多数同学应该感觉难度不大,或者说是送分考点。然而到了大学阶段,一些规划问题的求解已经不是人力可以轻松算出来的了,必须借助于计算机来进行计算。那么对于规划问题的软件选择,又应当如何进行呢?
    7 l; ~5 I( h5 I3 m) N
    ' A0 z/ ^& P% n4 Q. M* h二、 软件分析与选择
    7 a* F7 @/ `' H. }6 p( i' ?. [% u# N. v: G8 [
      Matlab相比之下是一个面面俱到的编程软件,也可用于求解规划问题。但是如果一定要去和某些“针对特定功能而开发的软件”去比的话,Matlab有时也会稍显逊色。就好比一款顶级的耳机能通吃高中低音,但是去和另一款顶级的为高音而设计的耳机去比较的话,也难免会被比下去。这也就是为什么在规划问题上,很多人会去使用Lingo进行求解。. ~0 D( K$ J, C: G

    * {7 i/ z; h5 A/ v& `; \  首先我们来区分一下Lindo和Lingo这两款软件。Lingo是在Lindo基础之上做成的软件,处理解线性规划问题之外还加了非线性的求解器,更关键的是还追加了集的概念。可以更方便的解决复杂的问题。所以本文只对Lingo进行讲解。 4 n0 X! e  Z( A7 U; _9 q6 F
      而对于Matlab与Lingo的区别,就好比手动挡与自动挡的区别,有针对性的专业软件会对用户做很多的优化。这里引用知乎上大佬 花开花落 的回答
    " s- w5 |) r5 D' F% S; E6 r9 d* Hhttps://www.zhihu.com/question/49319704/answer/165923451
    ) n# Y, H8 N' N, T/ U, k0 r1 i
    ) `; r; y1 o) e0 j! S2 P  用MATLAB求解线性规划和整数规划问题,需要先将问题转化成如下标准型,其中X只能是向量,也就是单下标变量,然后用向量和矩阵来表达目标函数和约束条件。 , v- |. s5 y) V5 U4 b3 v
      然而,许多问题(如指派问题和运输问题)由于参数和决策变量是双下标变量,必须在基本的数学模型的基础上进行变换才能求解,这样得到的等式约束和不等式约束的系数矩阵规模就非常庞大,当然由MATLAB计算问题不大,但转换工作完全要由人工完成,工作量大而且容易出错,因此在这一块效率不高。 5 @8 J0 P0 W2 l4 ^6 H' S: g/ H- w; S
      而LINGO有自己的建模语言,在建立了集合的基础上,能够高效表达目标函数和各种约束条件。所写的模型基本上可以看作是对数学模型的翻译,不需要太多的转换。0 w1 w! z8 Z4 C3 ^9 _/ s6 ?5 J

    6 Z9 \# |% u7 x3 f5 u- _$ r+ l  那么现在我们基本上对LINGO和MATLAB对规划问题的处理方面有了初步认识与了解,至于是执着于MATLAB还是选择开辟LINGO这片新的领域,取决于队伍自身了。5 h5 q9 G( L) ]; {1 d1 A# j
    * @; Y$ _9 A0 d( b  H8 D! h
    三、 如何上手Lingo( O- r! a2 y: F' O) y* r; X+ b
    $ i4 ?0 s- a, X. s8 d8 k
      有很多人对于Lingo的评价都是,非常简单的软件,很好上手。
    4 e7 D" m* P- {  ], C+ ]7 K0 `  “简单”一词我觉得还比较恰当。Lingo的各种版本几乎全部都是免安装版本的,界面很简单,功能用法很简单,处理问题的方式简单快捷。确实是跟“简单”一词挂钩的。但是任何一款软件想要精通,都是有一定难度的。如果你只需要用Lingo处理一些简单的线性问题,那么2个小时不到,0编程基础的朋友就能上手。如果你认准了Lingo就是你处理各类规划问题的御用软件,那么还是有很长一段路要走的。当然这也取决于用户的编程基础。如果学习过面向对象的程序设计课程的朋友,对于类与对象概念有所了解,那么对于集这一概念也能快速理解上手,学习起来更加轻松。
    5 J5 Z, f5 l% Z$ c; g0 }4 l, F( K3 ~# Z* v: s. j7 X# }6 h
    四、 Lingo的基本语法规则
      Q, \( K  _6 f: j% k, t& Q, `& R7 k( g" \, k+ K
    1、求目标函数的最大最小值用 MAX=MAX= 和 MIN=MIN= 来表示;
    6 q, N/ ?* W1 Y" h5 `2、每个语句必须用分号“;”结束,每行可以有许多语句,一个语句可以跨行;
    + G: I' B- x: r# G# s- T3、变量名必须以字母A-Z开头,由字母、数字0-9和下划线组成,长度不超过32个字符,不区分大小写; 8 E3 w; S0 T2 C- j# g
    4、可以给语句加上标号;
    ) i) \7 c5 L" p% @( }$ T. K5、注释以“!”开头以“;”结束; " ?9 V) D7 w& w  ]; u+ U$ ^( s0 d
    6、默认所有的决策变量为非负数; ! a! O/ {: s& B7 z9 }& d5 W
    7、Lingo模型以“MODEL”开头以“END”结束。
    ) d* m( o' V2 @/ E" V8、Lingo把相联系的对象聚合成集,借助集,就能够用一个单一的长的简明的公式表示一系列相应的约束。 1 B; e- X4 F8 @0 b( [: ^% y0 V1 v
    9、Lingo程序会包含集合段,数据输入段,优化目标和约束段,初始段和数据预处理部分。
    , `; h) ]1 s' g10、Lingo函数包括有数学函数,金融函数,概率函数,变量界定义函数,集操作函数,集循环函数,输入输出函数,辅助函数等等。$ m+ Z$ Z! t: Q  [7 g

    $ w+ {# {/ C, R! M五、 谈一谈例子
    ; k; a% Z8 u' E2 D$ U5 {7 `. Z6 D) ^+ w7 V! d( @
      那么Lingo用起来到底有多简单呢,我们来看一个例子。
    . o) I6 a8 h( p$ Y# L5 ?! S2 S) l) @5 Y/ @; N
    例1:某家公诉制造书桌、餐桌和椅子,所用的资源有三种:木料、木工和漆工。生产数据如下表所示:
    + r+ |/ y7 K% ?: E7 r  E' h0 Z; z* F; b1 x& z/ a
             每个书桌        每个餐桌        每个椅子        现有资源总数
    5 a1 J( L# Q0 {, m" s木料        8个单位        6个单位        1个单位        48个单位
    - v# n0 {' f5 u; b漆工        4个单位        2个单位        1.5个单位        20个单位
    / `$ ?0 g" u9 Z" z" n  u  o" P木工        2个单位        1.5个单位        0.5个单位        8个单位
    * ]. ]$ U# z  \. k# }成品单价        60个单位        30个单位        20个单位           L; h5 W5 x. C: u" K$ L: S
      若要求桌子的生产量不超过5件,如何安排三种产品的生产可使利润最大?2 r) ~' v% U) b
    ' f' C8 C3 k& C. D$ W
    解:代码9 z1 W3 j. a" u' I
    2 v9 v6 _, Y( D
    max = 60 * desks + 30 * tables + 20 * chairs;$ d+ A7 i1 k  K: }5 e, X, T+ g
          8 * desks + 6 * tables + chairs <= 48;  E% U9 R! |1 l) Q% W2 {
          4 * desks + 2 * tables + 1.5 * chairs <= 20;
    8 ]: B9 n2 j" I5 B' W$ F+ I1 A. Z2 c      2 * desks + 1.5 * tables + .5 * chairs <= 8;' [3 I7 I5 H: m& {" x
    tables <= 5;
    3 E( h8 k+ M, a( U7 _7 ^; D$ d1* B; {3 V1 O/ p9 c* G0 @0 J
    2( n% S) w3 R  x& h
    3# N% H7 ?0 w: \6 j1 V5 k. i
    4* y; {* v& W' W% \' n
    5
    ' A1 w; [+ T$ q2 r9 E8 V# {可以得到结果: % u! q$ Y5 @. l5 F; A* c7 z

    ' T! }5 {- g, J4 r  这里的 Total solver iteration 表示一共迭代2次得到最优解。 " Q$ D1 G  |; K( j& z, h
      Objective value 表示最优值为280,而取280的时候各个变量取多少呢,底下的表格给出了答案。
    ' c. k- B0 C  o! w, C7 l  可以看到,没有定义变量,简简单单一个函数一个约束条件,迅速计算出了答案。Lingo看上去就像是为了非编程人员量身定制的一样。2 I( X0 m: ~  ^6 j) S6 L* m

    7 q2 L9 ~9 I, L! I' t) D2 D, z例2:给定一个直角三角形,求包含该三角形的最小正方形。" x5 A* n$ i0 t* y
    $ Z: w9 |6 B. q+ ?$ @$ A& [5 {
    我们可以作出如下正方形:
    % D, Q+ R4 [, @9 P. P+ D3 G1 n1 |$ u2 ~1 l- V7 f) L8 n

    % n( M" i  e# ^; h( O5 c  CE=asinx,AD=bcosx,DE=acosx+bsinxCE=asinx,AD=bcosx,DE=acosx+bsinx! U4 u# f, g- u3 B# C- o0 H
      转化为了规划问题那么正方形面积最小的时候即为最优解。
    - h/ {1 ?7 r  r. C  代码:$ p, H/ n1 m; L/ d" P

    2 s" @( H! \. Ymodel:  Z& c* a+ }. t
    sets:
      c* F7 @- `3 d, @6 O8 J    object/1..3/:f;- b! M9 k7 g7 w1 A
    endsets
    # G0 K0 d! t) X+ G  y& M# vdata:
    3 a7 D% T' m3 `7 f% U" B# |* R* ]    a, b = 3, 4;
    ; r7 j* ~! \' Tenddata
    5 }9 J$ B$ m. \1 D0 M- e2 W    f(1) = a * @sin(x);
    0 N& D, {/ F% d0 k6 n8 M! ]    f(2) = b * @cos(x);/ W# h" l2 e) J1 _) W6 ]4 O
        f(3) = a * @cos(x) + b * @sin(x);
    $ l5 Y. Z% K4 `7 c6 Y8 u, ~    min = @smax(f(1), f(2), f(3));& E) B( O- m9 a
        @bnd(0, x, 1.57);% [/ y0 }4 B4 D4 ^4 H
    end
    : [) j* v' J+ U2 K9 R/ X* s1
    & a9 y" @6 r0 F. W2
    " B/ a: r8 h  _) n- E6 r1 m31 m; {% _& o6 M; [; i& {
    4
    % g5 O* F9 B1 p5 g59 [) c6 O" L: Q1 X, [; h
    6
    ' G' i7 G- H, C- `4 Y2 u: w7
    9 z8 q- @3 z/ q& R8
    1 R1 R% o6 i9 T9 ?& z! Z6 h: D9$ c! ]+ v( b% a2 P
    10
    6 ~! S& H! K: k: f$ ~+ T3 k$ {! n11
    . q' ^) J! K3 G) e- W2 V+ W126 ]& I  K" \0 s
    13
    3 G2 N9 K- @+ K$ L+ D7 r: W  得到结果:
    & T& e  X& V  {+ L5 O  F! H6 V
    , E/ U3 @) {) U4 h$ p& v1 e6 n, A/ S* [, h" D9 W
      这里需要注意,lingo中如果没有代码说明,是默认 xx 的值大于0的。代码中用 bndbnd 函数限制了 xx 的范围。6 F1 e, [# w. ~# @
      那么再进阶一下,Lingo在处理TSP问题的时候表现如何呢?2 t' ~/ W  ~3 Q7 b% B
    ) }& H" p; A/ K9 n
    例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 的一个圈置换 ππ 就表示对所有零件的一个加工顺序,在此置换下,完成所有加工所需要的总时间为
    1 a6 I9 A% h" R# F( p' k$ x∑i=0n(ciπ(i)+piπ(i))=∑i=0nciπ(i)+∑j=0npj
    ! P$ T: @! |: t! P/ o9 R∑i=0n(ciπ(i)+piπ(i))=∑i=0nciπ(i)+∑j=0npj, X$ ^1 q% K2 j1 j8 Y1 U9 e$ l
    由于 ∑nj=0pj∑j=0npj 是一个常数,故该零件的加工顺序问题变成TSP。. h9 d" D. t1 a( L; a( }

    * o0 \  Q$ C/ F6 ^7 J+ I代码:# E6 C/ g0 q$ l+ E) _! b+ h
    & \- P; H8 I6 `- [9 z. N
    !旅行商问题;% I4 v/ u- d8 R4 G- ]0 \! C( T
    model:
    . R7 S% Y( t- I8 T: m5 O" k/ g8 C) [sets:/ o' F7 S. c, N( C' y
        city / 1.. 5/: u;; c% T* V3 {( t/ W3 U8 i
        link(city, city):
    ; J3 y) ~* n* l; O* M  l        dist, x; !距离矩阵;
    3 l: a6 j0 ]) A& W" I0 |endsets; N: r; ?" f/ Y6 P7 X
        n = @size(city);! ?" {9 k, o3 i. R+ v- j
    data: !距离矩阵,它并不需要是对称的;* k5 x" H3 C$ p% u3 R
        dist = @qrand(1); !随机产生,这里可改为你要解决的问题的数据;
    / L# O) g6 U* H! r% T0 Jenddata$ }* j4 |$ h! ?8 ]3 a
        min = @sum(link:dist * x);/ b, l% I! P: {4 m; [
        @FOR(city(K):
    " ]# G# _9 {$ m( B        @sum(city(I)|I #ne# K: x(I, K)) = 1;0 K( Q+ r# F( ^4 i- N, u
            !进入城市K;* S, S2 [7 y8 F
            @sum(city(J)|J #ne# K: x(K, J)) = 1;: i1 ~: |8 A5 F) K5 P
        );
    2 H: j+ z7 c7 u  ]7 p1 X    @for(city(I)|I #gt# 1:; F0 t) m7 I8 ]- V
            @for(city( J)| J#gt#1 #and# I #ne# J:
    0 y+ k/ a3 J, o) g             u(I) - u(J) + n * x(I,J) <= n - 1);
    8 ?: _8 A2 ]' x/ G) a    );
    , v3 G- H% G3 G1 N@for(city(I)|I #gt# 1: u(I) <= n - 2);; I- Z# D$ f2 K0 o4 T
    @for(link: @bin(x));% q- j4 e$ D. N1 H9 S
    end8 m1 P2 y6 [# a# p
    15 R; s3 R. `- w# A& X9 h1 T# H
    2- D! r1 r& K) I0 I
    35 f* o/ o: X4 A) d
    4
    , P+ C. T/ r* T  S* M& u5) ^- x2 f7 B" X$ k7 _& x  H
    6
    + b* k7 t  [4 f; ?/ L7 ~2 y1 Y7# W6 Y, i) R; ]2 M
    8  x' x. [+ I8 t) y
    9
    " Z2 Z. \; l# E0 F$ A) Q3 R* r10
    + z1 U% W" u  l* n+ Z$ T5 ^11' J" r, D3 B' j. y
    12
    9 U) [. m2 d$ M13' R2 @7 A/ j& t2 i
    14
    * }" `9 @0 G3 y& S7 ?+ r; {/ s7 w- ?% X15' y5 e2 z8 ~4 G4 ?% P
    16
    & {1 W- g$ h: D2 u' c& n17# n6 I1 X. f5 X/ B: I
    18
    7 }; I( Q. q. O5 G" ]5 x( o19
    5 Y+ q! m" P5 I20) C5 x( \# p" T: E4 q
    21* J  U' A2 S$ d# R
    22
    # N3 k  ~' g4 X230 Q+ `) D! n8 W1 a1 F, b* ?
    24
    ' m( i3 \* h" d: C! v: F) I可以得到结果:
    ; E+ C0 Z, W, o9 \
    4 W' h3 E9 |8 a---------------------
    3 N/ Z# s$ H4 ]/ [6 X( c* A
    , Q4 @! W7 A' U1 t: M% x& D# Y6 `$ b* W  ~
    * F' Y$ x) @0 [- Z0 C& q
    # M3 z! D2 C) x' x' l0 \
    / o( D' I7 Z* a
    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 15:05 , Processed in 0.402577 second(s), 51 queries .

    回顶部