![]() |
Mesh Oriented datABase
(version 5.4.1)
Array-based unstructured mesh datastructure
|
00001 #ifndef CPUTIMER_HPP
00002 #define CPUTIMER_HPP
00003
00004 #include "moab/MOABConfig.h"
00005 #ifdef MOAB_HAVE_MPI
00006 #include "moab_mpi.h"
00007 #endif
00008
00009 #include
00010
00011 namespace moab
00012 {
00013
00014 class CpuTimer
00015 {
00016 private:
00017 #ifdef MOAB_HAVE_MPI
00018 int mpi_initialized;
00019 #endif
00020 double tAtBirth, tAtLast;
00021 double runtime();
00022
00023 public:
00024 CpuTimer()
00025 #ifdef MOAB_HAVE_MPI
00026 : mpi_initialized( 0 )
00027 #endif
00028 {
00029 #ifdef MOAB_HAVE_MPI
00030 int flag = 0;
00031 if( MPI_SUCCESS == MPI_Initialized( &flag ) && flag )
00032 {
00033 mpi_initialized = 1;
00034 }
00035 #endif
00036 tAtBirth = runtime();
00037 tAtLast = tAtBirth;
00038 }
00039 double time_since_birth()
00040 {
00041 return ( tAtLast = runtime() ) - tAtBirth;
00042 };
00043 double time_elapsed()
00044 {
00045 double tmp = tAtLast;
00046 return ( tAtLast = runtime() ) - tmp;
00047 }
00048 };
00049
00050 inline double CpuTimer::runtime()
00051 {
00052 #ifdef MOAB_HAVE_MPI
00053 if( mpi_initialized )
00054 return MPI_Wtime();
00055 else
00056 return (double)clock() / CLOCKS_PER_SEC;
00057 #else
00058 return (double)clock() / CLOCKS_PER_SEC;
00059 #endif
00060 }
00061 } // namespace moab
00062
00063 #endif