allReduce.H
Go to the documentation of this file.
1 /*---------------------------------------------------------------------------*\
2  ========= |
3  \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
4  \\ / O peration |
5  \\ / A nd | www.openfoam.com
6  \\/ M anipulation |
7 -------------------------------------------------------------------------------
8  Copyright (C) 2012-2016 OpenFOAM Foundation
9 -------------------------------------------------------------------------------
10 License
11  This file is part of OpenFOAM.
12 
13  OpenFOAM is free software: you can redistribute it and/or modify it
14  under the terms of the GNU General Public License as published by
15  the Free Software Foundation, either version 3 of the License, or
16  (at your option) any later version.
17 
18  OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
19  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
20  FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
21  for more details.
22 
23  You should have received a copy of the GNU General Public License
24  along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
25 
26 InNamespace
27  Foam
28 
29 Description
30  Various functions to wrap MPI_Allreduce
31 
32 SourceFiles
33  allReduceTemplates.C
34 
35 \*---------------------------------------------------------------------------*/
36 
37 #ifndef allReduce_H
38 #define allReduce_H
39 
40 #include "UPstream.H"
41 
42 #include <mpi.h>
43 
44 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
45 
46 namespace Foam
47 {
48 
49 template<class Type, class BinaryOp>
50 void allReduce
51 (
52  Type& Value,
53  int count,
54  MPI_Datatype MPIType,
55  MPI_Op op,
56  const BinaryOp& bop,
57  const int tag,
58  const label communicator
59 );
60 
61 template<class Type>
62 void iallReduce
63 (
64  void* Value,
65  int count,
66  MPI_Datatype MPIType,
67  MPI_Op op,
68  const label communicator,
69  label& requestID
70 );
71 
72 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
73 
74 } // End namespace Foam
75 
76 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
77 
78 #ifdef NoRepository
79  #include "allReduceTemplates.C"
80 #endif
81 
82 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
83 
84 #endif
85 
86 // ************************************************************************* //
UPstream.H
Foam::iallReduce
void iallReduce(void *Value, int count, MPI_Datatype MPIType, MPI_Op op, const label communicator, label &requestID)
Definition: allReduceTemplates.C:171
Foam::allReduce
void allReduce(Type &Value, int count, MPI_Datatype MPIType, MPI_Op op, const BinaryOp &bop, const int tag, const label communicator)
Definition: allReduceTemplates.C:36
Foam
Namespace for OpenFOAM.
Definition: atmBoundaryLayer.C:33
allReduceTemplates.C
Foam::BitOps::count
unsigned int count(const UList< bool > &bools, const bool val=true)
Count number of 'true' entries.
Definition: BitOps.H:77