ESyS-Particle  2.3
Packer.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 
14 #ifndef ESYS_LSMPACKER_H
15 #define ESYS_LSMPACKER_H
16 
19 #include <boost/pool/object_pool.hpp>
20 #include <boost/shared_ptr.hpp>
21 
22 #include <set>
23 
24 namespace esys
25 {
26  namespace lsm
27  {
31  template <typename TmplParticleCollection>
32  class Packer
33  {
34  public:
35  typedef TmplParticleCollection ParticleCollection;
37  typedef boost::shared_ptr<ParticleCollection> ParticleCollectionPtr;
39  typedef boost::object_pool<Particle> ParticlePool;
40  typedef boost::shared_ptr<ParticlePool> ParticlePoolPtr;
42  typedef boost::shared_ptr<NTable> NTablePtr;
43  typedef
46  typedef
49 
50  Packer(NTablePtr nTablePtr);
51 
52  Packer(ParticlePoolPtr particlePoolPtr, NTablePtr nTablePtr);
53 
54  virtual ~Packer();
55 
56  virtual void generate() = 0;
57 
58  int getNumParticles() const;
59 
60  int getNextParticleId();
61 
62  void setNTablePtr(NTablePtr nTablePtr);
63  NTable &getNTable();
64  const NTable &getNTable() const;
65 
66  ParticlePoolPtr getParticlePoolPtr();
67  ParticlePool &getParticlePool();
68  const ParticlePool &getParticlePool() const;
69 
70  ParticleCollection &getParticleCollection();
71  const ParticleCollection &getParticleCollection() const;
72 
73  Particle &constructParticle(const Particle &particle);
74 
76 
78 
79  bool contains(const Particle &particle) const;
80 
81  Particle &createAndInsertParticle(const Particle &particle);
82 
83  protected:
84 
85  typedef std::set<int> IdSet;
86 
87  private:
88  NTablePtr m_nTablePtr;
89  ParticlePoolPtr m_particlePoolPtr;
90  ParticleCollectionPtr m_particleCollectionPtr;
91  IdSet m_idSet;
92  };
93  }
94 }
95 
96 #include "Geometry/Packer.hpp"
97 
98 #endif
virtual ~Packer()
Definition: Packer.hpp:44
Definition: ParticleCollection.h:68
Definition: Packer.h:32
ParticlePool & getParticlePool()
Definition: Packer.hpp:69
bool contains(const Particle &particle) const
Definition: Packer.hpp:151
ParticleCollection & getParticleCollection()
Definition: Packer.hpp:90
Particle & constructParticle(const Particle &particle)
Definition: Packer.hpp:104
virtual void generate()=0
NTable & getNTable()
Definition: Packer.hpp:55
ParticleCollection::ParticleConstIterator ParticleConstIterator
Definition: Packer.h:48
IdSet m_idSet
Definition: Packer.h:91
Definition: SimpleSpherePy.h:24
Definition: CheckPointable.cpp:16
std::set< int > IdSet
Definition: Packer.h:85
void setNTablePtr(NTablePtr nTablePtr)
Definition: Packer.hpp:49
boost::shared_ptr< ParticleCollection > ParticleCollectionPtr
Definition: Packer.h:37
ParticlePoolPtr m_particlePoolPtr
Definition: Packer.h:89
int getNumParticles() const
Definition: Packer.hpp:125
NTablePtr m_nTablePtr
Definition: Packer.h:88
TmplParticleCollection ParticleCollection
Definition: Packer.h:35
Particle & createAndInsertParticle(const Particle &particle)
Definition: Packer.hpp:139
ParticleCollection::Particle Particle
Definition: Packer.h:38
ParticleIterator getParticleIterator()
Definition: Packer.hpp:111
Definition: ParticleCollection.h:48
Definition: CircularNeighbourTable.h:33
boost::shared_ptr< ParticlePool > ParticlePoolPtr
Definition: Packer.h:40
ParticleCollection::ParticleIterator ParticleIterator
Definition: Packer.h:45
boost::object_pool< Particle > ParticlePool
Definition: Packer.h:39
Packer(NTablePtr nTablePtr)
Definition: Packer.hpp:19
Packer< ParticleCollection > PackerBase
Definition: Packer.h:36
CircularNeighbourTable< Particle > NTable
Definition: Packer.h:41
int getNextParticleId()
Definition: Packer.hpp:131
boost::shared_ptr< NTable > NTablePtr
Definition: Packer.h:42
ParticlePoolPtr getParticlePoolPtr()
Definition: Packer.hpp:76
ParticleCollectionPtr m_particleCollectionPtr
Definition: Packer.h:90