Mmg
Simplicial remeshers (mesh adaptation, isovalue discretization, lagrangian movement)
main_optim.F90
Go to the documentation of this file.
1!! =============================================================================
2!! This file is part of the mmg software package for the tetrahedral
3!! mesh modification.
4!! Copyright (c) Bx INP/Inria/UBordeaux/UPMC, 2004- .
5!!
6!! mmg is free software: you can redistribute it and/or modify it
7!! under the terms of the GNU Lesser General Public License as published
8!! by the Free Software Foundation, either version 3 of the License, or
9!! (at your option) any later version.
10!!
11!! mmg is distributed in the hope that it will be useful, but WITHOUT
12!! ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13!! FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
14!! License for more details.
15!!
16!! You should have received a copy of the GNU Lesser General Public
17!! License and of the GNU General Public License along with mmg (in
18!! files COPYING.LESSER and COPYING). If not, see
19!! <http://www.gnu.org/licenses/>. Please read their terms carefully and
20!! use this copy of the mmg distribution only if you accept them.
21!! =============================================================================
22!!
23
24!>
25!> Example of use of the mmgsls function of the mmgs library (basic use of
26!> level-set discretization option): here the user only provide the level-set
27!>
28!> @author Charles Dapogny (LJLL, UPMC)
29!> @author Pascal Frey (LJLL, UPMC)
30!> @author Algiane Froehly (Inria / IMB, Université de Bordeaux)
31!> @version 5
32!> @copyright GNU Lesser General Public License.
33!>
34
35PROGRAM main
36
37 IMPLICIT NONE
38
39!> Include here the mmgs library hader file
40! if the header file is in the "include" directory
41! #include "libmmgsf.h"
42
43! if the header file is in "include/mmg/mmgs"
44#include "mmg/mmgs/libmmgsf.h"
45
46 mmg5_data_ptr_t :: mmgmesh
47 mmg5_data_ptr_t :: mmgls
48 INTEGER :: ier,argc
49 CHARACTER(len=300) :: exec_name,inname,outname,lsname
50
51 !> to cast integers into MMG5F_INT integers
52 INTEGER,PARAMETER :: immg = mmg5f_int
53
54 WRITE(*,*) " -- TEST MMGSLIB"
55
56 argc = command_argument_count();
57 CALL get_command_argument(0, exec_name)
58
59 IF ( argc /=3 ) THEN
60 print*," Usage: ",trim(exec_name)," meshfile lsfile meshout"
61 CALL exit(1);
62 ENDIF
63
64 ! Name and path of the mesh file
65 CALL get_command_argument(1, inname)
66 CALL get_command_argument(2, lsname)
67 CALL get_command_argument(3, outname)
68
69 !> ------------------------------ STEP I --------------------------
70 !! 1) Initialisation of mesh and sol structures
71 !! args of InitMesh:
72 !! MMG5_ARG_start: we start to give the args of a variadic func
73 !! MMG5_ARG_ppMesh: next arg will be a pointer over a MMG5_pMesh
74 !! mmgMesh: your MMG5_pMesh (that store your mesh)
75 !! MMG5_ARG_ppLs: next arg will be a pointer over a MMG5_pSol storing a level-set
76 !! &mmgLs: pointer toward your MMG5_pSol (that store your level-set)
77
78 mmgmesh = 0
79 mmgls = 0
80
81 CALL mmgs_init_mesh(mmg5_arg_start, &
82 mmg5_arg_ppmesh,mmgmesh,mmg5_arg_ppls,mmgls, &
83 mmg5_arg_end)
84
85 !!------------------- Level set discretization option ---------------------
86 ! Ask for level set discretization: note that it is important to do this step
87 ! here because in iso mode, some filters are applied at mesh loading
88 !
89 ! Pass 0_8 (0 at 64 bytes precision) if you don't want to pass the mmgLs
90 ! structure (unused argument of Set_iparameter functions), it is equivalent to
91 ! pass a pointer toward NULL.
92 CALL mmgs_set_iparameter(mmgmesh,0_8,mmgs_iparam_iso, 1_immg,ier)
93 IF ( ier == 0 ) CALL exit(101)
94
95 ! Ask for optim mode: compute the mean of input edge lengths.
96 CALL mmgs_set_iparameter(mmgmesh,0_8,mmgs_iparam_optim, 1_immg,ier)
97 IF ( ier == 0 ) CALL exit(101)
98
99 ! Ask to do this with anisotropic metric (unit tensor metric is computed).
100 CALL mmgs_set_iparameter(mmgmesh,0_8,mmgs_iparam_anisosize, 1_immg,ier)
101 IF ( ier == 0 ) CALL exit(101)
102
103 !> 2) Build mesh in MMG5 format
104 !! Two solutions: just use the MMGS_loadMesh function that will read a .mesh(b)
105 !! file formatted or manually set your mesh using the MMGS_Set* functions
106
107 !> with MMGS_loadMesh function
108 CALL mmgs_loadmesh(mmgmesh,trim(adjustl(inname)),&
109 len(trim(adjustl(inname))),ier)
110 IF ( ier == 0 ) CALL exit(102)
111
112 !> 3) Build the level-set in MMG5 format
113 !! Two solutions: just use the MMGS_loadSol function that will read a .sol(b)
114 !! file formatted or manually set your level-set using the MMGS_Set* functions
115
116 !> With MMGS_loadSol function
117 CALL mmgs_loadsol(mmgmesh,mmgls,trim(adjustl(lsname)),&
118 len(trim(adjustl(lsname))),ier)
119 IF ( ier /= 1 ) THEN
120 CALL exit(104)
121 ENDIF
122
123 !> 4) (not mandatory): check the mesh and levelset sizes
124 CALL mmgs_chk_meshdata(mmgmesh,mmgls,ier)
125 IF ( ier /= 1 ) CALL exit(105)
126
127 !> ------------------------------ STEP II --------------------------
128 !! isovalue discretization: as we don't want to impose an input metric we pass
129 !! %val(0_8) instead of the metric structure as function argument (equivalent
130 !! to pass NULL value)
131 CALL mmgs_mmgsls(mmgmesh,mmgls,%val(0_8),ier)
132
133 IF ( ier == mmg5_strongfailure ) THEN
134 print*,"BAD ENDING OF MMGSLIB: UNABLE TO SAVE MESH"
135 stop 2
136 ELSE IF ( ier == mmg5_lowfailure ) THEN
137 print*,"BAD ENDING OF MMGSLIB"
138 ENDIF
139
140 !> ------------------------------ STEP III --------------------------
141 !! get results
142 !! Two solutions: just use the MMGS_saveMesh function
143 !! that will write .mesh(b) formatted file or manually get your mesh
144 !! using the MMGS_getMesh function
145
146 !> 1) Automatically save the mesh
147 CALL mmgs_savemesh(mmgmesh,trim(adjustl(outname)),&
148 len(trim(adjustl(outname))),ier)
149 IF ( ier /= 1 ) THEN
150 CALL exit(106)
151 ENDIF
152
153 !> 3) Free the MMGS5 structures
154 CALL mmgs_free_all(mmg5_arg_start, &
155 mmg5_arg_ppmesh,mmgmesh,mmg5_arg_ppls,mmgls, &
156 mmg5_arg_end)
157
158END PROGRAM
int main(int argc, char *argv[])
Definition mmg2d.c:275