CEPS  24.01
Cardiac ElectroPhysiology Simulator
FENode.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 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
31 
33 
35  ceps::HoldsGeomObject<GeomNode>(),
36  ceps::HoldsNodes<FENode>(),
37  ceps::HoldsCells<FEBase>()
38 {
39  m_owned = false;
40 }
41 
43  ceps::HoldsGeomObject<GeomNode>(gnode,owned),
44  ceps::HoldsNodes<FENode>(),
45  ceps::HoldsCells<FEBase>()
46 {
47 }
48 
49 FENode&
51 {
52  if (ceps::isDifferentPtr(this, &that))
53  this->setGeomObject(that.getGeomObject(),that.m_owned);
54  return *this;
55 }
56 
58 {
59 }
60 
61 void
63 {
65  this->setNodes({});
66  this->setCells({});
67  return;
68 }
bool CepsBool
Booleans.
Definition: CepsTypes.hpp:124
Abstract class for finite elements.
Definition: FEBase.hpp:65
A nodal point on a finite element. It is different from a geom node as it may have different properti...
Definition: FENode.hpp:46
void setGeomObject(GeomNode *node, CepsBool owned=false) override
Associate the geom node
Definition: FENode.cpp:62
FENode()
Default constructor.
Definition: FENode.cpp:34
FENode & operator=(const FENode &that)
Copy assignement.
Definition: FENode.cpp:50
~FENode() override
Destructor.
Definition: FENode.cpp:57
Base class for nodes used in meshes.
Definition: GeomNode.hpp:53
void setCells(const CepsVector< FEBase * > &cells)
Replaces currently held cell pointers.
CepsBool m_owned
Is the geom object owned by current CPU.
virtual void setGeomObject(_GeomObject *object, CepsBool owned)
Set the geom object.
_GeomObject * getGeomObject() const
Get the geom object.
void setNodes(const CepsVector< FENode * > &nodes)
Assign all nodes.
A namespace for all utility methods.
CepsBool isDifferentPtr(_Type *xptr, U *yptr)
Tells if two pointers designate two different addresses.
Definition: CepsMemory.hpp:86