6#ifndef DIST_DATA_COLLECTOR
7#define DIST_DATA_COLLECTOR
22 std::size_t numChunks;
28 double* collectedData;
36 const double BAD_VALUE = std::numeric_limits<double>::quiet_NaN();
55 MPI_Win_lock_all(MPI_MODE_NOCHECK, this->win);
62 MPI_Win_flush_all(this->win);
69 MPI_Win_unlock_all(this->win);
78 void put(
int chunkId,
const double* data);
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);
97 std::vector<double>
get(
int chunkId);
105 void get(
int chunkId,
double* buffer);
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);
124 return this->collectedData;
132 return this->numChunks;
140 return this->numSize;
147 if (this->win != MPI_WIN_NULL) {
148 MPI_Win_free(&this->win);
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