47 return (ref - pim->
offset);
72 return (pim->
lookup[key] / 4 - 1);
88 return (pim->
lookup[key] % 4);
99 return pim->
lookup[key] ? 0 : 1;
112 fprintf(stderr,
"\n ## Warning: Overwrite material reference %d"
113 " (from LSReferences line %d) with another entry from LSReferences line %d."
115 fprintf(stderr,
"\n Check your LSReferences table: if possible,"
116 " each material reference should be unique,\n"
117 " if not possible, you may"
118 " encounter unexpected issues (wrong domain mapping or erroneous"
119 " detection of non-manifold level-set)!\n");
186 fprintf(stderr,
"\n ## Warning: %s: material %" MMG5_PRId
" not found in table.\n",
188 fprintf(stderr,
" Please ensure that you provide all mesh"
189 " references in the material map\n"
190 " (that is, the whole list of"
191 " surface materials in lssurf mode,\n"
192 " and the whole list of domain"
193 " materials in ls mode).\n" );
242 for( ref = pim->
offset; ref < pim->offset + pim->
size; ref++ ) {
244 printf(
"%" MMG5_PRId
" (%" MMG5_PRId
"): %" MMG5_PRId
" %d\n",ref,
330 MMG5_int refmax,refmin;
337 fprintf(stderr,
"\n ## Error: %s: Only %d materials out of %d have been set.\n",
348 refmin = MMG5_INTMAX;
354 if( pm->
ref > refmax ) refmax = pm->
ref;
355 if( pm->
ref < refmin ) refmin = pm->
ref;
356 if( !pm->
dospl )
continue;
358 if( pm->
rin > refmax ) refmax = pm->
rin;
359 if( pm->
rin < refmin ) refmin = pm->
rin;
361 if( pm->
rex > refmax ) refmax = pm->
rex;
362 if( pm->
rex < refmin ) refmin = pm->
rex;
369 for ( k=1; k<=
mesh->
ne; ++k ) {
373 for ( k=1; k<=
mesh->
nt; ++k ) {
377 for ( k=1; k<=
mesh->
na; ++k ) {
384 pim->
size = refmax - refmin + 1;
385 assert( pim->
size > 0 );
474 int8_t found0,found1;
507 MMG5_int k,kk,iel,ns,nc,ip,ip1,ip2,npl,nmn;
514 fprintf(stderr,
" Exit program.\n");
519 for (k=1; k<=
mesh->
np; k++)
524 for (k=1; k<=
mesh->
np; k++) {
526 if ( !
MG_VOK(p0) )
continue;
536 for (k=1; k<=
mesh->
nt; k++) {
538 if ( !
MG_EOK(pt) )
continue;
539 for (i=0; i<3; i++) {
555 if ( p0->
flag && !smsgn ) {
569 for (k=1; k<=
mesh->
nt; k++) {
571 if ( !
MG_EOK(pt) )
continue;
572 for (i=0; i<3; i++) {
578 for(kk=0; kk<ilist; kk++) {
593 if ( npl == 1 && nmn == 0 )
595 else if ( npl == 0 && nmn == 1 )
601 fprintf(stdout,
" %8" MMG5_PRId
" points snapped, %" MMG5_PRId
" corrected\n",ns,nc);
626 MMG5_int refstart,*adja,k,ip1,ip2,end1;
628 static int8_t mmgWarn=0;
670 while ( smsgn && (k != start) );
718 while ( smsgn && (k != start) );
728 fprintf(stderr,
"\n ## Warning: %s: unsnap at least 1 point "
729 "(point %" MMG5_PRId
" in tri %" MMG5_PRId
").\n",__func__,
756 vol = (p1->
c[0]-p0->
c[0])*(p2->
c[1]-p0->
c[1]) - (p1->
c[1]-p0->
c[1])*(p2->
c[0]-p0->
c[0]);
778 double v[3],vfp,vfm,lam,area,eps,o1[2],o2[2];
779 MMG5_int ip[3],nplus,nminus,nzero;
780 int8_t i,i0,i1,i2,imin1,iplus1,iz;
793 v[0] =
sol->m[ip[0]];
794 v[1] =
sol->m[ip[1]];
795 v[2] =
sol->m[ip[2]];
798 nplus = nminus = nzero = 0;
799 imin1 = iplus1 = iz = -1;
801 for (i=0; i<3; i++) {
802 if ( fabs(v[i]) < eps ) {
804 if ( iz < 0 ) iz = i;
806 else if ( v[i] >= eps ) {
808 if ( iplus1 < 0 ) iplus1 = i;
812 if ( imin1 < 0 ) imin1 = i;
817 if ( nzero == 3 )
return 0.0;
821 vfp = (ppt[1]->
c[0]-ppt[0]->
c[0])*(ppt[2]->c[1]-ppt[0]->c[1]) - (ppt[1]->
c[1]-ppt[0]->
c[1])*(ppt[2]->c[0]-ppt[0]->c[0]);
823 if ( pm == 1 )
return vfp;
829 vfm = (ppt[1]->
c[0]-ppt[0]->
c[0])*(ppt[2]->c[1]-ppt[0]->c[1]) - (ppt[1]->
c[1]-ppt[0]->
c[1])*(ppt[2]->c[0]-ppt[0]->c[0]);
831 if ( pm == -1 )
return vfm;
841 lam = v[i0] / (v[i0]-v[i1]);
842 o1[0] = ppt[i0]->
c[0] + lam*(ppt[i1]->
c[0]-ppt[i0]->
c[0]);
843 o1[1] = ppt[i0]->
c[1] + lam*(ppt[i1]->
c[1]-ppt[i0]->
c[1]);
845 lam = v[i0] / (v[i0]-v[i2]);
846 o2[0] = ppt[i0]->
c[0] + lam*(ppt[i2]->
c[0]-ppt[i0]->
c[0]);
847 o2[1] = ppt[i0]->
c[1] + lam*(ppt[i2]->
c[1]-ppt[i0]->
c[1]);
849 vfm = (o1[0]-ppt[i0]->
c[0])*(o2[1]-ppt[i0]->c[1]) - (o1[1]-ppt[i0]->
c[1])*(o2[0]-ppt[i0]->c[0]);
852 if ( pm == -1 )
return vfm;
854 area = (ppt[1]->
c[0]-ppt[0]->
c[0])*(ppt[2]->c[1]-ppt[0]->c[1]) - (ppt[1]->
c[1]-ppt[0]->
c[1])*(ppt[2]->c[0]-ppt[0]->c[0]);
855 area = 0.5*fabs(area);
867 lam = v[i0] / (v[i0]-v[i1]);
868 o1[0] = ppt[i0]->
c[0] + lam*(ppt[i1]->
c[0]-ppt[i0]->
c[0]);
869 o1[1] = ppt[i0]->
c[1] + lam*(ppt[i1]->
c[1]-ppt[i0]->
c[1]);
871 lam = v[i0] / (v[i0]-v[i2]);
872 o2[0] = ppt[i0]->
c[0] + lam*(ppt[i2]->
c[0]-ppt[i0]->
c[0]);
873 o2[1] = ppt[i0]->
c[1] + lam*(ppt[i2]->
c[1]-ppt[i0]->
c[1]);
875 vfp = (o1[0]-ppt[i0]->
c[0])*(o2[1]-ppt[i0]->c[1]) - (o1[1]-ppt[i0]->
c[1])*(o2[0]-ppt[i0]->c[0]);
878 if ( pm == 1 )
return vfp;
880 area = (ppt[1]->
c[0]-ppt[0]->
c[0])*(ppt[2]->c[1]-ppt[0]->c[1]) - (ppt[1]->
c[1]-ppt[0]->
c[1])*(ppt[2]->c[0]-ppt[0]->c[0]);
881 area = 0.5*fabs(area);
914 double volc,voltot,v0,v1,v2;
915 MMG5_int k,kk,l,ll,ncp,ncm,ip0,ip1,ip2,cur,ipile,*pile,*adja,base;
926 for (k=1; k<=
mesh->
nt; k++) {
928 if ( !
MG_EOK(pt) )
continue;
937 printf(
" Exit program.\n");
944 for (k=1; k<=
mesh->
nt; k++) {
948 if ( !
MG_EOK(pt) )
continue;
949 if ( pt->
flag == base )
continue;
960 if ( v0 <= 0.0 && v1 <= 0.0 && v2 <= 0.0 )
continue;
967 fprintf(stderr,
"\n ## Problem in length of pile; function rmc.\n"
968 " Check that the level-set intersect the mesh.\n"
985 for (i=0; i<3; i++) {
987 if (
sol->m[ip0] <= 0.0 )
continue;
996 if ( pt2->
flag != base ) {
1000 if ( ipile >
mesh->
nt ) {
1001 fprintf(stderr,
"\n ## Problem in length of pile; function rmc. Exit program.\n");
1011 if ( pt2->
flag != base ) {
1015 if ( ipile >
mesh->
nt ) {
1016 fprintf(stderr,
"\n ## Problem in length of pile; function rmc. Exit program.\n");
1023 while ( ++cur < ipile );
1026 if ( volc < mesh->
info.
rmc*voltot ) {
1027 for (l=0; l<ipile; l++) {
1029 for (i=0; i<3; i++) {
1042 for (k=1; k<=
mesh->
nt; k++) {
1046 if ( !
MG_EOK(pt) )
continue;
1047 if ( pt->
flag == base )
continue;
1058 if ( v0 >= 0.0 && v1 >= 0.0 && v2 >= 0.0 )
continue;
1064 if ( ipile >
mesh->
nt ) {
1065 fprintf(stderr,
"\n ## Problem in length of pile; function rmc. Exit program.\n");
1079 for (i=0; i<3; i++) {
1081 if (
sol->m[ip0] >= 0.0 )
continue;
1090 if ( pt2->
flag != base ) {
1094 if ( ipile >
mesh->
nt ) {
1095 fprintf(stderr,
"\n ## Problem in length of pile; function rmc. Exit program.\n");
1105 if ( pt2->
flag != base ) {
1109 if ( ipile >
mesh->
nt ) {
1110 fprintf(stderr,
"\n ## Problem in length of pile; function rmc. Exit program.\n");
1118 while ( ++cur < ipile );
1121 if ( volc < mesh->
info.
rmc*voltot ) {
1122 for (l=0; l<ipile; l++) {
1124 for (i=0; i<3; i++) {
1135 for (l=0; l<ipile; l++) {
1137 for (i=0; i<3; i++) {
1142 if (
sol->m[ip1] < 0.0 ) {
1147 if (
sol->m[ip2] < 0.0 ) {
1157 for (l=0; l<ipile; l++) {
1159 for (i=0; i<3; i++) {
1177 printf(
"\n *** Removed %" MMG5_PRId
" positive parasitic bubbles and %" MMG5_PRId
" negative parasitic bubbles\n",ncp,ncm);
1195 for (k=1; k<=
mesh->
nt; k++) {
1197 if ( !pt->
v[0] )
continue;
1199 for (i=0; i<3; i++) {
1207 for (k=1; k<=
mesh->
nt; k++) {
1209 if ( !pt->
v[0] )
continue;
1229 MMG5_int k,ip,ip1,ref,refint,refext;
1230 int8_t i,i1,i2,nmn,npl,nz;
1232 for (k=1; k<=
mesh->
nt; k++) {
1234 if ( !
MG_EOK(pt) )
continue;
1238 for (i=0; i<3; i++) {
1272 for (i=0; i<3; i++) {
1277 if ( v == 0.0 && v1 == 0.0) {
1305 MMG5_int refstart,*adja,k;
1357 if ( k == 0 )
return 1;
1429 static int8_t mmgWarn = 0;
1432 for (k=1; k<=
mesh->
nt; k++) {
1434 if ( !
MG_EOK(pt) )
continue;
1438 for (i=0; i<3; i++) {
1450 if ( pt1->
ref != pt->
ref ) cnt++;
1461 fprintf(stderr,
"\n ## Warning: %s: at least 1 triangle with 3 boundary"
1462 " edges.\n",__func__);
1470 for (k=1; k<=
mesh->
nt; k++) {
1472 if ( !
MG_EOK(pt) )
continue;
1474 for (i=0; i<3; i++) {
1478 if (! iel )
continue;
1492 fprintf(stderr,
" *** Topological problem\n");
1493 fprintf(stderr,
" non manifold curve at point %" MMG5_PRId
"\n",pt->
v[i1]);
1494 fprintf(stderr,
" non manifold curve at tria %" MMG5_PRId
" (ip %d)\n", MMG5_indElt(
mesh,k),i1);
1501 fprintf(stdout,
" *** Manifold implicit surface.\n");
MMG5_pMesh MMG5_pSol * sol
int MMG5_boulet(MMG5_pMesh mesh, MMG5_int start, int ip, MMG5_int *list, int8_t s, int8_t *opn)
static int MMG5_InvMat_code(int k, int attr)
static void MMG5_InvMat_error(MMG5_pInvMat pim, int ref, int k)
int MMG5_rmc(MMG5_pMesh mesh, MMG5_pSol sol)
static int MMG5_InvMat_check(MMG5_pInvMat pim, int key)
int MMG5_isLevelSet(MMG5_pMesh mesh, MMG5_int ref0, MMG5_int ref1)
int MMG5_isNotSplit(MMG5_pMesh mesh, MMG5_int ref)
int MMG5_ismaniball(MMG5_pMesh mesh, MMG5_pSol sol, MMG5_int start, int8_t istart)
static int MMG5_isbr(MMG5_pMesh mesh, MMG5_int ref)
static int MMG5_InvMat_getParent(MMG5_pMesh mesh, MMG5_pInvMat pim, MMG5_int ref, MMG5_int *pref)
static MMG5_int MMG5_InvMat_key(MMG5_pInvMat pim, int ref)
static int MMG5_InvMat_getAttrib(MMG5_pInvMat pim, int ref)
int MMG5_snpval_ls(MMG5_pMesh mesh, MMG5_pSol sol)
int MMG5_isSplit(MMG5_pMesh mesh, MMG5_int ref, MMG5_int *refint, MMG5_int *refext)
static int MMG5_InvMat_set(MMG5_pMesh mesh, MMG5_pInvMat pim, int k)
static void MMG5_InvMat_print(MMG5_pMesh mesh, MMG5_pInvMat pim)
static double MMG5_voltri(MMG5_pMesh mesh, MMG5_int ip0, MMG5_int ip1, MMG5_int ip2)
int MMG5_MultiMat_init(MMG5_pMesh mesh)
int MMG5_getStartRef(MMG5_pMesh mesh, MMG5_int ref, MMG5_int *pref)
static double MMG5_vfrac(MMG5_pMesh mesh, MMG5_pSol sol, MMG5_int k, int pm)
int MMG5_resetRef_ls(MMG5_pMesh mesh)
int MMG5_chkmaniball(MMG5_pMesh mesh, MMG5_int start, int8_t istart)
int MMG5_chkmanimesh(MMG5_pMesh mesh)
static int MMG5_InvMat_getIndex(MMG5_pInvMat pim, int ref)
int MMG5_setref_ls(MMG5_pMesh mesh, MMG5_pSol sol)
#define MMG5_SAFE_CALLOC(ptr, size, type, law)
#define MMG5_ADD_MEM(mesh, size, message, law)
static const uint8_t MMG5_iprv2[3]
static const uint8_t MMG5_inxt2[6]
#define MMG5_DEL_MEM(mesh, ptr)
To store lookup table for references in the mesh (useful in LS mode)
To store user-defined references in the mesh (useful in LS mode)
Structure to store vertices of an MMG mesh.
Structure to store triangles of a MMG mesh.