`
一江春水邀明月
  • 浏览: 79024 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

仓库管理系统WMS 订单合并中的聚合算法运用

 
阅读更多

版权所有, 如需转载请保留链接  http://wangbt5191-hotmail-com.iteye.com/blog/1734160

业务需求:

在仓库管理系统WMS中, 在订单发货前, 有一个发货拣单作业, 对订单进行分拣, 根据订单中的品类数量从货区获取商品, 在大量订单作业的过程中, 需要对产品品类相似的订单进行聚合, 也就是根据订单间货物的信息进行预先分组以方便分拣人员分拣。

问题分析

假如我们有数据:

 

Order1 : [Sku1: 2件 , Sku2: 1件]
Order2 : [Sku2: 2件 , Sku3: 1件, Sku4: 1件]
Order3 : [Sku2: 1件 , Sku4: 2件, Sku5: 1件]

 我们假设现场有两个分拣线, 那么要分成两组, 那么我们该把Order1 和Order2 合并为一个Group 呢还是Order2 和Order3 合并? 那么合并的依据是什么? 我们怎么评价这个合并的方式比其他方式较优?

我们假设从采购车上来货的时候, 单品相商品在分捡过程中的数目对分拣复杂度不产生影响, 那么其实我们把每个Order 看成一个Set

Order1 ==> Set: [Sku1, Sku2]
Order2 ==> Set: [Sku2, Sku3, Sku4]
Order3 ==> Set: [Sku2, Sku4, Sku5]

那么问题就转变成, 如何为对已知的有一个个的Set 进行分组聚合。

对这个分组聚合我们又分为两个子问题:

1. 如何衡量两个Set 之间的相似度。

   我们假设以函数Similarity(x, y)表示两个集合的相似度。

   比如有以下4组集合 

 X={1, 2, 3} ; Y={1,2,3,4}; A = {1,2}; B= {1,2,3};

 我们从感性上会认为 Similarity(X, Y) >  Similarity(A, B);  

   那么比如以下4组集合

X= {1, 2, 3}; Y={1,2,3,4},  A = {1,2,3,5}, B= {1,2,3,4}

  我们感性上认为  Similarity(X, Y) >  Similarity(A, B)

2. 知道相似度算法后, 我们如何根据相似度进行聚合。

前一个问题涉及的是相似度算法, 后一个问题涉及到的是聚合算法。

数学建模

到这一节我们会涉及到很多数学集合运算的概念, 有关概念如果不清楚需要自行Google 之。到这一节我们会涉及到很多数学集合运算的概念, 有关概念如果不清楚需要自行Google 之。

1. 相似度算法建模

  这里经典的有两种算法

  Jaccard similarity

   我们假设两个集合X和Y, 这两个集合的相似度在不考虑加权的情况下只和如下两个因素相关

 A, B 的交集: A∩B

  A, B 的并集: A ∪B

  Jaccard similarity = |A ∩ B |/|A ∪ B |, 意思就是A,B 交集中的元素个数与A,B并集中个数的比值。

  vector space similarity

   我们假设两个集合A和B , 这两个集合的相似度在不考虑加权的情况下只和如下三个因素相关

   A, B的交集: A∩B

   A与B 的差集: A-B

   B 与A的差集: B-A

({x∣x∈A,且x∉B}叫做A与B的差集)

  我们假设 x = A∩B 元素数,y=A-B 元素数,z = B-A 元素数

vector similarity = x/sqrt( x *x + y*y + z*z ) .
从空间向量上看就是, 有点的坐标是(x, y, z), 去度量该向量与x 轴的余弦值。 所以这个算法又得名空间向量相似度算法。

PS:

通过这个我们可以类推下如果一个计算结果和n 个因素相关, 而这n 个因素互相独立又互相关联, 我们可以认为第x 个因素在整个度量体系中算占的权重就是在N维空间里面的向量与第X维夹角的余弦值。 

2. 聚合算法建模

聚合算法目前只找到中位算法比较适合我们的这个场景。

网上搜到的复杂的数学公式我就不上了, 这里就以图表加文字描述下它的原理。

假设我们现在 A--> R 18 个元素落在了一个二维平面上。我们要求把他们分成三个组;

1.  随机选择N个元素作为特征种子元素

   这里我们假设选择到了J, L, O 这三个元素作为特征种子

2.根据特征种子分划子集

    遍历集合中除种子以为的元素, 计算当前元素与选择的三个种子的距离。 找到与当前节点距离最短的种子, 然后我们把当前元素划归到这个种子元素所在的子集合,

    
   经过一轮的遍历和计算, 我们划出第一轮分组可以如下表示:

 

3. 为每个子集寻找特征种子

他的做法是在每个子集内部, 计算每个元素到子集内其他元素的距离总和, 然后我们可以找到这样一个元素, 以它为原点, 到其所在子集其他节点的距离最短;

从这里我们可以看到E, C, O目测应该是新的特征种子。

然后我们重复第二步到第三步的循环。

收敛判定:

这里我们可以看到我们从第二次划分子集开始, 就开始进行了循环, 那这里有个问题: 我们如何判断我们应该结束循环返回结果了?

这里有两个方案:

1. 暴力指定循环次数

2. 总种子距离比值比较

   我们在子集中寻找种子的时候, 记录下每个子集中种子到其他元素的距离和,上图中, 我们这个数值就是 (E分别到A, J, M和N的距离和)  +  (C 分别到D, K, B, L, G 和H的距离和)   +  ( O 分别到P, Q , F , R 和I  的距离和)
  每轮循环分划子集结束后, 如果这个值和上次的比值小于某个给定的阀值, 将停止循环

代码模拟

见附件

 

分享到:
评论

相关推荐

    和智云仓库管理系统(WMS)高保真原型

    和智云仓库管理系统(WMS)系统功能介绍: 1、入库功能: 1)货物到达仓库,根据采购订单进行核实,开箱验货,根据WMS系统组合信息进行条码打印、粘贴、放置托盘区; 2)利用PDA进行扫码核验,通过系统对库位进行...

    仓库管理系统WMS专题介绍PPT课件.pptx

    仓库管理系统在企业中的地位非常重要,企业运用WMS接入企业的企业资源计划即ERP(Enterprise Resource Planning)系统中,同时结合企业SCM(Supply chain management)供应链管理模块,可以和贸易伙伴、贸易联盟轻松...

    C#WMS仓库管理系统源码 WMS仓储管理系统源码数据库 SQL2008源码类型 WinForm

    WMS仓储管理系统作为现代物流系统中的主要组成部分,是一种多层次存放货物的高架仓库系统,由自动控制与管理系统、货架、巷道式堆垛机、出入库输送机等设 备构成,能按指令自动完成货物的搬运、存储作业,并能对库存...

    WMS仓库管理系统-winform

    仓库管理系统(WMS,Warehouse Management System)是企业信息化建设中的重要组成部分,主要用于优化库存控制、提升物流效率。本系统采用C#编程语言与Winform技术进行开发,结合了Dev2018.1第三方控件,以提供用户...

    JAVA版WMS仓储管理系统源码 物流仓库管理系统源码

    JAVA版WMS仓储管理系统源码 物流仓库管理系统源码 源码介绍: 基于JAVA开发的物流仓库管理系统(支持自营和第三方),包含PDA端和WEB端。 WMS在经过多家公司上线运行后,为了降低物流仓储企业的信息化成本...

    和智云仓库管理系统(WMS)高保真原型设计 演示网页

    和智云仓库管理系统(WMS)系统功能介绍: 1、入库功能: 1)货物到达仓库,根据采购订单进行核实,开箱验货,根据WMS系统组合信息进行条码打印、粘贴、放置托盘区; 2)利用PDA进行扫码核验,通过系统对库位...

    广州溯源DESOFT条码RFID仓库管理系统WMS

    广州溯源DESOFT条码RFID仓库管理系统WMS

    java jsp 仓库管理系统 wms 源码 源代码 程序 PC+Android 包含PDA端和WEB端.zip

    java jsp仓库管理系统 PC+Android 1、适用范围:第三方物流仓储企业,自营仓储等。 2、技术特点:基于JAVA的WEB后台, 基于ANDROID开发的PDA系统, 3、功能特点:涵盖订单管理系统(OMS),仓储管理 系统(WMS),计费...

    船舶智能制造技术:仓库管理系统(WMS).pptx

    在船舶智能制造的浪潮中,仓库管理系统(WMS)以其先进的技术特性,正在引领着仓储行业的一次重大变革。WMS不仅标志着仓库管理从传统的人工操作向自动化、智能化的迈进,而且在物流领域中扮演着至关重要的角色,尤其...

    智慧工厂立体仓库管理系统WMS解决方案.pptx

    智慧工厂立体仓库管理系统WMS解决方案 智慧城市、大数据、人工智能是当前热门话题,而智慧工厂立体仓库管理系统WMS解决方案正是将这些技术融合到一起,创建出一个高效、智能、自动化的仓库管理系统。本文将对智慧...

    仓库管理系统WMS.pptx

    仓库管理系统 WMS.pptx 仓库管理系统 WMS 是一种专业化的仓库管理软件,旨在帮助企业实现仓库管理的现代化。该系统能够对仓库作业的管理更细致、更全面,实现仓库管理的自动化和智能化。 WMS 系统的核心业务是面向...

    ASP.NET WMS仓库管理系统

    Wms仓库管理系统 源码描述: 一、源码介绍 这是一款仓库管理系统,主要采用了netcore3.1+mysql/sqlserver+EFCor架构,适合进行二次开发管理系统使用。 二、主要功能: 用户管理 角色管理 部门管理 数据字典...

    2仓库管理系统WMS.ppt

    【仓库管理系统WMS】是现代企业管理中不可或缺的一部分,它代表了Warehouse Management System,主要用于精细化、全面化地管理仓库作业流程。WMS系统旨在提升仓库效率,优化库存控制,确保物流配送中心的各项核心...

    ASP.NET MVC 多用户仓库管理系统源码/WMS/C#源码/云仓库管理系统

    这是一款基于ASP.NET MVC + Bootstrap的仓库管理系统。 新增了多仓库,多企业,采购销售,以及财务部分模块。 便于二次开发,可以快速应对一部分中小型客户需求。 主要功能模块 系统设置 (1)员工管理; (2)角色管理; ...

    推荐一款永久免费的仓库管理系统WMS软件(绝对可用).rar

    可用作自动化立体仓库管理系统、普通人工仓库管理系统、进销存系统、三方物流仓库管理系统。已经证实,真实可用,系统运行稳定,界面友好。文件内包含:数据库文件、服务端、客户端、后台配置工具、安装说明和操作...

    wms.zip_php仓库_php仓库管理_wms_仓库管理WMS_盘点系统

    仓库管理系统(Warehouse Management System,简称WMS)是企业内部物流管理的重要工具,尤其在信息化高度发展的今天,它已成为企业提高运营效率的关键环节。本文将深入探讨一个名为“wms”的PHP仓库管理系统,包括其...

    仓库管理系统wms-master.zip

    综上所述,"wms-master.zip"中的仓库管理系统是一个综合运用JavaWeb技术的复杂项目,涵盖了从数据库设计到前端展示,再到系统集成和安全控制等多个层面的知识,为企业提供了一套全面的仓库管理解决方案。

    金讯WMS仓库管理系统.ppt

    金讯WMS仓库管理系统 金讯WMS仓库管理系统是一种综合性的仓库管理系统,旨在帮助企业更好地管理仓库业务,提高物流效率,降低成本。该系统的主要功能包括基础信息管理、入库管理、出库管理、在库管理、统计查询、...

    ThinkPHP仓库管理系统,wms仓库进销存系统源码+数据库,主要模块有采购管理、销售管理、仓库管理、报表查询、系统管理等

    简单的仓储管理系统,能对商品种类、商品库存、 采购、货位、入库、出库、盘点等仓储动作和数据进行监控, 提升WMS的管理效益。 仓库管理,进销存系统 主要模块有采购管理、销售管理、仓库管理、报表查询、 系统管理...

Global site tag (gtag.js) - Google Analytics