Triangular Mesh Refinement
This function "refinepatch" can refine any triangular mesh surface ( patch) with 4-split spline interpolation, see screenshot.
Literature:
The spline interpolation of the face edges is done by the Opposite Edge Method, described in: "Construction of Smooth Curves and Surfaces from Polyhedral Models" by Leon A. Shirman
How it works:
The tangents (normals) and velocity on the edge points of all edges are calculated. Which are later used for b-spline interpolation when splitting the edges.
A tangent on an 3D line or edge is under defined and can rotate along the line, thus an (virtual) opposite vertex is used to fix the tangent and make it more like a surface normal.
B-spline interpolate a half way vertices between all existing vertices using the velocity and tangent from the edge points. After splitting a new face list is constructed with 4 times as many faces.
Implementation:
Some Matlab files are also available as MEX files to allow quick refinement of large meshes.
Please Leave a comment, if you find a bug, like the code or know improvements.
Zitieren als
Dirk-Jan Kroon (2024). Triangular Mesh Refinement (https://www.mathworks.com/matlabcentral/fileexchange/16215-triangular-mesh-refinement), MATLAB Central File Exchange. Abgerufen.
Kompatibilität der MATLAB-Version
Plattform-Kompatibilität
Windows macOS LinuxKategorien
- AI and Statistics > Curve Fitting Toolbox > Splines >
- MATLAB > Mathematics > Computational Geometry > Triangulation Representation >
Tags
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!Live Editor erkunden
Erstellen Sie Skripte mit Code, Ausgabe und formatiertem Text in einem einzigen ausführbaren Dokument.
Version | Veröffentlicht | Versionshinweise | |
---|---|---|---|
1.2.0.0 | Fixed NaN bug in case of all neighbor vertices
|
||
1.1.0.0 | Know also c-code files are available, and mesh no longer have to be closed. |
||
1.0.0.0 | Matlab code used an unknown function val_even , to determine even or odd value.. |