ESyS-Particle  2.3.4
FaultedBlock2d.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 __FAULTEDBLOCK2D_H
14 #define __FAULTEDBLOCK2D_H
15 
16 //--- STL includes ---
17 #include <vector>
18 #include <utility>
19 
20 using std::vector;
21 using std::pair;
22 
23 //-- project includes --
24 #include "Geometry/RandomBlock.h"
25 #include "Geometry/LineSegment.h"
26 
36 {
37  protected:
38  vector<pair<double,LineSegment> > m_fault;
39  vector<LineSegment> m_f2;
40  virtual Line *getClosestPlane(const SimpleParticle&);
41  double m_pad_size;
42 
43  virtual Vec3 getAPoint();
44 
45  public:
46  FaultedBlock2D(double,double,double,double,double,double,double,bool circ_x=false);
47  virtual ~FaultedBlock2D();
48 
49  void addSegment(const Vec3&,const Vec3&,double);
50  virtual bool checkAFit(const SimpleParticle&) ;
51  virtual void generate(int,unsigned int);
52  virtual void tagSplit(int,int,double);
53 };
54 
55 #endif // __FAULTEDBLOCK2D_H
SimpleParticle::getRad
double getRad() const
Definition: SimpleParticle.hpp:70
ARandomAssembly2D::m_rmax
double m_rmax
min/max particle radius
Definition: RandomAssembly2D.h:40
CRandomBlock2D::getNParts
virtual int getNParts() const
Definition: RandomBlock.h:44
ARandomAssembly::m_bpart
vector< SimpleParticle > m_bpart
Definition: ARandomAssembly.h:47
ARandomAssembly2D::m_rmin
double m_rmin
Definition: RandomAssembly2D.h:40
ARandomAssembly2D::m_xmax
double m_xmax
Definition: RandomAssembly2D.h:41
FaultedBlock2D
class for the generation of a 2D random block with a fault consisting of line segments
Definition: FaultedBlock2d.h:36
SimpleParticle::getPos
const Vec3 & getPos() const
Definition: SimpleParticle.hpp:30
ARandomAssembly2D::m_ymin
double m_ymin
Definition: RandomAssembly2D.h:41
RandomBlock.h
FaultedBlock2D::generate
virtual void generate(int, unsigned int)
Definition: FaultedBlock2d.cpp:109
CRandomBlock2D
Class for the generation of a 2D random lattice in a rectangular area.
Definition: RandomBlock.h:41
SimpleParticle
Definition: SimpleParticle.h:25
CRandomBlock2D::insertParticle
virtual void insertParticle(const SimpleParticle)
Definition: RandomBlock.cpp:115
FaultedBlock2D::m_pad_size
double m_pad_size
Definition: FaultedBlock2d.h:41
ARandomAssembly2D::fillSpace
void fillSpace(int)
Definition: RandomAssembly2D.cpp:169
Vec3::X
VEC3_INLINE double & X()
Definition: vec3.h:119
FaultedBlock2D::tagSplit
virtual void tagSplit(int, int, double)
Definition: FaultedBlock2d.cpp:230
Vec3::Z
VEC3_INLINE double & Z()
Definition: vec3.h:121
LineSegment.h
FaultedBlock2D::~FaultedBlock2D
virtual ~FaultedBlock2D()
Definition: FaultedBlock2d.cpp:39
ASimpleNTable::getInteractions
virtual void getInteractions(set< BasicInteraction, BILess > &, double)=0
FaultedBlock2d.h
ARandomAssembly::m_snt
ASimpleNTable * m_snt
Definition: ARandomAssembly.h:44
ARandomAssembly::m_iset
set< BasicInteraction, BILess > m_iset
Definition: ARandomAssembly.h:46
Line::sep
virtual double sep(const Vec3 &)
Definition: Line.cpp:30
ARandomAssembly2D::checkAFit
virtual bool checkAFit(const SimpleParticle &)
Definition: RandomAssembly2D.cpp:124
ARandomAssembly::m_random
double m_random(double, double)
Definition: ARandomAssembly.cpp:36
FaultedBlock2D::m_f2
vector< LineSegment > m_f2
Definition: FaultedBlock2d.h:39
Vec3::Y
VEC3_INLINE double & Y()
Definition: vec3.h:120
Line
Class representing a line.
Definition: Line.h:26
ARandomAssembly2D::m_ymax
double m_ymax
x,y borders of the lattice
Definition: RandomAssembly2D.h:41
Vec3
Definition: vec3.h:47
FaultedBlock2D::checkAFit
virtual bool checkAFit(const SimpleParticle &)
Definition: FaultedBlock2d.cpp:86
esys::lsm::bpu::iter
boost::python::object iter(const boost::python::object &pyOb)
Definition: Util.h:25
FaultedBlock2D::addSegment
void addSegment(const Vec3 &, const Vec3 &, double)
Definition: FaultedBlock2d.cpp:62
FaultedBlock2D::FaultedBlock2D
FaultedBlock2D(double, double, double, double, double, double, double, bool circ_x=false)
Definition: FaultedBlock2d.cpp:33
FaultedBlock2D::m_fault
vector< pair< double, LineSegment > > m_fault
Definition: FaultedBlock2d.h:38
ARandomAssembly2D::m_xmin
double m_xmin
Definition: RandomAssembly2D.h:41
FaultedBlock2D::getClosestPlane
virtual Line * getClosestPlane(const SimpleParticle &)
Definition: FaultedBlock2d.cpp:200
ARandomAssembly2D::getClosestPlane
virtual Line * getClosestPlane(const SimpleParticle &)
Definition: RandomAssembly2D.cpp:40
LineSegment
Class representing a line segment for intersection/fitting calculation in 2D.
Definition: LineSegment.h:29
FaultedBlock2D::getAPoint
virtual Vec3 getAPoint()
Definition: FaultedBlock2d.cpp:45