mirror of
https://github.com/triqs/dft_tools
synced 2025-01-12 14:08:24 +01:00
edd1ff4529
A first general restructuration of the doc according to the pattern [tour|tutorial|reference]. In the reference part, objects are documented per topic. In each topic, [definition|c++|python|hdf5] (not yet implemented)
23 lines
623 B
C++
23 lines
623 B
C++
#include <triqs/arrays.hpp>
|
|
#include <boost/mpi.hpp>
|
|
using triqs::arrays::array;
|
|
using triqs::clef::placeholder;
|
|
|
|
int main() {
|
|
boost::mpi::environment env; // argc, argv);
|
|
boost::mpi::communicator world;
|
|
|
|
array<long, 2> 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<array<long, 2>>(), 0);
|
|
|
|
int s = world.size();
|
|
if (world.rank() == 0) std::cout << " C = " << C << " should be " << array<long, 2>((s * (s + 1) / 2) * A) << std::endl;
|
|
}
|
|
|