一、物流配送中心拣货作业简介

1 物流配送中心拣货作业
1.1 问题描述

双区型仓库一般是由一定数量的等长巷道组成,巷道两侧的货架上存放着需要拣取的各种物品。横向有三条过道,不同于单区型仓库(single-block warehouse)的是:除巷道上下两端分别有过道外,中间还有一条过道(如图1中的过道b),而单区型仓库缺少中间这条过道。据相关文献分析,该条中间过道在提高大型仓库拣选效率方面有很大帮助[8,11,12]。

整个仓库平面图如图1所示,I/O为仓库的出入口,每个小方格代表一个货物储位,填充部分表示按某订单需拣取的货物所在的储位,上面的数组{x-y-z}代表对应的储位标号,其中x表示该所在的拣货巷道号,取值为1~10;y表示该储位位于巷道x的左边还是右边(1表示位于左边,2表示位于右边);z表示为该储位所在的行号(从下往上数),取值为1~40。例如:{5-2-26}表示该储位位于仓库中第5号巷道右边的第26行。

由于在本文设计的仓库中拣货巷道的宽度并不太宽,面对巷道时,拣货人员可以进行双侧取货,即对同一巷道中左右两边取货时拣货人员移动的距离可以忽略。

图1 双区型仓库平面图
为订单拣货的时间可分成行走(步行或驾驶车辆)时间、搜索时间、分拣时间等。按照Tompkins[13]的研究,行走时间常常占拣货时间的一半(见图2),可见,缩短行走距离对减少总的拣货时间作用很大。而所选的路径对行走路线长度和行走时间有直接的影响,因此,应该把路径选择作为提高拣货效率的一项重要的内容。

1.2 问题分类
由于拣货人员使用的推车的容量(或载重量)有限,本文将处理后的拣货订单的拣货方式分成一单一车和一单多车两种类型。

一单一车指的是某个拣货订单中所需的全部货物可以由一辆推车来回一次从仓库中一次全部取回,而不会超出推车的最大容量(或载重量)的情况。

一单多车指的是某个拣货订单中的所需的全部货物必须通过一辆推车来回多次才能全部从仓库中取回,即该订单上的所有货物的总体积(或总质量)已经超过了一辆推车的最大容量(或载重量)的情况。

1.3 模型建立
一单多车拣货路径问题主要考虑怎样将订单中所需货物分配到多个车次中拣取,使其总的拣货路径最优,该类问题类似于运筹学中的车辆路径问题(Vehicle Routing Problem,VRP),也称车辆调度问题(Vehicle Scheduling Problem,VSP)。

VRP的一般描述是:对一系列给定的客户点,要求确定适当的车辆行驶路线,使其从车场(如配送中心等)出发,有序地对它们进行服务,并在满足一定的约束条件下(如车辆载重量、客户需求量、时间窗限制等),使总运输成本达到最小(如使用车辆数最少,车辆行驶总距离最短等)[14,15]。

结合VRP的数学模型设计了一单多车拣货路径问题的数学模型。

(1)问题假设。现需y次车都从一个共同的源点(仓库出入口IO)出发,需要到仓库中不同的储位中去提取货物。假设储位为v1,v2,…,vm。并且源点和储位的位置是已知的,考虑到仓库中推车成本较低并且可重复使用,所以本问题不将车次数最小作为优化目标。

(2)模型目标。每一车次构成一个回路,确定每条回路内的路径安排和调度,使得所有回路的总行走距离S最小。

(3)变量说明。Qij:第i次车在其子回路上对应的第j个储位的取货量;li:第i条回路上的储位数;ci:第i次车对应的路径;cij:第i次车对应的子回路中顺序为j的储位点;i:每次车对应的编号;W:推车最大载重量;V:订单上所需拣取的货物总重量;m:订单中货物在仓库中的储位数;v0:源点;y:需要的车次数;S:总行走距离;di(j-1)j:第i次车对应的路线中顺序排列的第j-1个储位和第j个储位之间的最短距离;di(li)(0):第i次车对应的路线中第li个储位与源点v0之间的最短距离。

(4)建立模型

模型中,式(1)为目标函数,即最短的总行走距离;式(2)为推车的能力约束,即每个子回路中从储位拣取的货物的总量,保证每次车从储位中拣取的货物的总量不超过推车的最大载重量;式(3)表示拣取完订单所需的全部货物;式(4)~式(7)表示从每个待拣储位有且仅能取货一次;式(8)表示第i次车是否有拣货任务。

当订单上全部货物质量小于推车总的载重量W时,即就是式(2)中的W足够大,该数学模型表示一单一车情况下拣货路径模型。

2 遗传算法求解拣货路径问题
2.1 算法流程

基于遗传算法的拣货路径问题优化算法流程如图3所示。

图3 求解拣货路径问题的遗传算法流程图

2.2 确定编码方案
对于一单一车的境况,采用自然数编码方式,先对订单上的货物对应在仓库中的存储位置(储位)按顺序依次进行自然数编号,然后用这些储位点编号所组成的自然数序列表示拣货路径。其具体表示方法如下:

设订单中的有4种货物需要从仓库中拣取,这4种货物分布在仓库中4个储位位置上。则可以用0表示仓库出入口,从1至4的4个自然数分别依次表示一个储位。假设该订单的拣货路径如下:

路径:出入口0→储位点1→储位点4→储位点2→储位点3→出入口0

遗传算法所表示的自然数系列为:{0 1 4 2 3 0}。

考虑到一单多车情况下拣货路径问题中订单上的拣取任务可能要通过多次车次才能完成,为了在可行解中体现出多车次的特点,将对应的自然数序列插入相应的零来体现多车特点。具体方法如下:

设订单中的有7种货物需要从仓库中拣取,这7种货物分布在仓库中7个储位位置上。则可以用0表示仓库出入口,从1至7的7个自然数分别依次表示一个储位。假设该订单的拣货路径如下:

路径1:出入口0→储位点1→储位点5→储位点7→储位点4→出入口0

路径2:出入口0→储位点2→储位点3→储位点6→出入口0

遗传算法所表示的自然数系列为:{0 1 5 7 4 0 2 3 6 0}。

其中0的作用有两点:一是表示实际的路程起始点(即本题中的仓库出入口IO),二是用来分隔GA编码。具体分隔的方法是:首先得到一个不含0的可行自然数序列{1 5 7 4 2 3 6},再从左边开始,每次加入一点,直到加入下一个点就超出车辆装载能力限制为止,按所加入的点的先后顺序排列,得到一条子路径,即就是得到第一次车次的拣货任务,比如{1 5 7 4}。再从未加入的点继续该过程,获得下一条子路径。重复此过程至所有点均被选入为止,比如{2 3 6}。再在可行自然数序列中插入相应的0将个子路径分隔开来,于是得到了染色体编码{01 5 7 4 0 2 3 6 0}。

当染色体要进行下面的交叉、变异和“进化逆转”操作时,可先将染色体编码中表示多车的0去掉,算子操作完成后再按上面分隔编码方法插入相应的0得到相应的染色体。

2.3 确定适应度函数
问题的适应度函数取为哈密尔顿圈的长度的倒数(无惩罚函数),但是为了避免适应度过小,本文将该函数乘上一个起调节作用的系数,系数值为:

处理后的新适应度函数如下:

其中maxdd为订单中待拣货物所在的储位点之间的最大距离,lchrom为编码后的染色体的长度,即路径中经过储位点数(包括出入口结点),X为对应可行解的拣货路径长度。

2.4 选择(或复制)算子和交叉算子的设计
在文中用随机生成方法产生初始解群。然后按适应度比例方法(轮盘赌选择)从父代中每次挑选两个个体,以相应的概率参加交叉变异操作。
具体的交叉操作如下:

(1)随机在串中选择一个交配区域,如两父串交配区选定为:

(2)将B的交配区域加到A的前面或后面,A的交配区域加到B的前面或后面得到:

(3)在A′中自交配区域后依次删除与交配区相同的储位号码,得到最终的两个子串为:

与其它方法相比,这种方法在两父串相同的情况下也能产生一定程度的变异效果,能维持群体的多样化特征。

2.5 变异算子的设计
由于后面将引入了“进化逆转”操作技术,为保持群体内个体的多样化,本文采用连续多次对换的变异技术,使可行解有较大的顺序排列上的变化,以抑制“进化逆转”的同化作用。变异操作发生的概率取值比较小(本文设计变异操作发生概率Pm的取值为0.008),一旦变异操作发生,则用随机方法产生交换次数为K(本文设计K的取值为1~100的随机整数),对所需变异操作的染色体进行K次对换(对换的两码位也是随机产生的)。最后为保持群体内个体的多样化,在文中还采用了一种对解的扰动策略——最好解连续50代不变时则随机产生新的个体20个来替换20个随机抽取的旧个体[16]。

2.6“进化逆转”算子的设计
本文使用的“进化逆转”是一种单方向的(朝着改进的方向)和连续多次的“逆转”操作,即对于给定的染色体,若“逆转”使染色体(可行解)的适应度提高,则执行逆转操作,否则就放弃。如此反复,直到不存在这样的逆转操作为止。这一操作实际上使给定的染色体改良到它的局部极点,这种局部爬山能力与基本遗传算法的全局搜索能力相结合在实验中显示了较好的效果。

为了尽量避免算法出现“早熟”现象,在进化初期,控制“进化逆转”算子使用概率,确保算法能在全局范围内寻优;但是到了进化后期,为了加快算法局部爬山能力,加大该算子的使用概率。具体在程序设计中处理如下:

其中Pm*为“进化逆转”算子的操作发生概率,gen表示遗传进化代数。

二、部分源代码

clear all;
close all;
clc;
W=[0 0;10 15;10 20;10 70;10 85;20 5;20 95;30 70;45 75;45 85;50 55;60 60;70 70;70 85;70 95;75 20;75 45;80 5;80 45;90 75;95 90];
weight=[92 77 77 59 100 40 61 96 80 37 80 52 82 63 51 52 95 92 54 60];
NP=300;
D=20;
M=4;
fit=zeros(NP,D+M);
%fit
gen=0;
G=100;
N=size(W,1);
Dis=zeros(N);
fitness=zeros(1,NP);
pc=0.05;
pm=0.03;
bestg=[];
aa=100;%惩罚系数
fbestfitness=[];
for i=1:N
for j=1:N
Dis(i,j)=((W(i,1)-W(j,1))2+(W(i,2)-W(j,2))2)^0.5;
end
end
for i=1:NP
fit(i,:)=randperm(D+M);
rr1=find(fit(i,:)(D+1));
rr2=find(fit(i,:)(D+2));
rr3=find(fit(i,:)(D+3));
rr4=find(fit(i,:)(D+4));
fit(i,rr1(1,1))=0;
fit(i,rr2(1,1))=0;
fit(i,rr3(1,1))=0;
fit(i,rr4(1,1))=0;
end
dfitness=[];
sumfitness=0;
while gen<G
for i=1:NP
fitness(i)=fun1(fit(i,:),Dis,N,D,weight,aa,M);
end
maxfitness=max(fitness);
tt=find(fitness==maxfitness);
fit(NP,:)=fit(tt(1,1)

【路径规划】基于matlab遗传算法求解仓库拣货距离最短优化问题【含Matlab源码 2154期】相关推荐

  1. 【Matlab人脸识别】人脸实时检测与跟踪【含GUI源码 673期】

    一.代码运行视频(哔哩哔哩) [Matlab人脸识别]人脸实时检测与跟踪[含GUI源码 673期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1]孟逸凡,柳益君 ...

  2. 【Matlab指纹识别】指纹识别门禁系统【含GUI源码 1692期】

    一.代码运行视频(哔哩哔哩) [Matlab指纹识别]指纹识别门禁系统[含GUI源码 1692期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 包子阳,余继 ...

  3. 【Matlab树叶分类】BP神经网络植物叶片分类【含GUI源码 916期】

    一.代码运行视频(哔哩哔哩) [Matlab树叶分类]BP神经网络植物叶片分类[含GUI源码 916期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅 ...

  4. 【Matlab水果蔬菜识别】形态学水果蔬菜识别【含GUI源码 919期】

    一.代码运行视频(哔哩哔哩) [Matlab水果蔬菜识别]形态学水果蔬菜识别[含GUI源码 919期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅. ...

  5. 【Matlab青草识别】形态学马唐草+牛筋草识别【含GUI源码 908期】

    一.代码运行视频(哔哩哔哩) [Matlab青草识别]形态学马唐草+牛筋草识别[含GUI源码 908期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅 ...

  6. 【Matlab限速标志识别】形态学限速标志识别【含GUI源码 1142期】

    一.代码运行视频(哔哩哔哩) [Matlab限速标志识别]形态学限速标志识别[含GUI源码 1142期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] 蔡利梅 ...

  7. 【多式联运】基于matlab遗传算法求解多式联运运输问题(考虑碳税)【含Matlab源码 1996期】

    ⛄一.联运运输简介 1 引言 运输问题(Transportation Problem)[1]是一类特殊的线性规划问题,最早是由Hichcock于1941年提出的,由于它不仅能解决物资的合理调运和车辆的 ...

  8. 【Matlab路径规划】改进的遗传算法机器人避障路径规划【含GUI源码 703期】

    一.代码运行视频(哔哩哔哩) [Matlab路径规划]改进的遗传算法机器人避障路径规划[含GUI源码 703期] 二.matlab版本及参考文献 1 matlab版本 2014a 2 参考文献 [1] ...

  9. 【Matlab验证码识别】遗传算法和最大熵优化+大津法(OTSU)+自定义阈值数字验证码识别【含GUI源码 1694期】

    一.代码运行视频(哔哩哔哩) [Matlab验证码识别]遗传算法和最大熵优化+大津法(OTSU)+自定义阈值数字验证码识别[含GUI源码 1694期] 二.matlab版本及参考文献 1 matlab ...

最新文章

  1. 目标检测—YOLO不难学,你只是不会方法!
  2. python之拆包与装包
  3. 【性能优化】 之 10053 事件
  4. 【Redis】4.Redis数据存储listsetsorted_set
  5. mapgis编辑属性结构编辑不了_MapGIS67操作手册(3-17)MapGIS67编辑线属性结构的方法...
  6. vue.jsr入门_JSR 365更新:深入CDI 2.0
  7. python 重置索引_python pandas 对series和dataframe的重置索引reindex方法
  8. mysql 低端_mysql入门
  9. [看书笔记]《深入java虚拟机》——java体系结构(二)
  10. centos7安装Hive2.3.0
  11. 固定定位小技巧(HTML、CSS)
  12. linux下查看内存频率,内核函数,cpu频率
  13. 微信小程序即将支持 分享朋友圈 半屏显示
  14. c语言双精度型输出小数位数_C语言的double与float类型最多只能默认输出小数位数都取6位?...
  15. 威纶触摸屏485通信控制多台台达变频器程序
  16. SaaS模式、技术与案例详解——第17章 案例详解
  17. POJ 3422 Kaka's Matrix Travels(拆点+最大费用流)题解
  18. nova evacuate功能分析
  19. iOS中scheme详解
  20. 苹果六现价多少钱_六克拉的Derier多少钱 六克拉钻戒多少钱

热门文章

  1. 100内奇数之和流程图_数字物理猎奇研究|纯奇数数集中的加法,法则中的“n”的含义...
  2. 微信——企业付款到个人银行卡。
  3. 计算机管理检查表,系统管理员工作流程检查表_演练使用
  4. admui 框架源码 模板结构
  5. Jenkins Pipeline 手记(3)—— 自定义Checkout的陷阱
  6. 什么是大票零担?ZETA如何实现大票零担货物追踪可视化?
  7. foss测试_印度最大的针对语言技术的FOSS活动
  8. echarts树形图,分支过多,页面放不下,高度自适应方法
  9. 如何清理电脑版微信的硬盘空间?(本文章完全由chatGPT命题生成,一个字都没改)
  10. 全球十大数据安全事件