/OrigamiSimulator

Realtime WebGL origami simulator

Primary LanguageJavaScript

OrigamiSimulator

Live demo at git.amandaghassaei.com/OrigamiSimulator

This app allows you to simulate how any origami crease pattern will fold. It may look a little different from what you typically think of as "origami" - rather than folding paper in a set of sequential steps, this simulation attempts to fold every crease simultaneously. It does this by iteratively solving for small displacements in the geometry of an initially flat sheet due to forces exerted by creases. This solver extends work from the following sources:

    Origami Folding: A Structural Engineering Approach by Mark Schenk and Simon D. Guest
    Freeform Variations of Origami by Tomohiro Tachi

All simulation methods were written from scratch and are executed in parallel in several GPU fragment shaders for fast performance.


Instructions:

  • Slide the Fold Percent slider to control the degree of folding of the pattern (100% is fully folded, 0% is unfolded, and -100% is fully folded with the opposite mountain/valley assignments).
  • Drag to rotate the model, scroll to zoom.
  • Import other patterns under the Examples menu.
  • Upload your own crease patterns in SVG or FOLD formats, following the instructions under File > File Import Tips.
  • Export FOLD files or 3D models ( STL or OBJ ) of the folded state of your design ( File > Save Simulation as... ).
  • Visualize the internal strain of the origami as it folds using the Strain Visualization in the left menu.
  • If you are working from a computer connected to a Vive, follow the instructions near the VR menu to use this app in an interactive virtual reality mode.


External Libraries:


Built by Amanda Ghassaei as a final project for Geometric Folding Algorithms. Code available on Github. If you have interesting crease patterns that would make good demo files, please send them to me (Amanda) so I can add them to the Examples menu. My email address is on my website. Thanks!

More documentation coming soon.