GAMS示例
下面这个问题主要是用来举例说明GAMS是如何让您以一种自然的方式建立模型.GAMS能够处理大的多和高度复杂的问题.在这里只展示了GAMS的很少一部分的基本特征.
| 代数描述 |
下面是问题的标准的代数描述,这是用来最小化把货物从2个工厂运输到3个市场的费用.受约束于供需约束.
, m5 _+ n: |6 J# w& ?$ I5 b: }- d指标:
i=工厂(plants)
j=市场(markets)
给定的数据:
, ^2 t5 X1 a: ?# p5 F/ `' t+ W
=在工厂i日常供应量(批数cases)
=在市场j的日常需求量(批数cases)
=在工厂i和市场j之间的距离(千英里)
=在工厂i和市场j之间每单位的运输费用($/批/千英里)
| 距离 | 2 n) ^6 t' f1 `/ G||||
| 市场 | * V) q2 y7 h$ v/ P& N||||
| 工厂 | 1 B: F+ i3 L2 V* y- K* V( x2 J% i/ Y* RNew York | ! j+ u4 G$ ~( m0 ]- g: @9 v) IChicago | 7 M! P( f- c8 j; l3 [# k3 hTopeka | : z$ }# E9 h" V- ^供应量 |
| Seattle | 2.5 | 7 ~0 X& p8 X/ g% w) `' r1.7 | " g' b& ] o* k* L! O6 t1.8 | + t) ]3 A, F/ [350 |
| San Diego | 8 q) a/ D5 G: w2.5 | " Q5 u+ C5 s6 M/ c1 x. \ R5 I1.8 | 1.4 | 0 a7 j' L' _% g# j3 _* F$ \600 |
| 需求量 | 0 W; k( ~# g$ F( ?! _% c325 | 300 | / x% m0 m) V) L2 n' G1 H% O275 | ) X8 d- Y8 X. f1 g. y9 |% @|
F=每批每千英里的费用$
( G$ q( j8 t# c; f ^5 r9 m决策变量:
$ X4 ]# |4 h/ y0 h2 i" `
=日常从工厂i运输到市场j的总量(批数cases)
这里
适用所有i,j
约束:
在工厂i的供应量**(批数cases):
适用所有的i
在市场j的需求量:
适用所有的j
目标函数:
/ J, B! D# ?1 h W d) S6 u# IMinimize
(千元)
| ( ]7 Q" S2 t/ i% Y/ K9 T- c | GAMS模型 |
同样的模型在GAMS中建模.简练的代数描述使得模型高度紧凑,并带有逻辑结构.内部的文档,比如对参数的解释和测量的单位,使得模型很容易读懂.
集合(Sets)

GAMS让您以直接的方式指定指标:声明和命名集合(这里是I和J),并列举它们的元素.
参数
& b6 z: r6 |4 T- ^& P
这里的数据输入被作为指标参数A(I)和B(J),值简单的被列出.
; D Q7 w5 s; ]8 {+ W9 a; SGAMS让您可以在模型的任意位置放置解释性文本(以小写格式显示),当您在开发它时.您的注释自动被结合到输出报告中的合适位置.
表格

数据同样能够以方便的表格形式输入.GAMS让您以数据的基本形式来输入数据-转换是特定的代数化的.
标量(Scalar)
![]()
常量能够被声明为标量,它的值是指定的.
数据处理
. x/ o- N9 K, S) G# Q6 L" e4 Q![]()
当数据值要被计算前,您首先要声明参数(比如,给它一个符号,随意给它编个指标),然后给它一个代数公式.GAMS将自动进行计算.
变量

决策变量以代数的方式表达,带有特定的指标.从这种常见的形式,GAMS在域中生成变量的每个实例.
& @8 V4 [! W) v) \变量可以被指定为下列类型:任意(FREE),正值(POSITIVE),负值(NEGATIVE),二元(BINARY),或者整数(INTEGER).默认是任意(FREE).
目标变量(这里是z)仅被声明,没有指标(index).
方程式
$ J/ ]- K8 f$ r) X
目标函数和约束方程式首先被通过指定名字来声明.然后它们的概括的算术公式被声明.GAMS现在已经有了足够的信息(从上面的数据输入和从在方程式中指定的算术关系)来自动生成每个单独的约束声明-就像您能在下面的输出报告中看到的.
3 u- E7 a, t; ?& P! H& T4 W=E=表示'equal to' (等于)
=L=表示 'less than or equal to' (小于或等于)
=G=表示'greater than or equal to' (大于或等于)
模型声明
7 H8 h1 t9 R' F9 g- m![]()
模型被指定了一个唯一的名字(这里是TRANSPORT),模型缔造者指定那个方程式应该被包含到这个特别的公式中.在这里我们指定了ALL,也就是说所有的方程式都是模型的一部分.就等于是MODEL TRANSPORT /COST, SUPPLY, DEMAND/ . 这个方程式选择使您能够在单个的GAMS输入文件中以公式表达不同的模型,基于相同或不同的给定数据.
求解声明
![]()
求解声明(1)告诉GAMS那个模型要被求解,(2)选择要使用的求解器(在这里是LP求解器),(3)表明优化方向,或者是求最小值,或者是求最大值.(4)指定目标变量.
| ! P7 J; _% v; I* ]" Z | GAMS输出报告(部分摘录) |
完整的GAMS输出报告比下面列出的部分摘录详细的多,包含了更多的帮助用于解释和诊断您的模型.甚至您能够修改输出格式来符合您的特定的需要.
方程式列表
0 D7 \2 E' D' j" z% }' t
方程式列表显示从在GAMS输入中指定的分区(block)生成的单独的约束.在GAMS中使用者可以以一种非常紧凑的形式写下被索引的方程式分区(block),这将产生大量的单个方程式.在我们的示例中,我们指定了3个方程式分区,生成了6个单独的方程式.
' v6 g5 r8 C6 {- [* |: O列列表
' J4 d4 `$ E) g0 p2 x
列列表提供信息到生成的单独的变量上.变量X(I,J)扩展出6个单独的变量.当许多变量从一个分区中被生成,默认的列表只显示最初的3个(用户可以修改).
| 8 Q4 D% `/ u: H$ j" [' `0 ^7 E: a# [, P | 求解信息 |

求解声明将生成模型(单个方程式和对应到特定模型的变量的产物).首先一些关于生成的模型的统计表将会被显示:方程式数,变量和非零元素.
在求解汇总信息部分,我们看到BDMLP被调用来求解这个模型.BDMLP经过4次反复,耗时0.18秒找到了这个问题的最优解.求解信息下列的消息来自求解器.
解(Solution)
$ z! W9 w0 U! r/ z' P% o4 S1 ?
解被显示在这里.边际值(marginals)对应方程式的重复和变量减少的花费.
" }" w3 Y( j7 f( l Y, N写工具不需要学习一门其它的语言.在GAMS所有的数据处理,模型定义和报告编写都是在一个单独的环境中完成的.
| - { F* X& S6 Y( j- u" M | 参考 |
Dantzig G. B., Linear Programming and Extensions, Princeton University Press,Princeton, New Jersey, 1963, Chapter 3-3.
143.39 KB, 下载次数: 57, 下载积分: 体力 -2 点
GAMS 示例 (PDF格式)下载
| 欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) | Powered by Discuz! X2.5 |