From 448a06a5dbf9802a6c77d98ef7b5dad8ddb4143d Mon Sep 17 00:00:00 2001
From: Jane Tournois Introduced in CGAL 3.5, the package
+3D Mesh Generation
+is designed to generate a isotropic simplicial meshes discretizing 3D domains.
+Since then, multiple improvements in mesh quality, performances, and versatility have been made available in CGAL.
+Lately, CGAL authors have focused more on the quality of the output mesh, the ability of the
+mesh generation algorithm to represent the input surface in a more accurate way, for a wider range of input data types.
+ Recent releases of CGAL have introduced improvements to the 3D Tetrahedral Mesh Generation package:
+detection and protection of triple lines from labeled images,
+use of weighted labeled images,
+dealing with self-intersecting input surfaces,
+and a new approximation error criterion for polyline features. CGAL's tetrahedral mesh generation algorithm is able to compute tetrahedral meshes from 3D segmented images.
+For all types of inputs, detection and construction of one-dimensional features must be done a priori for the
+feature protection algorithm to be able to represent them properly in the generated mesh.
+In 3D segmented images, such features correspond to the intersections of the bounding box of the image with the surfaces defined by the image, as well as polylines that lie at the intersection of three or more subdomains (including the outside). The article
+Hege, H. C., Seebass, M., Stalling, D., & Zöckler, M. (1997), A generalized marching cubes algorithm based on non-binary classifications, provides a list of possible voxel configurations. This description has been generalized for tetrahedral mesh generation needs, and
+implemented in CGAL. After feature lines detection, similarly to what is done for polyhedral surfaces, the polyline features
+are added to the feature graph of the domain for feature protection. Two detection functors are provided :
+Jane Tournois
+GeometryFactory
+
+
+
+
+Triple lines from labeled images
+
+
+
+
When a segmented image is given as input for tetrahedral mesh generation, +the generated mesh surface sometimes sticks too closely to the voxels surface, causing an aliasing effect. A solution to generate +a smooth and accurate output surface was described by Stalling et al in +Stalling, D., Zöckler, M., Sander, O., & Hege, H. C. (1998), Weighted labels for 3D image segmentation. +It consists in generating a second input image, made of integer coefficients called weights, and use those weights to define +smoother domain boundaries. The 3D image of weights can be generated using CGAL::Mesh_3::generate_label_weights().
+ +The following example shows how to use weighted labeled images: mesh_3D_weighted_image.cpp.
+ +Utilizing tetrahedral mesh generation from labeled images, incorporating both feature detection and weighted labels, +presents challenges. A new method that combines feature detection and weighted labels has been +designed and implemented in CGAL, achieving smooth and feature preserving output meshes. +This method leverages the best of these two new functionalities.
+ + + + + +All these new improvements are already integrated in CGAL's master branch on the +CGAL GitHub repository, and has just been officially released +in the latest version of CGAL, CGAL 6.0-beta1.
+ + +Documentation of the package Mesh_3 +$7S5{X8hB2&4bxtd@twHFIRD#<=cjv P^QpmwG~-Q!3jJv+nWbUiKkxj`qWe4jeGIwBhV?wTG0Paikc*0#*(
z8nO|4pA-=dwESpo{RT~xE~pC0da>|UH`99lS3GxFsbi!EhMp0`_|s3ZdseJt*LyBY
z7wh{z>uDett~ ;nB^1pxo{%}1a&Kz&G))@@TwOU>jC^oAm
z +;B|H%X*ERkYop6j-XK$73(Mjtum`F0oz+;rXP6-e&RlKPfuvb9~LAN`wB16D{
zbpO!Z{RLH=zcSrg<-?RdcIPt5da3#SjKYt#x?R&d|K&VT!_%9{^-H&L)lZ-_FvI2P
z`Y^y5g(_vihTFoZ(h`G@w3~NeO=7wA99l#62NAAI=$H4er9x(F<%Q(c8|Py*06w2P
z24}9U3;^mo#uk{-q^b;$Yn31^a9t6zgvip0smexAkQMu9f`qIVR%{?9^dG!tsrXAi
zc%@U$43E+UX9~pBmQ{y8UHtY8g7R0b|FZf2MOIqGF#bK{uJvr&%zv!gr=Vgr1G!6s
z$o}N&9+d*|Jdn1seu+@P+-sT5N#I2|ppUlEYW%g_^SzBRD|;gWPts3~Wv9oRSHK$p
zpv0!Z`DJ*mH)2f>sfYl4#AHJWjz!#f4Go8gIl5@w<~_Hd$N@Q8^Y?qLWS>5L!iym1
zY!IZX)BNZY5%FvEa
k>#>&&zV*~h1$Lo?TQ6yGyB~x2CXVXYlg=;L?UABqw>R&C
zu+1kXwdFE5UAO86xq`B?UH6*ihg2ohz(oI7*!#lu-+{d0WF03dE>Yd-jxG-`rQ9+-
zX6J-jLat9y;02>}^mLlr6=kC-!8)#;re1my*9AR{u4Vii5IvGu-6h&_Qp+JOJu0R^%Yer`qHL6=!9++NBmE)C+pq!Zhfz`
zV+c?Yp-^a6T>$u7u~5_R=tS?X%k%TMMsn2>Bb1CiDk`L%H-5F83P*77tT!4-Vgq_o
z!9720)%53*ntUVs;@xfg8mwpQ$LUPbVWeWI$->Rh?%wyvNR^h$P_wGvot+I8E+nwq
z+Z!akdOJqe*lN2SOS5)_0eIpzTFM|v1RAI4CMnp>N+Isp;z4s`qQk)r;sd_X#kEfe
zcm;TN^w`lkP5)jQ;Ha%CO6|=x(S9$J^a!J*-=8N_e^@xS4^uey+N~$Q{sU<*hg)GhC}YgF#mp(r2asLZ!E29|
zyPc+F{<(b3;+`J)s8`3ScCS^w>KET72w#k2a?I_nIT2GM(uY7X=Zi`ywkO>Uhbyfb
z$$@jB!6vdN{X&q5K2a;N;fb2#^ic0vK{wt@livIYxIwuqAw&uK5Xs@0^J%
^*TpUiPy7D0vh-9F8QVP_Lny
z$ZuwkJiz_)F8y%KWspN@hGAQO{!tdzQeku!h_wuIw}H+6Rw+8$hGrP3p$d{mHTv%6
z<;|Ww>5!>LVSsq?f$U;=Wno1fRs?A`#w2%S5`*g)eAAjdLQV7bKiJO&P|u|kc7
znClH#+(WbPjI}G5m=AWAQeS%$I!=rf9Kpg#->U7sN<+ZIt}42&xjfyiFOn2