QQ登录

只需要一步,快速开始

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

GAMS示例——运输问题 【代码及演算过程】

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

1253

主题

443

听众

-516

积分

复兴中华数学头子

  • TA的每日心情
    开心
    2011-9-26 17:31
  • 签到天数: 3 天

    [LV.2]偶尔看看I

    自我介绍
    数学中国网站(www.madio.cn)是目前中国最大的数学建模交流社区

    邮箱绑定达人 优秀斑竹奖 发帖功臣 元老勋章 新人进步奖 原创写作奖 最具活力勋章 风雨历程奖

    群组越狱吧

    群组湖南工业大学数学建模同盟会

    群组四川农业大学数学建模协会

    群组重庆交通大学数学建模协会

    群组中国矿业大学数学建模协会

    跳转到指定楼层
    1#
    发表于 2009-11-14 04:27 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta |邮箱已经成功绑定

    GAMS示例

    4 `6 k6 V* F. b; Z& i8 F0 z* k

    下面这个问题主要是用来举例说明GAMS是如何让您以一种自然的方式建立模型.GAMS能够处理大的多和高度复杂的问题.在这里只展示了GAMS的很少一部分的基本特征.

    , K: C3 Z) P- ^, N; z; V( ?2 N7 K6 j% z% ^" I2 N1 q- I, G, {( I8 X1 Z/ ~$ V$ ?! h) V' I# p- q2 N* t" n$ [+ |7 d8 g1 \2 [
       代数描述
    1 ?% j1 o% \& v( K8 w

    下面是问题的标准的代数描述,这是用来最小化把货物从2个工厂运输到3个市场的费用.受约束于供需约束.

    . x9 A) A+ ~ Y- T* p* L

    指标:

    * M% B% s' z4 G, E% U0 Y

     i=工厂(plants)
    j=市场(markets)

    # M( @' x% J5 _( \" K+ O* J6 K

    给定的数据:

    $ w; S' ]/ e ~! Y

    =在工厂i日常供应量(批数cases)
    =在市场j的日常需求量(批数cases)
    =在工厂i和市场j之间的距离(千英里)
    =在工厂i和市场j之间每单位的运输费用($/批/千英里)

    6 J( }0 K, {. @ ' g9 k+ x' D& j% T- W; i5 r" f' {7 C6 L! v0 n% M Z+ e8 C4 [1 {: O# ]; A* D8 N* ~$ C. K. T, G6 i- }0 z. g" I1 N8 N! U# i1 m+ i( d( t4 d: j( D# Z' w$ `# W( _' J" \5 J8 `1 z8 \5 k+ q Z: N" t3 u$ `; q$ V U. M' O3 Q3 h' y+ T' z8 }7 z9 c, E& h! \. f Q3 K/ r B6 J( N6 x6 \7 \- B( q/ S% Z& J0 q* @. i) y( C$ T0 |: X2 ~$ x/ ~6 A) ^( W2 }2 R& L, J8 D% g; g2 m; {6 d+ p! r4 }. }% Z: d, Z- e6 A+ c! |! {( E! f- W7 P; A$ O7 Y% r; ?" j% v, P# z; Q" Q$ H0 I: G+ S+ `! a- f' @+ U# ^! Q2 m0 g& J r% D; ^1 v2 [/ H, K; A" @* E; i/ W; Y3 {+ Y, c2 s" c2 K; v& F' l+ U( C6 v5 [+ E( p2 f8 H7 n1 `( s8 t6 Y h c( V' U3 @4 J5 Y: O0 D r6 t& ^. W& h% l9 S) C2 `2 u, o2 D( y3 V9 i$ x7 y9 R% P' O5 X2 d4 h& W# z8 @# B) V, ~; d6 e Z. ~9 ]+ s0 m5 |6 V! j+ i9 J. w0 L2 Y: T1 V+ r$ s
    距离  
      市场  
    工厂 New York Chicago Topeka 供应量
    Seattle 2.5 1.7 1.8 350
    San Diego 2.5 1.8 1.4 600
    需求量 325 300 275  
    , o6 v7 R P. U3 |

     F=每批每千英里的费用$

    & M6 w; ~8 @% n1 @

    决策变量:

    6 N$ z5 ^3 ~0 P6 X1 z2 t# d

    =日常从工厂i运输到市场j的总量(批数cases)
    这里 适用所有i,j

    $ H+ I5 {6 e$ u1 ] U6 h" H, O

    约束:

    % m2 g( e, E9 z4 x

    在工厂i的供应量**(批数cases):适用所有的i
    在市场j的需求量:适用所有的j

    1 L2 o' k0 s; k c

    目标函数:

    5 P" T7 U6 z* C9 M5 z/ j. Y* {

    Minimize (千元)

    1 ?% l: M& @6 @; [, q1 x: W0 ? $ ^3 I+ ]/ r( }$ Y2 r M, O) N" [- H# D: M, P# G+ {4 t/ s% P# @3 l, B/ v* G% O4 U7 ?9 K" h7 F( l! _: X- x
       GAMS模型
    5 Z! m3 Z' f9 } m( ^. j* }

    同样的模型在GAMS中建模.简练的代数描述使得模型高度紧凑,并带有逻辑结构.内部的文档,比如对参数的解释和测量的单位,使得模型很容易读懂.
    / I. H* U/ `# t$ e

    集合(Sets)

    |7 W* j# P: {9 O

    8 R4 S" ]- j1 Z

    GAMS让您以直接的方式指定指标:声明和命名集合(这里是I和J),并列举它们的元素.

    7 R. ]# i: u$ ^8 e7 S; L7 P& Q

    参数

    & x, V3 M5 s$ _ P0 p

    ) W' O0 E0 r+ R" M) _# z

    这里的数据输入被作为指标参数A(I)和B(J),值简单的被列出.

    2 i( Z5 D! i8 ?

    GAMS让您可以在模型的任意位置放置解释性文本(以小写格式显示),当您在开发它时.您的注释自动被结合到输出报告中的合适位置.

    9 N/ ]' A- U5 y l. j6 Z/ P

    表格

    0 a$ { [1 ^9 j$ i" ]6 L) z


    数据同样能够以方便的表格形式输入.GAMS让您以数据的基本形式来输入数据-转换是特定的代数化的.

    % j! ~ m" k3 T* A' d7 G

    标量(Scalar)

    ) d4 ]. o4 d0 X* T


    常量能够被声明为标量,它的值是指定的. ; V* u( e ^/ P" a

    数据处理

    ) M6 T2 u+ l+ p1 `

    : t* Z0 b% n1 T$ z- Q

    当数据值要被计算前,您首先要声明参数(比如,给它一个符号,随意给它编个指标),然后给它一个代数公式.GAMS将自动进行计算.

    8 |# J( N Y. o+ J, p, Q4 T7 x( u8 m

    变量

    / }" t, c1 U+ ^

    + o2 _) X8 M) t) r

    决策变量以代数的方式表达,带有特定的指标.从这种常见的形式,GAMS在域中生成变量的每个实例.

    8 a) S& m' j+ }

    变量可以被指定为下列类型:任意(FREE),正值(POSITIVE),负值(NEGATIVE),二元(BINARY),或者整数(INTEGER).默认是任意(FREE).

    + W5 \2 z# ]1 j

    目标变量(这里是z)仅被声明,没有指标(index).

    3 X: D/ b" y% X. z- ] n+ m

    方程式

    9 e+ h2 B4 g, V! K( z

    9 y- S2 w# r7 m f* Q& k8 g, N" h

    目标函数和约束方程式首先被通过指定名字来声明.然后它们的概括的算术公式被声明.GAMS现在已经有了足够的信息(从上面的数据输入和从在方程式中指定的算术关系)来自动生成每个单独的约束声明-就像您能在下面的输出报告中看到的.

    4 A. Z% X# I5 H' H( e& Z- ~* F7 Y

    =E=表示'equal to' (等于)
    =L=表示 'less than or equal to' (小于或等于)
    =G=表示'greater than or equal to' (大于或等于)

    0 D4 Y) z: _0 t% T. q6 U0 j

    模型声明

    9 E0 T9 R' e/ r0 X$ }4 P

    ! K' u, v( ^# G

    模型被指定了一个唯一的名字(这里是TRANSPORT),模型缔造者指定那个方程式应该被包含到这个特别的公式中.在这里我们指定了ALL,也就是说所有的方程式都是模型的一部分.就等于是MODEL TRANSPORT /COST, SUPPLY, DEMAND/ . 这个方程式选择使您能够在单个的GAMS输入文件中以公式表达不同的模型,基于相同或不同的给定数据.

    `) r2 V& S$ \! [- S& ~

    求解声明

    & X, q8 ?* P+ l/ y* w6 [

    ; ~; P8 m% \/ [8 `

    求解声明(1)告诉GAMS那个模型要被求解,(2)选择要使用的求解器(在这里是LP求解器),(3)表明优化方向,或者是求最小值,或者是求最大值.(4)指定目标变量.

    ) Y5 L9 K) i$ V( l N - v: \$ Y% m& d. M2 X3 S: [3 x& I0 D, M3 t% N! S1 O, i2 z0 x. i1 X0 g& b' h9 |% X3 i
       GAMS输出报告(部分摘录)
    " U( y$ o. Y, W0 b- w. K

    完整的GAMS输出报告比下面列出的部分摘录详细的多,包含了更多的帮助用于解释和诊断您的模型.甚至您能够修改输出格式来符合您的特定的需要.

    ( t0 k# g/ v- q( l" l

    方程式列表

    ' L: U* q+ J" F- U3 i c

    + m7 T0 Z7 S* }# u& ]: _& T# }

    方程式列表显示从在GAMS输入中指定的分区(block)生成的单独的约束.在GAMS中使用者可以以一种非常紧凑的形式写下被索引的方程式分区(block),这将产生大量的单个方程式.在我们的示例中,我们指定了3个方程式分区,生成了6个单独的方程式.

    p. m+ B! y' d% ]

    列列表

    + ]5 N# g8 c7 Q, {' L; V9 q

    ) y2 b+ B- ?0 x& D7 s, m8 W7 q

    列列表提供信息到生成的单独的变量上.变量X(I,J)扩展出6个单独的变量.当许多变量从一个分区中被生成,默认的列表只显示最初的3个(用户可以修改).

    4 \! V( W8 P5 O- g1 K( }1 z( A' f. t; }: ]8 ?/ a5 ]+ @; P) }3 Q! i' ^' R% _! Q1 ^1 C& Y3 J- ^7 N1 c1 J
       求解信息
    ) z& Z9 F8 L* N/ I/ e6 [

    $ Y0 C3 z2 `/ G) k2 @+ Y' B

    求解声明将生成模型(单个方程式和对应到特定模型的变量的产物).首先一些关于生成的模型的统计表将会被显示:方程式数,变量和非零元素.

    9 g K; k' o3 e9 @ x9 ~* j

    在求解汇总信息部分,我们看到BDMLP被调用来求解这个模型.BDMLP经过4次反复,耗时0.18秒找到了这个问题的最优解.求解信息下列的消息来自求解器.

    . M0 _" F: S* t' p

    解(Solution)

    + A& L; u# P3 z( K8 E

    $ J2 ^5 H8 H5 }) N0 i5 F

    解被显示在这里.边际值(marginals)对应方程式的重复和变量减少的花费.

    $ Y0 I3 u) h! r3 `2 K& ~

    写工具不需要学习一门其它的语言.在GAMS所有的数据处理,模型定义和报告编写都是在一个单独的环境中完成的.

    4 x& i V, B2 w8 Y0 _3 d 1 S5 v3 B6 \+ C8 b. p+ N0 }0 P+ ~: `1 ]) @4 D" W8 P/ ?' S# H4 q) h; T4 A- p$ V9 H; B& e5 Q9 f$ W6 g8 d! Q( h! s" D
       参考
    9 [, k8 p, h) j- P/ Z

    Dantzig G. B., Linear Programming and Extensions, Princeton University Press,Princeton, New Jersey, 1963, Chapter 3-3.

    GAMS Example.pdf

    143.39 KB, 下载次数: 57, 下载积分: 体力 -2 点

    GAMS 示例 (PDF格式)下载

    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏1 支持支持2 反对反对0 微信微信

    0

    主题

    4

    听众

    18

    积分

    升级  13.68%

    该用户从未签到

    自我介绍
    呵呵 学化工的 做系统工程 跟数学打交道的机会太多了 努力学习各种建模和解模方法 请大家多多关照
    回复

    使用道具 举报

    gssdzc 实名认证       

    0

    主题

    2

    听众

    941

    积分

    升级  85.25%

    该用户从未签到

    群组兰州大学数学建模协会

    回复

    使用道具 举报

    xupu3517 实名认证       

    0

    主题

    2

    听众

    2

    积分

    升级  40%

    该用户从未签到

    回复

    使用道具 举报

    17

    主题

    3

    听众

    2216

    积分

  • TA的每日心情
    开心
    2012-1-30 23:29
  • 签到天数: 39 天

    [LV.5]常住居民I

    群组小草的客厅

    群组数学建模

    群组Matlab讨论组

    群组LINGO

    群组中南民族大学

    回复

    使用道具 举报

    domschke        

    0

    主题

    3

    听众

    19

    积分

    升级  14.74%

  • TA的每日心情
    开心
    2011-8-14 05:35
  • 签到天数: 1 天

    [LV.1]初来乍到

    回复

    使用道具 举报

    0

    主题

    3

    听众

    22

    积分

    升级  17.89%

  • TA的每日心情
    难过
    2012-2-12 19:46
  • 签到天数: 4 天

    [LV.2]偶尔看看I

    回复

    使用道具 举报

    0

    主题

    4

    听众

    22

    积分

    升级  17.89%

  • TA的每日心情
    开心
    2012-2-23 17:16
  • 签到天数: 1 天

    [LV.1]初来乍到

    回复

    使用道具 举报

    0

    主题

    4

    听众

    30

    积分

    升级  26.32%

  • TA的每日心情
    难过
    2012-4-24 16:16
  • 签到天数: 3 天

    [LV.2]偶尔看看I

    自我介绍
    数学建模
    回复

    使用道具 举报

    市_长 实名认证       

    0

    主题

    0

    听众

    5

    积分

    升级  0%

    该用户从未签到

    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

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

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

    蒙公网安备 15010502000194号

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

    GMT+8, 2026-6-28 20:12 , Processed in 0.525409 second(s), 106 queries .

    回顶部