#include #include using triqs::arrays::array; using triqs::clef::placeholder; int main() { boost::mpi::environment env; // argc, argv); boost::mpi::communicator world; array A(2, 2), B(2, 2), C(2, 2); placeholder<0> i_; placeholder<1> j_; A(i_, j_) << (1 + world.rank()) * (10 * i_ + j_); if (world.rank() == 0) std::cout << " A = " << A << std::endl; boost::mpi::reduce(world, A, C, std::plus>(), 0); int s = world.size(); if (world.rank() == 0) std::cout << " C = " << C << " should be " << array((s * (s + 1) / 2) * A) << std::endl; }