Add ability to retrieve the MPI communicator from LAMMPS instance via library/python interface #2357
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Summary
This enables retrieving the communicator used by a LAMMPS instance in either the C-library interface or the python interface.
Author(s)
Axel Kohlmeyer, Temple U
Licensing
By submitting this pull request, I agree, that my contribution will be included in LAMMPS and redistributed under either the GNU General Public License version 2 (GPL v2) or the GNU Lesser General Public License version 2.1 (LGPL v2.1).
Backward Compatibility
N/A
Implementation Notes
For increased portability between programming languages and MPI implementations, the new library function returns the Fortran representation of the communicator, which is always an integer. It can be converted back using
MPI_Comm_f2c()
.This is compatible with mpi4py and thus allows doing MPI calls from within Python functions that are launched via
python invoke
or similar. A minimal example for using it is:Which produces the following output when run with
mpirun -np 2 ./lmp -in in.mpi-in-python
:And, more importantly, when run with
mpirun -np 4 ./lmp -p 2x2 -in in.mpi-in-python
:Post Submission Checklist