1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21 class Group {
22 #if 0
23
24 #endif
25 public:
26
27 #if 0
28
29
30 inline Group() { }
31 inline Group(MPI_Group i) : pmpi_group(i) { }
32
33 inline Group(const Group& g) : pmpi_group(g.pmpi_group) { }
34
35 inline Group(const PMPI::Group& g) : pmpi_group(g) { }
36
37 inline virtual ~Group() {}
38
39 Group& operator=(const Group& g) {
40 pmpi_group = g.pmpi_group; return *this;
41 }
42
43
44 inline bool operator== (const Group &a) {
45 return (bool)(pmpi_group == a.pmpi_group);
46 }
47 inline bool operator!= (const Group &a) {
48 return (bool)!(*this == a);
49 }
50
51
52 Group& operator= (const MPI_Group &i) { pmpi_group = i; return *this; }
53 inline operator MPI_Group () const { return pmpi_group.mpi(); }
54
55 inline operator const PMPI::Group&() const { return pmpi_group; }
56
57 const PMPI::Group& pmpi() { return pmpi_group; }
58 #else
59
60
61 inline Group() : mpi_group(MPI_GROUP_NULL) { }
62 inline Group(MPI_Group i) : mpi_group(i) { }
63
64
65 inline Group(const Group& g) : mpi_group(g.mpi_group) { }
66
67 inline virtual ~Group() {}
68
69 inline Group& operator=(const Group& g) { mpi_group = g.mpi_group; return *this; }
70
71
72 inline bool operator== (const Group &a) { return (bool)(mpi_group == a.mpi_group); }
73 inline bool operator!= (const Group &a) { return (bool)!(*this == a); }
74
75
76 inline Group& operator= (const MPI_Group &i) { mpi_group = i; return *this; }
77 inline operator MPI_Group () const { return mpi_group; }
78
79
80 inline MPI_Group mpi() const { return mpi_group; }
81
82 #endif
83
84
85
86
87
88 virtual int Get_size() const;
89
90 virtual int Get_rank() const;
91
92 static void Translate_ranks (const Group& group1, int n, const int ranks1[],
93 const Group& group2, int ranks2[]);
94
95 static int Compare(const Group& group1, const Group& group2);
96
97 static Group Union(const Group &group1, const Group &group2);
98
99 static Group Intersect(const Group &group1, const Group &group2);
100
101 static Group Difference(const Group &group1, const Group &group2);
102
103 virtual Group Incl(int n, const int ranks[]) const;
104
105 virtual Group Excl(int n, const int ranks[]) const;
106
107 virtual Group Range_incl(int n, const int ranges[][3]) const;
108
109 virtual Group Range_excl(int n, const int ranges[][3]) const;
110
111 virtual void Free();
112
113 protected:
114 #if ! 0
115 MPI_Group mpi_group;
116 #endif
117
118 #if 0
119 private:
120 PMPI::Group pmpi_group;
121 #endif
122
123 };
124