From e53c1b0a0daa45a70ce41ca4ba3924c8c7db1220 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Franz=20P=C3=B6schel?= Date: Mon, 16 Sep 2024 12:06:48 +0200 Subject: [PATCH] Parallelize 10_streaming_write.py example --- examples/10_streaming_write.py | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/examples/10_streaming_write.py b/examples/10_streaming_write.py index 575079ea6d..02208b145f 100755 --- a/examples/10_streaming_write.py +++ b/examples/10_streaming_write.py @@ -2,6 +2,7 @@ import json import sys +from mpi4py import MPI import numpy as np import openpmd_api as io @@ -19,10 +20,13 @@ print("SST engine not available in ADIOS2.") sys.exit(0) + comm = MPI.COMM_WORLD + # create a series and specify some global metadata # change the file extension to .json, .h5 or .bp for regular file writing - series = io.Series("simData.sst", io.Access_Type.create, - json.dumps(config)) + series = io.Series( + "simData.bp5", io.Access_Type.create, comm, json.dumps(config) + ) series.set_author("Franz Poeschel ") series.set_software("openPMD-api-python-examples") @@ -54,8 +58,10 @@ dtype=np.dtype("double")) for dim in ["x", "y", "z"]: pos = electronPositions[dim] - pos.reset_dataset(io.Dataset(local_data.dtype, [length])) - pos[()] = local_data + pos.reset_dataset( + io.Dataset(local_data.dtype, [comm.size * length]) + ) + pos[comm.rank * length : (comm.rank + 1) * length] = local_data # optionally: flush now to clear buffers iteration.series_flush() # this is a shortcut for `series.flush()`