1、第三届浙江工业大学数学建模协会竞赛所选赛题: A B 我们承诺: 我们仔细阅读了浙江工业大学数学建模协会竞赛的竞赛规则。我们完全明白,在竞赛开始后参赛队员不能以任何方式(包括电话、电子邮件、网上咨询等)与队外的任何人研究、讨论与赛题有关的问题。 我们知道,抄袭别人的成果是违反竞赛规则的, 如果引用别人的成果或其他公开的资料(包括网上查到的资料),必须按照规定的参考文献的表述方式在正文引用处和参考文献中明确列出。 我们郑重承诺,严格遵守竞赛规则,以保证竞赛的公正、公平性。如有违反竞赛规则的行为,我们将受到严肃处理。物流优化设计问题摘要现代物流是以满足消费者的需要为目标,把制造、运输、销售等市场情
2、况统一起来思考的一种战略措施。它是集现代运输、信息网络、仓储管理、营销策划等诸多业务、技术门类于一体的多学科、多领域的综合管理科学 1。本文就 B 题所给出的物流配送系统运输路径和容量限制及扩充问题进行展开讨论,建立数学模型,得到运输成本1最低的最优运输策略。通过分析可知,该问题实际上是一个最小费用最大流问题。针对该问题,我们建立了两个模型进行解答。首先,考虑包含供应商、经销商、配送中心的物流配送系统,产量与销量绝对确定,采用线性规划的方法建立数学模型一,构造包含运输费用及扩充费用的方程式,考虑扩充时间限制以及容量限制等,针对方程中的变量进行限制,当总费用取得最小值是就是该配送系统的最优解,最
3、后利用 lingo 软件进行编程和求解,解得最低成本为 606.20。但是,如果使总运输费用最低的代价是其中一个经销商承担大部分的运输费,则该经销商的满意度会大大下降。再者,整个配送系统中的扩容时间直接作用于物流中心的收益。因此,在求解最优运输策略时,还要满足所有经销商满意度最高以及扩容时间最小。由于以上三者的相互制约,我们所能达到的是让三者都逼近其最小值。针对该目标,对模型一进行优化,构造包含运输费用、扩充费用、经销商满意度及扩容时间的优化模型,并用 lingo 进行求解。最终解得的策略中,两个经销商所承担的费用分别为 288.87 及 335.23,扩容时间为 34.6,而总成本为 624
4、.10。虽然其总成本要比基本模型略微大些,但其所花的时间仅仅是模型一所需扩容时间 168 的 20.6%,也使两经销商所承担的费用均最接近其最小值。关键字:物流配送系统 线性规划 最优运输策略 最小运输成本 满意度问题重述物流作为“第三利润源泉”在国民经济中的地位和作用越来越重要,它对于发展经济、加强军事力量、改善人们物质和文化生活以及扩大国际技术、经济文化的交流等都具有重要意义。在一个物流配送系统中有两个产品供应商 和 供应产品,其供应量(产量)分别1A2为 84 和 116;同时有两个经销商 和 ,其需求量 (销量)分别为 96 和 104。该物流1B22配送网络模型中供应商和经销商之间设
5、有两个物流配送中 和 ,并且 和 的容量均1O2为 40,其扩张的费用均为 0.35,配送中心 容量进行扩充的时间限制为 60,扩充一1单位容量所需的时间为 2,配送中心 容量进行扩充的时间限制为 45,扩充一单位容2O量所需的时间为 3。当物资运输的实际情况如上面所描述,请建模模型使得建立的运输路径和配送中心带容量限制及容量可扩充的物流配送网络模型就可以得到运输成本最低的最优运输策略。问题分析物流配送中心是社会物流网络中处于主要位置的结点,但不是所有物流结点都能称为物流中心。物流配送中心必须是具有较大规模的物资集散或转运地点。属于物资集散类型的如大型物资仓库,它主要在物流系统中起调节和缓冲作
6、用,解决供需节奏或批量不平衡的矛盾。如商业连锁系统的配送中心,主要是为了降低物流系统的成本,提高服务水平,提高物资输送末端系统效率等。 2。对配送中心的解释从物资运输实际情况表可以看出,通过配送中心的中转,物资从供应商到经销商所需运输费用明显降低。但是,配送中心的存在容量限制,可能无法满足经销商对供应商的产品需求。要想让配送中心能够更大的运输能力,就必须对其容量进行扩充,于此同时每个配送中心也有自身的单位扩充时间、费用、总时间限制等限制因素。而对于直接从供应商运输到经销商的产品,也必须考虑其较为昂贵的费用和本身的容量限制。因此,整个问题可以抽象成一个优化问题,要决策的是整个物资运输配送系统的最
7、优策略,要达到的目的即是运输成本最少。建立许多实际的优化问题的数学模型都是线性规划,本题也是如此。在本题中,每个供应商的产量和每个经销商的销量是唯一确定的,而最终的配送方法虽是非明确的,但受到容量限制和容量扩充时间限制着两个约束条件的限制。这就是说,在产量、销量、容量的约束下,最优策略应是唯一的。1AB11A121AB2运输费用 3.7 5 1.5 1.3 3.1 3.5容量限制 40 30 30 30 40 30容量扩充时间限制60 40 40 40 60 40单位扩充时间 3 2 2 2 3 2单位扩充费用 0.4 0.3 0.3 0.3 0.4 0.321AO1B12O1B2O运输费用
8、1 1 1.5 1.7 1.9 1.6容量限制 30 30 40 30 40 30容量扩充时间限制40 40 60 40 60 40单位扩充时间 2 2 3 2 3 2单位扩充费用 0.3 0.3 0.4 0.3 0.4 0.33模型假设 经销商对产品供应商没有特定的要求。 物流配送中心无中转缺失。 不考虑运输时间的影响,只考虑扩容时间。 所有运输费用由经销商承担。 所有产品单位均为如重量等之类的连续单位。符号说明1ijaijAO的 运 输 量2ijijB的 运 输 量3ijcij的 运 输 量iAi供 应 商 的 供 应 量iBi经 销 商 的 需 求 量1ijVijO的 容 量 限 制2i
9、jij的 容 量 限 制3ijijAB的 容 量 限 制1ijtij的 单 位 扩 充 时 间2ijijO的 单 位 扩 充 时 间3ijtijAB的 单 位 扩 充 时 间1ijTij的 容 量 扩 充 时 间 限 制2ijij的 容 量 扩 充 时 间 限 制3ijijAB的 容 量 扩 充 时 间 限 制1ijSijO的 单 位 扩 充 费 用2ijij的 单 位 扩 充 费 用3ijijAB的 单 位 扩 充 费 用4S总 总 扩 充 费1ijPijAO的 运 输 费2ijijB的 运 输 费3ijij的 运 输 费P总 总 运 输 费iWiB经 销 商 所 承 担 的 单 位 货 物
10、 费 用1,2,j模型建立和求解物流配送系统可以用如下图表示:模型一:只考虑运输成本最低的基本模型该问题实际上是个最小费用最大流问题。是经济学和管理学中的一类典型问题。在一个网络中每段路径都有“容量”和“费用”两个限制的条件下,此类问题的研究试图寻找出:流量从 A 到 B,如何选择路径、分配经过路径的流量,可以达到所用的费用最小的要求 3。整个配送系统可以抽象成一个网络,在这个网络中每段路径都有“容量”和“费用”两个限制。配送系统的总体运输成本由运输费用和扩充费用组成。即: =+WSP总 总 总运输费用是每条路线的运输费用的叠加,因此,总体运输费用表达式为: ijkkjap总供 应 商 1配送
11、中心 1 经销 商 1供 应 商 2 经销 商 2配送中心 25而扩充费则是单位扩充费用和扩充量的乘积。对其中一条线路,如果运输量小于该线路的容量限制,则不需要进行扩充。因此,总体扩充费用的表达式为: =(,)ijkijkkjSSfaV总其中 0.(,).xyfxy,xRy我们最终要达到的目的是使总运输费用达到最小值。即:(1)minW总由于每条路径扩充时间都有一定的限制,表达式必须满足约束条件:, (2)0ijkijkijijTaVt1,2,j、再者,由于每个供应商的产量与每个经销商的需求量已知,因此, 以及, (3)13ijijiaA1,223ijijjaB1,两个等式必须成立。在一个物流
12、配送系统中,配送中心只是一个中转结点,所有从经销商运输到配送中心的货物全都需要运输给供应商。即:, (4)12ijjiia1,对(1),(2)、(3)、(4)进行综合,得以下模型:模型一的求解对模型一编写 lingo 程序(见程序 1)可以得到如表一结果:13212min.01,2,3ijkijkijijijiijijjijjiWstTaVtABak总6表一线路 1AO121AO21OB12运输量 40.00 44.00 50.00 30.00 40.00 50.00线路 21B21B121A2运输量 24.00 50.00 0.00 0.00 32.00 4.00总费用 606.20模型二:
13、在模型一基础上考虑经销商满意度以及扩容时间的优化模型模型一只考虑了总运输费用最低,并没有考虑经销商的满意度。假定所有运输费用都有经销商来承担,则经销商的满意度便与其承担的运输费成反比,即所付运费越少,满意度越高。如果总体运输费用达到最低,而其中一个经销商承担的单位运输成本过大,即其满意度过低,则该经销商可能无法接受模型一所得的最优策略。同时,模型一没有考虑扩充所花费的时间。每条线路的扩充都需花费一定的时间,这直接作用于物流中心的收益问题。并且当一个经销商急需货物时,他可能更在意的是所需时间而非费用。因此,要得到运输最优策略,还需综合考虑各个经销商承担的费用以及扩充花费的时间。计算时,从供应商运
14、输到配送中心所产生的费用按供应商从配送中心所得到的货物的比例来分配。即: 1221,i iij ijj jaa因此,经销商 所承担的总费用表达式为:1B1112121313123(,)(,)(,)ijijiiiijijiijWSfaVSfaVSfaVpp而经销商 所承担的总费用为:2B11222323223(,)(,)(,)ijijiiiijijiijSfaVSfaVSfaVpp在整个配送系统中,扩充容量所需时间的表达式为: (,)ijkijkijkjTtfaV7由于每条路径扩充时间限制不变,每个供应商的产量与经销商的需求量确定并且不变,且同样应满足所有从经销商运输到配送中心的货物全都需要运输
15、给供应商。由以上三个约束条件,我们可以得到以两下个线性规划方程组:1规划 的最小值,记规划结果为 : 2规划 的最大值,记规划结果为 :1Wmin1W1 max1W11321min.0,21,ijkijkijijijiijijjijjistTaVtABa1321ax.0,21,ijkijkijijijiijijjijjistTVtaAB对以上两个线性规划编写 lingo 程序(见程序 2),便可得到规划结果 、min1W。max1W在同样的约束条件下,我们可以的到 、 以及 、 值(见程序min2Wax2minTax3、4)。但是,我们所需要达到的目标是 、 以及 达到最小值。当然由于三者的相
16、互1制约性,要达到这个目标是不现实的,我们所能做的,是在总运费最小的情况下尽可能的让 、 和 T逼近其最小值。12为此,构造一个三维空间,分别以:、 、max1in(,0)iW max2in1(,0)jW maxin1(,)kT作为单位向量。则理想点但所在的 :位 矢 为 in1in2in+bestAjTk而目标点为: j我们要使目标点尽量接近理想点,即:813212min.0.1,2,3bestijkijkijijijiijijjijjiAstTaVtAaB当 与 距离最小,并满足约束条件时,我们便可以取得此模型的解。bestA模型二的求解由程序 2、3、4 可得两个经销商所承担的费用的最小
17、值及最大值及最大扩容时间。如下表:项目 min1Wmax1min2Wmax2minTmax值 275.84 342.46 303.69 449.62 0 248.00将 、 max1、 、 max2和 的值以及带入模型二,并编写 lingo 程序in1in2axT(见程序 5),可以得到结果如表二:表二项目 bestA1W2TW总值 0.32 288.87 335.23 34.60 624.10且运输路线如表三所示:表三线路 1AO121AO21OB12运输量 40.00 30.00 30.00 30.00 30.00 30.00线路 21B21B121A2运输量 22.70 37.30 7.
18、30 6.70 26.00 30.00结果的分析与检验模型一从模型一所得到的结果可以看出,除了所有与配送中心相联系的线路中,除了因其运费较为昂贵没有达到其容量限制外,所有线路都达到了其容量的最大值。21OB9其中,除了 2AO、 1B都进行了扩充。而所有直接从供应商运输到经销商的线路都没有进行扩充。这和经配送中心中转之后运费大大降低的实际情况相符合。另外,由于线路 所需的单位运输费用过高,所以应尽量不要选择该线路进行运输,这1和结果中 线路上运输量为零相符合, 1AB线路上运输量为零的原因也是如2此。因此,该模型所得的结果与题目所需结果符合很好。模型二从结果可以看出, 为 624.10,与基础
19、模型相比略微大些,但是 bestA已取得W总其最小值,即两个经销商所承受的费用及整个配送系统的扩充时间均最接近其最小值。模型二的结果显示,只有 1AO、 1进行了扩容,这大大降低了配送系统的扩容时间。其次,只有 、 没有达到其容量的最大值,这不仅与其运2B输成本较高相符,也符合了配送中心能够减少运输成本的特征。比较所有线路的运输费用和扩充费用的实际情况,模型二的结果与实际相符合。进而证明了模型二的正确性。优缺点与改进方向模型一中的线性规划方程简洁明了,便于计算。只要知道整个配送系统中,所有供应商需要的产量、经销商的需求量以及每个线路的费用及限制,就可以用此模型计算出成本最低的最优路线。但是,其
20、缺点也正是如此。如果只考虑总体的运输成本最低,就无法针对每个经销商的满意度以及扩充时间来制定运输路线,因而可能不会被某个经销商所认可。模型二针对模型一的缺点进行优化,并对此建立数学模型。最终,实现了两个经销商所承受的费用及整个配送系统的扩充时间均最接近其最小值的结果。通过计算可知,模型一所需扩容时间为 168,而模型二仅需 34.60,远远小于模型一。因此,虽然模型二所需成本要比模型一多了 17.9,但其节省的时间可为物流中心增添更多其他收入。同时,该模型可移植性强。如果在物流配送系统中增加几个物流结点,只要知道新路线的费用和限制条件,以及增加的供应商或经销商的产量或需求量,通过在模型中增添变
21、量并修改限制条件就可以求得最优解。但是,该模型的试用条件在于所有费用均由经销商承担。如果实际运输费用并非如此,而由供应商和经销商共同承担,则该模型无法适用。这也是该模型的缺点所在。实际运用过程中,还需考虑如油价、人员管理费用等会变化的费用,以及实际交通情况。若能将约束条件进行扩充,则能获得更加贴近现实的最佳方案,这也是两个模型的改进方向。参考文献1 陈光, 信息网络时代的现代物流我国物流业的现状与对策:2010。2中国大学生网,http:/ 年 6 月 2 日。103维基百科,最小费用最大流问题,http:/zh.wikipedia.org/wiki/%E6%9C%80%E5%B0%8F%E8
22、%B4%B9%E7%94%A8%E6%9C%80%E5%A4%A7%E6%B5%81:2008附录注:一下所有程序均由 lingo11.0 实现,并选用 Global Optimum 进行求解。程序 1:计算模型一的解model:sets:path/12/:aa,bb;way/13/:;trans(path,path):;line(way,path,path):a,v,t,s,p;endsetsdata:aa=84,116; !aa 表示A的供应量;bb=96,104; !bb 表示B的需求量;v=30,30,30,30, !v 表示容量限制;40,30,40,30,40,30,40,30;t
23、=50,50,50,50, !t 表示容量扩充后的最大容量;60,50,60,50,60,50,60,50;s=0.3,0.3,0.3,0.3, !s表示扩充费用;0.4,0.3,0.4,0.3,0.4,0.3,0.4,0.3;p=1.5,1.3,1,1, !p表示表示单位运费;1.5,1.7,1.9,1.6,3.7,5,3.1,3.5;enddatamin=sum(line:a*p+s*(a#GT#v)*(a-v); !目标函数;!以下四条对应约束条件;for(line:a=t); for(path(i):sum(path(j):a(1,i,j)+a(3,i,j)=aa(i); for(pa
24、th(j):sum(path(i):a(2,i,j)+a(3,i,j)=bb(j);for(path(i):sum(path(j):a(1,j,i)=sum(path(j):a(2,i,j);end程序 2:计算 的最小值(最大值仅需将 min 改成 max)1Wmodel:sets:path/12/:aa,bb;way/13/:;trans(path,path):;line(way,path,path):a,v,t,s,p;endsetsdata:11aa=84,116; !aa 表示A的供应量;bb=96,104; !bb 表示B的需求量;v=30,30,30,30, !v 表示容量限制;
25、40,30,40,30,40,30,40,30;t=50,50,50,50, !t 表示容量扩充后的最大容量;60,50,60,50,60,50,60,50;s=0.3,0.3,0.3,0.3, !s表示扩充费用;0.4,0.3,0.4,0.3,0.4,0.3,0.4,0.3;p=1.5,1.3,1,1, !p表示表示单位运费;1.5,1.7,1.9,1.6,3.7,5,3.1,3.5;enddatau=sum(path(i):a(2,i,1)/sum(trans(i,j):a(2,i,j); !在A到B的总费用中B1的分配比例;min=u*sum(trans(i,j):s(1,i,j)*(a
26、(1,i,j)#GT#v(1,i,j)*(a(1,i,j)-v(1,i,j)+sum(path(i):s(2,i,1)*(a(2,i,1)#GT#v(2,i,1)*(a(2,i,1)-v(2,i,1)+sum(path(i):s(3,i,1)*(a(3,i,1)#GT#v(3,i,1)*(a(3,i,1)-v(3,i,1)+u*sum(trans(i,j):a(1,i,j)*p(1,i,j)+sum(path(i):a(2,i,1)*p(2,i,1)+sum(path(i):a(3,i,1)*p(3,i,1); !目标函数;!以下四条对应约束条件;for(line:a=t); for(path
27、(i):sum(path(j):a(1,i,j)+a(3,i,j)=aa(i); for(path(j):sum(path(i):a(2,i,j)+a(3,i,j)=bb(j);for(path(i):sum(path(j):a(1,j,i)=sum(path(j):a(2,i,j); End程序 3:计算 的最小值(最大值仅需将 min 改成 max)2Wmodel:sets:path/12/:aa,bb;way/13/:;trans(path,path):;line(way,path,path):a,v,t,s,p;endsetsdata:aa=84,116; !aa 表示A的供应量;bb
28、=96,104; !bb 表示B的需求量;v=30,30,30,30, !v 表示容量限制;40,30,40,30,40,30,40,30;t=50,50,50,50, !t 表示容量扩充后的最大容量;60,50,60,50,60,50,60,50;s=0.3,0.3,0.3,0.3, !s表示扩充费用;0.4,0.3,0.4,0.3,0.4,0.3,0.4,0.3;12p=1.5,1.3,1,1, !p表示表示单位运费;1.5,1.7,1.9,1.6,3.7,5,3.1,3.5;enddatau=sum(path(i):a(2,i,2)/sum(trans(i,j):a(2,i,j); !在
29、A到B的总费用中B2的分配比例;min=u*sum(trans(i,j):s(1,i,j)*(a(1,i,j)#GT#v(1,i,j)*(a(1,i,j)-v(1,i,j)+sum(path(i):s(2,i,2)*(a(2,i,2)#GT#v(2,i,2)*(a(2,i,2)-v(2,i,2)+sum(path(i):s(3,i,2)*(a(3,i,2)#GT#v(3,i,2)*(a(3,i,2)-v(3,i,2)+u*sum(trans(i,j):a(1,i,j)*p(1,i,j)+sum(path(i):a(2,i,2)*p(2,i,2)+sum(path(i):a(3,i,2)*p(3
30、,i,2); !目标函数;!以下四条对应约束条件;for(line:a=t); for(path(i):sum(path(j):a(1,i,j)+a(3,i,j)=aa(i); for(path(j):sum(path(i):a(2,i,j)+a(3,i,j)=bb(j);for(path(i):sum(path(j):a(1,j,i)=sum(path(j):a(2,i,j); end程序 4:计算 的最小值(最大值仅需将 min 改成 max)Tmodel:sets:path/12/:aa,bb; way/13/:;trans(path,path):;line(way,path,path)
31、:a,v,t,s,p,c; endsetsdata:aa=84,116; !aa 表示A的供应量;bb=96,104; !bb 表示B的需求量;v=30,30,30,30, !v 表示容量限制;40,30,40,30,40,30,40,30;t=50,50,50,50, !t 表示容量扩充后的最大容量;60,50,60,50,60,50,60,50;s=0.3,0.3,0.3,0.3, !s表示扩充费用;0.4,0.3,0.4,0.3,0.4,0.3,0.4,0.3;p=1.5,1.3,1,1, !p表示表示单位运费;1.5,1.7,1.9,1.6,3.7,5,3.1,3.5;c=2,2,2,
32、2, !c表示单位扩充时间;3,2,3,2,3,2,3,2;enddatamin=sum(line:(a#GT#v)*(a-v)*c); !目标函数!以下四条对应约束条件;for(line:a=t); for(path(i):sum(path(j):a(1,i,j)+a(3,i,j)=aa(i); 13for(path(j):sum(path(i):a(2,i,j)+a(3,i,j)=bb(j);for(path(i):sum(path(j):a(1,j,i)=sum(path(j):a(2,i,j); end程序5:计算模型二的解model:sets:path/12/:aa,bb;way/1
33、3/:;trans(path,path):;line(way,path,path):a,v,t,s,p,c;endsetsdata:aa=84,116; !aa 表示A的供应量;bb=96,104; !bb 表示B的需求量;v=30,30,30,30, !v 表示容量限制;40,30,40,30,40,30,40,30;t=50,50,50,50, !t 表示容量扩充后的最大容量;60,50,60,50,60,50,60,50;s=0.3,0.3,0.3,0.3, !s表示扩充费用;0.4,0.3,0.4,0.3,0.4,0.3,0.4,0.3;p=1.5,1.3,1,1, !p表示表示单位运
34、费;1.5,1.7,1.9,1.6,3.7,5,3.1,3.5;c=2,2,2,2, !c表示单位扩充时间;3,2,3,2,3,2,3,2;enddatau1=sum(path(i):a(2,i,1)/sum(trans(i,j):a(2,i,j); !在A到B的总费用中B1的分配比例;w1=u1*sum(trans(i,j):s(1,i,j)*(a(1,i,j)#GT#v(1,i,j)*(a(1,i,j)-v(1,i,j)+sum(path(i):s(2,i,1)*(a(2,i,1)#GT#v(2,i,1)*(a(2,i,1)-v(2,i,1)+sum(path(i):s(3,i,1)*(a
35、(3,i,1)#GT#v(3,i,1)*(a(3,i,1)-v(3,i,1)+u1*sum(trans(i,j):a(1,i,j)*p(1,i,j)+sum(path(i):a(2,i,1)*p(2,i,1)+sum(path(i):a(3,i,1)*p(3,i,1); !B1需支付的费用; u2=sum(path(i):a(2,i,2)/sum(trans(i,j):a(2,i,j);!在A到B的总费用中B2的分配比例;w2=u2*sum(trans(i,j):s(1,i,j)*(a(1,i,j)#GT#v(1,i,j)*(a(1,i,j)-v(1,i,j)+sum(path(i):s(2,
36、i,2)*(a(2,i,2)#GT#v(2,i,2)*(a(2,i,2)-v(2,i,2)+sum(path(i):s(3,i,2)*(a(3,i,2)#GT#v(3,i,2)*(a(3,i,2)-v(3,i,2)+u2*sum(trans(i,j):a(1,i,j)*p(1,i,j)+sum(path(i):a(2,i,2)*p(2,i,2)+sum(path(i):a(3,i,2)*p(3,i,2); !B2需支付的费用; time=sum(line:(a#GT#v)*(a-v)*c); !扩充过程花费的总时间;min=(w1-275.84)/(342.4649-275.84)2+(w2-303.6923)/(449.62-303.6923)2+(time/248)2; !目标函数 (其中的数据是根据前面的程序得出的)!以下四条对应约束条件;for(line:a=t); 14for(path(i):sum(path(j):a(1,i,j)+a(3,i,j)=aa(i); for(path(j):sum(path(i):a(2,i,j)+a(3,i,j)=bb(j);for(path(i):sum(path(j):a(1,j,i)=sum(path(j):a(2,i,j); end