From 721ae9e6c4539bb7e1e8dd55b06f6ee89b97bbe5 Mon Sep 17 00:00:00 2001 From: Christophe Geuzaine <cgeuzaine@ulg.ac.be> Date: Sun, 14 May 2006 00:48:20 +0000 Subject: [PATCH] - fixed 2 special cases in quad->prism extrusion (bad node ordering) - fixed .msh save of negative volume 2nd order hexas --- Mesh/3D_Extrude.cpp | 8 ++++---- Mesh/Print_Mesh.cpp | 17 ++++++++--------- 2 files changed, 12 insertions(+), 13 deletions(-) diff --git a/Mesh/3D_Extrude.cpp b/Mesh/3D_Extrude.cpp index a0a96e0180..c8502a2a18 100644 --- a/Mesh/3D_Extrude.cpp +++ b/Mesh/3D_Extrude.cpp @@ -1,4 +1,4 @@ -// $Id: 3D_Extrude.cpp,v 1.91 2006-01-06 00:34:25 geuzaine Exp $ +// $Id: 3D_Extrude.cpp,v 1.92 2006-05-14 00:48:20 geuzaine Exp $ // // Copyright (C) 1997-2006 C. Geuzaine, J.-F. Remacle // @@ -366,15 +366,15 @@ void Create_HexPri(int iEnt, Vertex * v[8]) if(j == 2) { if(dup[0] == 0 && dup[1] == 1) - newp = Create_Prism(v[0], v[3], v[7], v[1], v[6], v[2]); + newp = Create_Prism(v[0], v[3], v[7], v[1], v[2], v[6]); else if(dup[0] == 1 && dup[1] == 2) newp = Create_Prism(v[0], v[1], v[4], v[3], v[2], v[7]); else if(dup[0] == 2 && dup[1] == 3) - newp = Create_Prism(v[0], v[3], v[4], v[1], v[5], v[7]); + newp = Create_Prism(v[0], v[3], v[4], v[1], v[2], v[5]); else if(dup[0] == 0 && dup[1] == 3) newp = Create_Prism(v[0], v[1], v[5], v[3], v[2], v[6]); else { - Msg(GERROR, "Uncoherent hexahedron (nodes %d %d %d %d %d %d %d %d)", + Msg(GERROR, "Uncoherent hexahedron (nodes %d %d %d %d %d %d %d %d)", v[0], v[1], v[2], v[3], v[4], v[5], v[6], v[7]); return; } diff --git a/Mesh/Print_Mesh.cpp b/Mesh/Print_Mesh.cpp index 6979f8ef87..4ad993768f 100644 --- a/Mesh/Print_Mesh.cpp +++ b/Mesh/Print_Mesh.cpp @@ -1,4 +1,4 @@ -// $Id: Print_Mesh.cpp,v 1.74 2006-05-13 22:32:13 geuzaine Exp $ +// $Id: Print_Mesh.cpp,v 1.75 2006-05-14 00:48:20 geuzaine Exp $ // // Copyright (C) 1997-2006 C. Geuzaine, J.-F. Remacle // @@ -168,9 +168,7 @@ static void _msh_print_simplex(void *a, void *b) type = TETRAHEDRON; if(s->Volume_Simplexe() < 0) { Vertex *temp; - temp = s->V[0]; - s->V[0] = s->V[1]; - s->V[1] = temp; + temp = s->V[0]; s->V[0] = s->V[1]; s->V[1] = temp; } } } @@ -280,11 +278,12 @@ static void _msh_print_hexahedron(void *a, void *b) Vertex *temp; temp = h->V[0]; h->V[0] = h->V[2]; h->V[2] = temp; temp = h->V[4]; h->V[4] = h->V[6]; h->V[6] = temp; - temp = h->VSUP[0]; h->VSUP[0] = h->VSUP[4]; h->VSUP[4] = temp; - temp = h->VSUP[1]; h->VSUP[1] = h->VSUP[10]; h->VSUP[10] = temp; - temp = h->VSUP[2]; h->VSUP[2] = h->VSUP[8]; h->VSUP[8] = temp; - temp = h->VSUP[5]; h->VSUP[5] = h->VSUP[6]; h->VSUP[6] = temp; - temp = h->VSUP[7]; h->VSUP[7] = h->VSUP[11]; h->VSUP[11] = temp; + Vertex *old[12]; + for(int i = 0; i < 12; i++) old[i] = h->VSUP[i]; + h->VSUP[0] = old[3]; h->VSUP[1] = old[5]; h->VSUP[2] = old[6]; + h->VSUP[3] = old[0]; h->VSUP[4] = old[4]; h->VSUP[5] = old[1]; + h->VSUP[6] = old[2]; h->VSUP[7] = old[7]; h->VSUP[8] = old[10]; + h->VSUP[9] = old[11]; h->VSUP[10] = old[8]; h->VSUP[11] = old[9]; } } else { -- GitLab