QQ登录

只需要一步,快速开始

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

    " a7 p7 P& V' k9 ^) v& j

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

    2 c- d9 \6 P" q8 @, J: N8 N% g # F j5 d$ d0 G0 Y3 {* B5 X, i! Q; z) `: L: o" A7 v3 S/ \2 Y- I- L2 `) M" B# K S8 q$ A& T! P
       代数描述
    $ i, G. i; ~/ |! L% ?( x. y

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

    7 e/ L% a) T! [' N6 r0 x

    指标:

    5 ~ L8 }( T% ]5 w- J, b

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

    7 D7 c- k5 ]; K$ I! s8 j& K

    给定的数据:

    % r) A' {! T1 D0 _$ \1 O# S

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

    ; ^2 K% g7 k& |+ q# S! Y/ \ ' }: Y5 f. K$ t, h5 D L$ u& j! E& k, W9 D5 _& X- S. A: B! U& g9 o& d" a, F9 `7 X5 x& ]9 h/ c) B& Q0 l' i; l" M5 K" n: y5 e: x' i: q" w: N- |2 O. _- c5 j1 }( {9 _. C8 \( i6 ^( S6 j. f& o% k P6 ^) O' \' |) }. J$ _4 J! T2 V) D: ?/ T: x" a8 l) D8 B) O' e, M+ j2 {' L0 s% g* d4 _6 b' s* i% @1 O! p% K1 u* G! V9 |. @, r) H7 ^& i0 B4 ]- m2 Y4 b. i9 S: f! C% F: g# R/ m& m2 _* a6 Z y1 I* Q y: ~& w2 b- ^# v( C* H) G0 [' o) ]+ `3 _$ G4 S: ~) `6 q1 a) U. c5 |" i# d1 ^* b- f r7 O5 s* \) _, ~3 C" f7 u0 e7 ~/ W! W# ^5 e+ o2 a# S! M# c' T1 [# g. h' J, u4 U; v7 r6 H$ W" ^5 f1 ~* Y3 M; s) G2 O2 Z; [3 E6 T0 D- w: ?' H4 V; B- A, A7 ^, u" K0 C" ]: w0 J) F0 g+ ~: g' R/ k/ W/ Z2 x3 e }# P+ R7 e6 T2 q; c1 N( H, X) C/ C+ J. I* J2 d% u4 E$ o/ S9 c h, J' q
    距离  
      市场  
    工厂 New York Chicago Topeka 供应量
    Seattle 2.5 1.7 1.8 350
    San Diego 2.5 1.8 1.4 600
    需求量 325 300 275  
    6 d$ r0 p; r. i9 j+ F% ~

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

    1 B0 J O$ L2 Q1 r

    决策变量:

    / m0 k3 A: j$ I0 [0 o7 ]7 F5 X

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

    - W' B% f" |; C6 Z- y- u% Q: j

    约束:

    . w5 ]# [# G1 Q

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

    2 g; [5 c) P! @- z H- U

    目标函数:

    5 W8 {" o, [$ ~3 H" e3 S- n1 L, z

    Minimize (千元)

    v; ~7 r& L3 v, B+ U4 c2 a! G$ {/ T$ C* Y4 T# F' y2 |/ r! ^$ X0 o# T6 N- H8 X5 S- r/ p/ L5 p0 ~8 V1 ]7 l3 A* ~5 x$ B9 c- [
       GAMS模型
    1 |1 O6 B; X1 Y. s# l% \) Y

    同样的模型在GAMS中建模.简练的代数描述使得模型高度紧凑,并带有逻辑结构.内部的文档,比如对参数的解释和测量的单位,使得模型很容易读懂.
    V$ G" Y4 `( `0 y' F- o

    集合(Sets)

    ) O5 C- X" n- w/ M+ i% @$ ]

    8 a" a6 q3 `: X. M& o# g

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

    , p: }! A, F5 Z' u& ]

    参数

    6 K* g- S+ k+ P% [* O4 \

    " p5 S7 Z1 t) g; }! K7 V8 D3 @/ b

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

    / m* ~4 N# w @

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

    * H% ]) ^6 c! p

    表格

    # |4 h( e+ v9 X% P1 k


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

    P, Q5 G! }! g i" a% D

    标量(Scalar)

    2 W1 a" A# K2 E0 k3 u7 }; m3 g


    常量能够被声明为标量,它的值是指定的. " }; o% i O- w3 R s. S

    数据处理

    1 Z# `; a" J# J2 }2 L

    # x K7 }" N3 a: K* k% {

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

    9 Y$ w% `' _2 {2 H- h" K# S0 N

    变量

    & q' f7 B0 N# `/ X2 t6 X1 V! c( l

    ( b! S4 i+ }1 z+ r* E5 e' a( g7 y% N

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

    3 Z; g# b! @6 u' h. R

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

    9 C* e$ l# ~& H+ l, b/ e

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

    * L* Y" Y9 ^1 i! ]% v: A

    方程式

    & y( Z a X* f. \( J' @

    |0 {3 H& Z+ }7 f, P, j. e) u

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

    5 I+ |4 N* r/ i+ h7 s7 F

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

    5 \9 h2 Q% a" X X' ^

    模型声明

    1 Q" \1 z5 o0 ?

    5 ?; e. a% s8 C: J% b& p

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

    " l6 u3 I5 S0 z1 p

    求解声明

    ; W$ M9 q# w5 ]- f% O4 D4 ^# v

    3 [ a9 w2 K" a4 d' ^; f% r

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

    : I: m: Z( i+ m' P$ f- F6 ?$ ~ k& C1 g+ L; L4 K6 f) u% J: ^6 j, Z+ D/ s$ S1 M" e3 O5 h0 l* M8 @
       GAMS输出报告(部分摘录)
    . E# e- T* t, c' {7 x/ N

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

    ( d# U( u0 Q* F* m S; S. e O

    方程式列表

    9 v- |5 @5 i$ w

    7 a9 J2 |5 V; Q3 i* E1 E9 _

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

    7 i0 u2 p6 @# y& Q

    列列表

    G! t5 j# i. {! h0 l) ?

    2 Y+ p6 t% a( J i% H

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

    0 M) ~, Y8 S! i/ f- Y7 s - c, O6 c9 {# M, F* _/ p8 d, |% d9 K! T i& V' k, b: G( O1 @! T% [3 d# M; E; U$ S# |& X. {
       求解信息
    " R* G: Q! F& E) ]+ K3 | T' ^

    - L4 d* \5 w2 G! S4 Q; K/ T

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

    : Z# x9 p3 y. Y2 o4 w9 b9 [% n8 X

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

    " a2 c- w; N/ Y0 ~. l) L7 N

    解(Solution)

    " U4 k0 j7 d* e# }: C! m( `

    ( H6 H3 n1 B% y/ g4 n1 I, T

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

    F; ?; }! t& v

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

    6 T: O+ \9 t6 Z 3 K* e" n8 M3 k, K. r, y$ v$ ^* }# `7 L. s& a. ]- a) s1 x; `5 @) n0 E$ T( [# {* K0 d6 W2 S) C8 U
       参考
    " G$ r: L- B& }/ X* h1 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

    群组中南民族大学

    辛苦版主啊% q. m7 ]' N4 {0 x2 D; \" k

      {7 G" g4 A$ f/ x- a$ R' j% l
      o& V' H* f* ]2 l$ U" @6 O+ v9 O   
    回复

    使用道具 举报

    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:13 , Processed in 0.573561 second(s), 106 queries .

    回顶部