【转】云社区 博客 博客详情 二维异形件排版算法介绍(一)

转自:https://bbs.huaweicloud.com/blogs/175385

【摘要】 排样问题(Nesting Problem)又称为下料问题(Cutting and stock problems)或填充问题(Packing Problem),其目标是在材料切割过程中寻找一个较高的材料利用率。排样问题属于经典的NP-Hard问题,其时间复杂度随着问题规模的增加迅速上升,难以在合理时间内精确求解大规模实例。

算法简介

 

排样问题(Nesting Problem)又称为下料问题(Cutting and stock problems)或填充问题(Packing Problem),其目标是在材料切割过程中寻找一个较高的材料利用率。排样问题属于经典的NP-Hard问题,其时间复杂度随着问题规模的增加迅速上升,难以在合理时间内精确求解大规模实例。相较于矩形排样问题,异形件排样问题的突出特点是裁片的边界轮廓复杂,计算过程中需要复杂的几何运算,其算法复杂度将进一步上升,是学术界和工业界公认的难以求解的问题。因此在大多数情况下,不规则形状排样算法主要是以启发式算法和智能搜索算法为主。

综上所述,二维异形件排样算法涉及到的关键技术主要有三个,如图1所示,分别是高效率的几何算法、排样策略和优化算法。

图1. 排样算法关键技术

NFP求解算法

 

二维异形件排样算法的一个相当重要的方面是计算几何算法,其主要内容在于计算异形件之间的靠接位置、确定裁片与面料之间的包含关系、判断是否重叠以及实现二维区域之间的交、并、差等布尔运算。

为寻找一种更简便高效的靠接和重叠判断计算方法,研究人员提供了临界多边形(No-Fit Polygon,NFP)的概念[1]。临界多边形NFP的简要定义如下:给定两个多边形,其中一个固定,另一个多边形围绕固定的多边形作不旋转的刚体运动,并围绕固定多边形滑动,直到回到起点位置,在此过程中在运动多边形上选取一点作为参考点,则参考点在环绕过程中形成的轨迹就称为临界多边形,如图2所示。

 

 

图2. 临界多边形概念(图片来源:参考文献[2])

NFP求解还会遇到特殊场景,如图3所示,图a由于多边形A存在凹槽,多边形B可以在凹槽内部移动,此时将形成空腔NFP;图b由于多边形B恰好可以沿着多边形A凹槽移动,此时NFP将退化成线;图c多边形B恰好可以放在多边形B凹槽内,此时NFP将退化成点。NFP求解算法同时要考虑这些特殊情景。

 

图3. 特殊NFP场景:a. 空腔NFP;b. NFP退化成线;c. NFP退化成点(图片来源:参考文献[3])

由于临界多边形的重要性质,NFP目前已成为二维不规则形状排样算法的基础性几何工具。如何快速准确的计算出NFP是异形件排样问题的关键技术。学界目前的求解算法主要有4种,分别是凸化分割法、移动碰撞法[4]、明科夫斯基矢量和法[5]以及轨迹线法[2]。简要介绍如下:

(1)凸化分割法。凸化分割法基本思路是将凹多边形分割为凸多边形,然后求得凸多边形之间的NFP,最后将凸多边形的NFP进行合并得到最终的NFP。凹多边形凸化分割的算法有多种,例如三角划分、凹点划分、条带分割、角平分线分割等。设多边形边数为n,凹点个数为r,目前最少次数分割算法时间复杂度不超过O(n+r2min(r2,n)), 当简单多边形的凹点个数达到n/2时,该分割算法的复杂度已达到O(n3)。如果再加上求解凸多边形的NFP和求解多边形并集的布尔运算,该方法的时间复杂度将进一步增加。此外,该方法可以得到内部空腔NFP,但是对于NFP退化场景,标准多边形求并运算无法得到。

(2)移动碰撞法。移动碰撞法的基本步骤如下:如图4所示,首先根据多边形A和B当前时刻的靠接状态,得到B下一步的移动方向,在该移动方向上,计算出A和B之间的最小碰撞距离,从而得到移动距离,根据移动方向和移动距离,将B移动到新的位置,然后重复以上过程,直至绕完一圈,回到初始位置。该算法比较容易实现,但是该算法总的时间复杂度较高,达到(O(m+n)mn)。此外,该算法可以处理空腔NFP和退化NFP等特殊场景。

 

图4. 移动碰撞法计算NFP(图片来源:参考文献[2])

(3)明科夫斯基矢量和法。两个凸多边形之间的NFP等价于计算两者的明科夫斯基矢量和,其算法复杂度为O(m+n)。其基本求解思路如下:如图5所示,首先多边形A(固定多边形)按照逆时针排列,多边形B(移动多边形)按照顺时针排列。然后,将多边形A和多边形B的所有边矢量置于原点(0,0),接着,对所有边矢量按与起始矢量的夹角从小到大排序,最后将排序后的边矢量进行串联累加,即可得到A和B的临界多边形NFPAB。然而,当两个多边形中有一个为凹多边形时,凹边的遍历次序将会被打乱,从而不能合成一个临界多边形。为解决此问题,研究人员引入了斜率图的概念来解决此问题[5,6]。然而,该方法实现复杂,时间复杂度也比较高,最坏情况下的时间复杂度为O(m2n2log(mn))。此外,该算法也可以处理空腔NFP和退化NFP等特殊场景。

图5. 明科夫斯基矢量和法求解凸多边形NFP(图片来源:参考文献[2])

(4)轨迹线法。轨迹线法的基本原理是:如图6所示,首先求得多边形每个顶点相对于另一个多边形的所有轨迹线,然后从轨迹线集合中得到外围多边形和内部顺时针环,即为临界多边形。该算法从NFP的本身定义出发,算法过程简单,平均时间复杂度为O(mn),并且能够处理内部空腔NFP和退化NFP等特殊情景。

 

图6. 轨迹线法NFP算法原理图(图片来源:参考文献[2])

总结

NFP是二维异形件排样算法的基础性几何工具,实现不好将严重影响排样算法性能。作者曾采用凸化分解法求解100个多边形的NFP,由于多边形平均点数较大(平均82个),单纯计算NFP的时间开销就达到半小时。因此,非常有必要对各种NFP求解算法进行比较分析,选择一种高效的NFP求解算法。表1总结了4种NFP算法的时间复杂度,以及是否可以处理特殊情景。

文献[2, 4, 5]是各种NFP求解算法的巅峰之作,建议初学者先从移动碰撞法[4]入手学习(该文实现细节讲解清楚,其余文章则较少),然后再考虑实现其他方法。

 

表1. 4种NFP求解算法对比

 时间复杂度能否处理内部空腔能否处理退化场景
凸化分解法>O(m3+n3)YesNo
移动碰撞法O((m+n)mn)YesYes
明科夫斯基矢量和法O(m2n2log(mn))YesYes
轨迹线法O(mn)YesYes

  更多有关排版算法的介绍将在后续博客中更新,欢迎大家关注。

参考文献

 

[1] Adamowicz M, Albano A. Nesting two-dimensional shapes in rectangular modules[J]. Computer-Aided Design, 1976, 8(1): 27-33.

[2] Huyao L, Yuanjun H, Bennell J A. The irregular nesting problem: a new approach for nofit polygon calculation[J]. Journal of the Operational Research Society, 2007, 58(9): 1235-1245.

[3] Bennell J A, Oliveira J F. The geometry of nesting problems: A tutorial[J]. European journal of operational research, 2008, 184(2): 397-415.

[4] Burke E K, Hellier R S R, Kendall G, et al. Complete and robust no-fit polygon generation for the irregular stock cutting problem[J]. European Journal of Operational Research, 2007, 179(1): 27-49.

[5] Bennell J A, Song X. A comprehensive and robust procedure for obtaining the nofit polygon using Minkowski sums[J]. Computers & Operations Research, 2008, 35(1): 267-281.

[6] Ghosh P K. A unified computational framework for Minkowski operations[J]. Computers & Graphics, 1993, 17(4): 357-378.


 

登录后可下载附件,请登录或者注册

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区),文章链接,文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件至:huaweicloud.bbs@huawei.com进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/435993.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

增加RIL组件时编辑出现的问题

当我把RIL组件加进到CE6的项目里去编译,本来好好的项目编译不过去了,我就选择了RIL的所有feature,没有改任何东西,理论上sysgen就可以了,但是确总是编译不过去 看根目录下的build.log: E:/WINCE600/OSDesigns/POS410/POS410/Wince600/E6000_ARMV4I/cesy…

android 微信两个服务的,微信上线两个新功能

微信又上线新功能了!一个与你的钱包相关,一个与你的微信号相关,赶紧来看看吧微信支付分全面开放每个微信用户都拥有自己的一个分数值 ,且每月根据综合数据更新一次。达到一定的分值门槛,用户即可享受超千项便捷服务。这…

【转】二维异形件排版算法介绍(二)

转自:https://bbs.huaweicloud.com/blogs/196289【摘要】 二维不规则异形件主要有两种策略:分别是基于可行解的排样策略和基于重叠移除的排样策略。所谓基于可行解的排样策略,是指在排样过程中零件之间始终是不重叠的,而基于重叠移…

解决用户控件循环引用的笨办法

在上一篇中提到使用MagicAjax开发了一个项目,因为做这个项目之前对MagicAjax不是很了解,在里面使用了用户控件,我发现这是一个很致命的错误,用户控件在MagicAjax中用起来很痛苦.因我们的项目不是简单的只要求"看起来像"没有刷新页面,其中一个主要的页面有那么一点点复…

【转】介绍一些免费/开源的医学影像后处理工具

转自:https://blog.csdn.net/liaopiankun0618/article/details/84328331 来源:融视影像科技 综述 医学影像的处理有两个特质。一是复杂,整个处理流程涉及多种算法,需要调整的参数较多。二是发展快,从采集、重建到后…

android 安卓市场,安卓市场(Android Market).doc

安卓市场(Android Market)安卓市场(Android Market)Android (HiMarket) China market is the earliest and largest Android software and online game download platform, Netdragon well-known products, provide good service for users of mobile phone software. Since it…

IROM 浅见

IROM其实是三星已经固化在CPU里面的一段代码,我们要做的事情就是提供一段可以供IROM读取的8K代码程序,至于这8K代码放在哪里,由CPU的相关引脚决定(OM1-OM4,GPN13-GPN15)。也就是说从哪里启动的意思。 如果从…

LINQ是死是活?——很奇怪为什么会有这样的话题?

LINQ是死是活??? 如果我问您:机器代码死了吗?汇编死了吗?C死了吗?VB6.0死了吗?Delphi死了吗?您可能会觉得我很无聊。所以我觉得“LINQ是死是活”的说法也很奇怪? LINQ诞…

android gradle 语法,Gradle 1.语法

8种机械键盘轴体对比本人程序员,要买一个写代码的键盘,请问红轴和茶轴怎么选?gradle 语法解析:gradle的语法十分简洁,以至于看起来跟像是配置文件。先看一个简单的android项目完整的gradle脚本:build.gradle123456789101112131415…

【转】二维异形件排版算法介绍(三)

转自:https://bbs.huaweicloud.com/blogs/203947 【摘要】 相比于基于可行解的排样算法,重叠移除算法在改变解的状态时,允许零件之间发生重叠,然后采用分离技术消除重叠,直到达到算法的终止条件为止。重叠移除算法的关…

WinCE6.0中应用程序如何直接访问物理空间

在实际开发过程中,经常希望能在应用程序中直接读写设备的物理空间。以前在做WinCE6.0下的MEMMgr时通过秘密加载一个内核态驱动实现了这个需求。但这种方式有一个明显的缺陷,每次读写都必须经由它才能完成。如果只是读取GPIO,那问题不算大。如…

开博之文

逛园子很久了,读而不写非礼也。分享技术,交流经验,体味人生,本博主旨,此为09年的开年大事。转载于:https://www.cnblogs.com/imstand/archive/2009/01/11/1373712.html

【转】Dicom格式文件解析器!!!!!!!

转自:https://www.cnblogs.com/assassinx/archive/2013/01/09/dicomViewer.html Dicom全称是医学数字图像与通讯,这里讲的暂不涉及通讯的问题 只讲*.dcm 也就是diocm格式文件的读取,读取本身是没啥难度的 无非就是字节码数据流处理。只不过确…

android 设置view最大高度,android-在RecyclerView上设置最大高度

我有一个对话框片段,其中包含线性布局,其中涉及RecyclerView上方的titleText,在最底部,recyclerView下方有一个按钮.由于recyclerView根据适配器设置的项目数展开或折叠,因此按钮有时会被截断并且不再显示在屏幕上,因为recyclerView仅覆盖整个屏幕.我的问题是,有没有一种方法可…

【转贴】利用 Javascript 获取 URL 参数(适合IE、FF)

.  ... .../test.html?str123456如何用Javascript接收类似上面的url参数呢?这个问题网上有很多答案,看了看,主要有两种,一个是利用字符串的截取,另一种是利用正则表达式。[正则式&#xff3d…

【WinCE】流设备驱动简介及GPIO驱动的实现

流设备驱动实际上就是导出标准的流接口函数的驱动,这是文档上面的定义。在WinCE中,所有的流设备都导出流设备接口,这样WinCE中的Device Manager可以加载和管理这些流设备驱动。 流设备驱动的架构如图: 首先我声明一下,…

android contentprovider api,Content Provider Basics

一个内容提供者访问数据的中央资源库。提供者是应用程序的一部分,提供自己的操作数据的UI。然而,内容提供者主要是被其他应用程序引用,通过提供者客户对象访问提供者。提供者和提供者客户端为数据提供一个一致的,标准的接口&#…

【转】医学影像调窗技术!!!!

转自:https://www.cnblogs.com/assassinx/p/3139505.html 在年初的时候做过一个dicom格式文件解析,当时只是提了下。看着跟别人的显示出来也差不多 其实是我想太简单了。整理了下思路 这里提供正确的调窗代码。 医学影像 说得挺高科技的 其实在这个过程…

开始-运行 下常用快捷命令

在“开始”菜单上单击“运行“,输入 1. eventvwr.msc /s 打开事件查看器 (可查看系统日志) 2.gpedit.msc 打开组策略 示例:在Windows Server 2003中关闭系统事件跟踪程序: 单击“开始→运行”,输入gped…

解决6410 WINCE6 应用层调用SetSystemPowerState api关机无效的问题

6410平台下的wince6系统,在应用层中使用SetSystemPowerState api函数关机发现无效。 应用层调用如下: [cpp]view plaincopy SetSystemPowerState(NULL, POWER_STATE_OFF, POWER_FORCE); 注:该调用需要引用pm.h头文件,该头文件在…