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-2024 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
43namespace UG
44{
45
46///
47/// class ParaTimerMpi
48/// (Timer used in MPI communication)
49///
50class ParaTimerMpi : public ParaTimer
51{
52
53 double startTime; ///< satrt time
54
55public:
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__
Base class of communicator object.
Definition: paraComm.h:102
class ParaTimerMpi (Timer used in MPI communication)
Definition: paraTimerMpi.h:51
double startTime
satrt time
Definition: paraTimerMpi.h:53
double getElapsedTime()
get elapsed time
Definition: paraTimerMpi.h:85
ParaTimerMpi()
constructor
Definition: paraTimerMpi.h:60
void init(ParaComm *comm)
Initialize timer.
~ParaTimerMpi()
destructor
Definition: paraTimerMpi.h:69
class ParaTimer
Definition: paraTimer.h:49
double offset
offset of start time
Definition: paraTimer.h:53
static ScipParaCommTh * comm
Definition: fscip.cpp:73
Base class of communicator for UG Framework.
Base class for Timer.