ASPECT
introspection.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_introspection_h
23 #define _aspect_introspection_h
24 
25 #include <deal.II/base/index_set.h>
26 #include <deal.II/base/quadrature.h>
27 #include <deal.II/fe/component_mask.h>
28 #include <deal.II/fe/fe_values_extractors.h>
29 #include <deal.II/fe/fe.h>
30 
32 #include <aspect/parameters.h>
33 
34 #include <map>
35 
36 namespace aspect
37 {
42  template <int dim>
43  std::vector<VariableDeclaration<dim>>
44  construct_default_variables (const Parameters<dim> &parameters);
45 
46 
53  {
57  enum Type
58  {
60  stress = 1,
61  strain = 2,
63  porosity = 4,
64  density = 5,
65  entropy = 6,
66  generic = 7,
68  } type;
69 
73  constexpr static unsigned int n_types = 9;
74 
79  static
80  Type
81  parse_type(const std::string &input)
82  {
83  if (input == "chemical composition")
85  else if (input == "stress")
87  else if (input == "strain")
89  else if (input == "grain size")
91  else if (input == "porosity")
93  else if (input == "density")
95  else if (input == "entropy")
97  else if (input == "generic")
99  else if (input == "unspecified")
101  else
102  AssertThrow(false, ExcNotImplemented());
103 
105  }
106  };
107 
125  template <int dim>
127  {
128  public:
132  Introspection (const std::vector<VariableDeclaration<dim>> &variables,
133  const Parameters<dim> &parameters);
134 
138  ~Introspection ();
139 
140 
141 
154  const unsigned int n_components;
155 
159  const unsigned int n_compositional_fields;
160 
166 
172 
178  {
179  std::array<unsigned int, dim> velocities;
180  unsigned int pressure;
181  unsigned int temperature;
182  std::vector<unsigned int> compositional_fields;
183  };
189 
195  const unsigned int n_blocks;
196 
202  {
203  unsigned int velocities;
204  unsigned int pressure;
205  unsigned int temperature;
206  std::vector<unsigned int> compositional_fields;
207 
215  std::vector<unsigned int> compositional_field_sparsity_pattern;
216  };
217 
223 
228  struct Extractors
229  {
230  Extractors (const ComponentIndices &component_indices);
231 
233  const FEValuesExtractors::Scalar pressure;
234  const FEValuesExtractors::Scalar temperature;
235  const std::vector<FEValuesExtractors::Scalar> compositional_fields;
236  };
237 
243 
254  {
255  unsigned int velocities;
256  unsigned int pressure;
257  unsigned int temperature;
258  std::vector<unsigned int> compositional_fields;
259  };
260 
266 
275  {
276  unsigned int max_degree;
277  unsigned int velocities;
278  unsigned int temperature;
279  std::vector<unsigned int> compositional_fields;
281  };
282 
288 
308  struct Quadratures
309  {
310  Quadrature<dim> velocities;
311  Quadrature<dim> pressure;
312  Quadrature<dim> temperature;
313  Quadrature<dim> compositional_field_max;
314  std::vector<Quadrature<dim>> compositional_fields;
315  Quadrature<dim> system;
316  };
317 
323 
333  {
334  Quadrature<dim-1> velocities;
335  Quadrature<dim-1> pressure;
336  Quadrature<dim-1> temperature;
337  Quadrature<dim-1> compositional_fields;
338  Quadrature<dim-1> system;
339  };
340 
346 
353  {
355 
359  ComponentMask velocities;
360 
364  ComponentMask pressure;
365 
369  ComponentMask temperature;
370 
377  std::vector<ComponentMask> compositional_fields;
378 
383  ComponentMask compositions;
384  };
385 
392 
406  std::vector<types::global_dof_index> system_dofs_per_block;
407 
413  struct IndexSets
414  {
422 
430  std::vector<IndexSet> system_partitioning;
431 
440  std::vector<IndexSet> system_relevant_partitioning;
441 
447  std::vector<IndexSet> stokes_partitioning;
448 
456 
462 
468  };
469 
476 
482 
489 
506  const std::vector<unsigned int> &
507  get_composition_base_element_indices() const;
508 
516  const std::vector<unsigned int> &
517  get_compositional_field_indices_with_base_element(const unsigned int base_element_index) const;
518 
527  unsigned int
528  compositional_index_for_name (const std::string &name) const;
529 
536  std::string
537  name_for_compositional_index (const unsigned int index) const;
538 
542  const std::vector<std::string> &
543  get_composition_names () const;
544 
549  const std::vector<CompositionalFieldDescription> &
550  get_composition_descriptions () const;
551 
559  const std::vector<std::string> &
560  chemical_composition_field_names () const;
561 
569  const std::vector<unsigned int> &
570  chemical_composition_field_indices () const;
571 
579  unsigned int
580  n_chemical_composition_fields () const;
581 
590  bool
591  composition_type_exists (const CompositionalFieldDescription::Type &type) const;
592 
602  unsigned int
603  find_composition_type (const CompositionalFieldDescription::Type &type) const;
604 
613  bool
614  compositional_name_exists (const std::string &name) const;
615 
620  const std::vector<unsigned int> &
621  get_indices_for_fields_of_type (const CompositionalFieldDescription::Type &type) const;
622 
627  const std::vector<std::string> &
628  get_names_for_fields_of_type (const CompositionalFieldDescription::Type &type) const;
629 
634  unsigned int
635  get_number_of_fields_of_type (const CompositionalFieldDescription::Type &type) const;
636 
644  bool
645  is_stokes_component (const unsigned int component_index) const;
646 
654  bool
655  is_composition_component (const unsigned int component_index) const;
656 
657  private:
662  std::vector<std::string> composition_names;
663 
669  std::vector<CompositionalFieldDescription> composition_descriptions;
670 
676  std::vector<std::vector<std::string>> composition_names_for_type;
677 
683  std::vector<std::vector<unsigned int>> composition_indices_for_type;
684 
689  std::vector<unsigned int> composition_base_element_indices;
690 
696  std::map<unsigned int, std::vector<unsigned int>> compositional_field_indices_with_base_element;
697  };
698 }
699 
700 
701 #endif
std::vector< IndexSet > system_relevant_partitioning
const std::vector< bool > use_discontinuous_composition_discretization
std::map< unsigned int, std::vector< unsigned int > > compositional_field_indices_with_base_element
const FEValuesExtractors::Vector velocities
Quadrature< dim > compositional_field_max
std::vector< VariableDeclaration< dim > > construct_default_variables(const Parameters< dim > &parameters)
Parameters< dim >::AdvectionFieldMethod::Kind temperature_method
std::vector< unsigned int > compositional_fields
std::vector< unsigned int > compositional_fields
const unsigned int n_blocks
std::vector< std::vector< unsigned int > > composition_indices_for_type
std::vector< Quadrature< dim > > compositional_fields
::TrilinosWrappers::MPI::Vector Vector
Definition: global.h:262
const BaseElements base_elements
const PolynomialDegree polynomial_degree
const FEValuesExtractors::Scalar temperature
const unsigned int n_components
const Extractors extractors
std::vector< IndexSet > system_partitioning
std::vector< typename Parameters< dim >::AdvectionFieldMethod::Kind > compositional_field_methods
std::vector< CompositionalFieldDescription > composition_descriptions
enum aspect::CompositionalFieldDescription::Type type
std::vector< std::vector< std::string > > composition_names_for_type
const unsigned int n_compositional_fields
const ComponentIndices component_indices
std::vector< unsigned int > compositional_fields
Definition: compat.h:59
std::vector< unsigned int > compositional_fields
const bool use_discontinuous_temperature_discretization
std::array< unsigned int, dim > velocities
const FaceQuadratures face_quadratures
const Quadratures quadratures
const BlockIndices block_indices
std::vector< unsigned int > compositional_field_sparsity_pattern
const std::vector< FEValuesExtractors::Scalar > compositional_fields
const FEValuesExtractors::Scalar pressure
const ComponentMasks component_masks
std::vector< types::global_dof_index > system_dofs_per_block
static constexpr unsigned int n_types
Definition: introspection.h:73
std::vector< unsigned int > composition_base_element_indices
std::vector< std::string > composition_names
std::vector< ComponentMask > compositional_fields
std::vector< IndexSet > stokes_partitioning
static Type parse_type(const std::string &input)
Definition: introspection.h:81