矩形件排样程序实现(要求:只能由一个学生独立完成,不得抄袭) 工业上经常需要在一块大板材上下料得到若干个小的矩形件,使得板材的利用率最高,即所剩余的边角料最少。例如在一块宽40、高15的矩形板材上,排列25块尺寸已知的小矩形,25块小矩形的尺寸如表1,板材的利用率达100%,如图1所示。 file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-14128.png 图1 一种排样方案 表1 小矩形的尺寸 如果上述排样方案未知,即不知道图1的排法,那么如何将这25块小矩形按照某种次序排在一个大的板材上呢?目前这仍是一个世界难题。 通常要求在一个排样图中,任何一个矩形件在不超出板材边界的情况下,按照一个排样方案(给定的次序)采用下列一些方法来安排实际矩形件的排列,对于一个排样方案(解)file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-19663.png,其中file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-22856.png,file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-5836.png,pi为矩形件的序号,r
5 V! m! H( L& Bi为排样方式,r
y) ]" I( g7 E' m8 Z+ zi=1表示将矩形件旋转90°," k! x! V; C- ]* z+ b& H7 f
r' }$ S- r* ]% K0 k) B
i=0表示矩形件不旋转。将第i个矩形件安排在板材上的过程中,均不能再往下、往左移动,则称其满足BL条件(bottom-left-condition,BL-condition)。 基于BL条件,有一种下台阶算法,具体步骤如下: (1) 将零件file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-5288.png排放在板材的左下角,若file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-6738.png则将其旋转90°后再排放,求出排放后所占板材的最大高度; (2) 将file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-25672.pngfile:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-11128.png根据其排样方式置于板材右边最大高度处,向下向左移动file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-1248.png,且向下移动优先(即原本已无法再向下移动,故开始向左移动,而在向左移动的过程中若发现又能继续向下移动,则先向下移动),直至file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-20777.png无法向下向左移动为止(即接触到其他零件或板材边界),并求出此时的最大高度; (3) 重复上述过程,直至所有零件排放完毕,最后所得最大高度即为所需板材高度。 其排样过程如图2所示,就好象下台阶一样,于是形象地称之为下台阶算法。
; e! G% J a8 o( I6 ?7 T/ _4 h file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-29311.png 图2 下台阶算法的排样过程 剩余矩形排样法是目前所提出的一种有效的排样算法,该方法记录了所有可利用的空间,更能合理地分配给待排样的矩形件,提高了每个排样方案的板材利用率,更接近最优排样方案。例如对于同一个矩形件序列file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-3294.png进行排样,图3(a)中下方的空洞以往的排样算法都无法利用,矩形4只能被排到上方。而利用剩余矩形排样法可以很好的解决这个问题,它可以使矩形4充分利用下方的空间,如图3(b)。 file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-20428.png 图3 剩余矩形排样法的优越性 剩余矩形排样算法用一个矩形数据集合来表示板材目前的剩余位置情况,任何未被排样的空间(包括孤立的缝隙),都在剩余矩形集合中表示,不会遗漏任何一个。而在每一个矩形件被排入前,都需根据这个剩余矩形集合中的数据来选择最为合理的位置进行排放。下面给出剩余矩形的具体形成方法(这里用矩形的左下角坐标和右上角坐标来确定这个矩形的的位置): (1) 板材的左下角和右上角坐标分别为file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-26959.png,于是开始时剩余矩形数据集中只有一个矩形为file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-27790.png。 (2) 当排入一个矩形件file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-20334.png(宽file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-3366.png高file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-23654.png)后,需将剩余矩形数据集合中的每一个矩形都减掉此矩形件所占的位置。若此矩形件的左下角坐标为file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-25374.png,且为横排(即矩形件不旋转90°),则每个剩余矩形都减掉与矩形件file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-2172.png相交的部分。例如矩形file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-26371.png减掉与矩形件file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-11772.png相交的部分后,形成了四个新的剩余矩形为: file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-1559.png$ H: U- {8 k8 ?# B* x0 d
file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-14496.png 按顺时针方向记录矩形。如图4所示。若为竖排(即矩形件旋转90°),计算方法类似。 file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-27305.png ; W, T+ |7 r1 L% N2 g
1 e. R8 W# W1 U7 V; O
2 I, ?, V; \" R6 g! `% p
3 M9 l! Q7 N6 ^. {4 Q
; e' V9 ?) v/ D- [, B, Y9 O6 K
" ? B6 U8 P( j/ z' t6 [# u
; A5 u& V" K/ C" B
/ k( E5 V& P0 v9 ` r% z! i- Q
1 [4 j) W: i& o9 l) u p
7 n: @: L* B% o
G6 T' O( J$ j& }: x _; L
) y: A/ [$ V& p
% [% b' e$ x" {; q' f) u
! A( Q5 B# ?/ H! q( \7 V; {
. l0 G0 L7 [7 M9 D
t9 D0 c3 T3 i8 j1 R) S7 @/ k
图4 剩余矩形表示法 依此类推,将矩形数据集中的所有剩余矩形都作如此操作,减去所排入矩形件file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-18702.png所占位置,形成新的剩余矩形。 (3) 由于新的剩余矩形的产生,又将引起原矩形数据集的改变,因此对其进行整理:去掉面积为零的或已无法排下所剩的任何一个矩形件的剩余矩形;把具有完全包含关系的剩余矩形中面积小的矩形去除、有相交关系的矩形全部保留。得到新的剩余矩形集,为下一次排放使用。 用剩余矩形表示法可记录每个可形成最大矩形的空间,用于排样。将这种表示法与BL排样算法结合,就形成了剩余矩形排样算法,对于给定的一个排样方案file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-7186.png,其中file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-13661.png,file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-23460.png,具体排样过程如下: (1) 开始时剩余矩形集file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-22218.png中仅有一个矩形,即板材本身file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-3602.png。 (2) 从排列file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-22016.png中取出第一个需排的矩形件file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-15639.png(宽file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-29337.png,高file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-23406.png),将file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-26571.png根据相应排放方式 file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-1361.png排放在板材的左下角,用上面所述的剩余矩形表示法计算新的板材剩余矩形集file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-24413.png: 若file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-2578.png(横排),则file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-14132.png,file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-30412.png,如图5; 若file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-7952.png(竖排),则file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-29899.png,file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-15602.png。 file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-10665.png 图5 剩余矩形排样过程 (3) 依此类推,按顺序逐一排放file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-28784.png,直至所有矩形排放完毕。每放入一矩形件,都需根据剩余矩形集确定其排放位置,即在剩余矩形集中选择宽高均大于等于此矩形件的底部最低的最靠左的剩余矩形(先靠下后靠左),让矩形件与剩余矩形的左下角重叠。同时放入矩形后要对剩余矩形集进行整理更新。 同样,剩余矩形排样算法也满足BL条件。 我们的问题叙述如下: 现在有宽为15、高为充分大的板材(即板材的高度没有限制),将表1中的25块矩形安排到板材上有下列3种排样方案: (1)P=(4,2,1,3,6,5,7,9,8,10,11,12,14,13,19,15,18,17,20,16,21,22,24,23,25); R=(1,1,1,1,1,1,1,1,1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1); 具体排样图见图6. (2)P=(10,5,1,13,23,24,22,8,14,4,7,25,11,19,6,2,16,20,18,9,17,3,12,15,21); R=( 0,1,1, 1, 0, 1, 1,0, 1,1,1, 0, 0, 1,1,1, 0, 1, 0,0, 0,1, 1, 0, 0); 具体排样图见图7. (3) P=(23,21,20,16,17,2,24,25,9,3,5,8,22,14,15,18,7,6,10,19,4,12,11,13,1); R=( 0, 0, 1, 0, 1,1, 0, 0,0,1,0,1, 0, 0, 0, 1,0,1, 1, 0,1, 0, 1, 0,0); 具体排样图未给出,由参赛同学编制相应程序绘制。 现在的问题是,请学生根据剩余矩形排样算法编制一个通用的程序仿照图6、图7绘制上述3种排样方案的图形(由程序自动绘制,不是手工绘制)。使用语言不限,最后成果需提交程序清单、程序使用说明以及由程序绘制的三张排样图。 file:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-8201.pngfile:///C:/DOCUME~1/Jk/LOCALS~1/Temp/ksohtml/wps_clip_image-17760.png
7 T7 [1 P) P9 _# }/ g
8 k/ Q* W" K5 W$ C# N+ ^- M/ |) x
E3 R7 H2 U$ K2 E) C1 q
: I) l( _- f3 P' H1 {; p" v8 [/ L
4 j( a% o% e7 f# l4 y
# M0 z% Q; D4 K0 G2 S
1 v' f' \8 e8 Z" y2 j8 a
2 v- |. o' l$ A+ b
1 t2 p$ p4 ]9 f% E, A; F$ L h U Y
) f- }1 k4 t( R& F. v; p; ?
! P. ]# A- j: n; d6 y
" Y: i7 [3 y; t; S# k1 L
- }4 n' ?5 G! I# A# d9 b3 f2 ]
3 Y& I. M& K$ K% p+ P l' @4 S
! q7 n& C+ \- p6 g+ X3 e
: P* J% H5 k8 H$ N& F7 M( }
+ f2 v, {4 d3 `7 ^
5 y1 _' u) W+ M& P
图6 问题(1)的排样图 图7 问题(2)的排样图
3 g1 z% K1 K$ e |