From 580f4b9f52128e47cb2a13de547faf73babe16b5 Mon Sep 17 00:00:00 2001 From: Joachim Schoeberl Date: Thu, 16 Jun 2011 17:55:08 +0000 Subject: [PATCH] parallel ngs --- config.h.in | 3 + configure.ac | 4 +- libsrc/general/hashtabl.hpp | 1 - libsrc/general/template.hpp | 9 + libsrc/meshing/topology.cpp | 571 ++++++++++++++++++------------------ ng/ngappinit.cpp | 24 +- ng/parallelfunc.cpp | 2 +- 7 files changed, 300 insertions(+), 314 deletions(-) diff --git a/config.h.in b/config.h.in index a71eeea9..1b506b31 100644 --- a/config.h.in +++ b/config.h.in @@ -67,6 +67,9 @@ /* Define to the one symbol short name of this package. */ #undef PACKAGE_TARNAME +/* Define to the home page for this package. */ +#undef PACKAGE_URL + /* Define to the version of this package. */ #undef PACKAGE_VERSION diff --git a/configure.ac b/configure.ac index 911cfe9f..d1f2666a 100644 --- a/configure.ac +++ b/configure.ac @@ -87,8 +87,8 @@ AC_ARG_ENABLE([nglib], AC_ARG_ENABLE([parallel], [AC_HELP_STRING([--enable-parallel],[enable mpi parallelization])], - [AC_SUBST([MPI_INCLUDES], "-I/usr/lib64/mpi/gcc/openmpi/include -DPARALLEL -I/usr/include/metis -DMETIS -I/usr/local/include/vampirtrace") - AC_SUBST([MPI_LIBS], "-L/usr/lib64/mpi/gcc/openmpi/lib64 -lmpi_cxx -lmetis") + [AC_SUBST([MPI_INCLUDES], "-I/usr/lib64/mpi/gcc/openmpi/include -DPARALLEL -I/usr/include/metis -I/home/lv70202/jschoebe/tcltk/include -DMETIS -I/usr/local/include/vampirtrace") + AC_SUBST([MPI_LIBS], "-L/usr/lib64/mpi/gcc/openmpi/lib64 -L/home/lv70202/jschoebe/tcltk/lib -lmpi_cxx -lmetis") ] ) # -DVTRACE diff --git a/libsrc/general/hashtabl.hpp b/libsrc/general/hashtabl.hpp index 66dd934b..a705d399 100644 --- a/libsrc/general/hashtabl.hpp +++ b/libsrc/general/hashtabl.hpp @@ -72,7 +72,6 @@ public: - /// class BASE_INDEX_2_HASHTABLE { diff --git a/libsrc/general/template.hpp b/libsrc/general/template.hpp index 80352fcd..0bb83f27 100644 --- a/libsrc/general/template.hpp +++ b/libsrc/general/template.hpp @@ -370,6 +370,15 @@ public: }; +inline bool operator< (const INDEX_4 & a, const INDEX_4 & b) +{ + for (int j = 0; j < 4; j++) + { + if (a[j] < b[j]) return true; + if (a[j] > b[j]) return false; + } + return false; +} diff --git a/libsrc/meshing/topology.cpp b/libsrc/meshing/topology.cpp index 8d2e0fd0..74fca285 100644 --- a/libsrc/meshing/topology.cpp +++ b/libsrc/meshing/topology.cpp @@ -491,6 +491,8 @@ namespace netgen // cout << "build edges done" << endl; + + // generate faces if (buildfaces) // && mesh.GetDimension() == 3) { @@ -502,273 +504,6 @@ namespace netgen - - /* - - - faces.SetSize(ne); - surffaces.SetSize(nse); - - // face2vert.SetSize(0); // keep old faces - nfa = face2vert.Size(); - // INDEX_3_HASHTABLE vert2face(ne+nse+1); - INDEX_3_CLOSED_HASHTABLE vert2face(8*ne+2*nse+nfa+2); - - for (int i = 1; i <= face2vert.Size(); i++) - { - INDEX_3 f; - f.I1() = face2vert.Get(i)[0]; - f.I2() = face2vert.Get(i)[1]; - f.I3() = face2vert.Get(i)[2]; - vert2face.Set (f, i); - } - - for (int i = 1; i <= ne; i++) - { - const Element & el = mesh.VolumeElement (i); - - int nelfaces = GetNFaces (el.GetType()); - const ELEMENT_FACE * elfaces = GetFaces1 (el.GetType()); - - for (int j = 0; j < 6; j++) - faces.Elem(i)[j] = 0; - for (int j = 0; j < nelfaces; j++) - if (elfaces[j][3] == 0) - - { // triangle - - int facenum; - int facedir; - - INDEX_3 face(el.PNum(elfaces[j][0]), - el.PNum(elfaces[j][1]), - el.PNum(elfaces[j][2])); - - facedir = 0; - if (face.I1() > face.I2()) - { - swap (face.I1(), face.I2()); - facedir += 1; - } - if (face.I2() > face.I3()) - { - swap (face.I2(), face.I3()); - facedir += 2; - } - if (face.I1() > face.I2()) - { - swap (face.I1(), face.I2()); - facedir += 4; - } - - if (vert2face.Used (face)) - facenum = vert2face.Get(face); - else - { - nfa++; - vert2face.Set (face, nfa); - facenum = nfa; - - INDEX_4 hface(face.I1(),face.I2(),face.I3(),0); - face2vert.Append (hface); - // face2vert.SetSize(face2vert.Size()+1); - } - - faces.Elem(i)[j] = 8*(facenum-1)+facedir+1; - } - - else - - { - // quad - int facenum; - int facedir; - INDEX_4Q face4(el.PNum(elfaces[j][0]), - el.PNum(elfaces[j][1]), - el.PNum(elfaces[j][2]), - el.PNum(elfaces[j][3])); - - facedir = 0; - if (min2 (face4.I1(), face4.I2()) > - min2 (face4.I4(), face4.I3())) - { // z - flip - facedir += 1; - swap (face4.I1(), face4.I4()); - swap (face4.I2(), face4.I3()); - } - if (min2 (face4.I1(), face4.I4()) > - min2 (face4.I2(), face4.I3())) - { // x - flip - facedir += 2; - swap (face4.I1(), face4.I2()); - swap (face4.I3(), face4.I4()); - } - if (face4.I2() > face4.I4()) - { // diagonal flip - facedir += 4; - swap (face4.I2(), face4.I4()); - } - // face4.Sort(); - - INDEX_3 face(face4.I1(), face4.I2(), face4.I3()); - - if (vert2face.Used (face)) - { - facenum = vert2face.Get(face); - } - else - { - nfa++; - vert2face.Set (face, nfa); - facenum = nfa; - - // face2vert.SetSize(face2vert.Size()+1); - - INDEX_4 hface(face4.I1(),face4.I2(),face4.I3(),face4.I4()); - face2vert.Append (hface); - } - - faces.Elem(i)[j] = 8*(facenum-1)+facedir+1; - } - } - - face2surfel.SetSize(nfa+nse); - for (int i = 1; i <= face2surfel.Size(); i++) - face2surfel.Elem(i) = 0; - - for (int i = 1; i <= nse; i++) - { - const Element2d & el = mesh.SurfaceElement (i); - - const ELEMENT_FACE * elfaces = GetFaces1 (el.GetType()); - - if (elfaces[0][3] == 0) - - { // triangle - - int facenum; - int facedir; - - INDEX_3 face(el.PNum(elfaces[0][0]), - el.PNum(elfaces[0][1]), - el.PNum(elfaces[0][2])); - - facedir = 0; - if (face.I1() > face.I2()) - { - swap (face.I1(), face.I2()); - facedir += 1; - } - if (face.I2() > face.I3()) - { - swap (face.I2(), face.I3()); - facedir += 2; - } - if (face.I1() > face.I2()) - { - swap (face.I1(), face.I2()); - facedir += 4; - } - - if (vert2face.Used (face)) - facenum = vert2face.Get(face); - else - { - nfa++; - vert2face.Set (face, nfa); - facenum = nfa; - - // face2vert.SetSize(face2vert.Size()+1); - INDEX_4 hface(face.I1(),face.I2(),face.I3(),0); - face2vert.Append (hface); - } - - surffaces.Elem(i) = 8*(facenum-1)+facedir+1; - face2surfel.Elem(facenum) = i; - } - - else - - { - // quad - int facenum; - int facedir; - - INDEX_4Q face4(el.PNum(elfaces[0][0]), - el.PNum(elfaces[0][1]), - el.PNum(elfaces[0][2]), - el.PNum(elfaces[0][3])); - - facedir = 0; - if (min2 (face4.I1(), face4.I2()) > - min2 (face4.I4(), face4.I3())) - { // z - orientation - facedir += 1; - swap (face4.I1(), face4.I4()); - swap (face4.I2(), face4.I3()); - } - if (min2 (face4.I1(), face4.I4()) > - min2 (face4.I2(), face4.I3())) - { // x - orientation - facedir += 2; - swap (face4.I1(), face4.I2()); - swap (face4.I3(), face4.I4()); - } - if (face4.I2() > face4.I4()) - { - facedir += 4; - swap (face4.I2(), face4.I4()); - } - - INDEX_3 face(face4.I1(), face4.I2(), face4.I3()); - - if (vert2face.Used (face)) - facenum = vert2face.Get(face); - else - { - nfa++; - vert2face.Set (face, nfa); - facenum = nfa; - - // face2vert.SetSize(face2vert.Size()+1); - INDEX_4 hface(face4.I1(),face4.I2(),face4.I3(),face4.I3()); - face2vert.Append (hface); - } - - surffaces.Elem(i) = 8*(facenum-1)+facedir+1; - face2surfel.Elem(facenum) = i; - } - } - - - surf2volelement.SetSize (nse); - for (int i = 1; i <= nse; i++) - { - surf2volelement.Elem(i)[0] = 0; - surf2volelement.Elem(i)[1] = 0; - } - for (int i = 1; i <= ne; i++) - for (int j = 0; j < 6; j++) - { - int fnum = (faces.Get(i)[j]+7) / 8; - if (fnum > 0 && face2surfel.Elem(fnum)) - { - int sel = face2surfel.Elem(fnum); - surf2volelement.Elem(sel)[1] = - surf2volelement.Elem(sel)[0]; - surf2volelement.Elem(sel)[0] = i; - } - } - - face2vert.SetAllocSize (face2vert.Size()); - */ - - - - - - - faces.SetSize(ne); surffaces.SetSize(nse); @@ -795,6 +530,7 @@ namespace netgen } + /* for (int pass = 1; pass <= 2; pass++) { nfa = oldnfa; @@ -811,6 +547,7 @@ namespace netgen vert2face.Set (face, fnr+1); } + // cout << "inherited faces: " << endl << vert2face << endl; @@ -826,30 +563,18 @@ namespace netgen if (elfaces[j][3] == 0) { // triangle - - int facenum; - int facedir; - + int facenum, facedir; INDEX_3 face(el.PNum(elfaces[j][0]), el.PNum(elfaces[j][1]), el.PNum(elfaces[j][2])); facedir = 0; if (face.I1() > face.I2()) - { - swap (face.I1(), face.I2()); - facedir += 1; - } + { swap (face.I1(), face.I2()); facedir += 1; } if (face.I2() > face.I3()) - { - swap (face.I2(), face.I3()); - facedir += 2; - } + { swap (face.I2(), face.I3()); facedir += 2; } if (face.I1() > face.I2()) - { - swap (face.I1(), face.I2()); - facedir += 4; - } + { swap (face.I1(), face.I2()); facedir += 4; } if (face.I1() != v) continue; @@ -864,7 +589,6 @@ namespace netgen INDEX_4 hface(face.I1(),face.I2(),face.I3(),0); if (pass == 2) face2vert.Append (hface); } - // cout << "face = " << face << " elnr = " << elnr << endl; faces.Elem(elnr)[j] = 8*(facenum-1)+facedir+1; } @@ -872,8 +596,7 @@ namespace netgen { // quad - int facenum; - int facedir; + int facenum, facedir; INDEX_4Q face4(el.PNum(elfaces[j][0]), el.PNum(elfaces[j][1]), el.PNum(elfaces[j][2]), @@ -1029,14 +752,288 @@ namespace netgen } surffaces.Elem(elnr) = 8*(facenum-1)+facedir+1; - // face2surfel.Elem(facenum) = elnr; } } } + face2vert.SetAllocSize (nfa); + } + */ + + + + + + + + + for (int pass = 1; pass <= 2; pass++) + { + nfa = oldnfa; + for (int v = PointIndex::BASE; v < nv+PointIndex::BASE; v++) + { + int first_fa = nfa; + + INDEX_3_CLOSED_HASHTABLE vert2face(2*max_face_on_vertex+10); + + for (int j = 0; j < vert2oldface[v].Size(); j++) + { + int fnr = vert2oldface[v][j]; + INDEX_3 face (face2vert[fnr].I1(), + face2vert[fnr].I2(), + face2vert[fnr].I3()); + vert2face.Set (face, fnr+1); + } + + + if (pass == 2) + for (int j = nfa; j < face2vert.Size(); j++) + { + if (face2vert[j][0] == v) + { + INDEX_3 face (face2vert[j].I1(), + face2vert[j].I2(), + face2vert[j].I3()); + vert2face.Set (face, j+1); + nfa++; + } + else + break; + } + + + // cout << "inherited faces: " << endl << vert2face << endl; + + + for (int j = 0; j < (*vert2element)[v].Size(); j++) + { + int elnr = (*vert2element)[v][j]; + const Element & el = mesh.VolumeElement (elnr); + + int nelfaces = GetNFaces (el.GetType()); + const ELEMENT_FACE * elfaces = GetFaces1 (el.GetType()); + + for (int j = 0; j < nelfaces; j++) + if (elfaces[j][3] == 0) + + { // triangle + int facenum, facedir; + INDEX_3 face(el.PNum(elfaces[j][0]), + el.PNum(elfaces[j][1]), + el.PNum(elfaces[j][2])); + + facedir = 0; + if (face.I1() > face.I2()) + { swap (face.I1(), face.I2()); facedir += 1; } + if (face.I2() > face.I3()) + { swap (face.I2(), face.I3()); facedir += 2; } + if (face.I1() > face.I2()) + { swap (face.I1(), face.I2()); facedir += 4; } + + if (face.I1() != v) continue; + + if (vert2face.Used (face)) + facenum = vert2face.Get(face); + else + { + nfa++; + vert2face.Set (face, nfa); + facenum = nfa; + + INDEX_4 hface(face.I1(),face.I2(),face.I3(),0); + face2vert.Append (hface); + } + faces.Elem(elnr)[j] = 8*(facenum-1)+facedir+1; + } + + else + + { + // quad + int facenum, facedir; + INDEX_4Q face4(el.PNum(elfaces[j][0]), + el.PNum(elfaces[j][1]), + el.PNum(elfaces[j][2]), + el.PNum(elfaces[j][3])); + + facedir = 0; + if (min2 (face4.I1(), face4.I2()) > + min2 (face4.I4(), face4.I3())) + { // z - flip + facedir += 1; + swap (face4.I1(), face4.I4()); + swap (face4.I2(), face4.I3()); + } + if (min2 (face4.I1(), face4.I4()) > + min2 (face4.I2(), face4.I3())) + { // x - flip + facedir += 2; + swap (face4.I1(), face4.I2()); + swap (face4.I3(), face4.I4()); + } + if (face4.I2() > face4.I4()) + { // diagonal flip + facedir += 4; + swap (face4.I2(), face4.I4()); + } + + + INDEX_3 face(face4.I1(), face4.I2(), face4.I3()); + + if (face.I1() != v) continue; + + if (vert2face.Used (face)) + { + facenum = vert2face.Get(face); + } + else + { + nfa++; + vert2face.Set (face, nfa); + facenum = nfa; + + INDEX_4 hface(face4.I1(),face4.I2(),face4.I3(),face4.I4()); + face2vert.Append (hface); + } + + faces.Elem(elnr)[j] = 8*(facenum-1)+facedir+1; + } + } + + for (int j = 0; j < (*vert2surfelement)[v].Size(); j++) + { + int elnr = (*vert2surfelement)[v][j]; + // cout << "surfelnr = " << elnr << endl; + const Element2d & el = mesh.SurfaceElement (elnr); + + const ELEMENT_FACE * elfaces = GetFaces1 (el.GetType()); + + if (elfaces[0][3] == 0) + + { // triangle + + int facenum; + int facedir; + + INDEX_3 face(el.PNum(elfaces[0][0]), + el.PNum(elfaces[0][1]), + el.PNum(elfaces[0][2])); + + // cout << "face = " << face << endl; + + facedir = 0; + if (face.I1() > face.I2()) + { + swap (face.I1(), face.I2()); + facedir += 1; + } + if (face.I2() > face.I3()) + { + swap (face.I2(), face.I3()); + facedir += 2; + } + if (face.I1() > face.I2()) + { + swap (face.I1(), face.I2()); + facedir += 4; + } + + if (face.I1() != v) continue; + + if (vert2face.Used (face)) + facenum = vert2face.Get(face); + else + { + nfa++; + vert2face.Set (face, nfa); + facenum = nfa; + + INDEX_4 hface(face.I1(),face.I2(),face.I3(),0); + face2vert.Append (hface); + } + + surffaces.Elem(elnr) = 8*(facenum-1)+facedir+1; + } + + else + + { + // quad + int facenum; + int facedir; + + INDEX_4Q face4(el.PNum(elfaces[0][0]), + el.PNum(elfaces[0][1]), + el.PNum(elfaces[0][2]), + el.PNum(elfaces[0][3])); + + facedir = 0; + if (min2 (face4.I1(), face4.I2()) > + min2 (face4.I4(), face4.I3())) + { // z - orientation + facedir += 1; + swap (face4.I1(), face4.I4()); + swap (face4.I2(), face4.I3()); + } + if (min2 (face4.I1(), face4.I4()) > + min2 (face4.I2(), face4.I3())) + { // x - orientation + facedir += 2; + swap (face4.I1(), face4.I2()); + swap (face4.I3(), face4.I4()); + } + if (face4.I2() > face4.I4()) + { + facedir += 4; + swap (face4.I2(), face4.I4()); + } + + INDEX_3 face(face4.I1(), face4.I2(), face4.I3()); + if (face.I1() != v) continue; + + if (vert2face.Used (face)) + facenum = vert2face.Get(face); + else + { + nfa++; + vert2face.Set (face, nfa); + facenum = nfa; + + INDEX_4 hface(face4.I1(),face4.I2(),face4.I3(),face4.I3()); + face2vert.Append (hface); + } + + surffaces.Elem(elnr) = 8*(facenum-1)+facedir+1; + } + } + + // sort faces + // *testout << "faces = " << face2vert << endl; + if (pass == 1) + { + *testout << "sort from " << first_fa << " to " << nfa << endl; + for (int i = first_fa; i < nfa; i++) + for (int j = first_fa+1; j < nfa; j++) + if (face2vert[j] < face2vert[j-1]) + Swap (face2vert[j-1], face2vert[j]); + } + // *testout << "faces, sorted = " << face2vert << endl; + } + + + face2vert.SetAllocSize (nfa); + } + *testout << "face2vert = " << endl << face2vert << endl; + + + + + + + face2surfel.SetSize (nfa); face2surfel = 0; diff --git a/ng/ngappinit.cpp b/ng/ngappinit.cpp index baa3abda..9b54f44f 100644 --- a/ng/ngappinit.cpp +++ b/ng/ngappinit.cpp @@ -379,28 +379,6 @@ int Tcl_AppInit(Tcl_Interp * interp) // return TCL_ERROR; } - // if ITcl and ITk are installed on the system, then - // they must also be initialized - /* - if (Itcl_Init(interp) == TCL_ERROR) { - cerr << "Problem in Itcl_Init: " << endl; - cerr << interp->result << endl; - // return TCL_ERROR; - } - - if (Itk_Init(interp) == TCL_ERROR) { - cerr << "Problem in Itk_Init: " << endl; - cerr << interp->result << endl; - // return TCL_ERROR; - } - */ - /* - if (!nodisplay && Tix_Init(interp) == TCL_ERROR) { - cerr << "Problem in Tix_Init: " << endl; - cerr << interp->result << endl; - // return TCL_ERROR; - } - */ if (Ng_Init(interp) == TCL_ERROR) { cerr << "Problem in Ng_Init: " << endl; @@ -408,7 +386,7 @@ int Tcl_AppInit(Tcl_Interp * interp) // cerr << interp->result << endl; // return TCL_ERROR; } - + if (!nodisplay && Ng_Vis_Init(interp) == TCL_ERROR) { cerr << "Problem in Ng_Vis_Init: " << endl; cout << "result = " << Tcl_GetStringResult (interp) << endl; diff --git a/ng/parallelfunc.cpp b/ng/parallelfunc.cpp index fdfe9ba1..d84297e8 100644 --- a/ng/parallelfunc.cpp +++ b/ng/parallelfunc.cpp @@ -125,7 +125,7 @@ void ParallelRun() if ( message.compare(0, 3, "ngs") == 0 ) { - PrintMessage ( 1, "Starting NgSolve routine ", message ) ; + // PrintMessage ( 1, "Starting NgSolve routine ", message ) ; if (NGS_ParallelRun == NULL) {