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.
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.
FILE IMPORT TIPS
Bad design files will throw errors and create models that explode or cannot be solved, here are some tips for importing FOLD or svg files that work.
The FOLD file format is specified in these docs. This tool imports FOLD v1.0 files with all of the following fields populated:
This tool currently supports an interactive Virtual Reality mode using the Vive headset and controllers. For this to work, you must first use a WebVR enabled browser: currently only Firefox Nightly is supported by this app.
When you open this page with the appropriate browser and a Vive connected through Steam VR, you will see a button that says "Enter VR". Clicking this will put the app into an interactive VR mode. The hand controllers will allow you to grab the origami mesh and pull on it. This is especially interesting if you set the Mesh Material to Strain Visualization so you can see how your interactions change the internal strains in the material.
If the simulation looks choppy, consider lowering the Num simulation steps per render setting under Animation Settings in the right hand menu.
VR mode currently does not support all the UI of the regular app, so you will need someone in the "outside world" to help you load new files, change the fold percent, etc.
The dynamic simulation is calculated by solving for all the forces in the system, moving time forward in small Δt steps, and updating the vertices of the origami incrementally. The time step size for this animation is calculated automatically based on the material stiffnesses set in the Simulation Settings section: more stiff settings require shorter time steps to solve and will slow down the simulation.
Num simulation steps per render allows you to control the number of tiny time steps forward to take on each render cycle. If the simulation looks choppy to you, you might consider lowering this setting. Lowering the number of steps per render will slow down the simulation, but will result in a more smooth animation.
Average vertex error gives a sense of how much the distance constraints in the origami pattern are being violated (i.e. how much the sheet is being stretched). The error at each vertex is evaluated by averaging the percent deviation of all its distance constraints with adjacent vertices. This error is reported as a percent of the total length of the distance constraint to remove scaling effects.
This measurement is equivalent to Cauchy strain or engineering strain of the distance constraints on this system. Increasing the Axial Stiffness will tighten these constraints and lower the error in the simulation.
To visualize the error of each vertex graphically, select Strain Visualization under Mesh Material in the left menu.
This app uses a compliant dynamic simulation method to solve for the geometry of an origami pattern at a given fold angle. The simulation sets up several types of constraints: distance constraints prevent the sheet from stretching or compressing, and angular constraints fold or flatten the sheet. Each of these constraints is weighted by a stiffness - the stiffer the constraint, the better it is enforced in the simulation.
Axial Stiffness is the stiffness of the distance constraints. Increasing axial stiffness will decrease the stretching/compression (strain) in the simulation, but it will also slow down the solver.
Fold and facet stiffnesses correspond to two types of angular constraints. Fold Stiffness is the stiffness of the mountain and valley creases in the origami pattern. Facet Stiffness is the stiffness of the triangulated faces between creases in the pattern. Increasing facet stiffness causes the faces between creases to stay very flat as the origami is folded. As facet stiffness becomes very high, this simulation approaches a rigid origami simulation, and models the behavior of a rigid material (such as metal) when folded.
Internally, constraint stiffnesses are scaled by the length of the edge associated with that constraint to determine its geometric stiffness. For Axial constaints, stiffness is divided by length and for angular constraints, stiffness is multiplied by length.
Since this is a dynamic simulation, vertices of the origami move with some notion of acceleration and velocity. In order to keep the system stable and help it converge to a static solution, damping is applied to slow the motion of the vertices. The Damping slider allows you to control the amount of damping present in the simulation, from 0 (no damping) to 1 (critical damping). Decreasing damping makes the simulation more "springy". It may be useful to temporarily turn down damping to help the simulation more quickly converge towards its static solution - especially for patterns that take a long time to curl.
COMPLIANT DYNAMIC SIMULATION
COMPLIANT STATIC SIMULATION
RIGID STATIC SIMULATION
Cauchy strain or engineering strain is a unitless measurement of how much a material is being stretched or compressed under load. The Strain Visualization illustrates the strain across an origami sheet by mapping it to a color from blue (no strain) to red (max strain).
Speed : ( radians per frame )
Color (rgb hex) :
SVG IMPORT SETTINGS
Vertex merge tolerance (px) :