具体实施方式
下面结合附图和实施例对本申请作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释相关发明,而非对该发明的限定。另外还需要说明的是,为了便于描述,附图中仅示出了与有关发明相关的部分。
需要说明的是,在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互组合。下面将参考附图并结合实施例来详细说明本申请。
图1示出了可以应用本申请的分拣中心的货物分拣方法或分拣中心的货物分拣装置的实施例的示例性系统架构100。
如图1所示,系统架构100可以包括分拣中心110、网络(图中未示出)和服务器120。分拣中心110包括多个落袋口111以及多个AGV112。落袋口111可以与某一个配送区域相对应。例如,分拣中心110可以包括三个对应于北京市海淀区这一配送区域的落袋口,一个对应于北京市昌平区这一配送区域的落袋口,五个对应于北京市朝阳区这一配送区域的落袋口,等等。AGV112用以向其中一个落袋口运输配送目的地隶属于与该落袋口所对应的配送区域的货物。
网络可以在AGV112和服务器120之间提供通信链路的介质。网络可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
AGV112通过网络104与服务器120交互,以接收或发送消息等。例如,AGV112可以通过向服务器120发送当前所承载货物的标识信息(例如,货物的配送目的地信息、货物的重量信息、货物的体积信息等等),服务器120基于所接收到的标识信息生成运输指令,并将所生成的运输指令通过网络发送给AGV112。运输指令例如可以用于指示AGV112的运输路径、运输速度、运输终点所对应的落袋口位置等等。
需要说明的是,本申请实施例所提供的分拣中心的货物分拣方法一般由服务器120执行,相应地,分拣中心的货物分拣装置一般设置于服务器120中。
应该理解,图1中的分拣中心110、网络和服务器120的数目仅仅是示意性的。根据实现需要,可以具有任意数目的分拣中心110、网络和服务器120。
继续参考图2,示出了根据本申请的分拣中心的货物分拣方法的一个实施例的流程200。
分拣中心包括多个以预设分布方式分布的落袋口以及用于向各落袋口传送货物的AGV。AGV可以在分拣中心的货物存放区和各落袋口之间往复穿梭,从而将货物存放区的货物传送至相应的落袋口。各落袋口分别与某个目标配送区域相对应。
在一些应用场景中,与同一个分拣中心中的各落袋口相对应的配送区域例如可以同属于一个配送片区。也即是说,一个配送片区可以包括多个相互邻接和/或相互部分交叉的配送区域,而同属该配送片区的配送区域的货物可以由同一个分拣中心分拣,并输送至相应的配送区域。
在这里,分布方式可以用于指示分拣中心所包含的各落袋口的位置信息。预设分布方式可以是根据分拣中心的具体应用场景(例如,包括但不限于分拣中心所对应的配送片区的面积和单位时间内的配送量、分拣中心的面积等)而预先设置的分布方式。
例如,在一些应用场景中,如图3A所示,分拣中心的各落袋口310可以以阵列分布的方式设置。在这些应用场景中,各落袋口可以作为一M行N列的阵列中的一个元素,且相邻落袋口之间的间距为一已知距离值。在这些应用场景中,AGV可以在各落袋口之间的间隔区运行,从而将货物运送至相应的落袋口。
或者,在另一些应用场景中,如图3B所示,分拣中心的各落袋口320还可以以某一预设间隔均匀地分布在一圆周上。在这些应用场景中,AGV可以在圆周上运行,从而将货物运送至相应的落袋口。
需要说明的是,无论分拣中心的落袋口以何种预设分布方式设置,本实施例的分拣中心的货物分拣方法应用其上的电子设备(例如,图1中的服务器120)均可以实时或者预先获得分拣中心的落袋口的分布方式。
本实施例的分拣中心的货物分拣方法,包括以下步骤:
步骤210,确定分拣中心所包含的各第一落袋口的当前位置,其中,第一落袋口为分拣中心内,单位时间内的分拣量超过预设分拣量的落袋口。
由于落袋口与某一个配送区域相对应,而各配送区域由于某种原因,单位时间内的配送量存在差异,因此,各落袋口在单位时间内的分拣量也存在差异。例如,在一些应用场景中,分拣中心中,某一落袋口A所对应的配送区域为一写字楼,而另一落袋口B所对应的配送区域为一居民区。由于这两个配送区域内的常住人口及其购买力的差异,落袋口A和落袋口B所对应的配送区域在单位时间内的配送量可能存在较大的差异。相应地,在单位时间内,落袋口A的分拣量和落袋口B的分拣量也存在较大的差异。
在一些应用场景中,可以分别对分拣中心内一段时间内与各配送区域相对应的落袋口的分拣量进行计数,得到该一段时间内各落袋口的分拣量,进而可以确定出各落袋口单位时间内的分拣量。
在一些应用场景中,例如可以在预设分布方式所指示的分布位置中随机分布各第一落袋口,以确定出分拣中心中各第一落袋口的当前位置。
步骤220,将各第一落袋口的当前位置作为当前聚类中心。
步骤230,对分拣中心中的各落袋口执行聚类操作。
在这里,执行聚类操作所应用的聚类算法可以是目前使用或者待未来开发的任意一种聚类算法。包括但不限于聚合聚类算法(例如,CURE算法)、基于密度的聚类算法(例如,DBSCAN算法)、基于网格的聚类算法(例如,STING算法)、基于平方误差的迭代重分配聚类算法(例如,K-means算法)等等。
通过上述的步骤220和步骤230,可以将分拣中心的各个落袋口划分为多个聚类,且聚类的数量与第一落袋口的数量相对应。
例如,分拣中心包含3个第一落袋口,那么通过执行上述步骤220和步骤230,可以将该分拣中心的各落袋口划分为3个聚类,并且分拣中心的每个落袋口属于其中某一个聚类。
在执行步骤230之后,分拣中心的各落袋口划分形成了多个组(即,多个聚类),且每个聚类均具有一实际的聚类中心。以Kmeans算法为例,基于Kmean算法得到的各个聚类中,类中心的位置可以基于该聚类中各元素的位置均值确定。
步骤240,响应于各聚类的实际聚类中心的位置与各第一落袋口的当前位置相对应,将各第一落袋口的当前位置作为各第一落袋口的最终位置。
在这里,各聚类的实际聚类中心的位置与各第一落袋口的当前位置相对应,可以理解为,各聚类中,属于该聚类的第一落袋口所处的位置与该聚类的实际聚类中心之间的距离不大于该聚类中其它元素(即该聚类中其它落袋口)与该聚类的实际聚类中心之间的距离。
若各聚类的实际聚类中心的位置与分拣中心中的各第一落袋口的当前位置相对应,则可以认为,分拣中心所包含的第一落袋口在该分拣中心的预设分布方式中,尽可能地均匀分布。
步骤250,利用自动导引运输车,向分拣中心的各落袋口传送货物。
例如,在一些应用场景中,本实施例的分拣中心的货物分拣方法应用其上的电子设备可以向AGV发送分拣指令,以使AGV将货物传送至相应的落袋口。
本实施例的分拣中心的货物分拣方法,通过将单位时间内的分拣量大于预设分拣量的第一落袋口作为当前聚类中心,来对分拣中心的各落袋口进行聚类,并在各聚类的实际聚类中心的位置与各第一落袋口的当前位置相对应时,将各第一落袋口的当前位置作为述第一落袋口的最终位置,实现了各第一落袋口在分拣中心内分散排布。在利用AGV向分拣中心的各落袋口进行货物运输时,有利于缓解AGV局部拥堵,进而有利于提高分拣效率。
在一些可选的实现方式中,本实施例的分拣中心的货物分拣方法还可以进一步包括:
步骤260,响应于各聚类的实际聚类中心的位置与各第一落袋口的当前位置不对应,将实际聚类中心作为各当前聚类中心,并执行步骤230的聚类操作。
这样一来,若各聚类的实际聚类中心的位置与各第一落袋口的当前位置不对应,通过步骤230和步骤260的循环迭代,可以将各第一落袋口的最终位置设置为与各聚类的实际聚类中心的位置相对应的位置,从而实现各第一落袋口在分拣中心内分散排布,进而缓解AGV在向分拣中心的各落袋口传送货物时可能引起的局部拥堵。
在一些可选的实现方式中,本实施例的分拣中心的货物分拣方法中,步骤230的对分拣中心中的各落袋口执行聚类操作,还可以进一步包括:
步骤231,将分拣中心中的各第二落袋口向其中一个当前聚类中心聚类,其中,第二落袋口为分拣中心内,除第一落袋口之外的其它落袋口。
例如,对于每一个第二落袋口,可以首先确定该第二落袋口与各当前聚类中心的距离。接着,将与该第二落袋口距离最近的当前聚类中心作为该第二落袋口所属的聚类的聚类中心。
在一些应用场景中,可以基于各第二落袋口与各当前聚类中心的欧氏距离作为衡量二者之间距离的指标。
步骤232,确定聚类结果中,各聚类的实际聚类中心的位置。
在步骤232中,例如,可以首先确定各聚类所包含的落袋口在预设坐标系下的坐标值的平均值。接着,将平均值所指示的位置作为该聚类的实际聚类中心的位置。
在这里,预设坐标系可以与分拣中心落袋口的分布方式相关联。
例如,在一些应用场景中,分拣中心落袋口的分布方式为图3A所示的阵列式分布,那么,预设坐标系例如可以是以某一位置为原点以阵列的行方向为横轴、以阵列的列方向为纵轴的笛卡尔坐标系。
或者,在另一些应用场景中,分拣中心落袋口的分布方式为图3B所示的分布方式以预设间隔均匀地分布在一圆周上。在这些应用场景中,预设坐标系例如可以是以该圆周所对应的圆心为极点,以过极点并沿某一预设方向延伸的射线为极轴的极坐标系。
在一些应用场景中,各聚类所包含的落袋口在预设坐标系下的坐标值的平均值所指示的位置可能并不等同于预设分布方式中的任意一个落袋口位置。在这些应用场景中,可以将与该坐标值平均值所指示的位置最接近的落袋口位置作为该聚类的实际聚类中心的位置。
下面将进一步结合图4A和图4B来进一步阐述本申请的分拣中心的货物分拣方法的执行过程,从而使得本申请的方法的原理和技术效果更加明确。
在图4A和图4B所示的应用场景中,假设分拣中心包括49个落袋口410,且其中包括3个单位时间内分拣量超过预设分拣量阈值(例如10000件/小时)的第一落袋口。分拣中心所包括这些落袋口以7×7的阵列方式分布,且任意沿阵列行方向或列方向相邻的二落袋口之间的间距相等。
首先,如图4A所示,确定各第一落袋口A~C的当前位置。从图4A中可以看出,第一落袋口A的当前位置为[3,2](即7×7阵列中第三行第二列的位置),类似地,第一落袋口B的当前位置为[2,6],第一落袋口C的当前位置为[6,5]。
以[3,2]、[2,6]和[6,5]为聚类中心,对各落袋口进行聚类后,可以将分拣中心的落袋口划分为三个聚类,分别对应于图4A中虚线划分形成的三个区域。
接着,确定三个聚类的实际聚类中心。
通过求取各聚类中,落袋口坐标值的均值可以确定,[3,2]和[2,6]分别是所属聚类的实际聚类中心,而[6,5]所属聚类的实际聚类中心为[6,4]。在这里,由于落袋口以阵列方式分布,且任意沿阵列行方向或列方向相邻的二落袋口之间的间距相等,可以用各落袋口在该阵列中所处的位置来作为各落袋口的坐标值,例如,对于落袋口[6,5]而言,可以将6视为其纵坐标的坐标值,并将5视为其横坐标的坐标值。
接着,以[3,2]、[2,6]和[6,4]为聚类中心,对各落袋口进行聚类,得到的聚类结果如图4B所示。
通过再次求取各聚类中,落袋口坐标值的均值可以确定,[3,2]、[2,6]和[6,4]均为所属聚类的实际聚类中心。这样一来,便可以将[3,2]、[2,6]和[6,4]分别作为分拣中心内,各第一落袋口的最终位置。
在确定各第一落袋口的最终位置后,便可以利用AGV向分拣中心的各落袋口传送货物。由于对分拣中心内各第一落袋口的位置进行了合理的分散排布,在利用AGV向分拣中心的各落袋口进行货物运输时,有利于缓解AGV局部拥堵,进而有利于提高分拣效率。
此外,在本申请的分拣中心的货物分拣方法的一些可选的实现方式中,分拣中心的货物分拣方法还可以进一步包括:
基于各第二落袋口在单位时间内的分拣量确定各第二落袋口在所属的聚类中与该聚类的实际聚类中心的距离。
例如,可以根据单位时间内的分拣量,来确定属于同一个聚类中的各第二落袋口的位置,使得该聚类中任意一个第二落袋口与该聚类的实际聚类中心之间的距离不小于单位时间内的分拣量小于该第二落袋口的其它第二落袋口与该聚类的实际聚类中心之间的距离。
这样一来,可以根据单位时间内的分拣量大小,进一步地对各聚类中第二落袋口的位置进行合理分散排布,从而进一步缓解AGV向分拣中心的各落袋口进行货物运输时,可能出现的局部拥堵现象。
需要说明的是,本申请各实施例的分拣中心的货物分拣方法,在确定分拣中心各第一落袋口(以及,在一些可选的实现方式中,确定各第二落袋口)的位置时,若确定前第一落袋口的位置与确定后第一落袋口的位置不一致,在确定后,本申请各实施例的分拣中心的货物分拣方法应用其上的电子设备(例如,图1中的服务器120)可以通过修改落袋口与目标配送区域之间的对应关系的方式来调整该第一落袋口的位置,而无需真正将第一落袋口从原位置移动至确定后的位置。
具体地,仍以图4A和图4B的应用场景为例。假设在图4A中,第一落袋口C的目标配送区域为a,落袋口[6,4]的目标配送区域为b。重新确定第一落袋口的位置后,原第一落袋口C的位置改变成为第一落袋口C’,其新的位置变为[6,4]。此时,仅需将[6,4]这一落袋口重新与目标配送区域a进行关联,而将[6,5]这一落袋口与目标配送区域b进行关联,便实现了第一落袋口位置的调整。
进一步参考图5,作为对上述各图所示方法的实现,本申请提供了一种分拣中心的货物分拣装置的一个实施例,该装置实施例与图2所示的方法实施例相对应,该装置具体可以应用于各种电子设备中。
分拣中心包括多个以预设分布方式分布的落袋口以及用于向各落袋口传送货物的自动导引运输车,各落袋口与一个目标配送区域相对应。
如图5所示,本实施例的分拣中心的货物分拣装置500包括当前位置确定单元510、中心确定单元520、聚类单元530、最终位置确定单元540以及传送单元550。
当前位置确定单元510可配置用于确定分拣中心所包含的各第一落袋口的当前位置,其中,第一落袋口为分拣中心内,单位时间内的分拣量超过预设分拣量的落袋口。
中心确定单元520可配置用于将各第一落袋口的当前位置作为当前聚类中心。
聚类单元530可配置用于对分拣中心的各落袋口执行聚类操作。
最终位置确定单元540可配置用于响应于各聚类的实际聚类中心的位置与各第一落袋口的当前位置相对应,将各第一落袋口的当前位置作为各第一落袋口的最终位置。
传送单元550可配置用于利用自动导引运输车,向分拣中心的各落袋口传送货物。
在一些可选的实现方式中,最终位置确定单元540还可配置用于:响应于各聚类的实际聚类中心的位置与各第一落袋口的当前位置不对应,将实际聚类中心作为各当前聚类中心,并利用聚类单元执行聚类操作。
在一些可选的实现方式中,聚类单元530还可进一步包括:当前聚类子单元,配置用于将分拣中心中的各第二落袋口向其中一个当前聚类中心聚类,其中,第二落袋口为分拣中心内,除第一落袋口之外的其它落袋口;以及位置确定子单元,配置用于确定聚类结果中,各聚类的实际聚类中心的位置。
在一些可选的实现方式中,当前聚类子单元还可进一步配置用于:对于每一个第二落袋口,确定该第二落袋口与各当前聚类中心的距离;以及将与该第二落袋口距离最近的当前聚类中心作为该第二落袋口所属的聚类的聚类中心。
在一些可选的实现方式中,位置确定子单元还可进一步配置用于:确定各聚类所包含的落袋口在预设坐标系下的坐标值的平均值;以及将平均值所指示的位置作为该聚类的实际聚类中心的位置。
在一些可选的实现方式中,本实施例的分拣中心的货物分拣装置还包括:第二位置确定单元(图中未示出),配置用于基于各第二落袋口在单位时间内的分拣量确定各第二落袋口在所属的聚类中与该聚类的实际聚类中心的距离。
此外,本申请还公开了一种货物分拣系统。该货物分拣系统包括多个以预设分布方式分布的落袋口以及多个自动导引运输车。
其中,各落袋口与一个目标配送区域相对应。自动导引运输车用于基于如上所述的分拣中心的货物分拣方法来将货物传送至其中一个落袋口。
下面参考图6,其示出了适于用来实现本申请实施例的服务器的计算机系统600的结构示意图。图6示出的服务器仅仅是一个示例,不应对本申请实施例的功能和使用范围带来任何限制。
如图6所示,计算机系统600包括中央处理单元(CPU)601,其可以根据存储在只读存储器(ROM)602中的程序或者从存储部分608加载到随机访问存储器(RAM)603中的程序而执行各种适当的动作和处理。在RAM 603中,还存储有系统600操作所需的各种程序和数据。CPU 601、ROM 602以及RAM 603通过总线604彼此相连。输入/输出(I/O)接口605也连接至总线604。
以下部件连接至I/O接口605:包括键盘、鼠标等的输入部分606;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分607;包括硬盘等的存储部分608;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分609。通信部分609经由诸如因特网的网络执行通信处理。驱动器610也根据需要连接至I/O接口605。可拆卸介质611,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器610上,以便于从其上读出的计算机程序根据需要被安装入存储部分608。
特别地,根据本公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分609从网络上被下载和安装,和/或从可拆卸介质611被安装。在该计算机程序被中央处理单元(CPU)601执行时,执行本申请的方法中限定的上述功能。需要说明的是,本申请所述的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本申请中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本申请中,计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
可以以一种或多种程序设计语言或其组合来编写用于执行本申请的操作的计算机程序代码,所述程序设计语言包括面向对象的程序设计语言—诸如Java、Smalltalk、C++,还包括常规的过程式程序设计语言—诸如“C”语言或类似的程序设计语言。程序代码可以完全地在用户计算机上执行、部分地在用户计算机上执行、作为一个独立的软件包执行、部分在用户计算机上部分在远程计算机上执行、或者完全在远程计算机或服务器上执行。在涉及远程计算机的情形中,远程计算机可以通过任意种类的网络——包括局域网(LAN)或广域网(WAN)—连接到用户计算机,或者,可以连接到外部计算机(例如利用因特网服务提供商来通过因特网连接)。
附图中的流程图和框图,图示了按照本申请各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,该模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本申请实施例中所涉及到的单元可以通过软件的方式实现,也可以通过硬件的方式来实现。所描述的单元也可以设置在处理器中,例如,可以描述为:一种处理器包括当前位置确定单元、中心确定单元、聚类单元、最终位置确定单元和传送单元。其中,这些单元的名称在某种情况下并不构成对该单元本身的限定,例如,当前位置确定单元还可以被描述为“确定所述分拣中心所包含的各第一落袋口的当前位置的单元”。
作为另一方面,本申请还提供了一种计算机可读介质,该计算机可读介质可以是上述实施例中描述的装置中所包含的;也可以是单独存在,而未装配入该装置中。上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该装置执行时,使得该装置:确定分拣中心所包含的各第一落袋口的当前位置,其中,第一落袋口为分拣中心内,单位时间内的分拣量超过预设分拣量的落袋口;将各第一落袋口的当前位置作为当前聚类中心;对分拣中心的各落袋口执行聚类操作;响应于各聚类的实际聚类中心的位置与各第一落袋口的当前位置相对应,将各第一落袋口的当前位置作为各第一落袋口的最终位置;以及利用自动导引运输车,向分拣中心的各落袋口传送货物。
以上描述仅为本申请的较佳实施例以及对所运用技术原理的说明。本领域技术人员应当理解,本申请中所涉及的发明范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离上述发明构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本申请中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。