ESyS-Particle  4.0.1
VectorTriangleFieldMaster.h
00001 
00002 //                                                         //
00003 // Copyright (c) 2003-2011 by The University of Queensland //
00004 // Earth Systems Science Computational Centre (ESSCC)      //
00005 // http://www.uq.edu.au/esscc                              //
00006 //                                                         //
00007 // Primary Business: Brisbane, Queensland, Australia       //
00008 // Licensed under the Open Software License version 3.0    //
00009 // http://www.opensource.org/licenses/osl-3.0.php          //
00010 //                                                         //
00012 
00013 #ifndef __VECTORTRIANGLEFIELDMASTER_H
00014 #define __VECTORTRIANGLEFIELDMASTER_H
00015 
00016 //--- project includes ---
00017 #include "FieldMaster.h"
00018 #include "vec3.h"
00019 
00020 //--- STL includes ---
00021 #include <map>
00022 using std::map;
00023 
00032 class VectorTriangleFieldMaster :  public AFieldMaster
00033 {
00034  protected:
00035   map<int,Vec3> m_data; // id,value
00036 
00037   virtual void writeAsDX();
00038   virtual void writeAsRAW();
00039   virtual void writeAsSUM(){};
00040   virtual void writeAsMAX(){};
00041   virtual void writeAsRAW_SERIES(){};
00042 
00043   void collectFull();
00044   void collectFullDX();
00045   
00046  public:
00047   VectorTriangleFieldMaster(TML_Comm*,const string&,const string&,const string&,const string&,int,int,int);
00048   ~VectorTriangleFieldMaster();
00049   
00050   virtual void collect();
00051   virtual void write();
00052 };
00053 
00054 #endif //__VECTORTRIANGLEFIELDMASTER_H