Download presentation
Published byDarlene Hawkins Modified over 9 years ago
1
Block Packing: From Puzzle-Solving to Chip Design
Igor Markov, Advanced Computer Architecture Lab
2
Students Hayward Chan: optimal block-packing
undergraduate student Saurabh Adya: industrial-strength placement will be getting his Ph.D. in May
3
Overview The rectangle packing problem Packing representations
Optimal block-packer Slicing packings: an approximation Optimal slicing block-packer Large-scale block-packing
4
Rectangle Packing Problem
Given rectangles (blocks) R1,…,Rn, assign orientation (rotated 90°?) and location to (the lower-left corner of) each of them s.t. no blocks overlap the bounding box of all rectangles is as small as possible The decision version is NP-complete
5
Example Bad Better
6
Packing Representations
Locations of blocks? R1 at (0,3), R2 at (2,1) etc… Pros: simple, no effort to realize the packing Cons: hard to detect overlaps infinitely many possible assignments, most of which are redundant
7
Redundant Packings Not compacted packings are redundant
left-compact -no block can move left fixing other blocks bottom-compact -no blk can move down fixing other blks Only have to consider left-bottom-compact packings
8
R. Korf’s Ongoing Work An optimal block packer for fixed-size blocks
Location-based Assumes that block dimensions are small integers Uses new pruning techniques: wasted-space bounds, dominance-based pruning, etc Cannot process soft blocks
9
Combinatorial Representations
Implicit representations, e.g., topological the implied block locations cause no overlaps optimal packing can be captured only a finitely variety (the smaller the better) the overhead to figure out block locations is small Facilitate faster algorithms Simulated annealing Branch-and-bound
10
Sequence Pair Represents a packing of n blocks by two
permutations of order n [Murata et.al ’96], e.g. <1234, 4132> for 4 blocks Encodes a relative constraint for each pair of blocks Namely, for blocks a and b, <…a…b…, …a…b…> = a is on the left of b <…a…b…, …b…a…> = a is above b
11
Sequence Pair --- example
Consider <1234, 4132>, < , >, so R1 is left of R3 < , >, so R2 is above R3
12
Properties of Sequence Pairs
optimal solution can be encoded (n!)2 sequence pairs for n blocks can compute block locations in O(n2) time O(n log n) and even O(n log log n) algos exists However, many represented packings are not compacted several sequence-pairs represent same packing
13
O-Tree Represent a packing by a rooted-ordered tree [Guo et.al ’99], where: Root = left boundary of the bounding box Each node (≠ root) represents a block x-coord(child) = x-coord(parent) + width(parent)
14
Encoding an O-Tree (1) A rooted-ordered tree can be encoded as a bit-vector, that records its pre-order traversal Start with the root, 0 records “down” 1 records “up” Encoding:
15
Encoding an O-Tree (2) Notation: <T,p,d> denotes an O-Tree where
T is a bit-vector describing the tree (2n bits) p is a permutation, recording sequence of block visited in pre-order traversal (perm. of order n) d is a bit-vector, same length as p, recording orientations of the blocks (n bits) d(i) = 0 means block p(i) is not rotated d(i) = 1 means block p(i) is rotated by 90°
16
Example of an O-Tree Tree T Permutation P Orientation d
Permutation P Orientation d
17
Properties of O-Trees Encode only bottom-compact solutions, including optimal ones Solution space is O(n! 25n-3 / n1.5) (smallest known for FP representations) O(n) time to compute block locations We chose O-Trees for our optimal packer because of small solution space
18
Optimal Block-Packer Branch-and-bound
Searches in the space of partial O-Trees Successor function appends: 2 bits to T (partial tree) 1 blocks to p (partial permutation) 1 bit to d (partial orientation bit-vector) Depth-first traversal Blocks are indexed from 1 to n
19
Optimal Block-Packer At any time, we have a partial packing
Example: suppose T, p, d are incomplete T = p = d = 00000
20
Optimal Block-Packer Not all bit-vectors of length 2n specify a tree
For example (n = 3): (too many up-edges) (too many down-edges) A bit-vector of length 2n specifies a tree for n blocks iff, for every prefix, # 0’s ≥ # 1’s # 0’s ≤ n Every time when we append 2 bits to T, we check if the result satisfies the criteria (if not, backtrack)
21
Area Lower Bounds Given a partial packing, we can estimate the dead-space of all extended solutions minimum bounding rectangle all unplaced block will be packed above the partial packing, hence its bounding rectangle gives an area lower bound
22
Area Lower Bounds permanent dead-space:
dead-space below a block in the partial packing
23
Area Lower Bounds extended dead-space
if the “valley” above a block is narrower than any unplaced block, then the dead-space is permanent
24
Area Lower Bounds trial-block estimation
any unplaced block A locates above the partial packing for an unplaced block A, estimate the area of extended packings by putting A in several spots
25
Area Lower Bounds minimum min-edge estimation
min-edge of a block: its shorter edge minimum square: a square whose side is the minimum of the min-edges among all unplaced blocks if T has more 0’s than 1’s, then place the minimum squares according to T
26
Non Left-compact Packings
O-Tree specifies left-compact packings not necessarily bottom-compact require every block to touch its parent
27
Dominance a packing can be flipped/rotated to 7 other orientations
can to consider only one orientation require the lower-left blocks to have smallest index among the “corner blocks”
28
Identical Blocks Identical blocks come up very frequently
can be interchanged regardless where they are require the one with lower index proceeds the other in p size of solution space shrinks by (k!) if k blocks are identical
29
Empirical Results Runtime depends on: presence of identical blocks
``quality’’ of the optimal solution optimal solution has a lot of dead-space usually means the lower bounds are loose deadspace is often large when blocks have extreme aspect ratios and/or areas
30
Empirical Results Can pack up to 9 blocks in 12 mins w/o identical blocks (12 blocks with only 2 types of blocks) Dead-space % decreases with # blocks Dead-space % decreases when the blocks are similar (in terms of aspect ratios,area)
31
Slicing Packings General packings are hard to analyze (lack of structure) Slicing packings: the bounding box can be recursively cut horizontally/vertically into rooms each room has exactly one block
32
Slicing Packings --- example
For example: Slicing Floorplan Slicing Packing
33
Slicing Packings Slicing packings are easier to deal with since they are hierarchical a slicing packing is made of 2 smaller ones easier to make incremental changes to a block simple representation: binary tree
34
Slicing Tree A slicing (binary) tree represents a slicing packing where: the leaves represents a block (n of them) each internal node denotes a horizontal or a vertical merger of its children + for vertical merger * for horizontal merger
35
Slicing Tree --- example
36
Polish expression Encode a slicing tree using its post-order traversal
The Polish expression: 1 2 * 3 * * +
37
Optimal Slicing Block-Packer
branch-and-bound looks for the optimal slicing packing searches in the space of partial Polish expressions successor function appends: either a block or a + or * if possible
38
Empirical Results pack 12 distinct blocks in 10 min (16 blocks if there are only 2 types) gap between optimal slicing and non-slicing packing is less than 1.5% on average
39
Large-scale Block-Packing
Solve large instances hierarchically: group blocks into clusters pack each cluster optimally treat each cluster as a block, and pack them into higher-level clusters
40
Hierarchical Block-Packing
41
Hierarchical Block-Packing
Other tricks: store multiple shapes for each cluster, hopefully can pack tighter at a higher-level avoid clusters with extreme aspect ratios by imposing constraint during search stop at packings that are slightly suboptimal (e.g. 2%): large speed up
42
Empirical Results Robust performance on sets of 10, 100, 1K, 10K blocks consistent solution quality runtime grows near-linearly improves the best published results (both runtime and solution quality)
43
Sample Packing ami49_40: 1960 blocks, 3.25% dead-space, obtained in 185s on a 1.2GHz Athlon.
44
Summary Optimal rectangle-packing is NP-hard and also hard in practice
Location-based vs topological packing representations Slicing packings are surprisingly good Our optimal block-packers BloBB & Compass are available Extensions to large-scale block-packing
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.