QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3224|回复: 0
打印 上一主题 下一主题

助力国赛 | 第3弹 规划问题(Lingo版)

[复制链接]
字体大小: 正常 放大
杨利霞        

5273

主题

82

听众

17万

积分

  • TA的每日心情
    开心
    2021-8-11 17:59
  • 签到天数: 17 天

    [LV.4]偶尔看看III

    网络挑战赛参赛者

    网络挑战赛参赛者

    自我介绍
    本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。

    群组2018美赛大象算法课程

    群组2018美赛护航培训课程

    群组2019年 数学中国站长建

    群组2019年数据分析师课程

    群组2018年大象老师国赛优

    跳转到指定楼层
    1#
    发表于 2020-6-7 14:34 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta

    9 }1 `! \& E: f; K& \: a9 h$ {助力国赛 | 第3弹 规划问题(Lingo版)9 T' z. c  u, c( j) i1 J6 k, _6 O$ K/ S
    / r2 H0 S( N2 x

    ( s. n- L- r# U* W7 k" s前言
    上次介绍了用MATLAB来求解规划问题,功能强大是强大,但总觉得有点不爽,函数里面的参数有点难记,万一输错了岂不玩完了。的确在可读性这方面,MATLAB做的差一点。正是基于此在此向各位推荐另一款软件——Lingo。Lingo在数学规划上也是大名鼎鼎的。本次首先会简单介绍下Lingo和其基本操作,齐次介绍些高级操作,最后还是回到实际问题中,在具体问题中一睹Lingo的强大。
    • 基本操作
    • 高级操作
    • 实际应用
      - D" j7 r$ O) K2 y4 j3 P  @4 B
    # G2 q( e) C; }6 r7 o3 Y: a9 A
    基本操作简介
    Lingo是美国Lindo系统公司开发的一套专业的求解最优化问题的软件包,可以求解线性规划、二次规划、非线性规划、线性方程组、非线性方程组和整数规划等。LINGO软件有多种版本,如LINDO,GINO 和LINGO(包括LINGO NL)软件。在这些软件中关系最让人“头痛”的恐怕就时Lingo与Lindo的关系,其实可以这样简单的理解:Lindo是可以是这些软件集合的代名词,Lingo只是其中一种具体的软件而已。管他们什么关系,知道现在被广泛使用的是Lingo就行了。
    ) D  L# ]' I" _5 L) jLingo是一款商业软件,使用是需要付费的,可以登录他们的官网:http://www.lindo.com 进行查看,但在天国获取的方法就不仅限于此了,具体可以访问某度,在此就不细说了。' m' j4 Z" z4 ^2 Q0 s' w0 c

    ) C: ~3 _( P) u9 @9 i* e* @
    下面“吹一吹”Lingo。
    强大的求解整数规划功能是Lingo软件的最大特色,且求解速度非常快。Lingo还是最优化问题的一种数学建模语言,它包括许多常用的数学函数,这些函数可供使用者在建立最优化模型时调用。此外,Lingo提供与文本文件、Excel文件和数据库文件的接口,便于输入、求解和分析大规模最优化问题。

    6 y. w- S7 R7 P1 t初印象
    第一眼还是很重要的,下面就看一看Lingo。
    4 A1 \/ y7 _$ O9 K6 W建面如下:! i- K1 `- Q0 ~8 k1 E
    & A' i4 d0 b& _/ g
    常用工具栏:

    2 }5 M2 q# W2 x8 P5 A
    Lingo文件类型:
    文件后缀名为“.lg4”保存了模型窗口中所能够看到的所有文本和其他对象及其格式信息。
    运算符
    算数运算符: 用于数与数之间的数学运算。
    ; z% a0 G, u) w9 t2 w' P5 MLINGO中的算术运算符有以下5种:! G/ J8 i" }& D
    +(加法)
    8 m( s$ {: o9 s. |( b-(减法或负号)4 {9 r- M3 |+ w7 A2 v
    *(乘法)
    7 j. ]1 X- l+ ^  P% ]8 K; M/(除法)/ M2 @: B$ H3 X1 K
    ^ (求幂)
    关系运算符:表示“数与数之间”的大小关系。
    ( L# O! r) ?2 @) K$ f- B9 ULINGO中关系运算符有3种:
    3 H. u3 W& N0 A  t7 U5 Y< (即<=,小于等于)
    ( _% X( o. X% f: \= (等于)7 @; h5 H; S- @/ C6 \" g6 N9 X0 L
    > (即>=,大于等于)
    简单程序编写
    求解如下问题:, V( ?- p0 ]( L
    / }* x  @9 m6 ~
    编写程序:

    ! X! O/ p. G% N: f; A' V# I+ W
    点击求解按钮:
    ! o1 M3 x# [! E! k  h1 ^
    分析结果:

    * |- H7 M. G4 `9 j
    所以当x1 = 0,x2 = 5时,取得目标函数的最优值15。
    高级操作
    下面详细介绍Lingo的用法。
    基本语法
    在LINGO语句中通常以MODEL开始,END结束(MODEL和END行也可以删除),目标函数表达式前需要加“MAX=”或“MIN=”. 在写LINGO模型中,注意:
    • LINGO模型已假设各个决策变量非负. 若变量无非负约束或有上下界,则可以考虑用@free、@sub、@slb或@bnd来定义.
    • 变量名不能超过32个字符,且必须以字母(A-Z)开头,其后可以是字母、数字(0-9)和下划线(_)的任意组合.
    • 变量名不区分大小写.
    • 在约束中“&gt;=”与“&gt;”等同,“&lt;=”与“&lt;”等同.
    • 在目标函数或约束条件中需要以“;”结束.
    • 标点符号等要在英文状态下输入.
    • “!”为注释符号,其后为注释内容,注释以“;”结束.
    • 逻辑运算主要包括:#EQ#(等于),#NE#(不等于),#GE#(大于等于),#LT#(小于),#LE#(小于等于).
      6 Y# l  I6 h: ?) l8 l
    LINGO中建立的优化模型可以由六个部分组成,或称为六“段”。
    • 集合段:用于定义数组型性变量SETS: ……ENDSETS
    • 数据段:用于变量赋值与数据传递DATA: ……ENDDATA
    • 目标与约束段:用于列出目标与约束唯一一个没有段的开始和结束标记
    • 计算段:用于数据初始整理计算CALC: ……ENDCALC
    • 初始段:用于变量赋初值迭代寻优INIT: ……ENDINIT
    • 子模型段:用于表达子模型进行调用@SUBMODEL mymodel:可执行语句(约束+目标)ENDSUBMODEL
      & j5 p5 m' O$ c
    有了这些我们就可以,不必把表达式全都列举出来了,下面这个表达方式:
    4 f- B/ `; y5 E* g9 {# r' @' ]

    " o+ L& m2 B4 T* _' i
    code:
    sets:!集合段;s/1..100/:x;!基本集合, 集合名与属性变量;endsets!目标与约束段;@sum(s(i):x(i))<90;!循环求和函数;
    4 f- d  }4 A5 }
    ' A) Q+ S' O8 [9 s1 h4 G
    code:
    sets:!集合段;ss/1..10/:b;endsetsdata:! 数据段;b=1 0 1 2 3 5 2 6 1 2;enddata7 ~0 ]" C- S) W1 ^1 J

    5 q1 I% n7 \$ |  O* c
    code:
    sets:!集合段;a/1..100/:x;b/1..200/:y;Endsets!目标与约束段;@for(b(j):@gin(y(j)));@for(a(i):@bin(x(i));! ^; C8 I+ d! W* e
    派生集合
    派生集合就是派生出来的集合,看几个例子就懂了。2 q" n9 h3 K! ?

    ! Z/ N# c4 a  n) A7 ]7 T" P* ]
    code:
    sets:a/1..100/:;b/1..200/:;C(a,b):x;!派生集合;Endsets!目标与约束段;@sum(c(i,j):x(i,j))=280;
    $ X+ o8 F4 M; O/ _( O: S
    ' `7 m8 B8 M9 r, `" e6 h) o
    code:
    sets:a/1..100/:;b/1..200/:;C(a,b):x;Endsets!目标与约束段;@for(b(j):@sum(a(i):x(i,j))>150.001);!集合元素的循环函数;
    ) @; O4 f4 A2 W+ u# v& I
    7 ]5 H0 Q+ o- W6 m0 b1 m
    code:
    sets:a/1..100/:;b/1..200/:y;C(a,b):x;Endsets!目标与约束段;@for(b(j):@gin(y(j)));@for(c(i,j):@bin(x(i,j));
    2 i$ A6 X  H* a+ R逻辑运算符与过滤条件
    这个前面提到过,再罗列一次:
    , f, Y6 F. [2 a' p+ _LINGO逻辑运算符有9种:. n- u: {! n( h* [! M& Z2 E' G4 H
    #AND#(与),#OR#(或),#NOT#(非):
    ' H: z. q7 M6 d  r) V#EQ#(等于),#NE#(不等于),- y# O) m# O& v% J  p5 A) S
    #GT#(大于),#GE#(大于等于),
    + G5 n9 H% b& y7 P( s: `) ^#LT#(小于),#LE#(小于等于)
    * b3 A2 n0 _  J6 i看下面一个例子:
    & B7 q1 W3 S6 O4 l' Z; `* Q
    + T6 ?5 k: x+ J+ F0 Q( k
    code:
    sets:a/1..20/:;b/1..30/:;C/1..40/:;d(a,b,c):x;Endsets!目标与约束段;@for(a(i):@for(b(j):@sum(c(i,j,k)|k#gt#1#and#k#ne#10:x(i,j,k))=100));!过滤条件;
    - b" B9 M; v) I
    如果我们表示一个分段函数时,就可以是if函数
    @IF(logical_condition, true_result, false_result)" o6 p. `: {7 X
    当逻辑表达式logical_condition的结果为真时,返回true_result,否则返回false_result。

      r3 l& I, e- k  D9 p
    code:
    f=@IF(X#LE#500,4*X,@IF(X#LE#1000,500+3*X,1500+2*X));3 o1 i% R9 ^- x5 Q7 L
    掌握上述方法,可以解决掉大部分规划问题,如果还想进一步了解,可以去查阅相关书籍。
    实际应用线性规划
    & k& K& W  `! D: J
    原运输问题变量更换为:

    0 M' o* ?7 [% X: ^4 }. B
    建立模型为:

    0 H/ i* B) {6 W  C/ l& e4 x6 _& r
    模型进一步转化为:
    ' a5 s" E% h" K0 V4 N
    程序编写:
    MODEL:TITLE 调运大米的运输问题程序3;!定义集合段;SETSIANGKU/1..2/:A;!定义粮库的集合;LIANGZHAN/1..3/:B;!定义粮站的集合;YULIANG(LIANGKU,LIANGZHAN):X,C;!定义运量和距离;ENDSETSDATA:!粮库到粮站的距离;C=12 24 830 12 24;!粮库的限量;A=4 8 ;!粮站的限量;B=2 4 5;ENDDATAMIN=@SUM(YULIANG:C*X);!粮库上限的约束;@FOR(LIANGKU(I):@SUM(LIANGZHAN(J):X(I,J))<A(I));!粮站下限的约束;@FOR(LIANGZHAN(J):@SUM(LIANGKU(I):X(I,J))>B(J));END6 _. B: A5 g- j8 ]/ D! e$ Q
    运行程序即可得到结果。
    非线性规划
    CUMCM2004C请你参考下面给出的数据(或自己收集资料)建立饮酒后血液中酒精含量的数学模型,并讨论以下问题:
    • 对大李碰到的情况做出解释;
    • 。。。% B$ ^# F& d, E+ m" t4 L& m
    参考数据
    • 。。。
    • 体重约70kg的某人在短时间内喝下2瓶啤酒后,隔一定时间测量他的血液中酒精含量(毫克/百毫升),得到数据如下:
      ! ^3 x8 t! V$ c0 M# d' Q, [) W# }, n

    4 |, o1 p2 g/ q  \% O8 Y4 U
    分析:把人体内酒精的吸收,代谢,排除过程分成两个“室”,胃是第一个室,血液为第二室,酒精先进入胃,然后被吸收进入血液,由循环到达体液内,再通过代谢,分解及排泄,出汗,呼气等方式排除。/ J% u  s( V% j: k) e0 M5 v" _
    假设胃里的酒精被吸收进入血液的速度与胃中的酒量x(t)成正比,比例常数为k1,血液中的酒被排除的速度与血液的酒量y(t)成正比,比例系数为k2,G0为短时间内喝入胃的酒精总量,则可以建立微分方程:
    * r- T2 M! W/ f' V. i( J
    求解得:
    + Q$ i- v( z0 L! f
    变换为:: ^( o' |. p2 v! G5 Q" @; w

    2 l) j  P, y+ W# o$ G/ d; }* R
    因而问题就可以转化为:

    ; x5 N0 G- l2 ^( M0 p! ]3 k1 P3 C
    编写程序:
    MODEL:SETS:BAC/R1..R23/:T,Y;ENDSETSDATA:T=0.25 0.5 0.75 1 1.5 2 2.5 3 3.5 4 4.5 5 6 7 8 9 10 11 12 13 1415 16;Y=30 68 75 82 82 77 68 68 58 51 50 41 38 35 28 25 18 15 12 10 77 4;ENDDATAMIN=@SUM(BACA1*(@EXP(-A2*T)-@EXP(-A3*T))-Y)^2);END
    / N2 }. v1 t. V9 P2 Y) f: r0 X* J
    运行程序,即可获得结果。
    整数规划:
    对上次最后一个题目,用Lingo进行求解。) k3 C0 e& Q9 x( G
    编写程序:
    model:sets:row/1..4/:b;col/1..5/:c1,c2,x;link(row,col):a;endsetsdata:c1=1,1,3,4,2;c2=-8,-2,-3,-1,-2;a=1 1 1 1 11 2 2 1 62 1 6 0 00 0 1 1 5;b=400,800,200,200;enddatamax=@sum(col:c1*x^2+c2*x);@for(row(i):@sum(col(j):a(i,j)*x(j))<b(i));@for(col:@gin(x));@for(col:@bnd(0,x,99));end
    5 ^# Z4 G( G2 l/ A: e7 J
    运行即可求出结果,还是满精确的。
    % h3 e! H' A3 y, P( x0 ?; c/ \' v: o( E

    - g7 S' }! @7 M2 O/ L' h
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏1 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-4-13 09:28 , Processed in 0.440916 second(s), 51 queries .

    回顶部