ESyS-Particle  2.3.4
BlockGenerator.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 
14 #ifndef ESYS_LSMBLOCKGENERATOR_H
15 #define ESYS_LSMBLOCKGENERATOR_H
16 
19 #include <Foundation/BoundingBox.h>
20 
21 #include <vector>
22 #include <set>
23 
24 namespace esys
25 {
26  namespace lsm
27  {
28  typedef std::vector<bool> BoolVector;
33  {
34  public:
36  NTable &nTable,
37  ParticlePool &particlePool,
38  const BoundingBox &bBox,
39  const BoolVector &periodicDimensions,
40  double tolerance
41  );
42 
43  virtual ~BlockGenerator();
44 
45  virtual void generate() = 0;
46 
47  virtual void generateSeedParticles();
48 
49  virtual SimpleParticle generateParticle(const Vec3 &point);
50 
51  virtual double getRadius() const = 0;
52 
53  virtual double getGridRadius() const = 0;
54 
55  size_t getNumParticles() const;
56 
57  int getNextId();
58 
59  virtual bool particleFits(const SimpleParticle &particle) const;
60 
61  bool is2d() const;
62 
63  bool particleFitsInBBox(const SimpleParticle &particle) const;
64 
65  bool particleFitsWithNeighbours(const SimpleParticle &particle) const;
66 
67  void insertParticle(const SimpleParticle &particle);
68 
69  double getTolerance() const;
70 
71  const BoundingBox &getBBox() const;
72 
73  bool contains(const SimpleParticle &particle) const;
74 
77 
79  {
81  }
82 
83  typedef std::set<int> IdSet;
84  private:
88  double m_tolerance;
90  };
91  }
92 }
93 
94 #endif
SimpleParticle::getRad
double getRad() const
Definition: SimpleParticle.hpp:70
esys::lsm::BlockGenerator::generateParticle
virtual SimpleParticle generateParticle(const Vec3 &point)
Definition: BlockGenerator.cpp:137
esys::lsm::BlockGenerator::getBBox
const BoundingBox & getBBox() const
Definition: BlockGenerator.cpp:41
ParticleGenerator.h
esys::lsm::BlockGenerator::BlockGenerator
BlockGenerator(NTable &nTable, ParticlePool &particlePool, const BoundingBox &bBox, const BoolVector &periodicDimensions, double tolerance)
Definition: BlockGenerator.cpp:24
esys::lsm::BlockGenerator::is2d
bool is2d() const
Definition: BlockGenerator.cpp:61
esys::lsm::SimpleParticleData::getID
Id getID() const
Definition: SimpleParticleData.hpp:109
esys::lsm::CircularNeighbourTable::ParticleVector
Inherited::ParticleVector ParticleVector
Definition: CircularNeighbourTable.h:38
GridIterator.h
BlockGenerator.h
esys::lsm::ParticleGenerator::getNTable
NTable & getNTable()
Definition: ParticleGenerator.cpp:40
esys::lsm::BlockGenerator
Definition: BlockGenerator.h:33
esys::lsm::BlockGenerator::ParticleIterator
NTable::ParticleIterator ParticleIterator
Definition: BlockGenerator.h:76
esys::lsm::BlockGenerator::getTolerance
double getTolerance() const
Definition: BlockGenerator.cpp:56
esys::lsm::BlockGenerator::m_particleVector
ParticleVector m_particleVector
Definition: BlockGenerator.h:87
esys::lsm::ParticleGenerator::ParticlePool
boost::object_pool< SimpleParticle > ParticlePool
Definition: ParticleGenerator.h:33
esys::lsm::BlockGenerator::getParticleIterator
ParticleIterator getParticleIterator()
Definition: BlockGenerator.h:78
SimpleParticle::getPos
const Vec3 & getPos() const
Definition: SimpleParticle.hpp:30
esys::lsm::BlockGenerator::m_bBox
BoundingBox m_bBox
Definition: BlockGenerator.h:85
esys::lsm::NeighbourTable::getNeighbourVector
ParticleVector getNeighbourVector(const Vec3 &pt, double radius) const
Definition: NeighbourTable.hpp:181
esys::lsm::BlockGenerator::~BlockGenerator
virtual ~BlockGenerator()
Definition: BlockGenerator.cpp:37
esys::lsm::BlockGenerator::particleFitsWithNeighbours
bool particleFitsWithNeighbours(const SimpleParticle &particle) const
Definition: BlockGenerator.cpp:102
esys::lsm::ParticleGenerator::getParticlePool
ParticlePool & getParticlePool()
Definition: ParticleGenerator.cpp:50
SimpleParticle
Definition: SimpleParticle.h:25
esys::lsm::BlockGenerator::contains
bool contains(const SimpleParticle &particle) const
Definition: BlockGenerator.cpp:132
esys::lsm::BlockGenerator::particleFitsInBBox
bool particleFitsInBBox(const SimpleParticle &particle) const
Definition: BlockGenerator.cpp:66
esys::lsm::BlockGenerator::m_tolerance
double m_tolerance
Definition: BlockGenerator.h:88
esys::lsm::BoundingBox
3D bounding box
Definition: BoundingBox.h:28
esys
Definition: CheckPointable.cpp:17
esys::lsm::BlockGenerator::m_idSet
IdSet m_idSet
Definition: BlockGenerator.h:89
SimpleParticle.h
esys::lsm::BlockGenerator::getGridRadius
virtual double getGridRadius() const =0
esys::lsm::BoundingBox::contains
bool contains(const Vec3 &pt, double tolerance=0.0) const
Definition: BoundingBox.hpp:60
esys::lsm::BlockGenerator::getNumParticles
size_t getNumParticles() const
Definition: BlockGenerator.cpp:46
esys::lsm::CircularNeighbourTable::insert
void insert(Particle *pParticle)
Definition: CircularNeighbourTable.hpp:224
esys::lsm::BlockGenerator::particleFits
virtual bool particleFits(const SimpleParticle &particle) const
Definition: BlockGenerator.cpp:119
esys::lsm::CircularNeighbourTable::getNumParticles
size_t getNumParticles() const
Definition: CircularNeighbourTable.hpp:265
esys::lsm::BlockGenerator::getNextId
int getNextId()
Definition: BlockGenerator.cpp:51
esys::lsm::BoolVector
std::vector< bool > BoolVector
Definition: BlockGenerator.h:28
esys::lsm::ParticleGenerator
Definition: ParticleGenerator.h:30
Vec3
Definition: vec3.h:47
esys::lsm::bpu::iter
boost::python::object iter(const boost::python::object &pyOb)
Definition: Util.h:25
esys::lsm::BlockGenerator::insertParticle
void insertParticle(const SimpleParticle &particle)
Definition: BlockGenerator.cpp:124
esys::lsm::ForwardIterator
Definition: StlIterator.h:30
esys::lsm::GridIterator::hasNext
bool hasNext() const
Definition: GridIterator.h:207
esys::lsm::BlockGenerator::IdSet
std::set< int > IdSet
Definition: BlockGenerator.h:83
esys::lsm::BlockGenerator::generateSeedParticles
virtual void generateSeedParticles()
Definition: BlockGenerator.cpp:142
esys::lsm::BlockGenerator::generate
virtual void generate()=0
esys::lsm::BlockGenerator::m_periodicDimensions
BoolVector m_periodicDimensions
Definition: BlockGenerator.h:86
esys::lsm::GridIterator::next
Vec3 next()
Definition: GridIterator.h:255
esys::lsm::BlockGenerator::ParticleVector
NTable::ParticleVector ParticleVector
Definition: BlockGenerator.h:75
esys::lsm::BlockGenerator::getRadius
virtual double getRadius() const =0
esys::lsm::GridIterator
Definition: GridIterator.h:29
esys::lsm::CircularNeighbourTable
Definition: CircularNeighbourTable.h:34
BoundingBox.h