CEPS  24.01
Cardiac ElectroPhysiology Simulator
LaplacianSolver.cpp
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 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
30 
32  : FEStaticSolver(problem)
33 {
34 }
35 
37 {
38 }
39 
42 {
43  return ceps::runtimeCast<LaplacianProblem*>(m_problem);
44 }
45 
46 void
48 {
49  FEDivKGradAssembler* opAsb = ceps::getNew<FEDivKGradAssembler>(m_fe);
50  // Set diffusion coefficient for the single unknown
51  for (Unknown* u: m_problem->getUnknowns())
52  if (u->isSpatial())
53  opAsb->setKForUnknown(u,getLaplacianProblem()->getDiffusionTensor(u));
54  m_opAsb = opAsb;
55 
56  m_bcAsb = ceps::getNew<FEDivKGradBCAssembler>(m_fe);
57 }
58 
const CepsVector< Unknown * > & getUnknowns() const
List of unknowns of the pb.
AbstractAssembler * m_bcAsb
Assembler for Robin and Neumann BCs.
AbstractAssembler * m_opAsb
Assembler for the operator matrix.
AbstractPdeProblem * m_problem
Link to PDE to solve.
Assembles the stiffness matrix for a given k-simplexes geometry.
void setKForUnknown(Unknown *u, CepsMathScalar k)
Register the diffusion coefficient (x,t,...) for given unknown.
Solve a static problem using Finite Elements. Based on finite elements assemblers.
FiniteElements * m_fe
Geometry and reference FE.
Laplacian PDE, single unknown, constant stiffness coefficient.
void initializeAssemblers() override
Creates the LHS assembler.
LaplacianProblem * getLaplacianProblem() const
Returns a pointer to the linked problem with appropriate type.
LaplacianSolver(LaplacianProblem *problem)
Constructor.
~LaplacianSolver() override
Destructor.
A class used to defined an unknown of a PDE problem The unknown can be defined on a specific region,...
Definition: Unknown.hpp:45