Flow123d  release_3.0.0-910-g56968e3
fe_system.hh
Go to the documentation of this file.
1 /*!
2  *
3  * Copyright (C) 2015 Technical University of Liberec. All rights reserved.
4  *
5  * This program is free software; you can redistribute it and/or modify it under
6  * the terms of the GNU General Public License version 3 as published by the
7  * Free Software Foundation. (http://www.gnu.org/licenses/gpl-3.0.en.html)
8  *
9  * This program is distributed in the hope that it will be useful, but WITHOUT
10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
11  * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
12  *
13  *
14  * @file fe_system.hh
15  * @brief Class FESystem for compound finite elements.
16  * @author Jan Stebel
17  */
18 
19 #ifndef FE_SYSTEM_HH_
20 #define FE_SYSTEM_HH_
21 
22 #include <vector>
23 #include <memory>
24 
25 #include "fem/finite_element.hh"
26 #include "fem/fe_values.hh"
27 
28 
29 
30 /**
31 * Auxiliary class that stores the relation of dofs in the FESystem to the base FE class.
32 * For each dof in FESystem it provides:
33 * - base FE class,
34 * - index of the basis function within base FE,
35 * - component index of the dof in FESystem.
36 */
38 
39  DofComponentData(unsigned int fei, unsigned int bi, unsigned co)
40  : fe_index(fei),
41  basis_index(bi),
43  {};
44 
45  /// Index of base FE class in the vector fe_.
46  unsigned int fe_index;
47  /// Index of basis function in the base FE.
48  unsigned int basis_index;
49  /// Component index in the FESystem.
50  unsigned int component_offset;
51 };
52 
53 
54 
56 {
57 public:
58 
59  /**
60  * @brief Constructor.
61  */
62  FESystemFunctionSpace(const std::vector<std::shared_ptr<FunctionSpace> > &fs_vector);
63 
64  const double basis_value(unsigned int basis_index,
65  const arma::vec &point,
66  unsigned int comp_index = 0
67  ) const override;
68 
69  const arma::vec basis_grad(unsigned int basis_index,
70  const arma::vec &point,
71  unsigned int comp_index = 0
72  ) const override;
73 
74  const unsigned int dim() const override { return dim_; }
75 
76  virtual ~FESystemFunctionSpace() {};
77 
78 private:
79 
80  /// Function spaces that are put together.
82 
83  /// Indices of basis functions relative to the sub-spaces.
85 
86  /// Number of basis functions.
87  unsigned int dim_;
88 
89 };
90 
91 
92 
93 /**
94  * @brief Compound finite element on @p dim dimensional simplex.
95  *
96  * This type of FE is used for vector-valued functions and for systems of equations.
97  */
98 template <unsigned int dim>
99 class FESystem : public FiniteElement<dim>
100 {
101 public:
102 
103  /**
104  * @brief Constructor for FEVectorContravariant and FEVectorPiola.
105  * @param fe Base finite element class (must be scalar).
106  * @param t Type (must be FEVectorContravariant or FEVectorPiola).
107  */
108  FESystem(std::shared_ptr<FiniteElement<dim> > fe, FEType t);
109 
110  /**
111  * @brief Constructor for FEVector, FETensor and FEMixedSystem.
112  * If @p t == FEVector then @p n must be the space dimension into which
113  * the reference cell will be mapped and that @p fe is scalar.
114  * If @p t == FETensor then @p n must be square of the space dimension into which
115  * the reference cell will be mapped and that @p fe is scalar.
116  * If @p t == FEMixedSystem, then @p n is the number of components.
117  * @param fe Base finite element class (must be scalar if @p t is FEVector or FETensor).
118  * @param t Type of FESystem (must be either FEVector, FETensor or FEMixedSystem).
119  * @param n Multiplicity (number of components).
120  */
121  FESystem(const std::shared_ptr<FiniteElement<dim> > &fe, FEType t, unsigned int n);
122 
123  /**
124  * @brief Constructor. FESystem for mixed elements.
125  * @param fe Base finite element classes.
126  */
127  FESystem(std::vector<std::shared_ptr<FiniteElement<dim> > > fe);
128 
130  { return scalar_components_; }
131 
133  { return vector_components_; }
134 
136  { return tensor_components_; }
137 
138  UpdateFlags update_each(UpdateFlags flags) override;
139 
141  { return fe_; }
142 
143 
144 private:
145 
146  /// Initialization of the internal structures from the vector of base FE.
147  void initialize();
148 
149  void compute_node_matrix() override;
150 
151  /// Pointers to base FE objects.
153 
157 
158 };
159 
160 
161 
162 
163 
164 
165 #endif /* FE_SYSTEM_HH_ */
UpdateFlags
Enum type UpdateFlags indicates which quantities are to be recomputed on each finite element cell...
Definition: update_flags.hh:67
const std::vector< std::shared_ptr< FiniteElement< dim > > > & fe()
Definition: fe_system.hh:140
std::vector< unsigned int > get_tensor_components() const
Definition: fe_system.hh:135
const unsigned int dim() const override
Dimension of function space (number of basis functions).
Definition: fe_system.hh:74
unsigned int component_offset
Component index in the FESystem.
Definition: fe_system.hh:50
std::vector< DofComponentData > dof_indices_
Indices of basis functions relative to the sub-spaces.
Definition: fe_system.hh:84
virtual ~FESystemFunctionSpace()
Definition: fe_system.hh:76
DofComponentData(unsigned int fei, unsigned int bi, unsigned co)
Definition: fe_system.hh:39
unsigned int dim_
Number of basis functions.
Definition: fe_system.hh:87
std::vector< unsigned int > vector_components_
Definition: fe_system.hh:155
Class FEValues calculates finite element data on the actual cells such as shape function values...
FEType
std::vector< unsigned int > get_scalar_components() const
Definition: fe_system.hh:129
std::vector< std::shared_ptr< FiniteElement< dim > > > fe_
Pointers to base FE objects.
Definition: fe_system.hh:152
std::vector< unsigned int > get_vector_components() const
Definition: fe_system.hh:132
Compound finite element on dim dimensional simplex.
Definition: fe_system.hh:99
unsigned int basis_index
Index of basis function in the base FE.
Definition: fe_system.hh:48
unsigned int fe_index
Index of base FE class in the vector fe_.
Definition: fe_system.hh:43
Abstract class for description of finite elements.
Abstract class for the description of a general finite element on a reference simplex in dim dimensio...
std::vector< unsigned int > tensor_components_
Definition: fe_system.hh:156
std::vector< unsigned int > scalar_components_
Definition: fe_system.hh:154