Skip to content

Commit

Permalink
Testing, examples
Browse files Browse the repository at this point in the history
  • Loading branch information
franzpoeschel committed Dec 19, 2023
1 parent 0f33508 commit b540b48
Show file tree
Hide file tree
Showing 4 changed files with 63 additions and 19 deletions.
17 changes: 10 additions & 7 deletions examples/10_streaming_read.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@ using namespace openPMD;
int main()
{
#if openPMD_HAVE_ADIOS2
using position_t = double;
auto backends = openPMD::getFileExtensions();
if (std::find(backends.begin(), backends.end(), "sst") == backends.end())
{
Expand Down Expand Up @@ -40,15 +39,15 @@ int main()
std::cout << "Current iteration: " << iteration.iterationIndex
<< std::endl;
Record electronPositions = iteration.particles["e"]["position"];
std::array<std::shared_ptr<position_t>, 3> loadedChunks;
std::array<RecordComponent::shared_ptr_dataset_types, 3> loadedChunks;
std::array<Extent, 3> extents;
std::array<std::string, 3> const dimensions{{"x", "y", "z"}};

for (size_t i = 0; i < 3; ++i)
{
std::string const &dim = dimensions[i];
RecordComponent rc = electronPositions[dim];
loadedChunks[i] = rc.loadChunk<position_t>(
loadedChunks[i] = rc.loadChunkVariant(
Offset(rc.getDimensionality(), 0), rc.getExtent());
extents[i] = rc.getExtent();
}
Expand All @@ -64,10 +63,14 @@ int main()
Extent const &extent = extents[i];
std::cout << "\ndim: " << dim << "\n" << std::endl;
auto chunk = loadedChunks[i];
for (size_t j = 0; j < extent[0]; ++j)
{
std::cout << chunk.get()[j] << ", ";
}
std::visit(
[&extent](auto &shared_ptr) {
for (size_t j = 0; j < extent[0]; ++j)
{
std::cout << shared_ptr.get()[j] << ", ";
}
},
chunk);
std::cout << "\n----------\n" << std::endl;
}
}
Expand Down
23 changes: 14 additions & 9 deletions examples/2_read_serial.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -75,20 +75,25 @@ int main()

Offset chunk_offset = {1, 1, 1};
Extent chunk_extent = {2, 2, 1};
auto chunk_data = E_x.loadChunk<double>(chunk_offset, chunk_extent);
// Loading without explicit datatype here
auto chunk_data = E_x.loadChunkVariant(chunk_offset, chunk_extent);
cout << "Queued the loading of a single chunk from disk, "
"ready to execute\n";
series.flush();
cout << "Chunk has been read from disk\n"
<< "Read chunk contains:\n";
for (size_t row = 0; row < chunk_extent[0]; ++row)
{
for (size_t col = 0; col < chunk_extent[1]; ++col)
cout << "\t" << '(' << row + chunk_offset[0] << '|'
<< col + chunk_offset[1] << '|' << 1 << ")\t"
<< chunk_data.get()[row * chunk_extent[1] + col];
cout << '\n';
}
std::visit(
[&chunk_offset, &chunk_extent](auto &shared_ptr) {
for (size_t row = 0; row < chunk_extent[0]; ++row)
{
for (size_t col = 0; col < chunk_extent[1]; ++col)
cout << "\t" << '(' << row + chunk_offset[0] << '|'
<< col + chunk_offset[1] << '|' << 1 << ")\t"
<< shared_ptr.get()[row * chunk_extent[1] + col];
cout << '\n';
}
},
chunk_data);

auto all_data = E_x.loadChunk<double>();

Expand Down
18 changes: 15 additions & 3 deletions examples/4_read_parallel.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,8 @@ int main(int argc, char *argv[])
Offset chunk_offset = {static_cast<long unsigned int>(mpi_rank) + 1, 1, 1};
Extent chunk_extent = {2, 2, 1};

auto chunk_data = E_x.loadChunk<double>(chunk_offset, chunk_extent);
// If you know the datatype, use `loadChunk<double>(...)` instead.
auto chunk_data = E_x.loadChunkVariant(chunk_offset, chunk_extent);

if (0 == mpi_rank)
cout << "Queued the loading of a single chunk per MPI rank from "
Expand All @@ -72,9 +73,20 @@ int main(int argc, char *argv[])
for (size_t row = 0; row < chunk_extent[0]; ++row)
{
for (size_t col = 0; col < chunk_extent[1]; ++col)
{
cout << "\t" << '(' << row + chunk_offset[0] << '|'
<< col + chunk_offset[1] << '|' << 1 << ")\t"
<< chunk_data.get()[row * chunk_extent[1] + col];
<< col + chunk_offset[1] << '|' << 1 << ")\t";
/*
* For hot loops, the std::visit(...) call should be moved
* further up.
*/
std::visit(
[row, col, &chunk_extent](auto &shared_ptr) {
cout << shared_ptr
.get()[row * chunk_extent[1] + col];
},
chunk_data);
}
cout << std::endl;
}
}
Expand Down
24 changes: 24 additions & 0 deletions test/SerialIOTest.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1544,6 +1544,15 @@ TEST_CASE("dtype_test", "[serial]")
}
}

struct ReadFromAnyType
{
template <typename T>
static std::shared_ptr<void> call(RecordComponent &rc)
{
return std::static_pointer_cast<void>(rc.loadChunk<T>());
}
};

inline void write_test(const std::string &backend)
{
Series o = Series("../samples/serial_write." + backend, Access::CREATE);
Expand Down Expand Up @@ -1642,6 +1651,21 @@ inline void write_test(const std::string &backend)
}

o.flush();

o.close();

Series read("../samples/serial_write." + backend, Access::READ_ONLY);
auto rc = read.iterations[1].particles["e"]["position"]["x"];
auto opaqueTypeDataset = rc.visit<ReadFromAnyType>();

auto variantTypeDataset = rc.loadChunkVariant();
rc.seriesFlush();
std::visit(
[](auto &&shared_ptr) {
std::cout << "First value in loaded chunk: '" << shared_ptr.get()[0]
<< '\'' << std::endl;
},
variantTypeDataset);
}

TEST_CASE("write_test", "[serial]")
Expand Down

0 comments on commit b540b48

Please sign in to comment.