QQ登录

只需要一步,快速开始

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

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

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

1253

主题

442

听众

-586

积分

复兴中华数学头子

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

    [LV.2]偶尔看看I

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

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

    群组越狱吧

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

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

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

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

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

    GAMS示例

    2 Z) R8 U7 \- @( ^3 c1 Q8 {& T, g8 e

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

    . G4 h) M$ O8 f) I 8 ^6 Z' z& B7 s$ k8 T7 D6 z9 k0 N) R/ c- J) S$ W7 E! J! K* J! g; w: X/ @! {/ g" g; w4 `
       代数描述
    / G' V2 w3 j( h+ C3 e

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

    ) \1 V* b; n* W* Q- _, Z

    指标:

    7 J1 D6 b! y9 o' K

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

    0 l# d& W+ u |0 J9 `: |8 o) Q

    给定的数据:

    5 d0 r- O' K4 ?5 c. M4 H* f

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

    1 s5 V2 L9 F0 G6 D4 U " D- M: {( ~& @8 a( \2 h( O5 H" z! u# m+ n7 Y* B. F6 `8 n/ t) d- F+ `' Y+ z- ^: L# l" G+ r7 G4 [) E- |0 z& N7 x5 p8 i, O, ~: T- t- G6 Q: A6 x/ x6 I9 P4 m( S, s7 ~( q; d1 c: ~- q4 v9 Y& _7 ?5 a, I6 x6 F4 m0 y. l2 E" \4 i3 C( `! U: S! h$ f% ~3 X+ O3 m3 Z1 i8 V8 N6 [8 W9 g7 P/ G6 i: l8 W$ N1 q7 q) q( t$ x7 g. Y; x- {, h+ S6 _, V# ]6 L$ K! |' g7 c1 |, @' ^, O) x* v7 Q! _4 n/ n9 a1 H8 B( ~/ ] h; [( n8 p7 H, G& N+ M4 U% {% w( m5 s% A" c: z, Z# K7 {2 M1 s+ q4 O( v7 k y2 k- J1 D8 G; s) b2 r# A% [) q. a9 P! d3 V9 i8 X2 c& {& U# {( t3 K# I8 A8 m5 `$ H5 M. Q1 F' E4 ^; W. n! c! G; U0 T1 b" l; u) ~) T+ O( R5 _5 ] Y% ?! u& }7 R; ^& C% b7 K3 C8 l, o+ \, J0 h+ ^% G% ?. [1 _' _: l+ I; G* O* }; W e! o$ Q9 I& x) l$ p) H( j. }& u) M. F" y8 ?; w* b4 N( M9 ?* c2 |* 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  
    8 }" M- {) H+ _, q3 h! I9 a

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

    & V' @6 T: k: T1 C# S$ Z

    决策变量:

    + f3 i; W5 {1 c9 ]4 W

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

    % u3 @$ x' x4 Q; {3 d! ]

    约束:

    % C0 f3 l- n/ y1 J9 A8 i3 z

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

    # u. T% E6 w6 u. d4 a

    目标函数:

    ) ]% O$ G$ t& H

    Minimize (千元)

    6 c0 u& J6 E, F; O( g# |/ B/ R3 ~! W4 A% t* a$ p$ o F7 u( N$ c8 w6 e$ M2 E5 y1 g% _' n! z: O+ G/ ~/ k3 O8 U) M4 K" k' u0 \* q V$ g
       GAMS模型
    " v9 ]0 F1 S6 ? y

    同样的模型在GAMS中建模.简练的代数描述使得模型高度紧凑,并带有逻辑结构.内部的文档,比如对参数的解释和测量的单位,使得模型很容易读懂.
    A% p, f- l; G) U

    集合(Sets)

    # W' F- M' |: W; I% M% o

    1 b& Z/ Y& M$ u% B" {8 I- _2 i

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

    + M& R( Z9 T0 n6 u, z7 Q, x8 m6 ?- D

    参数

    2 x# C0 Z' V. P) @+ w

    ( n; ]6 |4 D: z5 U

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

    3 n. }, [6 D v; W) n. a

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

    " B$ b' d+ w1 E. B5 S( p' u

    表格

    5 c- w" H. p6 U) H2 O) c


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

    - u$ T" @, ^& u

    标量(Scalar)

    ! x y1 @# J' d) A* x# R* j


    常量能够被声明为标量,它的值是指定的. U. Q+ ~5 h7 D$ Z( R' }6 [; i

    数据处理

    ]! S8 a& w2 j1 T

    5 [7 l& W& Q; A8 n0 Q

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

    7 W3 g. b/ ?+ {5 w7 l4 @1 q

    变量

    - G$ g# K3 P- j1 ?* P

    ! \' v+ q8 |7 b* |' l$ P

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

    5 X; n9 v! h& @/ [6 C

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

    * j; |& C6 R. V; [, e' b

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

    . A0 X2 x4 ?) w9 y/ y$ R- s

    方程式

    I. A! F+ ^1 n( j

    8 F* W/ @* `' X/ y- D

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

    ( h. l7 {, | ~3 I/ h. B H8 s1 U

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

    & }" F5 R6 I2 D/ m+ u& h

    模型声明

    ; w: d/ i6 r4 G7 A

    * ^9 M& ?+ O A0 F- X

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

    / a; G* W. g$ b6 d

    求解声明

    # j: i! T% ~* l! Z: t

    8 m3 _- x7 ~9 Z: _; f6 M+ U# f( A

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

    1 _5 P1 {6 I( Z+ B. } % [& d( Q/ m T) Y( ]3 P- A' @- F; k; _2 X$ P/ B* b6 A. J, j+ ~* w9 v( j7 [! s) k
       GAMS输出报告(部分摘录)
    8 @. ^) X0 I }/ r& w/ c- E' z

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

    , I. x p! t" {& d: W4 `

    方程式列表

    * ^- `2 e- l: z6 c8 b

    _4 c+ p2 S- T; L/ K* ~6 ]3 v

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

    ; w0 J4 y" a- @3 P' N H* r: S% K

    列列表

    & b! c! V1 M" y, g& B% `3 S

    : d, Y+ a4 p- t# B! M r- |

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

    4 M2 g# W2 i A# [) E2 h Q; {$ V7 v3 W; M: L9 O8 t* S; v9 \4 e3 W, f, B" [% O& k. O+ w' Y% ]" P; O
       求解信息
    2 F/ E1 l, E; a P% `5 k# h G

    E& l6 o) V) O8 m; h- l0 E

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

    2 E; ^. Q A/ u1 ]* u

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

    5 x! c6 n8 K/ E7 E j: w

    解(Solution)

    % B4 U9 f3 c2 D* T+ |5 [- |

    - B+ S0 @( e% x) W

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

    9 u# }! M! u* I, K- l

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

    5 ^" A4 U: t: |. O# D ' G6 l0 i0 {( Q/ U+ P/ p( i! _4 P1 N9 T. [* D7 T3 {: V2 K' N' [3 H z8 g. t6 W/ ~2 t* v$ N( B& }" C2 L3 A
       参考
    1 D' J+ A3 o* \( W5 b% E0 x

    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

    群组中南民族大学

    辛苦版主啊, {. t" X4 V7 ^! a) q6 i$ P+ p
    + m# G, z$ G4 n, s% N3 ?8 t1 d$ C5 d
      k3 p9 F2 v: N
       
    回复

    使用道具 举报

    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-4-17 00:04 , Processed in 0.500655 second(s), 107 queries .

    回顶部