Anatomy Transformation Analysis

MATLAB class provides tools for scaling, translating, and rigid body transforming 3D STL models with landmark handling
0 Downloads
Updated 1 Sep 2025

View License

This MATLAB class provides a framework for geometric transformations and evaluation of 3D surface models. It was developed in the context of orthopaedic research to align and compare pelvis geometries, but can be applied to other anatomical or technical models as well.
Key Features:
1. Scaling: Scales mesh geometry and corresponding anatomical landmarks.
2. Translation: Translates mesh and landmarks to a specified reference point.
3. Transformation (Kabsch Algorithm):
  • Computes optimal rigid body transformation (translation + rotation) between landmarks.
  • Returns transformation matrix, translation vector, Euler angles, and landmark errors.
  • Applies transformation to all mesh vertices.
4. Distance Measures
  • Vertex-to-Nearest-Neighbour Distance: Evaluates vertex correspondence between two meshes, visualizable via colormap.
  • Hausdorff Distance: Computes the bidirectional Hausdorff distance between two meshes.
How to Use
  1. Code structure: The Transformation Class can be integrated into a corresponding main script. The key parts of the code are extracted into individual functions for reuse.
  2. Import: Import your STL mesh and landmarks into MATLAB
  3. Apply transformation: Scaling, Translation, Transformation (Kabsch)
  4. Evaluate accuracy: vertex-to-nearest-neighbour distances, Hausdorff distances
  5. Results: for visualization or error mapping
Use Cases:
  • Alignment of anatomical STL models (e.g., pelvis, femur, etc.)
  • Quantitative evaluation of registration accuracy
  • Mesh comparison and error visualization
Benefits
  • Flexible: Works with any STL-based geometry.
  • Quantitative evaluation: Provides Euclidean error, vertex distances, and Hausdorff distance
  • Visualization-ready: Distance measures can be mapped onto mesh faces for intuitive color-coded analysis
Keywords
STL, transformation, mesh registration, rigid body alignment, Kabsch algorithm, Hausdorff distance, nearest neighbour, anatomical landmarks, pelvis
Compatibility:
This class is compatible with MATLAB and can easily be integrated into existing workflows for analysing the transformation of anatomical models. It is optimised for MATLAB 2024a but should be compatible with the most recent versions of MATLAB.
Disclaimer:
This MATLAB class is provided on the MATLAB File Exchange for educational and research purposes. Users should ensure that the class meets their specific analysis requirements and may need to adapt it accordingly. The code is provided "as-is," and the author assumes no responsibility for its use or any consequences thereof.
References:
  • C. M. Micheler, J. J. Lang, N. J. Wilhelm, I. Lazic, F. Hinterwimmer, C. Fritz, R. V. Eisenhart-Rothe, M. F. Zäh, and R. H. Burgkart, ‘‘Scaling Methods of the Pelvis without Distortion for the Analysis of Bone Defects,’’ Current Directions in Biomedical Engineering, vol. 8, no. 2, pp.797–800, 2022.
  • C. M. Micheler, ‘‘Anatomy Boundary Analysis,’’ MATLAB Central File Exchange, 2025. [Online]. Available: https://ww.mathworks.com/matlabcentral/fileexchange/157001-anatomy-boundary-analysis
  • W. Kabsch, ‘‘A solution for the best rotation to relate two sets of vectors,’’ Acta Crystallographica Section A, vol. 32, no. 5, pp. 922–923, sep 1976. [Online].
  • W. Kabsch, ‘‘A discussion of the solution for the best rotation to relate two sets of vectors,’’ Acta Crystallographica Section A, vol. 34, no. 5, pp.827–828, sep 1978. [Online].
  • E. Schreiber, ‘‘Kabsch algorithm,’’ MATLAB Central File Exchange, 2025. [Online]. Available: https://de.mathworks.com/matlabcentral/fileexchange/25746-kabsch-algorithm

Cite As

Carina Micheler (2025). Anatomy Transformation Analysis (https://in.mathworks.com/matlabcentral/fileexchange/181345-anatomy-transformation-analysis), MATLAB Central File Exchange. Retrieved .

MATLAB Release Compatibility
Created with R2024a
Compatible with any release
Platform Compatibility
Windows macOS Linux

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Anatomy-Transformation-Analysis

Anatomy-Transformation-Analysis/Functions

Anatomy-Transformation-Analysis/individual Functions

Version Published Release Notes
1.0.5

Update description

1.0.4

Update description

1.0.3

Update files and description

1.0.2

Update Image

1.0.1

Update Description

1.0.0