Forked from
agnumpde / dune-tectonic
152 commits ahead of the upstream repository.
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
supportpatchfactorytest.cc 5.03 KiB
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#define MY_DIM 2
#include <dune/common/parallel/mpihelper.hh>
#include <dune/common/parametertree.hh>
#include <dune/common/parametertreeparser.hh>
#include <dune/fufem/formatstring.hh>
#include "../assemblers.hh"
#include "../gridselector.hh"
#include "../explicitgrid.hh"
#include "../explicitvectors.hh"
#include "../factories/threeblocksfactory.cc"
#include "../spatial-solving/preconditioners/supportpatchfactory.hh"
#include "../utils/debugutils.hh"
//#include <dune/tectonic/transformedglobalratestatefriction.hh>
#include "common.hh"
const int dim = MY_DIM;
const int n = 5;
const bool simplexGrid = true;
const std::string path = "";
const std::string outputFile = "supportpatchfactorytest.log";
Dune::ParameterTree getParameters(int argc, char *argv[]) {
Dune::ParameterTree parset;
Dune::ParameterTreeParser::readINITree("/home/mi/podlesny/software/dune/dune-tectonic/src/multi-body-problem.cfg", parset);
Dune::ParameterTreeParser::readINITree(
Dune::Fufem::formatString("/home/mi/podlesny/software/dune/dune-tectonic/src/multi-body-problem-%dD.cfg", dim), parset);
Dune::ParameterTreeParser::readOptions(argc, argv, parset);
return parset;
}
template <class SupportPatchFactory>
void testSuite(const SupportPatchFactory& supportPatchFactory, const size_t bodyID, const int patchDepth = 0) {
/* const auto& coarseContactNetwork = supportPatchFactory.coarseContactNetwork();
const auto& gridView = coarseContactNetwork.body(bodyID)->gridView();
for (const auto& e : elements(gridView)) {
}
using Patch = typename SupportPatchFactory::Patch;
Patch patch0, patch1, patch2, patch3;
// (const size_t bodyID, const Element& coarseElement, const size_t localVertex, Patch& patchDofs, const int patchDepth = 0)
// interior patch inside of one body
supportPatchFactory.build(0, const Element& coarseElement, const size_t localVertex, patch0, patchDepth);
// patch at friction interface with two bodies in contact
supportPatchFactory.build(0, const Element& coarseElement, const size_t localVertex, patch1 patchDepth);
// patch at friction interface with two bodies in contact and with dirichlet boundary
supportPatchFactory.build(0, const Element& coarseElement, const size_t localVertex, patch2, patchDepth);
// crosspoint patch, where all 3 bodies are in contact
supportPatchFactory.build(0, const Element& coarseElement, const size_t localVertex, patch3, patchDepth);*/
}
int main(int argc, char *argv[]) { try {
Dune::MPIHelper::instance(argc, argv);
std::ofstream out(path + outputFile);
std::streambuf *coutbuf = std::cout.rdbuf(); //save old buffer
std::cout.rdbuf(out.rdbuf()); //redirect std::cout to outputFile
std::cout << "-------------------------------" << std::endl;
std::cout << "-- SupportPatchFactory Test: --" << std::endl;
std::cout << "-------------------------------" << std::endl << std::endl;
const auto parset = getParameters(argc, argv);
// set up contact network
ThreeBlocksFactory<Grid, Vector> threeBlocksFactory(parset);
//using ContactNetwork = typename ThreeBlocksFactory<Grid, Vector>::ContactNetwork;
//threeBlocksFactory.build();
//ContactNetwork& contactNetwork = threeBlocksFactory.contactNetwork();
// threeBlocksFactory.build();
// auto& contactNetwork = threeBlocksFactory.contactNetwork();
//const size_t bodyCount = contactNetwork.nBodies();
//for (size_t i=0; i<bodyCount; i++) {
//printDofLocation(levelContactNetwork.leafView(i));
/*auto& levelViews = levelContactNetwork.levelViews(i);
for (size_t j=0; j<levelViews.size(); j++) {
writeToVTK(*levelViews[j], "", "body_" + std::to_string(i) + "_level_" + std::to_string(j));
}
writeToVTK(levelContactNetwork.leafView(i), "", "body_" + std::to_string(i) + "_leaf"); */
//}
// assemble levelContactNetwork
//contactNetwork.assemble();
/* const auto& coarseContactNetwork = contactNetwork.level(0);
const auto& fineContactNetwork = contactNetwork.level(1);
SupportPatchFactory<decltype(coarseContactNetwork)> supportPatchFactory(coarseContactNetwork, fineContactNetwork);
// set levelContactNetwork
LevelContactNetwork levelContactNetwork;
NBodyAssembler nBodyAssembler(grids.size(), 1);
std::vector<const GridType*> grids_ptr(grids.size());
for (size_t i=0; i<grids_ptr.size(); i++) {
grids_ptr[i] = grids[i].get();
}
nBodyAssembler.setGrids(grids_ptr);
nBodyAssembler.setCoupling(coupling, 0);
nBodyAssembler.assembleTransferOperator();
nBodyAssembler.assembleObstacle();*/
bool passed = true;
std::cout << "Overall, the test " << (passed ? "was successful!" : "failed!") << std::endl;
std::cout.rdbuf(coutbuf); //reset to standard output again
return passed ? 0 : 1;
} catch (Dune::Exception &e) {
Dune::derr << "Dune reported error: " << e << std::endl;
} catch (std::exception &e) {
std::cerr << "Standard exception: " << e.what() << std::endl;
} // end try
} // end main