ESyS-Particle  2.3
RandomBlock.h
Go to the documentation of this file.
1 // //
3 // Copyright (c) 2003-2014 by The University of Queensland //
4 // Centre for Geoscience Computing //
5 // http://earth.uq.edu.au/centre-geoscience-computing //
6 // //
7 // Primary Business: Brisbane, Queensland, Australia //
8 // Licensed under the Open Software License version 3.0 //
9 // http://www.opensource.org/licenses/osl-3.0.php //
10 // //
12 
13 #ifndef __RANDOMBLOCK_H
14 #define __RANDOMBLOCK_H
15 
16 //-- project includes --
18 #include "Geometry/SimpleNTable.h"
19 #include "Geometry/Sphere2d.h"
20 #include "Geometry/Line.h"
22 
23 //-- STL includes --
24 #include <vector>
25 #include <string>
26 #include <utility>
27 
28 using std::vector;
29 using std::string;
30 using std::pair;
31 
41 {
42  protected:
43  virtual Vec3 getAPoint();
44  virtual int getNParts() const{return m_bpart.size();};
45  double m_maxConnDist;
46 
47  public:
48  CRandomBlock2D(double,double,double,double,double,double,double,bool circ_x=false);
49  virtual ~CRandomBlock2D();
50 
51  virtual void generate(int,unsigned int);
52  virtual void insertParticle(const SimpleParticle);
53  virtual void tagParticleClosestTo(const Vec3&,int);
54  virtual void tagEdgeY(int,int,double);
55  virtual void tagEdgeZ(int,int,double){}; // do nothing
56 
57  virtual void writeToGeoFile(const string&);
58  virtual double calcPorosity();
59  virtual vector<pair<double,double> > getSizeDistribution(int);
60 };
61 
62 #endif // __RANDOMBLOCK_H
virtual void tagEdgeY(int, int, double)
Definition: RandomBlock.cpp:237
vector< SimpleParticle > m_bpart
Definition: ARandomAssembly.h:47
virtual void writeToGeoFile(const string &)
Definition: RandomBlock.cpp:127
Definition: vec3.h:46
virtual void tagEdgeZ(int, int, double)
Definition: RandomBlock.h:55
virtual void generate(int, unsigned int)
Definition: RandomBlock.cpp:80
virtual int getNParts() const
Definition: RandomBlock.h:44
double m_maxConnDist
Definition: RandomBlock.h:44
virtual void insertParticle(const SimpleParticle)
Definition: RandomBlock.cpp:115
virtual double calcPorosity()
Definition: RandomBlock.cpp:173
virtual Vec3 getAPoint()
Definition: RandomBlock.cpp:64
virtual void tagParticleClosestTo(const Vec3 &, int)
Definition: RandomBlock.cpp:222
virtual vector< pair< double, double > > getSizeDistribution(int)
Definition: RandomBlock.cpp:194
Class for the generation of a 2D random lattice in a rectangular area.
Definition: RandomBlock.h:40
Abstract base class for random assemblies, to be used for initialization of random lattices...
Definition: RandomAssembly2D.h:36
Definition: SimpleParticle.h:24
virtual ~CRandomBlock2D()
Definition: RandomBlock.cpp:56
CRandomBlock2D(double, double, double, double, double, double, double, bool circ_x=false)
Definition: RandomBlock.cpp:35