ASPECT
introspection.h
Go to the documentation of this file.
1 /*
2  Copyright (C) 2011 - 2023 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 {
38  using namespace dealii;
39 
44  template <int dim>
45  std::vector<VariableDeclaration<dim>>
46  construct_default_variables (const Parameters<dim> &parameters);
47 
48 
55  {
59  enum Type
60  {
61  chemical_composition = 0,
62  stress = 1,
63  strain = 2,
64  grain_size = 3,
65  porosity = 4,
66  density = 5,
67  entropy = 6,
68  generic = 7,
69  unspecified = 8
70  } type;
71 
75  constexpr static unsigned int n_types = 9;
76 
81  static
82  Type
83  parse_type(const std::string &input)
84  {
85  if (input == "chemical composition")
87  else if (input == "stress")
89  else if (input == "strain")
91  else if (input == "grain size")
93  else if (input == "porosity")
95  else if (input == "density")
97  else if (input == "entropy")
99  else if (input == "generic")
101  else if (input == "unspecified")
103  else
104  AssertThrow(false, ExcNotImplemented());
105 
107  }
108  };
109 
127  template <int dim>
129  {
130  public:
134  Introspection (const std::vector<VariableDeclaration<dim>> &variables,
135  const Parameters<dim> &parameters);
136 
140  ~Introspection ();
141 
142 
143 
156  const unsigned int n_components;
157 
161  const unsigned int n_compositional_fields;
162 
168 
174 
180  {
181  unsigned int velocities[dim];
182  unsigned int pressure;
183  unsigned int temperature;
184  std::vector<unsigned int> compositional_fields;
185  };
191 
197  const unsigned int n_blocks;
198 
204  {
205  unsigned int velocities;
206  unsigned int pressure;
207  unsigned int temperature;
208  std::vector<unsigned int> compositional_fields;
209 
217  std::vector<unsigned int> compositional_field_sparsity_pattern;
218  };
219 
225 
230  struct Extractors
231  {
232  Extractors (const ComponentIndices &component_indices);
233 
235  const FEValuesExtractors::Scalar pressure;
236  const FEValuesExtractors::Scalar temperature;
237  const std::vector<FEValuesExtractors::Scalar> compositional_fields;
238  };
239 
245 
256  {
257  unsigned int velocities;
258  unsigned int pressure;
259  unsigned int temperature;
260  std::vector<unsigned int> compositional_fields;
261  };
262 
268 
277  {
278  unsigned int max_degree;
279  unsigned int velocities;
280  unsigned int temperature;
281  std::vector<unsigned int> compositional_fields;
283  };
284 
290 
310  struct Quadratures
311  {
312  Quadrature<dim> velocities;
313  Quadrature<dim> pressure;
314  Quadrature<dim> temperature;
315  Quadrature<dim> compositional_field_max;
316  std::vector<Quadrature<dim>> compositional_fields;
317  Quadrature<dim> system;
318  };
319 
325 
335  {
336  Quadrature<dim-1> velocities;
337  Quadrature<dim-1> pressure;
338  Quadrature<dim-1> temperature;
339  Quadrature<dim-1> compositional_fields;
340  Quadrature<dim-1> system;
341  };
342 
348 
355  {
357 
358  ComponentMask velocities;
359  ComponentMask pressure;
360  ComponentMask temperature;
361  std::vector<ComponentMask> compositional_fields;
362  };
363 
370 
384  std::vector<types::global_dof_index> system_dofs_per_block;
385 
391  struct IndexSets
392  {
400 
408  std::vector<IndexSet> system_partitioning;
409 
418  std::vector<IndexSet> system_relevant_partitioning;
419 
425  std::vector<IndexSet> stokes_partitioning;
426 
434 
440 
446  };
447 
454 
460 
467 
484  const std::vector<unsigned int> &
485  get_composition_base_element_indices() const;
486 
494  const std::vector<unsigned int> &
495  get_compositional_field_indices_with_base_element(const unsigned int base_element_index) const;
496 
505  unsigned int
506  compositional_index_for_name (const std::string &name) const;
507 
514  std::string
515  name_for_compositional_index (const unsigned int index) const;
516 
520  const std::vector<std::string> &
521  get_composition_names () const;
522 
527  const std::vector<CompositionalFieldDescription> &
528  get_composition_descriptions () const;
529 
537  const std::vector<std::string> &
538  chemical_composition_field_names () const;
539 
547  const std::vector<unsigned int> &
548  chemical_composition_field_indices () const;
549 
557  unsigned int
558  n_chemical_composition_fields () const;
559 
568  bool
569  composition_type_exists (const CompositionalFieldDescription::Type &type) const;
570 
580  unsigned int
581  find_composition_type (const CompositionalFieldDescription::Type &type) const;
582 
591  bool
592  compositional_name_exists (const std::string &name) const;
593 
598  const std::vector<unsigned int> &
599  get_indices_for_fields_of_type (const CompositionalFieldDescription::Type &type) const;
600 
605  const std::vector<std::string> &
606  get_names_for_fields_of_type (const CompositionalFieldDescription::Type &type) const;
607 
612  unsigned int
613  get_number_of_fields_of_type (const CompositionalFieldDescription::Type &type) const;
614 
622  bool
623  is_stokes_component (const unsigned int component_index) const;
624 
632  bool
633  is_composition_component (const unsigned int component_index) const;
634 
635  private:
640  std::vector<std::string> composition_names;
641 
647  std::vector<CompositionalFieldDescription> composition_descriptions;
648 
654  std::vector<std::vector<std::string>> composition_names_for_type;
655 
661  std::vector<std::vector<unsigned int>> composition_indices_for_type;
662 
667  std::vector<unsigned int> composition_base_element_indices;
668 
674  std::map<unsigned int, std::vector<unsigned int>> compositional_field_indices_with_base_element;
675  };
676 }
677 
678 
679 #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:233
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
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
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
Definition: compat.h:42
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:83