Scippy

UG

Ubiquity Generator framework

paraTimerMpi.h
Go to the documentation of this file.
1 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2 /* */
3 /* This file is part of the program and software framework */
4 /* UG --- Ubquity Generator Framework */
5 /* */
6 /* Copyright Written by Yuji Shinano <shinano@zib.de>, */
7 /* Copyright (C) 2021 by Zuse Institute Berlin, */
8 /* licensed under LGPL version 3 or later. */
9 /* Commercial licenses are available through <licenses@zib.de> */
10 /* */
11 /* This code is free software; you can redistribute it and/or */
12 /* modify it under the terms of the GNU Lesser General Public License */
13 /* as published by the Free Software Foundation; either version 3 */
14 /* of the License, or (at your option) any later version. */
15 /* */
16 /* This program is distributed in the hope that it will be useful, */
17 /* but WITHOUT ANY WARRANTY; without even the implied warranty of */
18 /* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the */
19 /* GNU Lesser General Public License for more details. */
20 /* */
21 /* You should have received a copy of the GNU Lesser General Public License */
22 /* along with this program. If not, see <http://www.gnu.org/licenses/>. */
23 /* */
24 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
25 
26 /**@file paraTimerMpi.h
27  * @brief ParaTimer extension for MPI timer.
28  * @author Yuji Shinano
29  *
30  *
31  *
32  */
33 
34 /*---+----1----+----2----+----3----+----4----+----5----+----6----+----7----+----8----+----9----+----0----+----1----+----2*/
35 
36 
37 #ifndef __PARA_TIMER_MPI_H__
38 #define __PARA_TIMER_MPI_H__
39 #include <mpi.h>
40 #include "paraComm.h"
41 #include "paraTimer.h"
42 
43 namespace UG
44 {
45 
46 ///
47 /// class ParaTimerMpi
48 /// (Timer used in MPI communication)
49 ///
50 class ParaTimerMpi : public ParaTimer
51 {
52 
53  double startTime; ///< satrt time
54 
55 public:
56 
57  ///
58  /// constructor
59  ///
61  )
62  {
63  startTime = MPI_Wtime();
64  }
65 
66  ///
67  /// destructor
68  ///
70  )
71  {
72  }
73 
74  ///
75  /// Initialize timer
76  ///
77  void init(
78  ParaComm *comm ///< communicator used
79  );
80 
81  ///
82  /// get elapsed time
83  /// @return elapsed time
84  ///
86  )
87  {
88  return ( MPI_Wtime() - startTime + offset );
89  }
90 
91 };
92 
93 }
94 
95 #endif // __PARA_TIMER_MPI_H__
static ScipParaCommTh * comm
Definition: fscip.cpp:73
double getElapsedTime()
get elapsed time
Definition: paraTimerMpi.h:85
double offset
offset of start time
Definition: paraTimer.h:53
Base class for Timer.
class ParaTimerMpi (Timer used in MPI communication)
Definition: paraTimerMpi.h:50
double startTime
satrt time
Definition: paraTimerMpi.h:53
Base class of communicator for UG Framework.
void init(ParaComm *comm)
Initialize timer.
~ParaTimerMpi()
destructor
Definition: paraTimerMpi.h:69
ParaTimerMpi()
constructor
Definition: paraTimerMpi.h:60
class ParaTimer
Definition: paraTimer.h:48
Base class of communicator object.
Definition: paraComm.h:101