8 #ifndef DISTRIBUTION_ATLASDISTRIBUTION_H_
9 #define DISTRIBUTION_ATLASDISTRIBUTION_H_
13 #include "ioda/distribution/NonoverlappingDistribution.h"
25 const eckit::Configuration & config);
28 void assignRecord(
const std::size_t recNum,
const std::size_t locNum,
29 const eckit::geometry::Point2 & point)
override;
31 bool isMyRecord(std::size_t recNum)
const override;
33 std::string
name()
const override;
Assigns records to MPI ranks for the AtlasDistribution.
Distribution assigning each record to the process owning the Atlas mesh partition containing the loca...
AtlasDistribution(const eckit::mpi::Comm &comm, const eckit::Configuration &config)
bool isMyRecord(std::size_t recNum) const override
Returns true if record RecNum has been assigned to the calling PE during a previous call to assignRec...
std::string name() const override
void assignRecord(const std::size_t recNum, const std::size_t locNum, const eckit::geometry::Point2 &point) override
If the record RecNum has not yet been assigned to a PE, assigns it to the appropriate PE.
std::unique_ptr< RecordAssigner > recordAssigner_
~AtlasDistribution() override
Implements some methods of Distribution in a manner suitable for distributions storing each observati...