NetDEM v1.0
Loading...
Searching...
No Matches
domain.hpp
Go to the documentation of this file.
1#pragma once
2
3#include "cell_manager.hpp"
4#include "particle.hpp"
5#include "particle_data.hpp"
6#include "wall.hpp"
7
8namespace netdem {
9
10class DomainManager;
11class MPIManager;
12
13class Scene;
24class Domain {
25 friend class Particle;
26 friend class Wall;
27 friend class MPIManager;
28 friend class DomainManager;
29
30private:
34 int self_rank{0};
35
39 int total_rank{0};
40
45 Vec3d bound_min{-0.5, -0.5, -0.5};
46
51 Vec3d bound_max{0.5, 0.5, 0.5};
52
53public:
59
60private:
68 VecXT<std::pair<Particle *, int>> outer_particle_list;
69
70public:
74 Domain();
75
82 Domain(Vec3d const &bmin, Vec3d const &bmax);
83
87 int GetSelfRank() const;
88
92 int GetTotalRank() const;
93
97 std::tuple<Vec3d, Vec3d> GetBound() const;
98
102 void Init();
103
109 void InitScene(Scene *const scene);
110
114 void InitScene();
115
121 Scene *GetScene();
122
133 void SetBound(double bmin_x, double bmin_y, double bmin_z, double bmax_x,
134 double bmax_y, double bmax_z);
135
143 void SetCellSpacing(double s_x, double s_y, double s_z);
144
154 bool IsJudgeDomain(Particle const &p, Particle const &q);
155
165 bool IsJudgeDomain(Particle const &p, Wall const &w);
166
176 bool IsBelongToDomain(Particle const &p);
177
187 bool IsBelongToDomain(ParticleData const &p);
188
195 bool IsBelongToDomain(Vec3d const &pos);
196
205 bool IsParticleProxyToSend(Particle const &p);
206
215 bool IsParticleProxyToRecv(Particle const &p);
216
225 bool IsParticleProxyToRecv(ParticleData const &p);
226
230 void Print();
231
237
241 void ClearLinkedLists();
242
243protected:
247 void RemoveLinkedParticle(int lookup_id);
248
249public:
256
260 ~Domain();
261
262private:
263 Scene *scene{nullptr};
264 bool scene_is_borrowed{true};
265};
266
267}; // namespace netdem
A class responsible for managing cells in a simulation grid.
Definition cell_manager.hpp:16
Class for managing the simulation domain and particles that belong to it.
Definition domain.hpp:24
std::tuple< Vec3d, Vec3d > GetBound() const
Get the bounds of the current domain.
Definition domain.cpp:15
bool IsBelongToDomain(Particle const &p)
Checks if a particle belongs to this domain.
Definition domain.cpp:98
void Init()
Initializes the domain.
Definition domain.cpp:24
Scene * GetScene()
Gets the pointer to the scene used by this domain.
Definition domain.cpp:61
~Domain()
Destructor for the Domain object.
Definition domain.cpp:256
void InitScene()
Initializes the domain with a default scene.
Definition domain.cpp:45
void ClearLinkedLists()
Clears linked lists.
Definition domain.cpp:145
STLModel GetSTLModel()
Returns an STLModel object for visualization purposes.
Definition domain.cpp:166
void RemoveLinkedParticle(int lookup_id)
Remove a linked particle by look-up id.
Definition domain.cpp:156
bool IsParticleProxyToRecv(Particle const &p)
Checks if a particle needs to be received from other domains for contact detection.
Definition domain.cpp:122
bool IsJudgeDomain(Particle const &p, Particle const &q)
Checks if a particle needs to be checked for contact detection in this domain.
Definition domain.cpp:80
void SetCellSpacing(double s_x, double s_y, double s_z)
Sets the cell spacing for the CellManager.
Definition domain.cpp:76
Domain()
Constructs a new Domain object with default settings.
Definition domain.cpp:9
void SetBound(double bmin_x, double bmin_y, double bmin_z, double bmax_x, double bmax_y, double bmax_z)
Sets the size of the domain.
Definition domain.cpp:63
bool IsParticleProxyToSend(Particle const &p)
Checks if a particle needs to be sent to other domains for contact detection.
Definition domain.cpp:116
CellManager cell_manager
Manages the cells, which are used in the borad-phase contact detection.
Definition domain.hpp:58
int GetTotalRank() const
Get the total ranks of the simulation.
Definition domain.cpp:13
void Print()
Prints information about this domain to the screen.
Definition domain.cpp:134
int GetSelfRank() const
Get the rank id of the domain.
Definition domain.cpp:11
VecXT< std::pair< Particle *, int > > const & GetLinkedOuterParticles()
Get the particles that belong to other domains but may potentially overlap with this domain.
Definition domain.cpp:141
A class that manages the domain and sub-domains for a DEM simulation.
Definition domain_manager.hpp:18
Manages the data exchange in a DEM simulation.
Definition mpi_manager.hpp:39
Definition particle.hpp:26
Class for working with STL models.
Definition stl_model.hpp:17
A class for managing the elements in a DEM simulation. Scene behaves as a std container:
Definition scene.hpp:56
A class representing a wall object in a physics simulation.
Definition wall.hpp:32
Definition bond_entry.hpp:7
std::vector< T > VecXT
Definition utils_macros.hpp:31
pos
Definition json_serilization.hpp:19
std::array< double, 3 > Vec3d
Definition utils_macros.hpp:18
A struct defining the particle data for MPI communication.
Definition particle_data.hpp:17