ASPECT
interface.h
Go to the documentation of this file.
1 /*
2  Copyright (C) 2011 - 2024 by the authors of the ASPECT code.
3 
4  This file is part of ASPECT.
5 
6  ASPECT is free software; you can redistribute it and/or modify
7  it under the terms of the GNU General Public License as published by
8  the Free Software Foundation; either version 2, or (at your option)
9  any later version.
10 
11  ASPECT is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  GNU General Public License for more details.
15 
16  You should have received a copy of the GNU General Public License
17  along with ASPECT; see the file LICENSE. If not see
18  <http://www.gnu.org/licenses/>.
19 */
20 
21 
22 #ifndef _aspect_mesh_deformation_interface_h
23 #define _aspect_mesh_deformation_interface_h
24 
25 #include <aspect/plugins.h>
27 #include <aspect/global.h>
28 
29 #include <deal.II/fe/fe_system.h>
30 #include <deal.II/dofs/dof_handler.h>
31 #include <deal.II/lac/affine_constraints.h>
32 #include <deal.II/base/index_set.h>
33 #include <deal.II/base/mg_level_object.h>
34 #include <deal.II/lac/la_parallel_vector.h>
35 #include <deal.II/multigrid/mg_constrained_dofs.h>
36 #include <deal.II/multigrid/mg_transfer_matrix_free.h>
37 #include <deal.II/multigrid/mg_transfer_global_coarsening.templates.h>
39 
40 namespace aspect
41 {
42  namespace Assemblers
43  {
50  template <int dim>
52  public SimulatorAccess<dim>
53  {
54  public:
55  ApplyStabilization(const double stabilization_theta);
56 
57  void
60 
61  private:
67  const double free_surface_theta;
68  };
69  }
70 
71  template <int dim> class Simulator;
72 
77  namespace MeshDeformation
78  {
88  template <int dim>
90  {
91  public:
95  virtual bool needs_surface_stabilization() const;
96 
97 
105  virtual
106  Tensor<1,dim>
107  compute_initial_deformation_on_boundary(const types::boundary_id boundary_indicator,
108  const Point<dim> &position) const;
109 
110 
121  virtual
122  void
123  compute_initial_deformation_as_constraints(const Mapping<dim> &mapping,
124  const DoFHandler<dim> &mesh_deformation_dof_handler,
125  const types::boundary_id boundary_indicator,
126  AffineConstraints<double> &constraints) const;
127 
135  virtual
136  void
137  compute_velocity_constraints_on_boundary(const DoFHandler<dim> &mesh_deformation_dof_handler,
138  AffineConstraints<double> &mesh_velocity_constraints,
139  const std::set<types::boundary_id> &boundary_ids) const;
140  };
141 
142 
143 
149  template <int dim>
150  class MeshDeformationHandler: public SimulatorAccess<dim>
151  {
152  public:
160 
164  ~MeshDeformationHandler() override;
165 
171  void initialize();
172 
177  void set_assemblers(const SimulatorAccess<dim> &simulator_access,
178  aspect::Assemblers::Manager<dim> &assemblers) const;
179 
184  void update();
185 
193  void execute();
194 
199  void setup_dofs();
200 
204  static
205  void declare_parameters (ParameterHandler &prm);
206 
210  void parse_parameters (ParameterHandler &prm);
211 
216  template <class Archive>
217  void save (Archive &ar,
218  const unsigned int version) const;
219 
224  template <class Archive>
225  void load (Archive &ar,
226  const unsigned int version);
227 
228  BOOST_SERIALIZATION_SPLIT_MEMBER()
229 
230 
247  static
248  void
249  register_mesh_deformation
250  (const std::string &name,
251  const std::string &description,
252  void (*declare_parameters_function) (ParameterHandler &),
253  std::unique_ptr<Interface<dim>> (*factory_function) ());
254 
259  const std::map<types::boundary_id, std::vector<std::string>> &
260  get_active_mesh_deformation_names () const;
261 
266  const std::map<types::boundary_id,std::vector<std::unique_ptr<Interface<dim>>>> &
267  get_active_mesh_deformation_models () const;
268 
273  const std::set<types::boundary_id> &
274  get_active_mesh_deformation_boundary_indicators () const;
275 
281  const std::set<types::boundary_id> &
282  get_tangential_velocity_with_active_mesh_deformation_boundary_indicators () const;
283 
289  const std::set<types::boundary_id> &
290  get_tangential_velocity_without_active_mesh_deformation_boundary_indicators () const;
291 
296  const std::set<types::boundary_id> &
297  get_boundary_indicators_requiring_stabilization () const;
298 
304  const std::set<types::boundary_id> &
305  get_free_surface_boundary_indicators () const;
306 
310  double get_free_surface_theta () const;
311 
326  const LinearAlgebra::Vector &
327  get_initial_topography () const;
328 
333  const LinearAlgebra::Vector &
334  get_mesh_displacements () const;
335 
339  const DoFHandler<dim> &
340  get_mesh_deformation_dof_handler () const;
341 
351  template <typename MeshDeformationType,
352  typename = typename std::enable_if_t<std::is_base_of<Interface<dim>,MeshDeformationType>::value>>
353  bool
354  has_matching_mesh_deformation_object () const;
355 
367  template <typename MeshDeformationType,
368  typename = typename std::enable_if_t<std::is_base_of<Interface<dim>,MeshDeformationType>::value>>
369  const MeshDeformationType &
370  get_matching_mesh_deformation_object () const;
371 
372 
378  const Mapping<dim> &
379  get_level_mapping(const unsigned int level) const;
380 
390  static
391  void
392  write_plugin_graph (std::ostream &output_stream);
393 
397  DeclException1 (ExcMeshDeformationNameNotFound,
398  std::string,
399  << "Could not find entry <"
400  << arg1
401  << "> among the names of registered mesh deformation objects.");
402 
403  private:
411  void make_initial_constraints ();
412 
425  void make_constraints ();
426 
431  void compute_mesh_displacements ();
432 
437  void compute_mesh_displacements_gmg ();
438 
454  void set_initial_topography ();
455 
459  void interpolate_mesh_velocity ();
460 
464  void update_multilevel_deformation ();
465 
471 
476  const FESystem<dim> mesh_deformation_fe;
477 
482 
489 
497 
502 
512 
522 
527 
532 
537  AffineConstraints<double> mesh_velocity_constraints;
538 
543  AffineConstraints<double> mesh_vertex_constraints;
544 
549  std::map<types::boundary_id,std::vector<std::unique_ptr<Interface<dim>>>> mesh_deformation_objects;
550 
555  std::map<types::boundary_id, std::vector<std::string>> mesh_deformation_object_names;
556 
563 
570 
577 
583 
590  std::set<types::boundary_id> zero_mesh_deformation_boundary_indicators;
591 
597  std::set<types::boundary_id> free_surface_boundary_indicators;
598 
603  std::set<types::boundary_id> boundary_indicators_requiring_stabilization;
604 
606 
613 
617  MGLevelObject<std::unique_ptr<Mapping<dim>>> level_mappings;
618 
622  MGLevelObject<::LinearAlgebra::distributed::Vector<double>> level_displacements;
623 
628 
632  MGConstrainedDoFs mg_constrained_dofs;
633 
634  friend class Simulator<dim>;
635  friend class SimulatorAccess<dim>;
636  };
637 
638 
639  template <int dim>
640  template <class Archive>
642  const unsigned int) const
643  {
644  // let all the mesh deformation plugins save their data in a map and then
645  // serialize that
646  //TODO: for now we assume the same plugins are active before and after restart.
647  std::map<std::string,std::string> saved_text;
648  for (const auto &boundary_id_and_mesh_deformation_objects : mesh_deformation_objects)
649  for (const auto &p : boundary_id_and_mesh_deformation_objects.second)
650  p->save (saved_text);
651 
652  ar &saved_text;
653  }
654 
655 
656  template <int dim>
657  template <class Archive>
659  const unsigned int)
660  {
661  // get the map back out of the stream; then let the mesh deformation plugins
662  // that we currently have get their data from there. note that this
663  // may not be the same set ofmesh deformation plugins we had when we saved
664  // their data
665  std::map<std::string,std::string> saved_text;
666  ar &saved_text;
667 
668  for (const auto &boundary_id_and_mesh_deformation_objects : mesh_deformation_objects)
669  for (const auto &p : boundary_id_and_mesh_deformation_objects.second)
670  p->load (saved_text);
671  }
672 
673 
674 
675 
676  template <int dim>
677  template <typename MeshDeformationType, typename>
678  inline
679  bool
681  {
682  for (const auto &object_iterator : mesh_deformation_objects)
683  for (const auto &p : object_iterator.second)
684  if (Plugins::plugin_type_matches<MeshDeformationType>(*p))
685  return true;
686 
687  return false;
688  }
689 
690 
691 
692  template <int dim>
693  template <typename MeshDeformationType, typename>
694  inline
695  const MeshDeformationType &
697  {
698  AssertThrow(has_matching_mesh_deformation_object<MeshDeformationType> (),
699  ExcMessage("You asked MeshDeformation::MeshDeformationHandler::get_matching_mesh_deformation_object() for a "
700  "mesh deformation object of type <" + boost::core::demangle(typeid(MeshDeformationType).name()) + "> "
701  "that could not be found in the current model. Activate this "
702  "mesh deformation in the input file."));
703 
704  for (const auto &object_iterator : mesh_deformation_objects)
705  for (const auto &p : object_iterator.second)
706  if (Plugins::plugin_type_matches<MeshDeformationType>(*p))
707  return Plugins::get_plugin_as_type<MeshDeformationType>(*p);
708 
709  // We will never get here, because we had the Assert above. Just to avoid warnings.
710  typename std::vector<std::unique_ptr<Interface<dim>>>::const_iterator mesh_def;
711  return Plugins::get_plugin_as_type<MeshDeformationType>(*(*mesh_def));
712 
713  }
714 
715 
722  template <int dim>
723  std::string
725 
726 
727 
735 #define ASPECT_REGISTER_MESH_DEFORMATION_MODEL(classname,name,description) \
736  template class classname<2>; \
737  template class classname<3>; \
738  namespace ASPECT_REGISTER_MESH_DEFORMATION_MODEL_ ## classname \
739  { \
740  aspect::internal::Plugins::RegisterHelper<aspect::MeshDeformation::Interface<2>,classname<2>> \
741  dummy_ ## classname ## _2d (&aspect::MeshDeformation::MeshDeformationHandler<2>::register_mesh_deformation, \
742  name, description); \
743  aspect::internal::Plugins::RegisterHelper<aspect::MeshDeformation::Interface<3>,classname<3>> \
744  dummy_ ## classname ## _3d (&aspect::MeshDeformation::MeshDeformationHandler<3>::register_mesh_deformation, \
745  name, description); \
746  }
747  }
748 }
749 
750 #endif
virtual void parse_parameters(ParameterHandler &prm)
const Simulator< dim > * simulator
::TrilinosWrappers::MPI::BlockVector BlockVector
Definition: global.h:269
ApplyStabilization(const double stabilization_theta)
std::set< types::boundary_id > prescribed_mesh_deformation_boundary_indicators
Definition: interface.h:562
std::set< types::boundary_id > tangential_velocity_without_prescribed_mesh_deformation_boundary_indicators
Definition: interface.h:576
MGLevelObject<::LinearAlgebra::distributed::Vector< double > > level_displacements
Definition: interface.h:622
void write_plugin_graph(std::ostream &output_stream)
std::set< types::boundary_id > boundary_indicators_requiring_stabilization
Definition: interface.h:603
::TrilinosWrappers::MPI::Vector Vector
Definition: global.h:263
AffineConstraints< double > mesh_velocity_constraints
Definition: interface.h:537
std::set< types::boundary_id > tangential_mesh_deformation_boundary_indicators
Definition: interface.h:582
AffineConstraints< double > mesh_vertex_constraints
Definition: interface.h:543
MGLevelObject< std::unique_ptr< Mapping< dim > > > level_mappings
Definition: interface.h:617
virtual void load(const std::map< std::string, std::string > &status_strings)
std::map< types::boundary_id, std::vector< std::string > > mesh_deformation_object_names
Definition: interface.h:555
LinearAlgebra::BlockVector mesh_velocity
Definition: interface.h:488
std::map< types::boundary_id, std::vector< std::unique_ptr< Interface< dim > > > > mesh_deformation_objects
Definition: interface.h:549
MGTransferMF< dim, double > mg_transfer
Definition: interface.h:627
std::string get_valid_model_names_pattern()
std::set< types::boundary_id > tangential_velocity_with_prescribed_mesh_deformation_boundary_indicators
Definition: interface.h:569
::MGTransferMatrixFree< dim, NumberType > MGTransferMF
Definition: compat.h:63
void load(Archive &ar, const unsigned int version)
Definition: interface.h:658
void execute(internal::Assembly::Scratch::ScratchBase< dim > &scratch, internal::Assembly::CopyData::CopyDataBase< dim > &data) const override
virtual void save(std::map< std::string, std::string > &status_strings) const
std::set< types::boundary_id > free_surface_boundary_indicators
Definition: interface.h:597
void save(Archive &ar, const unsigned int version) const
Definition: interface.h:641
std::set< types::boundary_id > zero_mesh_deformation_boundary_indicators
Definition: interface.h:590
static void declare_parameters(ParameterHandler &prm)
DeclException1(ProbabilityFunctionNegative, Point< dim >,<< "Your probability density function in the particle generator " "returned a negative probability density for the following position: "<< arg1<< ". Please check your function expression.")