diff --git a/AMDiS/libtool b/AMDiS/libtool index 5085abd47384de309fc7ed4c62546b5cf86917a0..730f91e3bbf372aaf166baad9d5d517ae0252bc6 100755 --- a/AMDiS/libtool +++ b/AMDiS/libtool @@ -85,7 +85,7 @@ NM="/usr/bin/nm -B" LN_S="ln -s" # What is the maximum length of a command? -max_cmd_len=98304 +max_cmd_len=1572864 # Object file suffix (normally "o"). objext=o @@ -128,7 +128,7 @@ old_postinstall_cmds="chmod 644 \$oldlib~\$RANLIB \$oldlib" old_postuninstall_cmds="" # A C compiler. -LTCC="/licsoft/libraries/openmpi/1.2.6/64bit/bin/mpicc" +LTCC="/usr/lib64/mpi/gcc/openmpi//bin/mpicc" # LTCC compiler flags. LTCFLAGS="-g -O2" @@ -233,10 +233,10 @@ finish_eval="" hardcode_into_libs=yes # Compile-time system search path for libraries. -sys_lib_search_path_spec="/usr/lib64/gcc/x86_64-suse-linux/4.1.2 /usr/lib64 /lib64 /fastfs/wir/local/lib /usr/x86_64-suse-linux/lib" +sys_lib_search_path_spec="/usr/lib64/gcc/x86_64-suse-linux/4.5 /usr/lib64 /lib64 /usr/x86_64-suse-linux/lib" # Run-time system search path for libraries. -sys_lib_dlsearch_path_spec="/lib /usr/lib /usr/X11R6/lib64/Xaw3d /usr/X11R6/lib64 /usr/X11R6/lib/Xaw3d /usr/X11R6/lib /usr/x86_64-suse-linux/lib /usr/local/lib64 /usr/local/lib /opt/kde3/lib64 /opt/kde3/lib /opt/gnome/lib64 /opt/gnome/lib /lib64 /lib /usr/lib64 /usr/lib /opt/cluster/intel/cce/9.1.042/lib /opt/cluster/intel/fce/9.1.036/lib /opt/cluster/Pathscale3.0/lib/2.9.99 /opt/cluster/Pathscale3.0/lib/2.9.99/32 /work/licsoft/compilers/pgi/linux86-64/6.2/lib /work/licsoft/compilers/pgi/linux86-64/6.2/libso " +sys_lib_dlsearch_path_spec="/lib /usr/lib /usr/X11R6/lib64/Xaw3d /usr/X11R6/lib64 /usr/lib64/Xaw3d /usr/X11R6/lib/Xaw3d /usr/X11R6/lib /usr/lib/Xaw3d /usr/x86_64-suse-linux/lib /usr/local/lib /opt/kde3/lib /lib64 /lib /usr/lib64 /usr/lib /usr/local/lib64 /opt/kde3/lib64 /usr/lib64/graphviz /usr/lib64/graphviz/sharp /usr/lib64/graphviz/java /usr/lib64/graphviz/perl /usr/lib64/graphviz/php /usr/lib64/graphviz/ocaml /usr/lib64/graphviz/python /usr/lib64/graphviz/lua /usr/lib64/graphviz/tcl /usr/lib64/graphviz/guile /usr/lib64/graphviz/ruby /usr/lib64/octave-3.2.4 " # Whether dlopen is supported. dlopen_support=unknown @@ -259,7 +259,7 @@ LD="/usr/x86_64-suse-linux/bin/ld -m elf_x86_64" old_archive_cmds="\$AR \$AR_FLAGS \$oldlib\$oldobjs~\$RANLIB \$oldlib" # A language specific compiler. -CC="/licsoft/libraries/openmpi/1.2.6/64bit/bin/mpicc" +CC="/usr/lib64/mpi/gcc/openmpi//bin/mpicc" # Is the compiler the GNU compiler? with_gcc=yes @@ -8914,7 +8914,7 @@ LD="/usr/x86_64-suse-linux/bin/ld -m elf_x86_64" old_archive_cmds="\$AR \$AR_FLAGS \$oldlib\$oldobjs~\$RANLIB \$oldlib" # A language specific compiler. -CC="/licsoft/libraries/openmpi/1.2.6/64bit/bin/mpicxx" +CC="/usr/lib64/mpi/gcc/openmpi//bin/mpicxx" # Is the compiler the GNU compiler? with_gcc=yes @@ -9039,17 +9039,17 @@ file_list_spec="" hardcode_action=immediate # The directories searched by this compiler when creating a shared library. -compiler_lib_search_dirs="/usr/lib64 /licsoft/libraries/openmpi/1.2.6/64bit/lib /usr/lib64/gcc/x86_64-suse-linux/4.1.2 /usr/lib64/gcc/x86_64-suse-linux/4.1.2/../../../../lib64 /lib/../lib64 /usr/lib/../lib64 /fastfs/wir/local/lib /usr/lib64/gcc/x86_64-suse-linux/4.1.2/../../../../x86_64-suse-linux/lib /usr/lib64/gcc/x86_64-suse-linux/4.1.2/../../.." +compiler_lib_search_dirs="/usr/lib64/mpi/gcc/openmpi/lib64 /usr/lib64/gcc/x86_64-suse-linux/4.5 /usr/lib64/gcc/x86_64-suse-linux/4.5/../../../../lib64 /lib/../lib64 /usr/lib/../lib64 /usr/lib64/gcc/x86_64-suse-linux/4.5/../../../../x86_64-suse-linux/lib /usr/lib64/gcc/x86_64-suse-linux/4.5/../../.." # Dependencies to place before and after the objects being linked to # create a shared library. -predep_objects="/usr/lib64/gcc/x86_64-suse-linux/4.1.2/../../../../lib64/crti.o /usr/lib64/gcc/x86_64-suse-linux/4.1.2/crtbeginS.o" -postdep_objects="/usr/lib64/gcc/x86_64-suse-linux/4.1.2/crtendS.o /usr/lib64/gcc/x86_64-suse-linux/4.1.2/../../../../lib64/crtn.o" +predep_objects="/usr/lib64/gcc/x86_64-suse-linux/4.5/../../../../lib64/crti.o /usr/lib64/gcc/x86_64-suse-linux/4.5/crtbeginS.o" +postdep_objects="/usr/lib64/gcc/x86_64-suse-linux/4.5/crtendS.o /usr/lib64/gcc/x86_64-suse-linux/4.5/../../../../lib64/crtn.o" predeps="" -postdeps="-lmpi_cxx -lmpi -lopen-rte -lopen-pal -libverbs -lrt -lnuma -ldl -lnsl -lutil -ldl -lstdc++ -lm -lgcc_s -lpthread -lc -lgcc_s" +postdeps="-lmpi_cxx -lmpi -lopen-rte -lopen-pal -ldl -lnsl -lutil -ldl -lstdc++ -lm -lgcc_s -lpthread -lc -lgcc_s" # The library search path used internally by the compiler when linking # a shared library. -compiler_lib_search_path="-L/usr/lib64 -L/licsoft/libraries/openmpi/1.2.6/64bit/lib -L/usr/lib64/gcc/x86_64-suse-linux/4.1.2 -L/usr/lib64/gcc/x86_64-suse-linux/4.1.2/../../../../lib64 -L/lib/../lib64 -L/usr/lib/../lib64 -L/fastfs/wir/local/lib -L/usr/lib64/gcc/x86_64-suse-linux/4.1.2/../../../../x86_64-suse-linux/lib -L/usr/lib64/gcc/x86_64-suse-linux/4.1.2/../../.." +compiler_lib_search_path="-L/usr/lib64/mpi/gcc/openmpi/lib64 -L/usr/lib64/gcc/x86_64-suse-linux/4.5 -L/usr/lib64/gcc/x86_64-suse-linux/4.5/../../../../lib64 -L/lib/../lib64 -L/usr/lib/../lib64 -L/usr/lib64/gcc/x86_64-suse-linux/4.5/../../../../x86_64-suse-linux/lib -L/usr/lib64/gcc/x86_64-suse-linux/4.5/../../.." # ### END LIBTOOL TAG CONFIG: CXX diff --git a/AMDiS/src/MeshStructure.cc b/AMDiS/src/MeshStructure.cc index 9f2e35a91c642cc67bbb2383582296121ffe8d62..e78226eb0325ee5e458602d8fe9bf6c5f9be278a 100644 --- a/AMDiS/src/MeshStructure.cc +++ b/AMDiS/src/MeshStructure.cc @@ -246,6 +246,8 @@ namespace AMDiS { else elInfo = stack.traverseFirstOneMacro(mesh, macroElIndex, -1, Mesh::CALL_EVERY_EL_PREORDER); + MSG("FIT 1\n"); + while (elInfo) { Element *element = elInfo->getElement(); @@ -281,8 +283,10 @@ namespace AMDiS { // refine mesh bool finished = true; - + MSG("FIT 2\n"); do { + MSG("RUN ON EL %d\n", macroElIndex); + finished = true; if (macroElIndex == -1) elInfo = stack.traverseFirst(mesh, -1, Mesh::CALL_LEAF_EL); @@ -303,18 +307,24 @@ namespace AMDiS { #if (DEBUG != 0) int oldMeshIndex = mesh->getChangeIndex(); #endif - + + MSG("AND REFINE!\n"); + if (macroElIndex == -1) manager->refineMesh(mesh); else manager->refineMacroElement(mesh, macroElIndex); - + + MSG("AND BACK!\n"); + #if (DEBUG != 0) TEST_EXIT(oldMeshIndex != mesh->getChangeIndex()) ("Mesh has not been changed by refinement procedure!\n"); #endif } } while (!finished); + + MSG("FIT 3\n"); } @@ -366,19 +376,21 @@ namespace AMDiS { { FUNCNAME("MeshStructure::getMeshStructureValues()"); + TEST_EXIT_DBG(mesh)("No mesh defined!\n"); + TEST_EXIT_DBG(vec)("No DOFVector defined!\n"); + values.clear(); TraverseStack stack; ElInfo *elInfo = stack.traverseFirstOneMacro(mesh, macroElIndex, -1, Mesh::CALL_EVERY_EL_PREORDER); while (elInfo) { - if (elInfo->getLevel() == 0) { + if (elInfo->getLevel() == 0) for (int i = 0; i < mesh->getGeo(VERTEX); i++) values.push_back((*vec)[elInfo->getElement()->getDof(i, 0)]); - } else { - if (!elInfo->getElement()->isLeaf()) - values.push_back((*vec)[elInfo->getElement()->getChild(0)->getDof(mesh->getDim(), 0)]); - } + + if (!elInfo->getElement()->isLeaf()) + values.push_back((*vec)[elInfo->getElement()->getChild(0)->getDof(mesh->getDim(), 0)]); elInfo = stack.traverseNext(elInfo); } @@ -392,7 +404,10 @@ namespace AMDiS { { FUNCNAME("MeshStructure::setMeshStructureValues()"); - TEST_EXIT_DBG(values.size() >= mesh->getGeo(VERTEX))("Should not happen!\n"); + TEST_EXIT_DBG(mesh)("No mesh defined!\n"); + TEST_EXIT_DBG(vec)("No DOFVector defined!\n"); + TEST_EXIT_DBG(static_cast<int>(values.size()) >= mesh->getGeo(VERTEX)) + ("Should not happen!\n"); unsigned int counter = 0; @@ -400,16 +415,15 @@ namespace AMDiS { ElInfo *elInfo = stack.traverseFirstOneMacro(mesh, macroElIndex, -1, Mesh::CALL_EVERY_EL_PREORDER); while (elInfo) { - if (elInfo->getLevel() == 0) { + if (elInfo->getLevel() == 0) for (int i = 0; i < mesh->getGeo(VERTEX); i++) - (*vec)[elInfo->getElement()->getDof(i, 0)] = values[counter++]; - } else { - if (!elInfo->getElement()->isLeaf()) { - TEST_EXIT_DBG(counter < values.size())("Should not happen!\n"); + (*vec)[elInfo->getElement()->getDof(i, 0)] = values[counter++]; - (*vec)[elInfo->getElement()->getChild(0)->getDof(mesh->getDim(), 0)] = - values[counter++]; - } + if (!elInfo->getElement()->isLeaf()) { + TEST_EXIT_DBG(counter < values.size())("Should not happen!\n"); + + (*vec)[elInfo->getElement()->getChild(0)->getDof(mesh->getDim(), 0)] = + values[counter++]; } elInfo = stack.traverseNext(elInfo); diff --git a/AMDiS/src/RefinementManager.cc b/AMDiS/src/RefinementManager.cc index 7f3a6717e1c31fd80b1dc097b4cea3be2c855112..7d12cdedac33b21b115c4a81e0ade22bd02af901 100644 --- a/AMDiS/src/RefinementManager.cc +++ b/AMDiS/src/RefinementManager.cc @@ -90,6 +90,9 @@ namespace AMDiS { while (doMoreRecursiveRefine) { doMoreRecursiveRefine = false; + + MSG("HERE 1\n"); + ElInfo *elInfo = stack->traverseFirstOneMacro(mesh, macroElIndex, -1, Mesh::CALL_LEAF_EL | Mesh::FILL_NEIGH | Mesh::FILL_BOUND); @@ -100,20 +103,28 @@ namespace AMDiS { doMoreRecursiveRefine || (elInfo->getElement()->getMark() > 1); elInfo = refineFunction(elInfo); } + MSG("WIRKLICH HERE? 1\n"); elInfo = stack->traverseNext(elInfo); + MSG("WIRKLICH HERE? 2\n"); } + + MSG("HERE 2\n"); } + MSG("HERE 3\n"); + if (newCoords) - setNewCoords(); // call of sub-class method + setNewCoords(macroElIndex); // call of sub-class method + MSG("HERE 4\n"); delete stack; - + MSG("HERE 5\n"); nElements -= mesh->getNumberOfLeaves(); - + MSG("HERE 6\n"); if (nElements != 0) aMesh->incChangeIndex(); + MSG("HERE 7\n"); } } diff --git a/AMDiS/src/RefinementManager.h b/AMDiS/src/RefinementManager.h index e7644bb48676e1e5c030cddb65b8438c55be4f99..b3167c59924681774895c6f93d8187ee29c16619 100644 --- a/AMDiS/src/RefinementManager.h +++ b/AMDiS/src/RefinementManager.h @@ -51,7 +51,7 @@ namespace AMDiS { * Generates new coordinates on curved boundaries. Can be overriden by * sub classes if used. */ - virtual void setNewCoords() + virtual void setNewCoords(int macroEl = -1) { FUNCNAME("RefinementManager::setNewCoords"); ERROR_EXIT("called for base class!\n"); diff --git a/AMDiS/src/RefinementManager1d.cc b/AMDiS/src/RefinementManager1d.cc index 9197fe71e7e9c6b8ba6b04ecce1c4812999b4a6b..e53bc43a3024afa2b816bc600f42f8a09d3e9851 100644 --- a/AMDiS/src/RefinementManager1d.cc +++ b/AMDiS/src/RefinementManager1d.cc @@ -138,7 +138,7 @@ namespace AMDiS { } } - void RefinementManager1d::setNewCoords() + void RefinementManager1d::setNewCoords(int) { TraverseStack stack; ElInfo *elInfo = stack.traverseFirst(mesh, -1, diff --git a/AMDiS/src/RefinementManager1d.h b/AMDiS/src/RefinementManager1d.h index f960b1e098ba11bea436a8ec7ed3b5e9efc8a17e..1cdf052aefafbd9583ab7e90c4db19992e766cf3 100644 --- a/AMDiS/src/RefinementManager1d.h +++ b/AMDiS/src/RefinementManager1d.h @@ -43,7 +43,7 @@ namespace AMDiS { Flag refineMesh(Mesh *aMesh); /// Implements RefinementManager::setNewCoords - void setNewCoords(); + void setNewCoords(int macroEl = -1); protected: /// Used by refineMesh while mesh traversal diff --git a/AMDiS/src/RefinementManager2d.cc b/AMDiS/src/RefinementManager2d.cc index 5f81b6863836e8b5e2266f05dd88d782d317589c..9a585034de685f33bf674365d0a63504426a4ab4 100644 --- a/AMDiS/src/RefinementManager2d.cc +++ b/AMDiS/src/RefinementManager2d.cc @@ -23,6 +23,8 @@ namespace AMDiS { if (elInfo->getElement()->getMark() <= 0) return elInfo; + MSG("RFCT 1\n"); + bool bound = false; DegreeOfFreedom *edge[2]; RCNeighbourList* refineList = new RCNeighbourList(2); @@ -114,12 +116,16 @@ namespace AMDiS { delete refineList; + MSG("RFCT 2\n"); + return elInfo; } void RefinementManager2d::newCoordsFct(ElInfo *elInfo) { + FUNCNAME("RefinementManager2d::newCoordsFct()"); + Element *el = elInfo->getElement(); int dow = Global::getGeo(WORLD); @@ -131,21 +137,33 @@ namespace AMDiS { if (el->getFirstChild() && projector && (!el->isNewCoordSet())) { WorldVector<double> *new_coord = new WorldVector<double>; + MSG("NU ABER 1\n"); for (int j = 0; j < dow; j++) (*new_coord)[j] = (elInfo->getCoord(0)[j] + elInfo->getCoord(1)[j]) * 0.5; + MSG("NU ABER 2\n"); projector->project(*new_coord); el->setNewCoord(new_coord); + + MSG("NU ABER 3\n"); } } - void RefinementManager2d::setNewCoords() + void RefinementManager2d::setNewCoords(int macroEl) { TraverseStack stack; - ElInfo *elInfo = stack.traverseFirst(mesh, -1, - Mesh::CALL_EVERY_EL_PREORDER | - Mesh::FILL_BOUND | Mesh::FILL_COORDS); + ElInfo *elInfo; + + if (macroEl == -1) + elInfo = stack.traverseFirst(mesh, -1, + Mesh::CALL_EVERY_EL_PREORDER | + Mesh::FILL_BOUND | Mesh::FILL_COORDS); + else + elInfo = stack.traverseFirstOneMacro(mesh, macroEl, -1, + Mesh::CALL_EVERY_EL_PREORDER | + Mesh::FILL_BOUND | Mesh::FILL_COORDS); + while (elInfo) { newCoordsFct(elInfo); elInfo = stack.traverseNext(elInfo); diff --git a/AMDiS/src/RefinementManager2d.h b/AMDiS/src/RefinementManager2d.h index ec1e07551abeb0dae07c0ceff6e7921bebebcdf0..fdcf032b541e9e770e82d29ca61ddd069ba4bf74 100644 --- a/AMDiS/src/RefinementManager2d.h +++ b/AMDiS/src/RefinementManager2d.h @@ -44,7 +44,7 @@ namespace AMDiS { void newCoordsFct(ElInfo *elInfo); /// Implements RefinementManager::setNewCoords - void setNewCoords(); + void setNewCoords(int macroEl = -1); /** \brief * gets the elements around the refinement edge with vertices node[0] and diff --git a/AMDiS/src/RefinementManager3d.cc b/AMDiS/src/RefinementManager3d.cc index efece1b14ea6872a4cfc07354925694aa2ddc2f6..cbced11779090151fa1257c7fb40b1fb4fa5399d 100644 --- a/AMDiS/src/RefinementManager3d.cc +++ b/AMDiS/src/RefinementManager3d.cc @@ -285,17 +285,26 @@ namespace AMDiS { } - void RefinementManager3d::setNewCoords() + void RefinementManager3d::setNewCoords(int macroEl) { if (refList) delete refList; refList = new RCNeighbourList(mesh->getMaxEdgeNeigh()); + ElInfo *elInfo; + + if (macroEl == -1) + elInfo = stack->traverseFirst(mesh, -1, + Mesh::CALL_EVERY_EL_PREORDER | + Mesh::FILL_BOUND | Mesh::FILL_COORDS | + Mesh::FILL_NEIGH); + else + elInfo = stack->traverseFirstOneMacro(mesh, macroEl, -1, + Mesh::CALL_EVERY_EL_PREORDER | + Mesh::FILL_BOUND | Mesh::FILL_COORDS | + Mesh::FILL_NEIGH); + - ElInfo *elInfo = stack->traverseFirst(mesh, -1, - Mesh::CALL_EVERY_EL_PREORDER | - Mesh::FILL_BOUND | Mesh::FILL_COORDS | - Mesh::FILL_NEIGH); while (elInfo) { newCoordsFct(elInfo); elInfo = stack->traverseNext(elInfo); diff --git a/AMDiS/src/RefinementManager3d.h b/AMDiS/src/RefinementManager3d.h index 875f4cefb7bd271c90576cba5c9216d7bc6ea40f..270f239fb749b9d5eed59f7744428bb7d38f7ed0 100644 --- a/AMDiS/src/RefinementManager3d.h +++ b/AMDiS/src/RefinementManager3d.h @@ -44,7 +44,7 @@ namespace AMDiS { int newCoordsFct(ElInfo *el_info); /// Implements RefinementManager::setNewCoords - void setNewCoords(); + void setNewCoords(int macroEl = -1); /** \brief * Gets the elements around the refinement edge with vertices node[0] and diff --git a/AMDiS/src/parallel/MeshDistributor.cc b/AMDiS/src/parallel/MeshDistributor.cc index a7d222045bd5fb7183f114c3773df8cba5159513..9ad76241aa0300a046f6c60cbcd033e80dee963a 100644 --- a/AMDiS/src/parallel/MeshDistributor.cc +++ b/AMDiS/src/parallel/MeshDistributor.cc @@ -56,6 +56,7 @@ namespace AMDiS { deserialized(false), writeSerializationFile(false), repartitioningAllowed(false), + nTimestepsAfterLastRepartitioning(0), lastMeshChangeIndex(0) { FUNCNAME("MeshDistributor::ParalleDomainBase()"); @@ -547,8 +548,14 @@ namespace AMDiS { // === The mesh has changed, so check if it is required to repartition the mesh. === - if (repartitioningAllowed) - repartitionMesh(); + nTimestepsAfterLastRepartitioning++; + + if (repartitioningAllowed) { + if (nTimestepsAfterLastRepartitioning >= 20) { + repartitionMesh(); + nTimestepsAfterLastRepartitioning = 0; + } + } } @@ -965,7 +972,7 @@ namespace AMDiS { DOFVector<double> tmpa(feSpace, "tmp"); tmpa.set(mpiRank); - VtkWriter::writeFile(tmpa, "before-repartition.vtu"); + VtkWriter::writeFile(testVec[0], "before-repartition.vtu"); MSG("USED-SIZE A: %d\n", mesh->getDofAdmin(0).getUsedDofs()); @@ -985,6 +992,7 @@ namespace AMDiS { MacroInfo* minfo = mesh->getMacroFileInfo(); TEST_EXIT_DBG(minfo)("No macro file info!\n"); + MSG("MARK 1\n"); // === Create map that maps macro element indices to pointers to the === // === macro elements. === @@ -994,7 +1002,7 @@ namespace AMDiS { it != minfo->mel.end(); ++it) elIndexMap[(*it)->getIndex()] = *it; - + MSG("MARK 2\n"); // === Create set of all new macro elements this rank will receive from === // === other ranks. === @@ -1014,7 +1022,7 @@ namespace AMDiS { it != mesh->endOfMacroElements(); ++it) allMacroEl.insert(*it); - + MSG("MARK 3\n"); // === Add new macro elements to mesh. === for (std::set<MacroElement*>::iterator it = newMacroEl.begin(); @@ -1029,7 +1037,7 @@ namespace AMDiS { mesh->getMacroElements().push_back(mel); } - + MSG("MARK 4\n"); // === Send and receive mesh structure codes. === std::map<int, MeshCodeVec> sendCodes; @@ -1043,34 +1051,53 @@ namespace AMDiS { elCode.init(mesh, *elIt); sendCodes[it->first].push_back(elCode); - std::vector<double> valVec; - elCode.getMeshStructureValues(mesh, *elIt, testVec, valVec); - sendValues[it->first].push_back(valVec); + for (unsigned int i = 0; i < testVec.size(); i++) { + std::vector<double> valVec; + elCode.getMeshStructureValues(mesh, *elIt, testVec[i], valVec); + sendValues[it->first].push_back(valVec); + } } } - + MSG("MARK 5\n"); StdMpi<MeshCodeVec> stdMpi(mpiComm, true); stdMpi.send(sendCodes); stdMpi.recv(partitioner->getRecvElements()); stdMpi.startCommunication<uint64_t>(MPI_UNSIGNED_LONG); - + MSG("MARK 6\n"); + StdMpi<std::vector<std::vector<double> > > stdMpi2(mpiComm, true); + stdMpi2.send(sendValues); + stdMpi2.recv(partitioner->getRecvElements()); + stdMpi2.startCommunication<double>(MPI_DOUBLE); + MSG("MARK 7\n"); // === Adapte the new macro elements due to the received mesh structure codes. === for (std::map<int, std::vector<int> >::iterator it = partitioner->getRecvElements().begin(); it != partitioner->getRecvElements().end(); ++it) { MeshCodeVec &recvCodes = stdMpi.getRecvData()[it->first]; - int i = 0; + std::vector<std::vector<double> > &recvValues = stdMpi2.getRecvData()[it->first]; + int i = 0; + int j = 0; TEST_EXIT_DBG(recvCodes.size() == it->second.size()) ("Should not happen!\n"); for (std::vector<int>::iterator elIt = it->second.begin(); - elIt != it->second.end(); ++elIt) - recvCodes[i++].fitMeshToStructure(mesh, refineManager, false, *elIt); + elIt != it->second.end(); ++elIt) { + MSG("START EL ADAPT\n"); + recvCodes[i].fitMeshToStructure(mesh, refineManager, false, *elIt); + MSG("END EL ADAPT\n"); + for (unsigned int k = 0; k < testVec.size(); k++) { + MSG("START VAL ADAPT\n"); + recvCodes[i].setMeshStructureValues(mesh, *elIt, testVec[k], recvValues[j++]); + MSG("END VAL ADAPT\n"); + } + + i++; + } } - + MSG("MARK 8\n"); // === Set correct neighbour information on macro elements. === for (std::set<MacroElement*>::iterator it = allMacroEl.begin(); @@ -1085,7 +1112,7 @@ namespace AMDiS { (*it)->setNeighbour(i, elIndexMap[neighIndex]); } } - + MSG("MARK 9\n"); // === Delete macros from mesh. === @@ -1101,22 +1128,22 @@ namespace AMDiS { deleteMacroElements.insert(elIndexMap[*elIt]); } } - + MSG("MARK 10\n"); mesh->removeMacroElements(deleteMacroElements, feSpace); if (mpiRank == 0) debug::writeElementIndexMesh(mesh, "elementIndexxxx.vtu"); // === Remove double DOFs. === - + MSG("MARK 11\n"); MeshManipulation meshManipulation(mesh); meshManipulation.deleteDoubleDofs(newMacroEl); - + MSG("MARK 12\n"); mesh->dofCompress(); DOFVector<double> tmp(feSpace, "tmp"); tmp.set(mpiRank); - VtkWriter::writeFile(tmp, "after-repartition.vtu"); + VtkWriter::writeFile(testVec[0], "after-repartition.vtu"); MSG("USED-SIZE B: %d\n", mesh->getDofAdmin(0).getUsedDofs()); diff --git a/AMDiS/src/parallel/MeshDistributor.h b/AMDiS/src/parallel/MeshDistributor.h index 45724f9dd1fc79e09fea1b27817c91f27f0ffd49..7b68386eb1ee5feb0bda31b1e5e9bffd28b64977 100644 --- a/AMDiS/src/parallel/MeshDistributor.h +++ b/AMDiS/src/parallel/MeshDistributor.h @@ -404,7 +404,7 @@ namespace AMDiS { } public: - DOFVector<double>* testVec; + std::vector<DOFVector<double>* > testVec; protected: /// @@ -565,6 +565,8 @@ namespace AMDiS { /// If true, it is possible to repartition the mesh during computations. bool repartitioningAllowed; + int nTimestepsAfterLastRepartitioning; + /** \brief * Stores the mesh change index. This is used to recognize changes in the mesh * structure (e.g. through refinement or coarsening managers).