MutableElement.hpp
00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035 #ifndef MUTABLEELEMENT_HPP_
00036 #define MUTABLEELEMENT_HPP_
00037
00038 #include "AbstractElement.hpp"
00039
00040 #include "ChasteSerialization.hpp"
00041 #include <boost/serialization/base_object.hpp>
00042 #include <boost/serialization/vector.hpp>
00043
00048 template<unsigned ELEMENT_DIM, unsigned SPACE_DIM>
00049 class MutableElement : public AbstractElement<ELEMENT_DIM, SPACE_DIM>
00050 {
00051 private:
00052
00053
00055 friend class boost::serialization::access;
00067 template<class Archive>
00068 void serialize(Archive & archive, const unsigned int version)
00069 {
00070 archive & boost::serialization::base_object<AbstractElement<ELEMENT_DIM, SPACE_DIM> >(*this);
00071 }
00072
00073 public:
00074
00081 MutableElement(unsigned index);
00082
00089 MutableElement(unsigned index,
00090 const std::vector<Node<SPACE_DIM>*>& rNodes);
00091
00092
00096 ~MutableElement();
00097
00103 void RegisterWithNodes();
00104
00111 void MarkAsDeleted();
00112
00118 void ResetIndex(unsigned index);
00119
00126 void UpdateNode(const unsigned& rIndex, Node<SPACE_DIM>* pNode);
00127
00133 void DeleteNode(const unsigned& rIndex);
00134
00141 void AddNode(Node<SPACE_DIM>* pNode, const unsigned& rIndex);
00142
00150 unsigned GetNodeLocalIndex(unsigned globalIndex) const;
00151
00157 bool IsElementOnBoundary() const;
00158
00159 };
00160
00161
00163
00164
00165
00167
00172 template<unsigned SPACE_DIM>
00173 class MutableElement<1, SPACE_DIM> : public AbstractElement<1,SPACE_DIM>
00174 {
00175 public:
00176
00183 MutableElement(unsigned index, const std::vector<Node<SPACE_DIM>*>& rNodes);
00184
00191 MutableElement(unsigned index);
00192
00196 virtual ~MutableElement();
00197
00204 void UpdateNode(const unsigned& rIndex, Node<SPACE_DIM>* pNode);
00205
00211 void RegisterWithNodes();
00212
00219 void MarkAsDeleted();
00220
00226 void ResetIndex(unsigned index);
00227
00233 void DeleteNode(const unsigned& rIndex);
00234
00241 void AddNode(Node<SPACE_DIM>* pNode, const unsigned& rIndex);
00242
00250 unsigned GetNodeLocalIndex(unsigned globalIndex) const;
00251
00257 bool IsElementOnBoundary() const;
00258 };
00259
00260 #endif