蔬菜分配数学建模蔬菜配送数学建模.docx

上传人:b****5 文档编号:28430791 上传时间:2023-07-13 格式:DOCX 页数:51 大小:308.33KB
下载 相关 举报
蔬菜分配数学建模蔬菜配送数学建模.docx_第1页
第1页 / 共51页
蔬菜分配数学建模蔬菜配送数学建模.docx_第2页
第2页 / 共51页
蔬菜分配数学建模蔬菜配送数学建模.docx_第3页
第3页 / 共51页
蔬菜分配数学建模蔬菜配送数学建模.docx_第4页
第4页 / 共51页
蔬菜分配数学建模蔬菜配送数学建模.docx_第5页
第5页 / 共51页
点击查看更多>>
下载资源
资源描述

蔬菜分配数学建模蔬菜配送数学建模.docx

《蔬菜分配数学建模蔬菜配送数学建模.docx》由会员分享,可在线阅读,更多相关《蔬菜分配数学建模蔬菜配送数学建模.docx(51页珍藏版)》请在冰豆网上搜索。

蔬菜分配数学建模蔬菜配送数学建模.docx

蔬菜分配数学建模蔬菜配送数学建模

 

2016年数学建模论文

第二套

 

论文题目:

 蔬菜供应方案设计 

组 别:

第38组  

姓名:

耿晨闫思娜王强  

提交日期:

 2016年7月13日

题目:

蔬菜供应方案设计

 

摘要

本次建模探究得是江平市蔬菜市场为满足不同条件的最优调配方案问题,模型求解时使用了Froyd算法,并用线性规划建立了一系列数学规划模型,采用MATLAB和LINGO软件编程计算出模型结果.

关于问题一:

为了实现蔬菜调运及预期的短缺损失为最小,我们建立了线性规划模型,用Froyd算法在MATLAB中编程,求出收购点至个菜市场的最短距离,并考虑每日各菜市场的需求量条件,用LINGO编程求得蔬菜调运及预期的短缺损失最小值为日均10280元。

关于问题二:

在模型一的基础增加各菜市场短缺量一律不超过需求量的20%的约束条件,用LINGO编程求得最少日均费用最少为10628元,并设计最优供应方案见正文。

关于问题三:

在模型一的基础上,条件改为供货充足、需求调运与短缺损失的费用最小值。

建立模型三时在模型一的基础上改变条件,并用LINGO编程求得日均最少费用为11200元,增产的蔬菜每天应分给C收购点7000Kg,分析过程见正文。

关键词:

蔬菜市场调配方案,Floyd算法,线性规划,MATLAB编程,LINGO

 

一、问题重述

江平市是一个人口不到20万人的小城市.根据该市的蔬菜种植情况,分别在菜市场(A),城乡路口(B)和南街口(C)设三个收购点,再由各收购点分送到全市的8个菜市场,该市道路情况,各路段距离(单位:

100m)及各收购点,菜市场①到⑧的具体位置见图1.

图1:

蔬菜供应网点图

按常年情况,A、B、C三个收购点每天收购量分别为250,200和180(单位:

100kg),各菜市场的每天需求量及发生供应短缺时带来的损失(元/100kg)见表1。

设从收购点至各菜市场蔬菜调运费为2元/(100kg。

100m)。

表1:

各蔬菜市场需求量表

菜市场

每天需求(100 kg)

短缺损失(元/100kg)

80

10

70

8

90

80

10

120

10

70

100

5

90

8

通过这次建模我们解决以下问题:

1.为该市设计一个从收购点至个菜市场的定点供应方案,使用于蔬菜调运及预期的短缺损失为最小;

2。

若规定各菜市场短缺量一律不超过需求量的20%,重新设计定点供应方案;

3.为满足城市居民的蔬菜供应,该市的领导规划增加蔬菜种植面积,试问增产的蔬菜每天应分别向A、B、C三个采购点供应多少最经济合理。

二、问题分析

2.1问题一的分析

要使用于蔬菜调运及预期的短缺损失为最小,即总费用R最小,也就是指调运费用P与缺货损失Q之和最小。

首先考虑调运费用P,调运费用与距离与送货量成正比,因此考虑距离问题,我们须先求出A、B、C三个采购点至各个菜市场的最短距离。

采用Froyd算法,结合MATLAB编程实现最短距离计算,确定出最短路线。

其次考虑缺货造成的损失Q,以题中每天需求量为约束条件,将损失最低作为目标建立线性规划模型,用LINGO编程求解缺货损失最小值。

2。

2问题二的分析

若按规定各菜市场短缺量一律不超过需求量的20%,也就是在模型一的基础上增加一个约束条件,即每个菜市场的供应量必须不低于需求量的80%。

则可得到满足条件要求的模型二。

2。

3问题三的分析

本题的目标有二:

首先要满足每个菜市场的供货量要充足的条件;其次要使得总费用最低.所以我们在模型一的基础上增加了上述两个限制条件,即得到模型三。

使得在供货量充足的情况下日均费用最小化.

三、问题假设

1、各个路口以及蔬菜销售点都可以作为中转点.

2、假设蔬菜种植基地直达某个销售地点,即销售点之间没有卸货的情况。

3、假设运输的蔬菜路途中没有损耗,也无意外发生。

4、假设只考虑运输费用和短缺费用,不考虑装卸等其它费用。

5、假设各蔬菜种植基地供应蔬菜同质且单位运价相同.

6、假设新增产的蔬菜能够满足缺货量.

7、日需求量与缺货损失费用不变。

四、变量说明

     从A到i(各个菜市场)的最短距离

   从B到i(各个菜市场)的最短距离

  从C到i(各个菜市场)的最短距离

从A到i(各个菜市场)的运货量

从B到i(各个菜市场)的运货量

 从C到i(各个菜市场)的运货量

    总调运费

    短缺损失

      总费用

五、模型建立

5.1 问题一模型的建立

按照问题的分析,我们知道调运总费用P与调运距离和调运量乘积有关,也就是说总调运费用等于每阶段调运距离和调运量的累计。

首先就要求解各采购点到菜市场的最短距离。

在图论里面关于最短路径问题比较常用的是Dijkstra算法,Dijkstra算法提供了从网络图中某一点到其他点的最短距离。

主要特点是以起始点为中心向外层扩展,直到扩展到终点为止。

但由于它遍历计算的节点很多,所以效率较低,实际问题中往往要求网络中任意两点之间的最短路距离。

如果仍然采用Dijkstra算法对各点分别计算,就显得很麻烦。

所以就可以使用网络各点之间的矩阵计算法,即Floyd算法.

Floyd算法的基本思想是:

从任意节点i到任意节点j的最短路径不外乎两种可能,一种是直接从i到j,另一种是从i经过若干个节点k到j。

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之间的最短距离了.

5。

2问题二模型的建立

各菜市场短缺量一律不超过需求量的20%,为满足这一条件,现对方案一进行调整。

只需在方案一中加一限制条件:

同理可用LINGO编程求出调运方案。

5.3问题三模型的建立

要足城市居民的蔬菜供应,增加蔬菜种植面积,则需要保证所有的菜市场都满足日需求量,且日均化费用要最小。

在问题一得基础上作出以下调整:

同理可用LINGO编程求出调运方案.

六、模型求解

6。

1问题一模型的求解

由图1和表格1的信息,建立一个线性规划模型并经过Floyd算法,使得蔬菜调运及预期的短缺损失为最小。

调运总费用P为:

   

(1)

若使调运总费用最少,则应保证A、B、C三个收购点到8个菜市场的路程最短,最短路线的求解过程如图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,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时,

=

为弧(

)的权;

②当(

)不属于E时,

=inf.(inf为无穷大,n为网络结点个数)

=0,i=1,2,3……n按上述规定,该网络的权矩阵为:

因为上述网络有15个结点,故网络的权矩阵均为15阶矩阵。

用Floyd算法求解图2中任意两个顶点的最短路径及其长度,名为Floyd.m的程序文件见附录程序1。

最终运行结果为:

D=

07  145   4 10812 18 12  15 20  2422 23

7  07 12 83  12    8141913 1920  24  19

14 7  0  16 13 611   71118 1218 17  23 16

5 12   16  0  6135  9   15  712  15 21  17 20

4 8 13 6   07   48 14 13 11 17 20 22   19

10  36 13  7 0 9511 16 1016  17 21 16

8 12  11  54  904  10 12  713 161815

12  8  79 8 5  4  0 6 11  511 1216 11

18 14 1115  14 1110 6 09  3 96  14   5

12 19 18 7 13  16 12 11 90  6  8 15 10   14

151312  12  11  10  7 5  3 6  0 6911 8

201918 1517 16  13 11  98 6 0 10  514

24 201721 2017 16 12 6  159 10  011 11

22 24 2317 22  211816 14 10  11  5 11 019

2319 16 20  191615 115148 1411190

path=

1  224 5   25 5 5 4  5 4 5 4 5

12 3  1 5  6 5 6 6    166  6 66

2 2  3 8 6 6  8   8  9  8  8   8989

1  17  45  5 7  7  710 7  107107

1   26 4  5  6 78 8  4  7 78  7  8

2 2  355688 8 8 8 8    888

5   5 8  4  5  87  8   8  4 11 11   8 118

56375 6 78 9 1111  119 119

8   838 8   8 8  8 911 11  1113 11 15

4 411 4 411  4 11 11  10 11 12 1114 11

7 88    778 7 8 9 10 11   12 9 12 9

1011 1110  11 11  111111 1011121314   11

99   9 99  9  9  99  9 9 12 13 149

10  12  12 10 12 12 12 12 12  10  12 12 131412

9 9   9  9  9 99 9 9 9 9 9  9 9 15

根据上述矩阵,分别找出A、B、C到①、②、③、④、⑤、⑥、⑦、⑧的最短距离,见表2:

表2:

收购点到菜市场的最短距离

最短距离(单位:

100千米)

A

4

8

8

19

11

6

22

20

B

3

17

C

2

10

调运量的限制:

短缺损失费为:

总费用为:

由以上约束条件,用LINGO软件进行线性规划求解(源程序及完整运行结果见附录程序2),部分运行结果如下:

Objectivevalue:

         10280。

00

Totalsolveriterations:

     14

Variable    Value ReducedCost

P     9640.000  0.000000

Q 640。

0000  0。

000000

SA1      80.000000。

000000

SA20。

000000  2。

000000

SA30。

000000     2。

000000

SA4  0。

000000 6.000000

SA5  100。

0000      0.000000

SA6    70.00000  0。

000000

SA7  0。

000000    24.00000

SA8 0。

00000010.00000

SB1      0.000000 20.00000

SB270.00000  0。

000000

SB3  90.00000  0.000000

SB4   40。

00000    0。

000000

SB5  0.000000  2.000000

SB6 0。

000000  20。

00000

SB70.000000 26。

00000

SB8  0.000000   4。

000000

SC1  0.000000 42。

00000

SC2 0。

000000  34.00000

SC3   0。

000000 18。

00000

SC4  0.000000   6.000000

SC5  20.00000     0.000000

SC6   0.000000 28。

00000

SC7     100.0000   0。

000000

SC8   60.00000     0.000000

从上述运行结果中可以得出调运方案为:

在此种方案下,蔬菜调运及预期的短缺损失最小,最小金额为10280元。

6.2 问题二模型的求解

将调整后的方案用LINGO编程(源程序及完整运行结果见附录程序3),部分运行结果如下:

Objectivevalue:

    10628.00

Totalsolveriterations:

         20

Variable Value ReducedCost

P   10064.00   0.000000

Q  564.0000   0.000000

SA1  80。

00000 0。

000000

SA2  0.000000    0.000000

SA3 24。

00000     0。

000000

SA4  0.000000    4.000000

SA5 76。

00000   0.000000

SA6 70.00000  0.000000

SA7 0.000000   24.00000

SA8  0。

000000   10。

00000

SB1    0.000000 22。

00000

SB270.00000  0。

000000

SB3 66。

00000  0.000000

SB4   64。

00000 0.000000

SB5 0.000000   4.000000

SB6  0.000000    22.00000

SB7   0。

000000   28.00000

SB80。

000000  6。

000000

SC1  0.000000  42.00000

SC2   0.000000   32。

00000

SC3 0。

000000  16。

00000

SC40。

000000    4.000000

SC5  28.00000    0.000000

SC60.000000   28.00000

SC7   80.00000  0。

000000

SC8  72。

00000  0。

000000

从上述运行结果中可以得出调运方案为:

 

6。

3问题三模型的求解

将调整后的方案用LINGO编程(源程序及完整运行结果见附录程序4),部分运行结果如下:

Objectivevalue:

          11200.00

Totalsolveriterations:

    16

Variable   Value  ReducedCost

P 11200。

00   0.000000

Q   0。

000000 0.000000

SA1 80。

00000  0。

000000

SA2     40.00000 0。

000000

SA3    0。

000000  0.000000

SA4   0。

000000  4。

000000

SA5 60。

00000        0.000000

SA6 70.00000     0。

000000

SA70。

000000   24.00000

SA8  0.000000    10.00000

SB1     0。

000000    22。

00000

SB2   30。

00000     0.000000

SB3  90.00000  0。

000000

SB4 80.00000   0.000000

SB5  0.000000 4.000000

SB6 0。

000000     22。

00000

SB70.000000 28.00000

SB8 0。

000000    6。

000000

SC1   0.000000  42.00000

SC2 0.000000  32。

00000

SC3   0。

000000   16.00000

SC4  0.000000    4。

000000

SC5  60。

00000   0.000000

SC6  0。

000000   28.00000

SC7   100.0000    0.000000

SC8    90.00000  0。

000000

从上述运行结果中可以得出调运方案为:

 

七、结果分析

7.1模型的评价

7。

1.1模型的优点:

模型简单易懂,主要用了Froyd算法与线性规划,使问题的求解变得十分方便,能适应更重新的要求。

且计算结果能大致能反映蔬菜调运的最小损失要求,模型的建立成功实现了建模的目的.

7.1。

2模型的缺点:

模型的建立中,采用了若干假设条件,假设的条件使得特殊情况模型失效或者偏离实际情况,比如第三问只考虑了运输费用最小,却没有考虑到供过于求造成的货物积压问题等,考虑更多现实的因素,模型有待进一步改进和完善。

7。

2模型的改进:

在第三问中由于模型只考虑了运输费用最小,却没有考虑到供过于求造成的货物积压问题.在计算时,应将货物堆积造成的损失计算进去,这样考虑结果将更加满足实际情况,使得模型更加完善。

八、参考文献

[1]夏鸿鸣,魏艳华,王丙参.数学建模。

 成都:

西南交通大学出版社,2014。

[2]张志涌,杨祖樱。

 MATLAB教程[M]。

北京:

北京航空航天大学出版社, 2011.

[3] 周品,赵新芬.数学建模. 北京:

国防工业出版社,2009.

[4]费培之,程中媛. 数学建模实用教程. 成都:

四川大学出版社,1998.

[5]陈如栋,于延荣。

 数学模型与数学建模.北京:

国防工业出版社,2006.

 

九、附录

程序1

function[D,path]=floyd(a)

n=size(a,1);

D=a

for i=1:

n

   forj=1:

n

   path(i,j)=j;

  end

end

path

fork=1:

n

 fori=1:

n

  for j=1:

n

     ifD(i,k)+D(k,j)〈D(i,j)

       D(i,j)=D(i,k)+D(k,j);path(i,j)=path(i,k);

   end

  end

 end

  D

 path

end

在MATLAB命令窗口输入命令:

a=[0 7inf5 4inf infinfinf infinfinf infinfinf;

707inf83infinf infinfinfinfinfinfinf;

inf70inf inf6inf711infinfinfinfinfinf; 

5 infinf0 6inf5 inf inf7infinfinfinf inf;

4 8inf6074 8inf infinfinfinf infinf; 

inf36inf 70

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 党团工作 > 党团建设

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1