赞
踩
前面,我们已经对Lingo有了一定的了解,但是要想真正的熟悉Lingo在解决优化问题中的强大之处,还需要不断加强相关训练,本文主要是使用Lingo来解决优化问题,该文的主要目的有以下三点:
优化模型主要有三个基本要素:决策变量、目标函数、约束条件。其一般形式如下:
Question:有三个生产地和四个销售地,其生产量、销售量及单位运费如表所示,求总运费最少的运输方案以及总运费。

由题意,我们不难看出优化模型的决策变量是每个生产地向各个销售地运输的货量,即
有以上问题分析,为求出总运费最小的方案,我们可以构建该问题的优化模型如下:
求解的Lingo代码如下:
sets:
supply/1..3/: s; !定义运输集,集中的每个元素都有对应的属性,即运输量s;
demand/1..4/: d; !定义需求集,集中的每个元素都有对应的属性,即需求量d;
link(supply, demand): p, x; !定义link衍生集,每个元素中都有两个属性,运费p,运输量x;
endsets
data:
s = 30 25 21; !定义数据集s,表示生产量;
d = 15 17 22 12; !定义数据集d,表示销售量;
p = 6 2 6 7 !定义数据集p,表示生产地向销售地所对应的运费;
4 9 5 3
8 8 1 5;
enddata
min = @sum(link(i,j): p(i,j)*x(i,j)); !目标函数;
@for(supply(i): @sum(demand(j): x(i,j)) <= s(i)); !生产地限制约束条件;
@for(demand(j): @sum(supply(i): x(i,j)) = d(j)); !销售地限制约束条件;
运行如上所示Lingo程序,我们可以得到如下结果:
通过上图展示,我们可以得到运输的最佳方案以及最小运费161个单位。运输方案图示如下:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。