CEPS  24.01
Cardiac ElectroPhysiology Simulator
HeatSolver.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 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
32 
33 // #include "ode/solver/RungeKutta.hpp"
34 
38 
40  FETimedSolver(problem)
41 {
42 // m_scaleSystem = 1.0 / problem->getTimeStep();
43 }
44 
46 {
47 }
48 
49 void
51 {
52  auto hpb = this->getHeatProblem();
53 
54 
55  FEHeatAssembler* opAsb = ceps::getNew<FEHeatAssembler>(m_fe);
56  for (Unknown* u: m_problem->getUnknowns())
57  if (u->isSpatial())
58  opAsb->setKForUnknown(u,hpb->getDiffusionTensor(u));
59  m_opAsb = opAsb;
60 
61  m_bcAsb = ceps::getNew<FEDivKGradBCAssembler>(m_fe);
62  m_bcAsb->setMatrix(m_lhs.get());
63 }
64 
67 {
68  return ceps::runtimeCast<HeatProblem*>(m_problem);
69 }
void setMatrix(DistributedMatrix *mat)
The matrix to assemble.
const CepsVector< Unknown * > & getUnknowns() const
List of unknowns of the pb.
DMatPtr m_lhs
Left hand side of the system.
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.
void setKForUnknown(Unknown *u, CepsMathScalar k)
Register the diffusion coefficient (x,t,...) for given unknown.
Assembles the heat problem matrix for a given set of finite elements. here the diffusion coefficient ...
Solve a timed problem using Finite Elements. Implemented numerical schemes: SBDF (1 (FBEuler),...
FiniteElements * m_fe
Geometry and reference FE.
Heat PDE, single unknown, constant diffusion coeff 1, homogeneous Neumann (no BC defined)
Definition: HeatProblem.hpp:36
void initializeAssemblers() override
Creates the right type of assemblers for LHS and BCs. Needs to be overriden.
Definition: HeatSolver.cpp:50
~HeatSolver() override
Destructor.
Definition: HeatSolver.cpp:45
HeatProblem * getHeatProblem() const
Returns a pointer to the pb with appropriate type.
Definition: HeatSolver.cpp:66
HeatSolver()=delete
Deleted constructor.
A class used to defined an unknown of a PDE problem The unknown can be defined on a specific region,...
Definition: Unknown.hpp:45