| | from baselines.common import mpi_util |
| | from baselines import logger |
| | from baselines.common.tests.test_with_mpi import with_mpi |
| | try: |
| | from mpi4py import MPI |
| | except ImportError: |
| | MPI = None |
| |
|
| | @with_mpi() |
| | def test_mpi_weighted_mean(): |
| | comm = MPI.COMM_WORLD |
| | with logger.scoped_configure(comm=comm): |
| | if comm.rank == 0: |
| | name2valcount = {'a' : (10, 2), 'b' : (20,3)} |
| | elif comm.rank == 1: |
| | name2valcount = {'a' : (19, 1), 'c' : (42,3)} |
| | else: |
| | raise NotImplementedError |
| | d = mpi_util.mpi_weighted_mean(comm, name2valcount) |
| | correctval = {'a' : (10 * 2 + 19) / 3.0, 'b' : 20, 'c' : 42} |
| | if comm.rank == 0: |
| | assert d == correctval, '{} != {}'.format(d, correctval) |
| |
|
| | for name, (val, count) in name2valcount.items(): |
| | for _ in range(count): |
| | logger.logkv_mean(name, val) |
| | d2 = logger.dumpkvs() |
| | if comm.rank == 0: |
| | assert d2 == correctval |
| |
|