CEPS  24.01
Cardiac ElectroPhysiology Simulator
FENullMeanConstraintAssembler.hpp
Go to the documentation of this file.
1 /*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2  This file is part of CEPS.
3 
4  CEPS is free software: you can redistribute it and/or modify
5  it under the terms of the GNU General Public License as published by
6  the Free Software Foundation, either version 3 of the License, or
7  (at your option) any later version.
8 
9  CEPS is distributed in the hope that it will be useful,
10  but WITHOUT ANY WARRANTY; without even the implied warranty of
11  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12  GNU General Public License for more details.
13 
14  You should have received a copy of the GNU General Public License
15  along with CEPS (see file LICENSE at root of project).
16  If not, see <https://www.gnu.org/licenses/>.
17 
18 
19  Copyright 2019-2024 Inria, Universite de Bordeaux
20 
21  Authors, in alphabetical order:
22 
23  Pierre-Elliott BECUE, Florian CARO, Yves COUDIERE(*), Andjela DAVIDOVIC,
24  Charlie DOUANLA-LONTSI, Marc FUENTES, Mehdi JUHOOR, Michael LEGUEBE(*),
25  Pauline MIGERDITICHAN, Valentin PANNETIER(*), Nejib ZEMZEMI.
26  * : currently active authors
27 
28 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
31 #pragma once
32 
36 
40 template<typename _OriginalAssembler>
41 class FENullMeanConstraintAssembler : public _OriginalAssembler
42 {
43 
44  public:
45 
47  using _OriginalAssembler::_OriginalAssembler;
48 
51 
53  void
55 
57  void
59 
60 
61  protected:
62 
73  void
75  FEBase* element,
76  CepsReal3D xQ,
77  CepsReal t,
78  const CepsMathDynamic1D& phi,
79  const CepsMathDynamic2D& gradPhi
80  ) override;
81 
82  protected:
83 
86 
87 };
88 
89 // Template definitions
Eigen::Matrix< CepsScalar, Eigen::Dynamic, 1 > CepsMathDynamic1D
Dynamic 1D array, eigen format.
Definition: CepsTypes.hpp:139
std::map< _Key, _Tp, _Compare, _Alloc > CepsMap
C++ map.
Definition: CepsTypes.hpp:196
std::set< _Type, _Compare, _Alloc > CepsSet
C++ set.
Definition: CepsTypes.hpp:209
float CepsReal
Need single precision floating point.
Definition: CepsTypes.hpp:100
CepsArray3< CepsReal > CepsReal3D
Three real scalars, used like this for compatibility in polynomials.
Definition: CepsTypes.hpp:178
Eigen::Matrix< CepsScalar, Eigen::Dynamic, Eigen::Dynamic > CepsMathDynamic2D
Dynamic 2D array, eigen format.
Definition: CepsTypes.hpp:140
A degree of freedom for any kind of problem The dof can be associated to a geometrical element or not...
Abstract class for finite elements.
Definition: FEBase.hpp:65
A class that adds a 0 mean constraint to an already existing assembler.
void computeBlocksOnElementAtQuadPoint(FEBase *element, CepsReal3D xQ, CepsReal t, const CepsMathDynamic1D &phi, const CepsMathDynamic2D &gradPhi) override
The function that is called to get the coefficients of the submatrix on a given finite element....
CepsMap< Unknown *, CepsReal > m_lagrangians
Lagrangian coefficients.
void addLagrangian(Unknown *lag, CepsSet< CepsAttribute > attrs={})
Adds the lagrangian constraint as 0D unknown lag.
~FENullMeanConstraintAssembler() override
destructor
void assembleForZeroDDof(DegreeOfFreedom *dof, CepsReal t=0.) override
Assembly of lagragian coeff line.
A class used to defined an unknown of a PDE problem The unknown can be defined on a specific region,...
Definition: Unknown.hpp:45