forked from Pyomo/mpi-sppy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmpi_one_sided_test.py
56 lines (42 loc) · 1.53 KB
/
mpi_one_sided_test.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
# This software is distributed under the 3-clause BSD License.
''' Basic test script to make sure that the one-sided MPI calls work as
intended. Runs on two processes. Will raise an assertion error if the
Lock/Get/Unlock combination blocks. Otherwise, exits normally and produces
no output.
Just because this test passes doesn't mean that MPI one-sided calls will
work as expected.
Takes about 4 seconds to execute, with all the sleep() calls.
'''
import mpi4py.MPI as mpi
import numpy as np
import time
def main():
assert(mpi.COMM_WORLD.Get_size() == 2)
rank = mpi.COMM_WORLD.Get_rank()
array_size = 10
win = mpi.Win.Allocate(mpi.DOUBLE.size*array_size, mpi.DOUBLE.size,
comm=mpi.COMM_WORLD)
buff = np.ndarray(buffer=win.tomemory(), dtype='d', shape=(array_size,))
if (rank == 0):
buff[:] = 3. * np.ones(array_size, dtype='d')
time.sleep(3)
buff[:] = np.arange(array_size)
win.Lock(1)
win.Put((buff, array_size, mpi.DOUBLE), target_rank=1)
win.Unlock(1)
elif (rank == 1):
buff = np.ones(array_size, dtype='d')
time.sleep(1)
win.Lock(0)
win.Get((buff, array_size, mpi.DOUBLE), target_rank=0)
win.Unlock(0)
assert(buff[-1] == 3.)
time.sleep(3)
win.Lock(1)
win.Get((buff, array_size, mpi.DOUBLE), target_rank=1)
win.Unlock(1)
assert(buff[-1] == array_size-1)
del buff # Important!
win.Free()
if __name__=='__main__':
main()