An Energy-Driven Approach to Linkage Unfolding
Abstract
We present a new algorithm for unfolding planar polygonal linkages without self-intersection based on following the gradient flow of a "repulsive" energy function. This algorithm has several advantages over previous methods. (1) The output motion is represented explicitly and exactly as a piecewise-linear curve in angle space. As a consequence, an exact snapshot of the linkage at any time can be extracted from the output in strongly polynomial time (on a real RAM supporting arithmetic, sin
and arcsin
). (2) Each linear step of the motion can be computed exactly in O(n2) time on a real RAM where n is the number of vertices. (3) We explicitly bound the number of linear steps (and hence running time) as a polynomial in n and the ratio between the maximum edge length and the initial minimum distance between a vertex and an edge. (4) Our method is practical and easy to implement. We provide a publicly accessible Java applet that implements the algorithm.
Best paper award at SoCG 2004.
Citation
Jason H. Cantarella, Eric D. Demaine, Hayley N. Iben, and James F. O'Brien. "An Energy-Driven Approach to Linkage Unfolding". In Proceedings of the 20th Annual Symposium on Computational Geometry, June 2004.
Supplemental Material
data:image/s3,"s3://crabby-images/264e8/264e890c5aebd92ff8f2d056fa75c98af18bb71e" alt=""
Teeth with energy method.
data:image/s3,"s3://crabby-images/8b59d/8b59d72031fd8dda9fb42ced9c9a32d5a82d394a" alt=""
Tree with energy method.
data:image/s3,"s3://crabby-images/70ebb/70ebb4117c6886c22b4045c303c405523b783cbe" alt=""
A spiral open chain.
data:image/s3,"s3://crabby-images/ed798/ed798b6dec12f2dad1b794bf20aa15cce66f9e93" alt=""
Tentacle opening.
data:image/s3,"s3://crabby-images/a6a2f/a6a2f0a24c2df93743614b45fd888335994ae185" alt=""
Spider shape opening.
Demonstration Applet
If your browser does not support the JRE plugin, then you may still be able to run this applet by installing the Java J2SE v 1.4 SDK and running the command "appletviewer" with this URL as the first argument in quotes: appletviewer "http://url_of_this_page.html" where you replace url_of_this_page with this page's address.