QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 25015|回复: 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示例

    0 e- j9 X5 F6 e9 F0 Q/ n: z/ m

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

    * [0 U( ^( d: k& ?4 F% l( X3 q# A1 s$ K/ I+ s6 }/ y$ |! g9 |( h7 Y1 F) T4 B8 t0 X3 V0 j$ D" w6 p. i1 |& G0 _* D/ m, ]- p' U- g
       代数描述
    6 o8 A) X0 M( K+ p' ?" q5 `& O2 o

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

    $ g/ a8 v. g/ F9 {$ g) n5 h0 D: d

    指标:

    ' L3 L4 ~" |4 A3 n& E2 g2 ?

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

    / M7 p# t& _+ r$ j

    给定的数据:

    : ]! `* F2 i x

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

    ( \/ x8 j; N0 D9 |1 Z& z2 o 0 L' ^4 @( R- l, k3 }& @4 H O" l% F6 G! |1 J' n, K: b/ I3 P9 I5 X4 e a3 h4 j) y5 |% @1 m; W) Q% u( I% A% U P! j' c& x! d7 O: `9 Q2 s3 q# |3 W5 h) B* B4 ~& ?: } J5 X5 r b' ]' I! w: g3 T' j6 Q2 }% k- N( V, ]4 D) H& d+ W: d9 h' M# v' S7 C* V& i+ Y( e6 S* i* ]) y- o: j# o# |# p) o6 _1 B; w1 W H& Q! S# p, z) ^/ S6 ~$ W" Q4 M# A* g) G1 n& R& a: e Y" f7 P4 m/ o% y. A b ~5 n% c# S, y6 D0 W8 Z0 G5 G" A/ V- i& ?, K. H# t2 U1 w0 ]% v. X( u1 p; Y4 `2 U& ]9 S. n* l( R- K( e4 ~+ z8 Z+ c' s9 q3 W3 V4 E+ C2 H$ [% @. U* _* n1 Q, d c0 y. k+ u( X7 [! B! f4 i3 R9 I6 e8 @7 L* O r) L& m. r1 p `9 L' Y5 K% ~' M" L' @! T- h' r9 B+ R- \3 r1 V% T7 X+ K$ f1 H* `4 f1 Y p( F( D. k4 b( l3 m0 ?% B2 _, d6 B& N, ~# V+ R5 u- Z- D+ J. J$ i+ j: ] j' r& |; _' ]+ Q% n' o$ x+ g6 S1 |! X
    距离  
      市场  
    工厂 New York Chicago Topeka 供应量
    Seattle 2.5 1.7 1.8 350
    San Diego 2.5 1.8 1.4 600
    需求量 325 300 275  
    ) G& f8 V8 ^5 U/ H

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

    2 h9 {7 y) t* N0 p g

    决策变量:

    3 Y {9 B8 u" V" I! G% g0 }+ V% S( ?

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

    0 X0 X" S& J" e3 S3 @

    约束:

    ! s+ ?3 g. ]* `4 D, X

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

    ) V3 N# f5 z- A

    目标函数:

    6 a+ l- R. @- I" J

    Minimize (千元)

    * @5 T2 `: P7 O: f, I' j8 C- V3 k- ]0 e. I4 v0 U9 W/ i: f0 m* Z, K5 `$ A+ S2 W4 M* B4 T& R' b( b0 K9 E! I1 f! K
       GAMS模型
    - Z; p& y: y! E0 W: H8 f$ l

    同样的模型在GAMS中建模.简练的代数描述使得模型高度紧凑,并带有逻辑结构.内部的文档,比如对参数的解释和测量的单位,使得模型很容易读懂.
    " U. J( ]2 p0 q0 r

    集合(Sets)

    " p+ Q2 B& B9 s9 Y5 y! D

    + k t5 j- ?" s4 E0 ?

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

    / A; o; B1 j2 L+ k' s6 Q

    参数

    - z4 I3 w9 ^1 V/ F

    + m+ L. `9 u% h

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

    , q! R& @. _1 V4 S

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

    # k! O' Z$ U$ u$ y+ N. Q4 ^1 z

    表格

    ) o2 J! O; F' {% {( c* i# k


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

    1 I" u. W/ Z; P5 E

    标量(Scalar)

    7 S- z: F* K' p( @. w


    常量能够被声明为标量,它的值是指定的. $ C, Q# O* x4 W$ g9 K+ X

    数据处理

    9 [2 c6 d1 A( H; C' d% x% a0 p

    & c5 ^+ I, k+ L# I7 o

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

    0 ^' T9 w, D4 Q; q) K8 B+ S; J

    变量

    # v4 T$ b) _2 Y* U

    . r% ?' @) l1 x: f+ j) N+ K

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

    % {9 o* }# n, Q+ H; r. O

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

    ; M& G5 T( b& B. H7 x

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

    9 e; K1 r+ D5 R' g

    方程式

    2 l- N9 k1 J" B! ~; e

    5 V( I9 l7 q/ ~- [: W

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

    ! B9 ^" U. e1 `5 j

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

    & g4 N6 X1 y. T7 n1 _8 y; Q

    模型声明

    $ T0 t5 C4 e7 u. h/ ]4 G" Q' }5 z

    7 r* S0 x- J6 i3 o) L W

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

    2 F: d2 Z3 T- C E8 x; G

    求解声明

    5 _! }8 W' i: Z( R; _

    & c0 a7 v5 H# Q7 Q7 P7 _

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

    5 t) e2 w2 _) }# f# ~7 R% A0 w : e0 {0 S* D, Z' A8 p/ W( S4 D; F/ D T0 O- i2 @0 I, \6 P( {2 r6 T- W, d+ t6 @) j% J, U+ E/ K: ?$ T
       GAMS输出报告(部分摘录)
    0 a3 K& h- T2 |! {; y* y" N

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

    7 X) l6 o9 e2 c' s* L& W5 t

    方程式列表

    * m! J& v- q6 o$ s4 H& B# [

    1 {2 x* x# c1 K+ ?) I& X7 |

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

    1 ]7 n, S6 m/ h8 b9 }

    列列表

    9 W& ]* p/ n: J

    , g( W! _2 W7 Y* c

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

    9 E U% u+ {3 {; O4 c2 K/ I) |4 J# P9 G+ K# ?# {7 w& s0 K7 |* W6 ]: F; w8 T0 \; ]9 N, z% |: _1 W2 J: A A2 M2 s, v$ o* A e% a' j
       求解信息
    3 `% N9 t4 |; Q% I7 W" G& _/ N5 { S

    $ a8 p% R+ s) x( r* _- |, x

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

    ' v, s- }/ d- ?# n* ?

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

    $ Y' _* B5 q% k* a( f$ k6 S ?

    解(Solution)

    ! h% W, T% ?, `9 ?" C) F& z

    * k7 @/ [7 q3 G2 A8 b

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

    ) R. o4 [ [' N8 E/ d& C

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

    5 q5 q/ V0 O' W8 c/ T) E' Z, j0 O. E6 G& ]4 F, `+ I5 ?$ C3 W; p( }/ N8 t8 P: z7 b: a& }- ]* _7 n9 I! ?) ? Q0 a5 P M( h
       参考
    8 ]4 W- [; ^6 U& p! N9 P* h

    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-4 01:43 , Processed in 0.547988 second(s), 108 queries .

    回顶部