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

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

【摘要】 相比于基于可行解的排样算法,重叠移除算法在改变解的状态时,允许零件之间发生重叠,然后采用分离技术消除重叠,直到达到算法的终止条件为止。重叠移除算法的关键技术点主要有:重叠度量方法、零件扰动技术、重叠消除技术。

1       二维异形件排样算法

上两篇博客提到二维异形件排样算法涉及到临界多边形(NFP)的求解算法,以及排样算法的排样策略,感兴趣的童鞋可以查看博文:          https://bbs.huaweicloud.com/blogs/175385

https://bbs.huaweicloud.com/blogs/196289

2       二维异形件重叠移除排样算法

 

相比于基于可行解的排样算法,重叠移除算法在改变解的状态时,允许零件之间发生重叠,然后采用分离技术消除重叠,直到达到算法的终止条件为止。重叠移除算法的基本流程伪代码如下图所示:

 

图1. 重叠移除算法基本流程伪代码(图片来源:参考文献[1])

其中,MinimizeOverlap函数是重叠移除算法的关键,涉及到的关键技术点主要有:重叠度量方法、零件扰动技术、重叠消除技术。下面分别就这三个方面进行简要介绍。

 

2.1   重叠度量方法

两个零件之间的重叠指标主要有三种方式,如图2所示,分别是重叠面积、最小嵌入深度,以及最小横向/纵向嵌入深度等。重叠面积是最直接的衡量零件重叠的方法,但是此种方法最大的问题是计算复杂度高,每移动一次零件,都要求计算其与其他零件的重叠面积。第2种重叠衡量方法是最小嵌入深度。所谓嵌入深度,是指为消除重叠,按照某个方向移动其中一个零件的距离。所谓最小嵌入深度,是指所有可能方向的嵌入深度的最小值。第3种重叠移除方法是第2种方法的特例,限制可能方向为横向和纵向两种。

 

图2. 重叠指标计算方法:(a) 重叠面积;(b) 最小嵌入深度;(c) 最小横向/纵向嵌入深度

 

 

重叠移除算法的一个主要瓶颈是计算量大,其中,零件重叠度量是其中主要瓶颈之一。为提高算法效率,学术界提出了很多种改进算法[2,3,4]。以第2种方法为例,直接的思路是计算参考点相对于NFP每条边的最小距离,从中选择最小值即为最小嵌入深度。这个方法的时间复杂度是O(n),其中n表示NFP的边个数。为简化计算,可采用Medial Axis算法对NFP进行剖分,当参考点落在其中某个剖分时,参考点到该剖分对应线段的最小距离即为该点到NFP所有线段的最小值。如图3所示,当参考点为v1时,其到线段s3的最小距离即为该点到NFP所有线段的最小距离。

 

图3. NFP的Medial Axis剖分(图片来源:参考文献[3])

2.2   零件扰动技术

零件扰动技术主要包括三大类:平移、旋转和交换[5]。扰动的目的是破坏当前的解结构,使零件之间产生重叠,以便使用重叠移除技术消除之。从优化的角度分析,零件扰动是为了跳出当前的局部最优解,向更优解进发的必要步骤。

2.3 重叠移除技术

 

重叠移除技术主要有两种策略:每次移动所有零件和每次移动一个零件。分别介绍如下:

(1)每次移动所有样片

以文献[3]中的基于非线性优化算法(LBFGS)的重叠移除方案为例,该算法使用重叠零件间的嵌入深度衡量重叠程度,以当前排样方案中所有零件间嵌入深度的加和作为优化目标,将消除重叠转化为一个连续优化问题进行求解。如图4所示,该算法将消除零件间重叠所需的最小位移定义为梯度函数,在梯度信息指导下进行零件的移动。相较于其他基于重叠移除策略的排样算法,该算法的局部寻优能力更强,但也更容易陷入局部病态解导致消除重叠失败。

 

图4. 零件间嵌入深度与最小分离向量

(2)每次移动一个样片

该算法每次只移动一个重叠零件。若移动后重叠指标变小,则保留此次移动,否则不进行移动。此方法主要涉及候选位置寻找算法和全局寻优算法。零件候选位置的选择通常有两种方法:一种是依次按照长度方向和宽度方向移动零件,直到零件重叠指标最小为止[4]。如图5所示,重叠零件通过3次移动最终寻找到了不发生重叠的位置;另一种是采用搜索算法,比如布谷鸟邻域搜索算法,迭代寻找重叠指标最小的点[1]。全局寻优算法一般采用Guide Local Search(GLS)算法,每次迭代后通过更新惩罚因子跳出局部最优[1,4]。

 

图5. 重叠零件候选位置寻找算法

3  总结

 

重叠移除算法原理简单,但要想实现一个高效可行的解决方案却并不容易。面临的主要难点主要有三点:

(1)  高效的计算几何算法:其中,NFP计算是首先需要攻克的难题之一;

(2)  高超的编程实现能力:重叠移除算法有部分功能函数是高频调用函数,实现细节对算法效率影响较大,一般情况需要持续优化;此外,所有的商用排版软件都采用了并行化实现方式,并行化实现方案对算法效率和效果影响也较大;、

(3)   参数调节:学术界对异形件排版算法的细节往往很少或没有介绍,这导致复现的算法几乎都达不到论文中呈现的结果,因此需要实现者自己调整算法参数,或者提出全新的改进方案。

   至此,二维异形件排版算法介绍完毕。若有问题,欢迎大家留言交流。

 

 

参考文献

 

[1] Elkeran A. A new approach for sheet nesting problem using guided cuckoo search and pairwise clustering[J]. European Journal of Operational Research, 2013, 231(3): 757-769.

[2] Egeblad J, Nielsen B K, Odgaard A. Fast neighborhood search for two-and three-dimensional nesting problems[J]. European Journal of Operational Research, 2007, 183(3): 1249-1266.

[3] Imamichi T, Yagiura M, Nagamochi H. An iterated local search algorithm based on nonlinear programming for the irregular strip packing problem[J]. Discrete Optimization, 2009, 6(4): 345-361.

[4] Umetani S, Yagiura M, Imahori S, et al. Solving the irregular strip packing problem via guided local search for overlap minimization[J]. International Transactions in Operational Research, 2009, 16(6): 661-683.

[5] Heckmann R, Lengauer T. A simulated annealing approach to the nesting problem in the textile manufacturing industry[J]. Annals of Operations Research, 1995, 57(1): 103-133.

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

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

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

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

相关文章

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头文件,该头文件在…

【转】理解字节序 大端字节序和小端字节序

转自:https://www.cnblogs.com/gremount/p/8830707.html 以下内容参考了 http://www.ruanyifeng.com/blog/2016/11/byte-order.html https://blog.csdn.net/yishengzhiai005/article/details/39672529 1. 计算机硬件有两种储存数据的方式:大端字节序…

Web-DispatcherServletUrlPatterns

Web-DispatcherServletUrlPatterns 在MANIFEST.MF文件中指定了Web-DispatcherServletUrlPatterns时千万要注意它的规则,首先它必须是符合servlet的url-pattern的,其规则如下: 在web.xml文件中,以下语法用于定义映射: …

WCHAR char CString等常用类型互转

1、CString to WCHAR*: [cpp]view plaincopy WCHAR *wch (WCHAR*)str.GetBuffer(str.GetLength()); str为CString类型。 2、WCHRA* to char*: [cpp]view plaincopy memset(buf, 0, bufInLen); // WCHRA to char WideCharToMultiByte( CP_ACP, 0, wch, -1, buf,…

html文件自动批阅器怎么设计,作业作业提交与批改系统HTML界面.doc

作业作业提交与批改系统HTML界面作业1-作业提交与批改系统HTML界面请根据以下需求部分功能或全部全部功能HTML界面代码;注意HTML代码附在本文后面一、作业提交与批改系统系统功能图基本功能1.学生注册2.学生、教师、管理员密码找回功能3&…

【转】Photoshop保存格式介绍大全

01 PSD格式 PSD格式:PSD是Photoshop默认的文件格式,他可以保留文档中的所有图层、蒙蔽、通道、路径、未栅格化的文字、图层样式等。通常情况下,我们都是将文件保存为PSD格式,以后可以对其修改。PSD是除大型文档格式(PS…

创建windows服务,定时监控网站应用程序池

最近网站总是报"Timer_Connection"错误,导致该网站所使用的应用程序池由于错误过多停止运行,网站也就出现了service unvaliable,无法访问,在网上查了很多资料,结果很让人无奈,这个问题已经困扰我了很久,一直没有得到解决,后来同事发来一篇文章让我有了新的解决方法,虽…

UNICODE十六进制数组转成中英文

UNICODE十六进制的数组转成中英文 实现char*转换成中英文,每两个char合成一个wchar_t: [cpp]view plaincopy // UNICODE十六进制数组转成中英文 // hex array to wchar_t* // wchs NULL, wchsLen as output(the size of wchs will be used) // er…

html+选择弹出选项卡,javascript – Chrome扩展程序:从弹出窗口获取当前选项卡

我正在撰写Chrome扩展程序,在其中一部分,当弹出页面上的按钮被点击时,我需要获取当前选项卡的标题和URL。我之前已经和Chrome的消息传递系统一起工作了,并且经过许多努力,已经设法让它在许多场合工作。不过&#xff0c…

【转】Qtcreator中常用快捷键和小技巧

转自:https://blog.csdn.net/imxiangzi/article/details/48863855 https://blog.csdn.net/jh1513/article/details/52346802 快捷键及对应含义 下载地址:http://download.csdn.net/detail/jh1513/9615209 快捷键 功能 Esc 切换到代码编辑状态 F1 …

添加蜂窝注册表及永久存储

1、 添加 Hive-based Registry 在 Platform Builder 的“ Catalog ”窗口中,单击打开 Catalog->Core OS->Windows ce devices->File Systems and Data Store->Registry Storage(Choose 1)->Hive-based-based Registry 节点,选中 Hive-b…