ESyS-Particle  2.3.4
RandomBlock3D.h
Go to the documentation of this file.
1 // //
3 // Copyright (c) 2003-2017 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.apache.org/licenses/LICENSE-2.0 //
10 // //
12 
13 #ifndef __RANDOMBLOCK3D_H
14 #define __RANDOMBLOCK3D_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  private:
44 
45  protected:
46  virtual Vec3 getAPoint();
47  virtual int getNParts() const{return m_bpart.size();};
48  double m_maxConnDist;
49 
50  public:
51  CRandomBlock3D(double,double,double,double,double,double,double,double,double,bool,bool is_bonded=true);
52  virtual ~CRandomBlock3D();
53 
54  virtual void generate(int,unsigned int);
55  virtual void insertParticle(const SimpleParticle);
56  //virtual void tagParticleClosestTo(const Vec3&,int);
57  virtual void tagEdgeY(int,int,double);
58  virtual void tagEdgeZ(int,int,double);
59 
60  virtual void writeToGeoFile(const string&);
61  virtual double calcPorosity();
62  virtual vector<pair<double,double> > getSizeDistribution(int);
63 };
64 
65 #endif // __RANDOMBLOCK3D_H
66 
CRandomBlock3D::calcPorosity
virtual double calcPorosity()
Definition: RandomBlock3D.cpp:241
ARandomAssembly3D::checkAFit
virtual bool checkAFit(const SimpleParticle &)
Definition: RandomAssembly3D.cpp:129
Console::Info
Console & Info()
set verbose level of next message to "inf"
ARandomAssembly3D::m_zmax
double m_zmax
x,y,z borders of the lattice
Definition: RandomAssembly3D.h:42
ARandomAssembly3D::m_circ_x
bool m_circ_x
Definition: RandomAssembly3D.h:43
SimpleNTable.h
ARandomAssembly::m_bpart
vector< SimpleParticle > m_bpart
Definition: ARandomAssembly.h:47
CRandomBlock3D::writeToGeoFile
virtual void writeToGeoFile(const string &)
Definition: RandomBlock3D.cpp:193
ARandomAssembly3D::fillSpace
void fillSpace(int)
Definition: RandomAssembly3D.cpp:176
ARandomAssembly3D::m_rmax
double m_rmax
min/max particle radius
Definition: RandomAssembly3D.h:41
ASimpleNTable::insertParticle
void insertParticle(SimpleParticle)
Definition: SimpleNTable.cpp:46
esys::lsm::Plane3D
::Plane3D Plane3D
Definition: Plane3D.h:60
ARandomAssembly3D::Borders
vector< Plane3D > Borders
Definition: RandomAssembly3D.h:40
SimpleNTable3D.h
console.h
ARandomAssembly3D::m_xmin
double m_xmin
Definition: RandomAssembly3D.h:42
ARandomAssembly3D::m_ymin
double m_ymin
Definition: RandomAssembly3D.h:42
CRandomBlock3D::getNParts
virtual int getNParts() const
Definition: RandomBlock3D.h:47
ARandomAssembly3D::m_xmax
double m_xmax
Definition: RandomAssembly3D.h:42
CRandomBlock3D::insertParticle
virtual void insertParticle(const SimpleParticle)
Definition: RandomBlock3D.cpp:134
SimpleParticle
Definition: SimpleParticle.h:25
CSimple3DNTable
Definition: SimpleNTable3D.h:33
Line.h
CRandomBlock3D::CRandomBlock3D
CRandomBlock3D(double, double, double, double, double, double, double, double, double, bool, bool is_bonded=true)
Definition: RandomBlock3D.cpp:40
SimpleParticle.h
ARandomAssembly3D::m_rmin
double m_rmin
Definition: RandomAssembly3D.h:41
CRandomBlock3D::m_maxConnDist
double m_maxConnDist
Definition: RandomBlock3D.h:47
Sphere2d.h
RandomBlock3D.h
NULL
#define NULL
Definition: t_list.h:17
ARandomAssembly3D::m_zmin
double m_zmin
Definition: RandomAssembly3D.h:42
ASimpleNTable::getInteractions
virtual void getInteractions(set< BasicInteraction, BILess > &, double)=0
ARandomAssembly::m_snt
ASimpleNTable * m_snt
Definition: ARandomAssembly.h:44
ARandomAssembly::m_iset
set< BasicInteraction, BILess > m_iset
Definition: ARandomAssembly.h:46
ARandomAssembly::m_random
double m_random(double, double)
Definition: ARandomAssembly.cpp:36
CRandomBlock3D::tagEdgeZ
virtual void tagEdgeZ(int, int, double)
Definition: RandomBlock3D.cpp:175
RandomAssembly3D.h
ARandomAssembly3D
Abstract base class for random assemblies, to be used for initialization of random lattices.
Definition: RandomAssembly3D.h:38
CRandomBlock3D::~CRandomBlock3D
virtual ~CRandomBlock3D()
Definition: RandomBlock3D.cpp:66
Vec3
Definition: vec3.h:47
esys::lsm::bpu::iter
boost::python::object iter(const boost::python::object &pyOb)
Definition: Util.h:25
CRandomBlock3D::generate
virtual void generate(int, unsigned int)
Definition: RandomBlock3D.cpp:92
CRandomBlock3D::tagEdgeY
virtual void tagEdgeY(int, int, double)
Definition: RandomBlock3D.cpp:156
ARandomAssembly3D::m_ymax
double m_ymax
Definition: RandomAssembly3D.h:42
CRandomBlock3D::getAPoint
virtual Vec3 getAPoint()
Definition: RandomBlock3D.cpp:75
CRandomBlock3D
Class for the generation of a 3D random lattice in a rectangular area.
Definition: RandomBlock3D.h:41
console
Console console
Definition: console.cpp:25
CRandomBlock3D::m_is_bonded
bool m_is_bonded
Definition: RandomBlock3D.h:43
CRandomBlock3D::getSizeDistribution
virtual vector< pair< double, double > > getSizeDistribution(int)
Definition: RandomBlock3D.cpp:264