VoronoiDataWriter.cpp
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
00036 #include "VoronoiDataWriter.hpp"
00037 #include "AbstractCellPopulation.hpp"
00038 #include "MeshBasedCellPopulation.hpp"
00039 #include "CaBasedCellPopulation.hpp"
00040 #include "NodeBasedCellPopulation.hpp"
00041 #include "PottsBasedCellPopulation.hpp"
00042 #include "VertexBasedCellPopulation.hpp"
00043
00044 template<unsigned ELEMENT_DIM, unsigned SPACE_DIM>
00045 VoronoiDataWriter<ELEMENT_DIM, SPACE_DIM>::VoronoiDataWriter()
00046 : AbstractCellPopulationWriter<ELEMENT_DIM, SPACE_DIM>("voronoi.dat")
00047 {
00048 }
00049
00050 template<unsigned ELEMENT_DIM, unsigned SPACE_DIM>
00051 void VoronoiDataWriter<ELEMENT_DIM, SPACE_DIM>::Visit(MeshBasedCellPopulation<ELEMENT_DIM, SPACE_DIM>* pCellPopulation)
00052 {
00053 assert(SPACE_DIM==2 || SPACE_DIM==3);
00054 VertexMesh<ELEMENT_DIM,SPACE_DIM>* voronoi_tesselation = pCellPopulation->GetVoronoiTessellation();
00055
00056
00057 for (typename VertexMesh<ELEMENT_DIM,SPACE_DIM>::VertexElementIterator elem_iter = voronoi_tesselation->GetElementIteratorBegin();
00058 elem_iter != voronoi_tesselation->GetElementIteratorEnd();
00059 ++elem_iter)
00060 {
00061
00062 unsigned elem_index = elem_iter->GetIndex();
00063
00064
00065 unsigned node_index = voronoi_tesselation->GetDelaunayNodeIndexCorrespondingToVoronoiElementIndex(elem_index);
00066
00067
00068 *this->mpOutStream << node_index << " ";
00069 c_vector<double, SPACE_DIM> node_location = pCellPopulation->GetNode(node_index)->rGetLocation();
00070 for (unsigned i=0; i<SPACE_DIM; i++)
00071 {
00072 *this->mpOutStream << node_location[i] << " ";
00073 }
00074
00075 double cell_volume = voronoi_tesselation->GetVolumeOfElement(elem_index);
00076 double cell_surface_area = voronoi_tesselation->GetSurfaceAreaOfElement(elem_index);
00077 *this->mpOutStream << cell_volume << " " << cell_surface_area << " ";
00078 }
00079 }
00080
00081 template<unsigned ELEMENT_DIM, unsigned SPACE_DIM>
00082 void VoronoiDataWriter<ELEMENT_DIM, SPACE_DIM>::Visit(CaBasedCellPopulation<SPACE_DIM>* pCellPopulation)
00083 {
00084 }
00085
00086 template<unsigned ELEMENT_DIM, unsigned SPACE_DIM>
00087 void VoronoiDataWriter<ELEMENT_DIM, SPACE_DIM>::Visit(NodeBasedCellPopulation<SPACE_DIM>* pCellPopulation)
00088 {
00089 }
00090
00091 template<unsigned ELEMENT_DIM, unsigned SPACE_DIM>
00092 void VoronoiDataWriter<ELEMENT_DIM, SPACE_DIM>::Visit(PottsBasedCellPopulation<SPACE_DIM>* pCellPopulation)
00093 {
00094 }
00095
00096 template<unsigned ELEMENT_DIM, unsigned SPACE_DIM>
00097 void VoronoiDataWriter<ELEMENT_DIM, SPACE_DIM>::Visit(VertexBasedCellPopulation<SPACE_DIM>* pCellPopulation)
00098 {
00099 }
00100
00101
00102 template class VoronoiDataWriter<1,1>;
00103 template class VoronoiDataWriter<1,2>;
00104 template class VoronoiDataWriter<2,2>;
00105 template class VoronoiDataWriter<1,3>;
00106 template class VoronoiDataWriter<2,3>;
00107 template class VoronoiDataWriter<3,3>;
00108
00109 #include "SerializationExportWrapperForCpp.hpp"
00110
00111 EXPORT_TEMPLATE_CLASS_ALL_DIMS(VoronoiDataWriter)