seapodym-parallel
Fish dynamics models with parameter estimations
Loading...
Searching...
No Matches
DistDataCollector.h
1#include <mpi.h>
2#include <set>
3#include <vector>
4#include <limits>
5
6#ifndef DIST_DATA_COLLECTOR
7#define DIST_DATA_COLLECTOR
8
9
15
16 private:
17
18 // MPI communicator to use for communication
19 MPI_Comm comm;
20
21 // number of chunks
22 std::size_t numChunks;
23
24 // local size of the data
25 std::size_t numSize;
26
27 // the array that collects the data of size numChunks * numSize on rank 0
28 double* collectedData;
29
30 // MPI window for remote memory access
31 MPI_Win win;
32
33 public:
34
35 // initial values
36 const double BAD_VALUE = std::numeric_limits<double>::quiet_NaN();
37
44 DistDataCollector(MPI_Comm comm, int numChunks, int numSize);
45
50
54 void inline startEpoch() {
55 MPI_Win_lock_all(MPI_MODE_NOCHECK, this->win);
56 }
57
61 void inline flush() {
62 MPI_Win_flush_all(this->win);
63 }
64
68 void inline endEpoch() {
69 MPI_Win_unlock_all(this->win);
70 }
71
78 void put(int chunkId, const double* data);
79
87 void inline putAsync(int chunkId, const double* data) {
88 MPI_Put(data, this->numSize, MPI_DOUBLE, 0, chunkId * this->numSize, this->numSize, MPI_DOUBLE, this->win);
89 }
90
97 std::vector<double> get(int chunkId);
98
105 void get(int chunkId, double* buffer);
106
114 void inline getAsync(int chunkId, double* buffer) {
115 MPI_Get(buffer, this->numSize, MPI_DOUBLE, 0, chunkId * this->numSize, this->numSize, MPI_DOUBLE, this->win);
116 }
117
124 return this->collectedData;
125 }
126
131 int getNumChunks() const {
132 return this->numChunks;
133 }
134
139 int getNumSize() const {
140 return this->numSize;
141 }
142
146 void free() {
147 if (this->win != MPI_WIN_NULL) {
148 MPI_Win_free(&this->win);
149 }
150 // No need to free the data, MPI_Win_free will free the pointer
151 //MPI_Free_mem(this->collectedData);
152 }
153
154 // Disable copy and assignment operations
155 // to prevent accidental copying of the DistDataCollector instance
156 // This is important because the class manages an MPI window and data pointer
157 // which should not be copied or assigned.
158 DistDataCollector(const DistDataCollector&) = delete; // Disable copy constructor
159 DistDataCollector& operator=(const DistDataCollector&) = delete; // Disable assignment operator
160 DistDataCollector(DistDataCollector&& other) noexcept; // Move constructor
161 DistDataCollector& operator=(DistDataCollector&& other) noexcept; // Move assignment operator
162};
163
164#endif // DIST_DATA_COLLECTOR
DistDataCollector is a class that collects data stored on multiple MPI processes into a large array s...
Definition DistDataCollector.h:14
void endEpoch()
End an epoch for RMA operations.
Definition DistDataCollector.h:68
void put(int chunkId, const double *data)
Put the local data into the collected array.
Definition DistDataCollector.cpp:33
int getNumSize() const
Definition DistDataCollector.h:139
std::vector< double > get(int chunkId)
Get a slice of the remote, collected array to the local worker.
Definition DistDataCollector.cpp:48
void startEpoch()
Start an epoch for RMA operations.
Definition DistDataCollector.h:54
double * getCollectedDataPtr()
Definition DistDataCollector.h:123
void putAsync(int chunkId, const double *data)
Put the local data into the collected array (non-blocking)
Definition DistDataCollector.h:87
void free()
Free the MPI window and empty the collected data.
Definition DistDataCollector.h:146
void flush()
Ensure that all RMA operations are completed.
Definition DistDataCollector.h:61
int getNumChunks() const
Definition DistDataCollector.h:131
void getAsync(int chunkId, double *buffer)
Get a slice of the remote, collected array to the local worker (non-blocking)
Definition DistDataCollector.h:114
~DistDataCollector()
Destructor.
Definition DistDataCollector.cpp:28
DistDataCollector(MPI_Comm comm, int numChunks, int numSize)
Constructor.
Definition DistDataCollector.cpp:8