QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 10052|回复: 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解法$ Z7 C3 e1 J+ J
    一、 从规划问题引入
    % k$ ^& x4 ]* l, o" n- }; m9 S- A2 `4 S$ i+ Q. p
      在我们学习探索的各个领域,规划问题都是无处不在的。通过列出约束条件及目标函数,再画出约束条件所表示的可行域,就能在可行域内求得目标函数的最优解以及最优值。当然我们在高中就已经学习过线性规划的相关知识,对于理科同学来说,大多数同学应该感觉难度不大,或者说是送分考点。然而到了大学阶段,一些规划问题的求解已经不是人力可以轻松算出来的了,必须借助于计算机来进行计算。那么对于规划问题的软件选择,又应当如何进行呢?
    " b. E0 Z4 d' Z( V! Z0 }2 y
    8 L& x2 U3 b- E& m, _8 p0 @- E二、 软件分析与选择
    " c7 r8 T6 u7 T4 ~1 ^5 G) w) @
    . t" K+ R# b5 T4 n6 y- F) n" X  Matlab相比之下是一个面面俱到的编程软件,也可用于求解规划问题。但是如果一定要去和某些“针对特定功能而开发的软件”去比的话,Matlab有时也会稍显逊色。就好比一款顶级的耳机能通吃高中低音,但是去和另一款顶级的为高音而设计的耳机去比较的话,也难免会被比下去。这也就是为什么在规划问题上,很多人会去使用Lingo进行求解。
    & X, ^# F. B0 I# w# p& q* w2 u1 a2 h0 u  `7 ?% N8 P2 l4 }
      首先我们来区分一下Lindo和Lingo这两款软件。Lingo是在Lindo基础之上做成的软件,处理解线性规划问题之外还加了非线性的求解器,更关键的是还追加了集的概念。可以更方便的解决复杂的问题。所以本文只对Lingo进行讲解。 3 v5 B! b  E# s  x& V
      而对于Matlab与Lingo的区别,就好比手动挡与自动挡的区别,有针对性的专业软件会对用户做很多的优化。这里引用知乎上大佬 花开花落 的回答
    ' k. Y8 _5 f- a0 b$ U: Whttps://www.zhihu.com/question/49319704/answer/1659234511 h: A( Z1 x( t- Z; q8 W% [

    3 R/ D; a) L2 k* ~7 n3 B& g  用MATLAB求解线性规划和整数规划问题,需要先将问题转化成如下标准型,其中X只能是向量,也就是单下标变量,然后用向量和矩阵来表达目标函数和约束条件。 # {7 q7 T* ~0 n; g- G2 z
      然而,许多问题(如指派问题和运输问题)由于参数和决策变量是双下标变量,必须在基本的数学模型的基础上进行变换才能求解,这样得到的等式约束和不等式约束的系数矩阵规模就非常庞大,当然由MATLAB计算问题不大,但转换工作完全要由人工完成,工作量大而且容易出错,因此在这一块效率不高。
    4 n5 d$ M! O$ w, ^9 H( I) _% Q  而LINGO有自己的建模语言,在建立了集合的基础上,能够高效表达目标函数和各种约束条件。所写的模型基本上可以看作是对数学模型的翻译,不需要太多的转换。1 H+ s. `# O, E1 o6 R- D

    1 G# \5 \/ c' x  那么现在我们基本上对LINGO和MATLAB对规划问题的处理方面有了初步认识与了解,至于是执着于MATLAB还是选择开辟LINGO这片新的领域,取决于队伍自身了。4 t) g. x- n3 n4 _2 G
    0 N. r& e! E4 p! S% L7 G1 t5 E
    三、 如何上手Lingo
    ) v, j  G  Z% A2 f: j
    3 k3 o/ H" G9 X+ ^  z  Q$ Z5 R  有很多人对于Lingo的评价都是,非常简单的软件,很好上手。 5 N0 Z2 J1 J5 M0 |2 [$ z, X+ \
      “简单”一词我觉得还比较恰当。Lingo的各种版本几乎全部都是免安装版本的,界面很简单,功能用法很简单,处理问题的方式简单快捷。确实是跟“简单”一词挂钩的。但是任何一款软件想要精通,都是有一定难度的。如果你只需要用Lingo处理一些简单的线性问题,那么2个小时不到,0编程基础的朋友就能上手。如果你认准了Lingo就是你处理各类规划问题的御用软件,那么还是有很长一段路要走的。当然这也取决于用户的编程基础。如果学习过面向对象的程序设计课程的朋友,对于类与对象概念有所了解,那么对于集这一概念也能快速理解上手,学习起来更加轻松。
    0 a1 `* h  b8 j4 e! N
    / V- T' x8 y9 ^# B( u  n  s; n5 D/ A四、 Lingo的基本语法规则
    6 f* u8 k& F; z- t4 A
    9 ^8 h5 p. R+ e# g1、求目标函数的最大最小值用 MAX=MAX= 和 MIN=MIN= 来表示;
    8 |( g1 @2 T5 t, P1 D: n2、每个语句必须用分号“;”结束,每行可以有许多语句,一个语句可以跨行;
    1 H# {6 ~# J4 {& n2 L1 Y3、变量名必须以字母A-Z开头,由字母、数字0-9和下划线组成,长度不超过32个字符,不区分大小写;
    ! M5 R2 y  g' p: O1 A4、可以给语句加上标号; # S4 i8 [  C4 x9 h' j( `
    5、注释以“!”开头以“;”结束;
    7 A4 z3 W. e% U6、默认所有的决策变量为非负数;
    ) a, [7 B7 ]7 I; Q' s& C7、Lingo模型以“MODEL”开头以“END”结束。
    1 U* N1 w% N1 g1 G8、Lingo把相联系的对象聚合成集,借助集,就能够用一个单一的长的简明的公式表示一系列相应的约束。 ' U9 x6 A0 b) H, y
    9、Lingo程序会包含集合段,数据输入段,优化目标和约束段,初始段和数据预处理部分。 3 J! q( X$ ~. ~& e" M
    10、Lingo函数包括有数学函数,金融函数,概率函数,变量界定义函数,集操作函数,集循环函数,输入输出函数,辅助函数等等。& E& J9 m+ r# c" [2 J. E
    4 R4 L, C0 b9 t) @9 W
    五、 谈一谈例子
    " S8 c4 ?5 h0 s( O; n& j; c$ z& `/ `% x8 g
      那么Lingo用起来到底有多简单呢,我们来看一个例子。7 u- v4 g, o" q: |# E4 Q- V! l

    * b6 |+ v8 O  k$ r2 L) f例1:某家公诉制造书桌、餐桌和椅子,所用的资源有三种:木料、木工和漆工。生产数据如下表所示:! A* x& j, Y- j7 O& f

    . l5 r- S7 l8 G& p$ J         每个书桌        每个餐桌        每个椅子        现有资源总数5 q5 C' k- m  i- |/ e
    木料        8个单位        6个单位        1个单位        48个单位- M2 s3 O' J" h8 K* ]% D0 n$ b
    漆工        4个单位        2个单位        1.5个单位        20个单位
    & a' ?# l+ h% G. ]+ j0 Y木工        2个单位        1.5个单位        0.5个单位        8个单位6 B6 [3 B% x, h/ X* j3 {3 \7 x1 `
    成品单价        60个单位        30个单位        20个单位         
    1 k2 u8 V1 e! y& m' i: Q  若要求桌子的生产量不超过5件,如何安排三种产品的生产可使利润最大?* a& `: O0 [* C9 k* A: i: e4 s; T

    * ~, K, l" v3 u解:代码
    / S' N+ M2 L0 U6 m2 N
    ( x$ B6 D# A. T3 d9 Mmax = 60 * desks + 30 * tables + 20 * chairs;
    % u5 w8 s8 ]8 _! J2 t8 U0 G      8 * desks + 6 * tables + chairs <= 48;
    7 N4 T4 w/ {; }) }      4 * desks + 2 * tables + 1.5 * chairs <= 20;& h5 S! V/ c( s9 Z5 T: R9 a4 E4 r
          2 * desks + 1.5 * tables + .5 * chairs <= 8;* f! R8 u3 F* H0 H# I
    tables <= 5;
    ; o5 g/ y6 {4 R+ b+ F1+ ], i- A1 O% p/ J5 f
    2* g) i, O; W) H# I) w- z) T
    3, A0 ^/ M( ?, \( V
    4# U% q  {# v1 Z; g8 V" R$ T
    53 {: n& T% M) w, A* C2 l, m0 U
    可以得到结果:
    ) h! q3 |- k( k( ?$ e! I4 s1 f( B
    ' O3 D% w6 M  e  这里的 Total solver iteration 表示一共迭代2次得到最优解。 0 s  V$ O" ]( r$ ^2 K: W& [
      Objective value 表示最优值为280,而取280的时候各个变量取多少呢,底下的表格给出了答案。 3 ?" z$ X7 V% x  R" C! l. S
      可以看到,没有定义变量,简简单单一个函数一个约束条件,迅速计算出了答案。Lingo看上去就像是为了非编程人员量身定制的一样。
    8 E( p- W' A3 m$ n% ~1 a0 I! _- N
    ) b, H! B, M6 T( l" ?例2:给定一个直角三角形,求包含该三角形的最小正方形。& e9 l" Y  h6 O9 H1 n# h
    * z  x  H% y4 w$ n0 F0 z0 {4 B+ ~
    我们可以作出如下正方形:
    . j. X/ k9 \- R, F/ W% G, p& o
    & p7 v& v: D( Y: o+ [# @0 L5 s; {; T; s' L
      CE=asinx,AD=bcosx,DE=acosx+bsinxCE=asinx,AD=bcosx,DE=acosx+bsinx
    % N/ h' C- a& F7 X7 {  转化为了规划问题那么正方形面积最小的时候即为最优解。
    1 u! U$ ^, A; i' W/ C$ r  代码:. o3 p% P; y. O$ w  f, l
    ' C! q3 Z- r" q. m) ^+ {7 a
    model:
    ( ]& u1 Q2 b* v; W, q! Xsets:" c0 P/ y" g; E" r) j
        object/1..3/:f;
    , k. D& L- B: c$ Hendsets( p% t; ]2 N3 h, s' {
    data:
    6 p( m. u& O0 }6 h$ N9 [( k& U    a, b = 3, 4;
    ' u! v0 ]. `& P( ?/ Qenddata7 {1 e4 N) Z+ V
        f(1) = a * @sin(x);6 J3 Q) u) v( L' M9 `7 A2 ~! K
        f(2) = b * @cos(x);7 A1 D5 [6 z4 @2 h  ]9 F  Q3 F
        f(3) = a * @cos(x) + b * @sin(x);/ y  ^9 q" S) p$ i
        min = @smax(f(1), f(2), f(3));
    ) d' n& N+ r, `& u8 g    @bnd(0, x, 1.57);
    . K3 f( l+ f* M! F' nend
    + a* ~/ V  \. j% c4 k4 p$ x1
    ; ^4 C7 ]% L% q) J4 W2; m7 ?4 s; S8 ^3 ?  s
    3! r8 a8 g. @% D" V; T$ q
    4. R" H: |' F. G+ g, J# P
    5
    / _6 t/ }0 D) N3 f68 n$ m$ C8 r' K+ N9 l. E/ a4 o
    7
    & o% S. p% t" V  r8& _, F: t6 x1 u3 X6 U6 w5 P; z
    9( r+ r" \* i1 @! a" u; v
    10/ b, }6 x/ h( n# L$ ~; N1 a" e" T
    11! S# h, r' o- f) y% P. e4 B& s
    12: ~; W" e0 T9 F# c! Y1 t
    13
    ! ?2 u) G2 n  G  t& l* }  得到结果:
      h* d! Q) W2 a2 _) A( Y- b% [
    . k6 E6 ^/ l5 E7 D+ r, ^7 E% H% I  }8 G* t' b, {
      这里需要注意,lingo中如果没有代码说明,是默认 xx 的值大于0的。代码中用 bndbnd 函数限制了 xx 的范围。
    $ |% i1 f, f& V6 a) ~  那么再进阶一下,Lingo在处理TSP问题的时候表现如何呢?8 b# n; b2 ]% q; A

    2 y) z; u3 E& s$ S例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/ ~/ Q. {* n+ p/ v
    ∑i=0n(ciπ(i)+piπ(i))=∑i=0nciπ(i)+∑j=0npj4 F- o$ c. K5 E9 [( k, @
    ∑i=0n(ciπ(i)+piπ(i))=∑i=0nciπ(i)+∑j=0npj
    + ]/ E3 @4 Y" m0 v" _由于 ∑nj=0pj∑j=0npj 是一个常数,故该零件的加工顺序问题变成TSP。
      Z4 \& [& S! [, M1 U6 k
    : p3 Y8 x2 a3 ]- q/ v代码:
    & [; }0 p( Q; m5 q: e( n+ B- a! Z" a0 a3 V+ ?/ T
    !旅行商问题;
    ' j9 F* D8 {5 t: @( v! M# D7 O- O% Q- cmodel:
    5 T/ I" K1 f% Jsets:
    6 ^6 q& T; A! d- |3 @! T8 _' S    city / 1.. 5/: u;/ B7 t6 r- u# `# u1 n
        link(city, city):* ~- |- |5 a5 O: ~$ t, @+ A
            dist, x; !距离矩阵;
    ) {) n1 F7 J6 E2 lendsets
    # q% x) T/ p3 ]$ |    n = @size(city);  l: a) L$ r  u# z! ~
    data: !距离矩阵,它并不需要是对称的;- n- _2 {8 x) D7 `! T
        dist = @qrand(1); !随机产生,这里可改为你要解决的问题的数据;
    - |" V2 H4 o0 E2 _enddata+ h7 R' A4 ^# l/ f6 r/ N
        min = @sum(link:dist * x);. P$ a0 w/ [- z8 I2 |. M" |  F, [6 t
        @FOR(city(K):& u- W+ k/ t/ V3 i. r* ~
            @sum(city(I)|I #ne# K: x(I, K)) = 1;
    9 z6 k1 S5 ~5 \2 B  i# R- l( c        !进入城市K;2 I$ ]- Y$ Q# D; t
            @sum(city(J)|J #ne# K: x(K, J)) = 1;2 K  m. b" Z) K. C) ]
        );
    . a4 V' V4 W7 G    @for(city(I)|I #gt# 1:
    ' d% b8 Z+ |, d1 ?, `5 {' M        @for(city( J)| J#gt#1 #and# I #ne# J:
    3 V- o! \/ s/ Q             u(I) - u(J) + n * x(I,J) <= n - 1);
    % t5 O% z9 y+ v) u1 {9 w. u    );9 ]3 T/ o  g4 o; L4 ~3 Z% m
    @for(city(I)|I #gt# 1: u(I) <= n - 2);1 x/ X3 @+ r9 h( t$ H
    @for(link: @bin(x));& z0 p- _3 e* t7 K8 S
    end
    + R  v7 {1 j+ R; @  G1 Q- M1
    # Z- F3 |' e& @0 ^, X25 y7 ^) C! v+ a
    3( z  L& i9 q; v$ @) Q
    4
    9 y% r9 Z1 N& b, j5 d$ c9 w( q5
      i" T) J! `5 O8 I3 ~0 J6
    ( J8 _- B3 {5 M- ?1 ?7/ {& e' q; T) ]& t! X( b8 r
    85 u; ]' V* e% W
    9' [% y5 i% i6 ^! x6 l* a- \) B# T
    10
    ) ~0 F4 J7 N# g5 \4 N' c11* T- B6 Z0 F: \4 m
    12/ _. Q+ E4 b4 ^1 I) H
    13* o* R9 ^0 m' X, l
    144 u0 C2 d; B9 u9 }
    15
    6 V; r7 P, g( E1 Z$ S. y, j. [16: l4 G0 n$ x* X4 {
    17+ s: Z- L# Y# M% Z. b# G1 j
    18* B0 t9 o7 r: r5 S
    19
    ) e) i0 U6 Z5 i  L3 T* j$ b20
    - j: N+ K6 y" M21
    ) I1 @, l" F5 m: P7 a225 E/ C% _( i9 B+ y  C5 u
    23
    6 |! f8 B/ p$ l" J  s246 ~( r. A- s' L" b8 f
    可以得到结果: 4 w) v2 e- O% v4 K

    7 u7 j# _( G: @/ p8 C' l$ r--------------------- # i7 O$ ?/ }* u: Q- S7 Q6 U" K, A
    / ^5 I' N: R+ h% N8 ^/ I; B

    . Z) s+ H% V; F1 M- u4 B
    7 ^0 f+ C  n7 o& }& H# _( S; a2 ]4 c8 |. `! l9 E
    7 n$ y# c& g7 Z
    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-4-17 15:13 , Processed in 0.421202 second(s), 51 queries .

    回顶部