#ifdef HAVE_CONFIG_H #include "config.h" #endif #include <dune/fufem/boundarypatch.hh> #include <dune/fufem/functions/constantfunction.hh> #include <dune/fufem/assemblers/localassemblers/neumannboundaryassembler.hh> #include <dune/tectonic/globalruinanonlinearity.hh> #include "assemblers.hh" // Assembles Neumann boundary term in f template <class GridView, class LocalVectorType, class AssemblerType> void assemble_neumann(GridView const &gridView, AssemblerType const &assembler, Dune::BitSetVector<1> const &neumannNodes, Dune::BlockVector<LocalVectorType> &f, Dune::VirtualFunction<double, double> const &neumann, double time) { // constant sample function on neumann // boundary BoundaryPatch<GridView> const neumannBoundary(gridView, neumannNodes); LocalVectorType SampleVector(0); neumann.evaluate(time, SampleVector[0]); SampleVector[1] = 0; ConstantFunction<LocalVectorType, LocalVectorType> const fNeumann( SampleVector); NeumannBoundaryAssembler<typename GridView::Grid, LocalVectorType> neumannBoundaryAssembler(fNeumann); assembler.assembleBoundaryFunctional(neumannBoundaryAssembler, f, neumannBoundary); } // Assembles constant 1-function on frictional boundary in nodalIntegrals template <class GridView, class LocalVectorType, class AssemblerType> Dune::shared_ptr<Dune::BlockVector<Dune::FieldVector<double, 1>>> assemble_frictional(GridView const &gridView, AssemblerType const &assembler, Dune::BitSetVector<1> const &frictionalNodes) { using Singleton = Dune::FieldVector<double, 1>; BoundaryPatch<GridView> const frictionalBoundary(gridView, frictionalNodes); ConstantFunction<LocalVectorType, Singleton> const constantOneFunction(1); NeumannBoundaryAssembler<typename GridView::Grid, Singleton> frictionalBoundaryAssembler(constantOneFunction); auto const nodalIntegrals = Dune::make_shared<Dune::BlockVector<Singleton>>(); assembler.assembleBoundaryFunctional(frictionalBoundaryAssembler, *nodalIntegrals, frictionalBoundary); return nodalIntegrals; } template <class MatrixType, class VectorType> Dune::shared_ptr<Dune::GlobalNonlinearity<MatrixType, VectorType> const> assemble_nonlinearity( Dune::ParameterTree const &parset, Dune::BlockVector<Dune::FieldVector<double, 1>> const &nodalIntegrals, Dune::BlockVector<Dune::FieldVector<double, 1>> const &state, Dune::BlockVector<Dune::FieldVector<double, 1>> const &normalStress) { auto const size = nodalIntegrals.size(); using SingletonVectorType = Dune::BlockVector<Dune::FieldVector<double, 1>>; // {{{ Assemble terms for the nonlinearity SingletonVectorType mu0(size); mu0 = parset.get<double>("mu0"); SingletonVectorType a(size); a = parset.get<double>("a"); SingletonVectorType V0(size); V0 = parset.get<double>("V0"); SingletonVectorType b(size); b = parset.get<double>("b"); SingletonVectorType L(size); L = parset.get<double>("L"); return Dune::make_shared< Dune::GlobalRuinaNonlinearity<MatrixType, VectorType> const>( nodalIntegrals, a, mu0, V0, normalStress, b, state, L); } #include "assemblers_tmpl.cc"