ESyS-Particle  4.0.1
RandomAssembly3D.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 __RANDOMASSEMBLY3D_H
00014 #define __RANDOMASSEMBLY3D_H
00015 
00016 //-- project includes --
00017 #include "Geometry/ARandomAssembly.h"
00018 #include "Geometry/SimpleParticle.h"
00019 #include "Geometry/BasicInteraction.h"
00020 #include "Geometry/Plane.h"
00021 
00022 //-- STL includes --
00023 #include <vector>
00024 #include <set>
00025 
00026 using std::set;
00027 using std::vector; 
00028 
00037 class ARandomAssembly3D : public ARandomAssembly
00038 {
00039  protected:
00040   vector<Plane> Borders;
00041   double m_rmin,m_rmax;                             
00042   double m_xmin,m_xmax,m_ymin,m_ymax,m_zmin,m_zmax; 
00043   bool m_circ_x;
00044 
00045   virtual Vec3 getAPoint()=0;
00046 
00047   bool findAFit(SimpleParticle&, const vector<SimpleParticle>&);
00048   bool findAFit(SimpleParticle&, const vector<SimpleParticle>&, const Plane&);
00049   virtual bool checkAFit(const SimpleParticle&);
00050   virtual Plane getClosestPlane(const SimpleParticle&);
00051   void fillSpace(int);
00052   virtual int getNParts() const=0;
00053 
00054  public:
00055   virtual void generate(int,unsigned int)=0;
00056   virtual void insertParticle(const SimpleParticle)=0;
00057   virtual void tagParticleClosestTo(const Vec3&,int)=0; 
00058   virtual void tagEdgeY(int,int,double)=0; 
00059   virtual void tagEdgeZ(int,int,double)=0; 
00060 };
00061 
00062 #endif // __RANDOMASSEMBLY3D_H