VertexElement.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 VERTEXELEMENT_HPP_
00036 #define VERTEXELEMENT_HPP_
00037
00038 #include "MutableElement.hpp"
00039
00040 #include "ChasteSerialization.hpp"
00041 #include <boost/serialization/base_object.hpp>
00042 #include <boost/serialization/vector.hpp>
00043
00050 template<unsigned ELEMENT_DIM, unsigned SPACE_DIM>
00051 class VertexElement : public MutableElement<ELEMENT_DIM, SPACE_DIM>
00052 {
00053 private:
00054
00058 std::vector<VertexElement<ELEMENT_DIM-1, SPACE_DIM>*> mFaces;
00059
00070 std::vector<bool> mOrientations;
00071
00073 friend class boost::serialization::access;
00085 template<class Archive>
00086 void serialize(Archive & archive, const unsigned int version)
00087 {
00088
00089 archive & mFaces;
00090 archive & mOrientations;
00091 archive & boost::serialization::base_object<MutableElement<ELEMENT_DIM, SPACE_DIM> >(*this);
00092 }
00093
00094 public:
00095
00103 VertexElement(unsigned index,
00104 const std::vector<VertexElement<ELEMENT_DIM-1, SPACE_DIM>*>& rFaces,
00105 const std::vector<bool>& rOrientations);
00106
00116 VertexElement(unsigned index);
00117
00124 VertexElement(unsigned index,
00125 const std::vector<Node<SPACE_DIM>*>& rNodes);
00126
00137 VertexElement(unsigned index,
00138 const std::vector<VertexElement<ELEMENT_DIM-1, SPACE_DIM>*>& rFaces,
00139 const std::vector<bool>& rOrientations,
00140 const std::vector<Node<SPACE_DIM>*>& rNodes);
00141
00145 ~VertexElement();
00146
00150 unsigned GetNumFaces() const;
00151
00157 void AddFace(VertexElement<ELEMENT_DIM-1, SPACE_DIM>* pFace);
00158
00164 VertexElement<ELEMENT_DIM-1, SPACE_DIM>* GetFace(unsigned index) const;
00165
00171 bool FaceIsOrientatedClockwise(unsigned index) const;
00172 };
00173
00174
00176
00177
00178
00180
00185 template<unsigned SPACE_DIM>
00186 class VertexElement<1, SPACE_DIM> : public MutableElement<1,SPACE_DIM>
00187 {
00188 public:
00189
00196 VertexElement(unsigned index, const std::vector<Node<SPACE_DIM>*>& rNodes);
00197
00201 unsigned GetNumFaces() const;
00202
00208 VertexElement<0, SPACE_DIM>* GetFace(unsigned index) const;
00209
00215 bool FaceIsOrientatedClockwise(unsigned index) const;
00216 };
00217
00218 #endif