aboutsummaryrefslogtreecommitdiff
path: root/Carpet/CarpetLib/src/mpi_string.hh
blob: 6ed8d447da358c917841720ab46908ef1332daeb (plain)
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
#include <string>
#include <vector>

#include <cctk.h>

#include <mpi.h>



namespace CarpetLib
{
  
  using namespace std;
  
  
  
  // String communication
  
  vector <string>
  allgather_string (MPI_Comm comm,
                    string const & data);
  
  vector <string>
  alltoallv_string (MPI_Comm comm,
                    vector <string> const & data);
  
  string
  broadcast_string (MPI_Comm comm, int root,
                    string const & data);
  
  
  
  // Arbitrary datatypes
  
  template <typename T>
  vector <vector <T> >
  allgatherv (MPI_Comm comm,
              vector <T> const & data);
  
  template <typename T>
  vector <T>
  alltoall (MPI_Comm comm,
            vector <T> const & data);
  
  template <typename T>
  vector <vector <T> >
  alltoallv (MPI_Comm comm,
             vector <vector <T> > const & data);
  
  template <typename T>
  vector <T>
  alltoallv1 (MPI_Comm comm,
              vector <vector <T> > const & data);
  
} // namespace CarpetLib