Mmg
Simplicial remeshers (mesh adaptation, isovalue discretization, lagrangian movement)
main_optim.c
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
35#include <assert.h>
36#include <stdio.h>
37#include <stdlib.h>
38#include <signal.h>
39#include <string.h>
40#include <ctype.h>
41#include <math.h>
42#include <float.h>
43
45// if the header file is in the "include" directory
46// #include "libmmg3d.h"
47// if the header file is in "include/mmg/mmg3d"
48#include "mmg/mmg3d/libmmg3d.h"
49
50int main(int argc,char *argv[]) {
51 MMG5_pMesh mmgMesh;
52 MMG5_pSol mmgLs;
53 int ier;
54 char *inname,*lsname,*outname;
55
56 fprintf(stdout," -- TEST MMG3DLS \n");
57
58 if ( argc != 4 ) {
59 printf(" Usage: %s meshfile lsfile meshout\n",argv[0]);
60 return(1);
61 }
62
63 /* Name and path of the mesh files */
64 inname = (char *) calloc(strlen(argv[1]) + 1, sizeof(char));
65 if ( inname == NULL ) {
66 perror(" ## Memory problem: calloc");
67 exit(EXIT_FAILURE);
68 }
69 strcpy(inname,argv[1]);
70
71 lsname = (char *) calloc(strlen(argv[2]) + 1, sizeof(char));
72 if ( lsname == NULL ) {
73 perror(" ## Memory problem: calloc");
74 exit(EXIT_FAILURE);
75 }
76 strcpy(lsname,argv[2]);
77
78
79 outname = (char *) calloc(strlen(argv[3]) + 1, sizeof(char));
80 if ( outname == NULL ) {
81 perror(" ## Memory problem: calloc");
82 exit(EXIT_FAILURE);
83 }
84 strcpy(outname,argv[3]);
85
87 /* args of InitMesh:
88 * MMG5_ARG_start: we start to give the args of a variadic func
89 * MMG5_ARG_ppMesh: next arg will be a pointer over a MMG5_pMesh
90 * &mmgMesh: pointer to your MMG5_pMesh (that stores your mesh)
91 * MMG5_ARG_ppLs: next arg will be a pointer over a MMG5_pSol storing a level-set
92 * &mmgLs: pointer to your MMG5_pSol (that stores your level-set)
93 */
94 mmgMesh = NULL;
95 mmgLs = NULL;
97 MMG5_ARG_ppMesh,&mmgMesh,MMG5_ARG_ppLs,&mmgLs,
99
101 /* Ask for level set discretization: note that it is important to do this step
102 * here because in iso mode, some filters are applied at mesh loading */
103 if ( MMG3D_Set_iparameter(mmgMesh,NULL,MMG3D_IPARAM_iso, 1) != 1 )
104 exit(EXIT_FAILURE);
105
106 /* Ask for optim mode: compute the mean of input edge lengths */
107 if ( MMG3D_Set_iparameter(mmgMesh,NULL,MMG3D_IPARAM_optim, 1) != 1 )
108 exit(EXIT_FAILURE);
109
110 /* Ask to do this with anisotropic metric */
111 if ( MMG3D_Set_iparameter(mmgMesh,NULL,MMG3D_IPARAM_anisosize, 1) != 1 )
112 exit(EXIT_FAILURE);
113
119 if ( MMG3D_loadMesh(mmgMesh,inname) != 1 ) exit(EXIT_FAILURE);
120
125 if ( MMG3D_loadSol(mmgMesh,mmgLs,lsname) != 1 )
126 exit(EXIT_FAILURE);
127
129 if ( MMG3D_Chk_meshData(mmgMesh,mmgLs) != 1 ) exit(EXIT_FAILURE);
130
140 ier = MMG3D_mmg3dls(mmgMesh,mmgLs,NULL);
141
142 if ( ier == MMG5_STRONGFAILURE ) {
143 fprintf(stdout,"BAD ENDING OF MMG3DLS: UNABLE TO SAVE MESH\n");
144 return(ier);
145 } else if ( ier == MMG5_LOWFAILURE )
146 fprintf(stdout,"BAD ENDING OF MMG3DLS\n");
147
148 /* (Not mandatory) Automatically save the mesh */
149 if ( MMG3D_saveMesh(mmgMesh,outname) != 1 )
150 exit(EXIT_FAILURE);
151
152 /* 9) free the MMG3D5 structures */
154 MMG5_ARG_ppMesh,&mmgMesh,MMG5_ARG_ppLs,&mmgLs,
156
157 free(inname);
158 inname = NULL;
159
160 free(outname);
161 outname = NULL;
162
163 free(lsname);
164 outname = NULL;
165
166 return(ier);
167}
int MMG3D_Init_mesh(const int starter,...)
Initialize a mesh structure and optionally the associated solution and metric structures.
int MMG3D_Chk_meshData(MMG5_pMesh mesh, MMG5_pSol met)
Check if the number of given entities match with mesh and sol size.
int MMG3D_Free_all(const int starter,...)
Deallocations before return.
int MMG3D_Set_iparameter(MMG5_pMesh mesh, MMG5_pSol sol, int iparam, MMG5_int val)
set an integer parameter of the remesher
int ier
program main
Example for using mmglib (basic use)
Definition: main.F90:6
int MMG3D_saveMesh(MMG5_pMesh mesh, const char *filename)
Save a mesh in .mesh/.meshb format.
Definition: inout_3d.c:1273
int MMG3D_loadSol(MMG5_pMesh mesh, MMG5_pSol met, const char *filename)
Load a metric field (or other solution).
Definition: inout_3d.c:2143
int MMG3D_loadMesh(MMG5_pMesh mesh, const char *filename)
Load a mesh (in .mesh/.mesb format) from file.
Definition: inout_3d.c:1049
int MMG3D_mmg3dls(MMG5_pMesh mesh, MMG5_pSol sol, MMG5_pSol umet)
Main "program" for the level-set discretization library.
Definition: libmmg3d.c:1192
@ MMG3D_IPARAM_anisosize
Definition: libmmg3d.h:166
@ MMG3D_IPARAM_optim
Definition: libmmg3d.h:153
@ MMG3D_IPARAM_iso
Definition: libmmg3d.h:148
#define MMG5_ARG_ppMesh
Definition: libmmgtypes.h:102
#define MMG5_ARG_end
Definition: libmmgtypes.h:179
#define MMG5_ARG_ppLs
Definition: libmmgtypes.h:112
#define MMG5_STRONGFAILURE
Definition: libmmgtypes.h:65
#define MMG5_LOWFAILURE
Definition: libmmgtypes.h:57
#define MMG5_ARG_start
Definition: libmmgtypes.h:93
MMG mesh structure.
Definition: libmmgtypes.h:613