1、蔬菜分配数学建模蔬菜配送数学建模2016年数学建模论文第 二 套论文题目: 蔬菜供应方案设计 组 别: 第38组 姓 名: 耿晨 闫思娜 王强 提交日期: 2016年7月13日 题目:蔬菜供应方案设计摘 要本次建模探究得是江平市蔬菜市场为满足不同条件的最优调配方案问题,模型求解时使用了Froyd算法,并用线性规划建立了一系列数学规划模型,采用MATLAB和LINGO软件编程计算出模型结果。关于问题一:为了实现蔬菜调运及预期的短缺损失为最小,我们建立了线性规划模型,用Froyd算法在MATLAB中编程,求出收购点至个菜市场的最短距离,并考虑每日各菜市场的需求量条件,用LINGO编程求得蔬菜调运及
2、预期的短缺损失最小值为日均10280元。关于问题二:在模型一的基础增加各菜市场短缺量一律不超过需求量的20%的约束条件,用LINGO编程求得最少日均费用最少为10628元,并设计最优供应方案见正文。关于问题三:在模型一的基础上,条件改为供货充足、需求调运与短缺损失的费用最小值。建立模型三时在模型一的基础上改变条件,并用LINGO编程求得日均最少费用为11200元,增产的蔬菜每天应分给C收购点7000Kg,分析过程见正文。关键词:蔬菜市场调配方案,Floyd算法,线性规划,MATLAB编程,LINGO一、问题重述江平市是一个人口不到20万人的小城市。根据该市的蔬菜种植情况,分别在菜市场(A),城
3、乡路口(B)和南街口(C)设三个收购点,再由各收购点分送到全市的8个菜市场,该市道路情况,各路段距离(单位:100m)及各收购点,菜市场到的具体位置见图1。图1:蔬菜供应网点图按常年情况,A、B、C三个收购点每天收购量分别为250,200和180(单位:100 kg),各菜市场的每天需求量及发生供应短缺时带来的损失(元/100kg)见表1。设从收购点至各菜市场蔬菜调运费为2元/(100kg.100m).表1:各蔬菜市场需求量表菜市场每天需求(100 kg)短缺损失(元/100kg)80107089058010120107081005908通过这次建模我们解决以下问题:1.为该市设计一个从收购点
4、至个菜市场的定点供应方案,使用于蔬菜调运及预期的短缺损失为最小; 2.若规定各菜市场短缺量一律不超过需求量的20%,重新设计定点供应方案;3.为满足城市居民的蔬菜供应,该市的领导规划增加蔬菜种植面积,试问增产的蔬菜每天应分别向A、B、C三个采购点供应多少最经济合理。二、问题分析2.1 问题一的分析要使用于蔬菜调运及预期的短缺损失为最小,即总费用R最小,也就是指调运费用P与缺货损失Q之和最小。首先考虑调运费用P,调运费用与距离与送货量成正比,因此考虑距离问题,我们须先求出A、B、C三个采购点至各个菜市场的最短距离。采用Froyd算法,结合MATLAB编程实现最短距离计算,确定出最短路线。其次考虑
5、缺货造成的损失Q,以题中每天需求量为约束条件,将损失最低作为目标建立线性规划模型,用LINGO编程求解缺货损失最小值。2.2 问题二的分析若按规定各菜市场短缺量一律不超过需求量的20%,也就是在模型一的基础上增加一个约束条件,即每个菜市场的供应量必须不低于需求量的80%。则可得到满足条件要求的模型二。2.3 问题三的分析本题的目标有二:首先要满足每个菜市场的供货量要充足的条件;其次要使得总费用最低。所以我们在模型一的基础上增加了上述两个限制条件,即得到模型三。使得在供货量充足的情况下日均费用最小化。三、问题假设1、各个路口以及蔬菜销售点都可以作为中转点。2、假设蔬菜种植基地直达某个销售地点,即
6、销售点之间没有卸货的情况。3、假设运输的蔬菜路途中没有损耗,也无意外发生。4、假设只考虑运输费用和短缺费用,不考虑装卸等其它费用。5、假设各蔬菜种植基地供应蔬菜同质且单位运价相同。6、假设新增产的蔬菜能够满足缺货量。7、日需求量与缺货损失费用不变。四、变量说明 从A到i(各个菜市场)的最短距离 从B到i(各个菜市场)的最短距离 从C到i(各个菜市场)的最短距离 从A到i(各个菜市场)的运货量 从B到i(各个菜市场)的运货量 从C到i(各个菜市场)的运货量 总调运费 短缺损失 总费用五、模型建立5.1 问题一模型的建立按照问题的分析,我们知道调运总费用P与调运距离和调运量乘积有关,也就是说总调运
7、费用等于每阶段调运距离和调运量的累计。首先就要求解各采购点到菜市场的最短距离。在图论里面关于最短路径问题比较常用的是Dijkstra算法,Dijkstra算法提供了从网络图中某一点到其他点的最短距离。主要特点是以起始点为中心向外层扩展,直到扩展到终点为止。但由于它遍历计算的节点很多,所以效率较低,实际问题中往往要求网络中任意两点之间的最短路距离。如果仍然采用Dijkstra算法对各点分别计算,就显得很麻烦。所以就可以使用网络各点之间的矩阵计算法,即Floyd算法。Floyd算法的基本思想是:从任意节点i到任意节点j的最短路径不外乎两种可能,一种是直接从i到j,另一种是从i经过若干个节点k到j。
8、i到j的最短距离不外乎存在经过i与j之间的k和不经过k两种可能,所以可以令k=1,2,3,n(n是菜市场的数目),再检查d(i,j)与d(i,k)+d(k,j)的值,在此d(i,k)与d(k,j)分别是目前为止所知道的i到k与k到j的最短距离。因此d(i,k)+d(k,j)就是i到j经过k的最短距离。所以,若有d(i,j)d(i,k)+d(k,j),就表示从i出发经过k再到j的距离要比原来的i到j距离短,自然把i到j的d(i,j)重写为d(i,k)+d(k,j),每当一个k查完了,d(i,j)就是目前的i到j的最短距离。重复这一过程,最后当查完所有的k时,d(i,j)里面存放的就是i到j之间的
9、最短距离了。5.2 问题二模型的建立各菜市场短缺量一律不超过需求量的20%,为满足这一条件,现对方案一进行调整。只需在方案一中加一限制条件:同理可用LINGO编程求出调运方案。5.3 问题三模型的建立要足城市居民的蔬菜供应,增加蔬菜种植面积,则需要保证所有的菜市场都满足日需求量,且日均化费用要最小。在问题一得基础上作出以下调整:同理可用LINGO编程求出调运方案。六、模型求解6.1 问题一模型的求解由图1和表格1的信息,建立一个线性规划模型并经过Floyd算法,使得蔬菜调运及预期的短缺损失为最小。调运总费用P为: (1)若使调运总费用最少,则应保证A、B、C三个收购点到8个菜市场的路程最短,最
10、短路线的求解过程如图2:图2:最短路程求解过程图分析上图可知,该路线为无向网络,就该图而言,网络弧集为:E=(v1,v2),(v1,v4),(v1,v5),(v2,v1),(v2,v3),(v2,v5),(v2,v6),(v3,v2),.(v3,v6),(v3,v8),(v3,v9),(v4,v1),(v4,v5).(v4,v7),(v4,v10),(v5,v1),(v5,v2),(v5,v4),(v5,v6),(v5,v7),(v5,v8),(v6,v2),(v6,v3),(v6,v5),(v6,v8),(v7,v4),(v7,v5),(v7,v8),(v7,v11),(v8,v3),(v8
11、,v5),(v8,v6),(v8,v7),(v8,v9),(v8,v11),(v9,v3),(v9,v8),(v9,v11),(v9,v13),(v9,v15),(v10,v4),(v10,v11),(v10,v12),(v10,v14),(v11,v7),(v11,v8),(v11,v9)(v11,v10),(v11,v12),(v12,v10),(v12,v11),(v12,v13),(v12,v14),(v13,v9),(v13,v12),(v13,v14),(v14,v10),(v14,v12),(v14,v13),(v15,v9)下面来确定网络权矩阵:W= (2)其中:当(,)属于E
12、时, =,为弧(,)的权;当(,)不属于E时, =inf。(inf为无穷大,n为网络结点个数)=0,i=1,2,3n按上述规定,该网络的权矩阵为:因为上述网络有15个结点,故网络的权矩阵均为15阶矩阵。用Floyd算法求解图2中任意两个顶点的最短路径及其长度,名为Floyd.m的程序文件见附录程序1。最终运行结果为:D =0 7 14 5 4 10 8 12 18 12 15 20 24 22 237 0 7 12 8 3 12 8 14 19 13 19 20 24 1914 7 0 16 13 6 11 7 11 18 12 18 17 23 165 12 16 0 6 13 5 9 15
13、 7 12 15 21 17 204 8 13 6 0 7 4 8 14 13 11 17 20 22 1910 3 6 13 7 0 9 5 11 16 10 16 17 21 168 12 11 5 4 9 0 4 10 12 7 13 16 18 1512 8 7 9 8 5 4 0 6 11 5 11 12 16 1118 14 11 15 14 11 10 6 0 9 3 9 6 14 512 19 18 7 13 16 12 11 9 0 6 8 15 10 1415 13 12 12 11 10 7 5 3 6 0 6 9 11 820 19 18 15 17 16 13 11
14、9 8 6 0 10 5 1424 20 17 21 20 17 16 12 6 15 9 10 0 11 1122 24 23 17 22 21 18 16 14 10 11 5 11 0 1923 19 16 20 19 16 15 11 5 14 8 14 11 19 0path =1 2 2 4 5 2 5 5 5 4 5 4 5 4 51 2 3 1 5 6 5 6 6 1 6 6 6 6 62 2 3 8 6 6 8 8 9 8 8 8 9 8 91 1 7 4 5 5 7 7 7 10 7 10 7 10 71 2 6 4 5 6 7 8 8 4 7 7 8 7 82 2 3 5
15、 5 6 8 8 8 8 8 8 8 8 85 5 8 4 5 8 7 8 8 4 11 11 8 11 85 6 3 7 5 6 7 8 9 11 11 11 9 11 98 8 3 8 8 8 8 8 9 11 11 11 13 11 154 4 11 4 4 11 4 11 11 10 11 12 11 14 11 7 8 8 7 7 8 7 8 9 10 11 12 9 12 910 11 11 10 11 11 11 11 11 10 11 12 13 14 119 9 9 9 9 9 9 9 9 9 9 12 13 14 910 12 12 10 12 12 12 12 12 10
16、 12 12 13 14 129 9 9 9 9 9 9 9 9 9 9 9 9 9 15根据上述矩阵,分别找出A、B、C到、的最短距离,见表2:表2:收购点到菜市场的最短距离最短距离(单位:100千米)A488191162220B14771612162317C20191114615510调运量的限制:短缺损失费为:总费用为:由以上约束条件,用LINGO软件进行线性规划求解(源程序及完整运行结果见附录程序2),部分运行结果如下:Objective value: 10280.00Total solver iterations: 14Variable Value Reduced CostP 964
17、0.000 0.000000Q 640.0000 0.000000SA1 80.00000 0.000000SA2 0.000000 2.000000SA3 0.000000 2.000000SA4 0.000000 6.000000SA5 100.0000 0.000000SA6 70.00000 0.000000SA7 0.000000 24.00000SA8 0.000000 10.00000SB1 0.000000 20.00000SB2 70.00000 0.000000SB3 90.00000 0.000000SB4 40.00000 0.000000SB5 0.000000 2.
18、000000SB6 0.000000 20.00000SB7 0.000000 26.00000SB8 0.000000 4.000000SC1 0.000000 42.00000SC2 0.000000 34.00000SC3 0.000000 18.00000SC4 0.000000 6.000000SC5 20.00000 0.000000SC6 0.000000 28.00000SC7 100.0000 0.000000SC8 60.00000 0.000000从上述运行结果中可以得出调运方案为:在此种方案下,蔬菜调运及预期的短缺损失最小,最小金额为10280元。6.2 问题二模型的求
19、解将调整后的方案用LINGO编程(源程序及完整运行结果见附录程序3),部分运行结果如下:Objective value: 10628.00Total solver iterations: 20Variable Value Reduced CostP 10064.00 0.000000Q 564.0000 0.000000SA1 80.00000 0.000000SA2 0.000000 0.000000SA3 24.00000 0.000000SA4 0.000000 4.000000SA5 76.00000 0.000000SA6 70.00000 0.000000SA7 0.000000
20、24.00000SA8 0.000000 10.00000SB1 0.000000 22.00000SB2 70.00000 0.000000SB3 66.00000 0.000000SB4 64.00000 0.000000SB5 0.000000 4.000000SB6 0.000000 22.00000SB7 0.000000 28.00000SB8 0.000000 6.000000SC1 0.000000 42.00000SC2 0.000000 32.00000SC3 0.000000 16.00000SC4 0.000000 4.000000SC5 28.00000 0.0000
21、00SC6 0.000000 28.00000SC7 80.00000 0.000000SC8 72.00000 0.000000从上述运行结果中可以得出调运方案为:6.3 问题三模型的求解将调整后的方案用LINGO编程(源程序及完整运行结果见附录程序4),部分运行结果如下:Objective value: 11200.00Total solver iterations: 16Variable Value Reduced CostP 11200.00 0.000000Q 0.000000 0.000000SA1 80.00000 0.000000SA2 40.00000 0.000000SA3
22、 0.000000 0.000000SA4 0.000000 4.000000SA5 60.00000 0.000000SA6 70.00000 0.000000SA7 0.000000 24.00000SA8 0.000000 10.00000SB1 0.000000 22.00000SB2 30.00000 0.000000SB3 90.00000 0.000000SB4 80.00000 0.000000SB5 0.000000 4.000000SB6 0.000000 22.00000SB7 0.000000 28.00000SB8 0.000000 6.000000SC1 0.000
23、000 42.00000SC2 0.000000 32.00000SC3 0.000000 16.00000SC4 0.000000 4.000000SC5 60.00000 0.000000SC6 0.000000 28.00000SC7 100.0000 0.000000SC8 90.00000 0.000000从上述运行结果中可以得出调运方案为:七、结果分析7.1模型的评价7.1.1模型的优点:模型简单易懂,主要用了Froyd算法与线性规划,使问题的求解变得十分方便,能适应更重新的要求。且计算结果能大致能反映蔬菜调运的最小损失要求,模型的建立成功实现了建模的目的。7.1.2模型的缺点:模
24、型的建立中,采用了若干假设条件,假设的条件使得特殊情况模型失效或者偏离实际情况,比如第三问只考虑了运输费用最小,却没有考虑到供过于求造成的货物积压问题等,考虑更多现实的因素,模型有待进一步改进和完善。7.2模型的改进:在第三问中由于模型只考虑了运输费用最小,却没有考虑到供过于求造成的货物积压问题。在计算时,应将货物堆积造成的损失计算进去,这样考虑结果将更加满足实际情况,使得模型更加完善。八、参考文献1 夏鸿鸣,艳华,王丙参. 数学建模. :西南交通大学,2014.2 志涌,祖樱. MATLAB教程M. :航空航天大学, 2011.3 周品,新芬. 数学建模. :国防工业, 2009.4 费培之
25、,程中媛. 数学建模实用教程. :大学, 1998.5 如栋,于延荣. 数学模型与数学建模. :国防工业, 2006.九、附录程序1functionD,path=floyd(a)n=size(a,1);D=afor i=1:n for j=1:n path(i,j)=j; endendpathfor k=1:n for i=1:n for j=1:n if D(i,k)+D(k,j)=0;8*(70-(SA2+SB2+SC2)=0;5*(90-(SA3+SB3+SC3)=0;10*(80-(SA4+SB4+SC4)=0;10*(120-(SA5+SB5+SC5)=0;8*(70-(SA6+SB6+SC6)=0;5*(100-(SA7+SB7+SC7)=
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1