# A fully general, exact algorithm for nesting irregular shapes

## Abstract

This paper introduces a fully general, exact algorithm for nesting irregular shapes. Both the shapes and material resource can be arbitrary nonconvex polygons. Moreover, the shapes can have holes and the material can have defective areas. Finally, the shapes can be arranged using both translations and *arbitrary* rotations (as opposed to a finite set of rotation angles, such as 0\(^\circ \)and 180\(^\circ \)). The insight that has made all this possible is a novel way to relax the constraint that the shapes not overlap. The key idea is to inscribe a few circles in each irregular shape and then relax the non-overlap constraints for the *shapes* by replacing them with non-overlap constraints for the *inscribed circles*. These relaxed problems have the form of quadratic programming problems (QPs) and can be solved to optimality to provide valid lower bounds. Valid upper bounds can be found via local search with strict non-overlap constraints. If the shapes overlap in the solution to the relaxed problem, new circles are inscribed in the shapes to prevent this overlapping configuration from recurring, and the QP is then resolved to obtain improved lower bounds. Convergence to any fixed tolerance is guaranteed in a finite number of iterations. A specialized branch-and-bound algorithm, together with some heuristics, are introduced to find the initial inscribed circles that approximate the shapes. The new approach, called “QP-Nest,” is applied to three problems as proof of concept. The most complicated of these is a problem due to Milenkovic that has four nonconvex polygons with 94, 72, 84, and 74 vertices, respectively. QP-Nest is able prove global optimality when nesting the first *two* or the first *three* of these shapes. When all *four* shapes are considered, QP-Nest finds the best known solution, but cannot prove optimality.

## Keywords

Fabric nesting Leather nesting Nonconvex polygon Irregular shape Inscribed circle Inner approximation Global optimization Quadratic programming Cutting and packing Translation Rotation Guaranteed optimality## Notes

### Acknowledgments

Lee Bristol of Delphi Interior and Lighting Systems introduced me to the fabric nesting problem, and Bill Crawford of Delphi Interior and Lighting Systems provided Fig. 1 and shared his knowledge on the nature the fabric nesting problem and the relative merits of different nesting approaches. Karen Daniels graciously guided me through the work she has done with Milenkovic and Li. Victor Milenkovic provided me with the data for his four-part test problem. Mary Dalzell of the GM Research library carried out a computerized literature search on the subject of nesting. Paul Sweeney and Bob Haessler of the University of Michigan also helped identify the relevant literature. Special thanks go to Chris Floudas of Princeton University for giving me an account on the Princeton computer system for carrying out the numerical experiments. Thanks also to Ruth Misener (co-creator of GloMIQO), who provided me with an updated literature search and helped me understand how different problem formulations would affect the performance of GloMIQO. Santosh Tiwari of GM installed LaTeX and BibTeX on my computer and showed me how to use them. Finally, I would like to thank the two anonymous reviewers for their comments and suggestions that pushed me to add clarifications, extend the literature review, and do additional numerical work, all of which substantially improved the paper.

## References

- 1.Albano, A., Sapuppo, G.: Optimal allocation of two-dimensional irregular shapes using heuristic search methods. IEEE Trans. Syst. Cybern.
**SMC–10**(5), 242–248 (1980)CrossRefGoogle Scholar - 2.Avnaim, F., Boissonnat, J.: Polygon placement under translation and rotation. Informatique theorique et applications
**23**(1), 5–28 (1989)Google Scholar - 3.Bennel, J.A., Oliveira, J.F.: A tutorial in irregular shape packing problems. J. Oper. Res. Soc.
**60**(1), 93–105 (2009)CrossRefGoogle Scholar - 4.Burke, E., Hellier, R., Kendall, G., Whitwell, G.: A new bottom-left-fill heuristic algorithm for the two-dimensional irregular packing problem. Oper. Res.
**54**(3), 587–601 (2006)CrossRefGoogle Scholar - 5.Burke, E., Hellier, R., Kendall, G., Whitwell, G.: Complete and robust no-fit polygon generation for the irregular stock cutting problem. Eur. J. Oper. Res.
**279**, 27–49 (2007)CrossRefGoogle Scholar - 6.Chin, F., Snoeyink, J., Wang, C.A.: Finding the medial axis of a simple polygon in linear time. Discret. Comput. Geomet.
**99**(3), 382–391 (1995)Google Scholar - 7.Costa, M.T., Gomes, A.M., Oliveira, J.F.: Heuristic approaches to large-scale periodic packing of irregular shapes on a rectangular sheet. Eur. J. Oper. Res.
**192**, 29–40 (2009)CrossRefGoogle Scholar - 8.Daniels, K., Milenkovic, V.: Multiple translational containment: approximate and exact algorithms. In: Clarkson, K. (ed.) Proceedings of the 6th Annual ACM-SIAM Symposium on Discrete Algorithms (1995)Google Scholar
- 9.Daniels, K., Milenkovic, V.: Column-based strip packing using ordered and compliant containment. In: Lin, M.C., Manocha, D. (eds.) Proceedings of the First ACM Workshop on Applied Computational Geometry (WACG), pp. 33–38 (1996)Google Scholar
- 10.de Berg, M., Cheong, O., van Kreveld, M., Overmars, M.: Computational Geometry: Algorithms and Applications. Springer, Berlin (2008)CrossRefGoogle Scholar
- 11.Dowsland, K., Dowsland, W.: Solution approaches to irregular nesting problems. Eur. J. Oper. Res.
**84**, 506–521 (1995)CrossRefGoogle Scholar - 12.Farley, A.A.: Mathematical models for cutting-stock problems in the clothing industry. J. Oper. Res. Soc.
**39**(1), 41–53 (1988)CrossRefGoogle Scholar - 13.Floudas, C.A., Visweswaran, V.: Handbook of Global Optimization, chap. Quadratic Optimization, pp. 217–270. Kluwer, Berlin (1995)Google Scholar
- 14.Heistermann, J., Lengauer, T.: Efficient automatic part nesting on irregular and inhomogeneous surfaces. In: Ramachandran, V. (ed.) Proceedings of the Fourth Annual ACM-SIAM Symposium on Discrete Algorithms, pp. 251–259 (1993)Google Scholar
- 15.Kallrath, J.: Cutting circles and polygons from area-minimizing rectangles. J. Glob. Optim.
**43**, 299–328 (2009)CrossRefGoogle Scholar - 16.Kallrath, J., Rebennack, S.: Cutting ellipses from area-minimizing rectangles. J. Glob. Optim. (2013). doi: 10.1007/s10898-013-0125-3
- 17.Lamousin, H., Waggenspack Jr, W.N.: Nesting of two-dimensional irregular parts using a shape reasoning heuristic. Comput. Aided Des.
**29**(3), 221–238 (1997)CrossRefGoogle Scholar - 18.Lasserrre, J.B.: An analytical expression and an algorithm for the volume of a convex polyhedron in \({R}^{n}\). J. Optim. Theory Appl.
**39**, 363–377 (1983)CrossRefGoogle Scholar - 19.Li, Z.: Compaction algorithms for non-convex polygons and their applications. Ph.D. thesis, Harvard University, Department of Computer Science (1994)Google Scholar
- 20.Li, Z., Milenkovic, V.: Compaction and separation algorithms for non-convex polygons and their applications. Eur. J. Oper. Res.
**84**, 539–561 (1995)CrossRefGoogle Scholar - 21.Milenkovic, V.: Rotational polygon containment and minimum enclosure using only robust 2d constructions. Comput. Geom.
**13**, 3–19 (1999)CrossRefGoogle Scholar - 22.Milenkovic, V.: Densest translational lattice packing of non-convex polygons. Comput. Geom.
**22**, 205–222 (2002)CrossRefGoogle Scholar - 23.Misener, R., Floudas, C.A.: GloMIQO: global mixed-integer quadratic optimizer. J. Glob. Optim.
**57**, 3–50 (2013)CrossRefGoogle Scholar - 24.O’Rourke, J.: Computational Geometry in C, 2nd edn. Cambridge University Press, Cambridge (2001)Google Scholar
- 25.Preparata, F.P., Shamos, M.I.: Computational Geometry. Springer, Berlin (1985)CrossRefGoogle Scholar
- 26.Sahinidis, N.V.: BARON: a general purpose global optimization software package. J. Glob. Optim.
**8**(2), 201–205 (1996)CrossRefGoogle Scholar - 27.Verkhoturov, M.A., Sergeyeva, O.Y.: The sequential value correction method for the two-dimensional irregular cutting stock problem. Pesquisa Operacional
**20**(2), 233–246 (2000)Google Scholar