5. 🪄 Use the Mesh Warper#
Warning
This documentation is 🪄 work-in-progress 🪄.
The mesh warping UI is mostly stable, but this documentation is still being
improved. Therefore, this tutorial might still have sections missing or elements
tagged with TODO
. However, what is here should be correct. Post an issue on
OpenSim Creator’s issues page if you think
something’s terribly wrong.
This tutorial will be fleshed out over time. We figured it’s better to show you what’s happening as we develop it, rather than only releasing it once it’s perfect.
In this tutorial, we will be using the Mesh Warping UI to perform landmark-driven mesh warping using the Thin-Plate Spline algorithm (explanation, literature source). The UI provides tooling for loading two meshes and creating landmark pairs between them:
5.1. Prerequisites#
This is a standalone tutorial. The mesh warping UI is designed to be separate from OpenSim, so that it can specifically address the requirement of placing (+ pairing) landmarks on generic mesh files to perform non-uniform warping.
For your own work, you will need two mesh files that are logically pair-able with landmarks. For example, two femur meshes with boney landmarks that are present (albeit, possibly in a different location) in both meshes. The meshes do not need to be anatomical: you can also use this technique to morph between entirely abstract shapes.
5.2. Topics Covered by this Tutorial#
A theoretical overview of the underlying Thin-Plate Spline (TPS) technique
A high-level overview of how OpenSim Creator’s mesh warping UI works
A concrete walkthrough of using the UI on an anatomical mesh
5.3. The Thin-Plate Spline (TPS) Technique#
Note
This section isn’t going to explain the Thin-Plate Spline (TPS) technique in extensive detail. Instead, it will provide a simplified explanation that should be good enough to get an of what’s happening when you use the mesh warping UI.
If you want to know more about the TPS technique, we recommend consulting the Relevant References section, where we’ve listed a variety of relevant literature.
As a colloquial explanation, imagine placing a flat, thin plate with points along its surface onto a table. Now imagine that each of those surface points has a corresponding “target” point somewhere in 3D space. Now imagine you could bend the plate. If you could figure out an “optimal” way to bend it, you could minimize the distance between each surface point and its corresponding “target” point.
The TPS technique models that idea, but in \(n\)-dimensional space, by making several assumptions:
It describes “bending” the plate as a bounded linear combination of some basis function, \(U(v)\). The original paper used \(U(v) = |v|^2 \log{|v|^2}\), but other sources, including OpenSim Creator, use \(U(v) = |v|\).
It treats the problem of transforming “source/reference” points (landmarks), \(x_i\), to “destination/reference” points (landmarks), \(y_i\), as an interpolation problem.
And it solves the coefficients of that linear combination while minimizing the “bending energy”. Wikipedia example:
The coefficients that drop out of this process can then be used to warp any point in the same space. If you’d like to know more, we recommend the literature in the Relevant References section.
Here’s how these high-level concepts from the TPS technique apply to OpenSim Creator’s mesh warping UI, which internally uses the TPS algorithm:
Source Mesh and Source Landmark refer to data in the “reference”, or “source” space. Each source landmark requires a corresponding destination landmark with the same name.
Destination Mesh and Destination Landmark refer to data in the “target”, or “destination” space. Each destination landmark must have a corresponding source landmark with the same name.
Warp Transform is the product of the TPS technique after pairing the source landmarks with the destination landmarks and solving the relevant TPS coefficients. The warp transform can be applied to any point in the source space to warp it into the destination space. E.g. in the mesh warping UI, the transform is applied to the source mesh to produce the result mesh. It’s also applied to non-participating landmarks to produce warped data points.
Result Mesh is the result of applying the warp transform to the source mesh.
Non-Participating Landmark is a landmark in the source mesh’s space that should be warped by the warp transform but shouldn’t participate in solving the TPS coefficients.
5.4. Opening the Mesh Warping UI#
The mesh warping UI is an independent “workflow” UI that’s separate from the main OpenSim Creator model editing/simulation UI:
5.5. Mesh Warping UI Overview#
The mesh warping UI uses separate windows to display relevant warp information. You can
toggle each window from the Window
menu at the top of the UI. Here is how each
window relates to mesh warping and the TPS technique:
Source Mesh (window): shows the source mesh, source landmarks, and non-participating landmarks. Source landmarks that have no corresponding destination landmark (an unpaired source landmark) are displayed in red, paired landmarks in green, and non-participating landmarks in purple.
Destination Mesh (window): shows the destination mesh and destination landmarks. Destination landmarks that have no corresponding source landmark (an unpaired destination landmark) are displayed in red, paired landmarks in green.
Result (window): shows the result mesh and any warped non-participating landmarks. There’s also an option to overlay the destination mesh in this panel, which helps with evaluating how closely the result mesh (made by warping the source mesh) matches the destination mesh. There is also a
Blending Factor
control, which enables blending between “not warped” (i.e. source data) and “fully warped” on a linear scale.Landmark Navigator (window): shows each (source/destination/non-participating) landmark the UI is editing. This is handy when editing many landmarks.
Toolbar (top): the main feature of note here is the ability to (un)lock the camera, which can make viewing paired meshes easier.
How you use these panels is up to you. A typical workflow has these steps:
Import/generate meshes in the source mesh and destination mesh panels
Import landmarks into each panel, or
LeftClick
on the mesh to place a landmark, orCtrl+LeftClick
to place a non-participating landmark on the source mesh.View the result mesh and non-participating landmarks.
Export whatever you need elsewhere using the
Export
buttons
Note
The main thing to take away from this high-level UI explanation is how each panel
relates to the underlying TPS technique and how data can be import
ed and
export
ed into each panel.
Apart from that, the easiest way to get familiar with the UI is to actually use it. We recommend “playing around” with some generated geometry, or mesh files, to “get a feel for the algorithm”, or continuing through this tutorial 📖
5.6. Walkthrough: Warping a Femur#
In this concrete walkthrough, we’ll go through pairing landmarks between two femur CT scans, followed by exporting the warped data.
TODO
: provide the meshesTODO
: load meshes using importTODO
: manually place some landmark pairs, rename, etc.TODO
: manually rename some landmarksTODO
: import example landmarks (additionally, or in place of, the manual ones)TODO
: play with resultTODO
: export result
5.7. Next Steps#
With the theory, UI, and a concrete example covered, the next steps we would recommend are:
Experiment with simple/generated meshes. Experimenting with the mesh warping UI by warping a generated/simple will help you feel more comfortable with the layout, keybindings, and functionality of the UI.
Import/export some data files/meshes to/from the UI. This will give you an idea of what the mesh warping UI can work with. For example, knowing the format of the landmark CSV files is useful for integrating the UI with scripts.
Go to the next section. 🪄 Use the Model Warper, covers using this techniques as part of warping an entire OpenSim model.
5.8. Relevant References#
These references were found during the development of OpenSim Creator’s mesh warping support (issue #467). They are here in case you (e.g.) want to write about this subject, or create your own implementation of the algorithm.
- Wikipedia: Thin-Plate Spline (link)
Top-level explanation of the algorithm
- Principal warps: thin-plate splines and the decomposition of deformations, Bookstein, F.L. (link)
Primary literature source
Note: newer publications tend to use a different basis function
- Manual Registration with Thin Plates, Herve Lombaert (link)
Easy-to-read explanation of the underlying maths behind the Thin-Plate Spline algorithm
Useful as a basic overview
- Thin Plates Splines Warping, Khanh Ha (link)
Explanation of the low-level maths behind the Thin-Plate Spline algorithm (e.g. radial basis functions). Includes concrete C/C++/OpenCV examples
Useful as a basic overview for C++ implementors
- Image Warping and Morphing, Frédo Durand (link)
Full presentation slides that explain the problem domain and how warping can be used to solve practical problems, etc. Explains some of the low-level maths very well (e.g. RBFs) and is a good tour of the field. Does not contain practical code examples.
Useful as a top-level overview of warping in general
- Thin Plate Spline editor - an example program in C++, Jarno Elonen (link)
C++/OpenGL/libBLAS implementation of the TPS algorithm
Useful for implementors
- CThinPlateSpline.h, Daniel FĂĽrth (link)
C++/OpenCV Implementation
Useful for implementors
- Interactive Thin-Plate Spline Interpolation, Sarath Chandra Kothapalli (link)
Basic python implementation of TPS using numpy and matlab.
Contains basic explanation of the algorithm in the README
Useful for implementors
- 3D Thin Plate Spline Warping Function, Yang Yang (link)
MATLAB implementation of the algorithm
Useful for implementors
- 3D Point set warping by thin-plate/rbf function, Wang Lin (link)
MATLAB implementation of the algorithm
Useful for implementors
- A Practical Guide to Sliding and Surface Semilandmarks in Morphometric Analyses, Bardua, C et. al. (link)
Introduces a UX for placing semi-landmarks (not supported by OpenSim Creator yet)
Useful for UI implementors