source: XIOS/trunk/src/timer.cpp @ 1638

Last change on this file since 1638 was 1638, checked in by yushan, 5 years ago

dev on ADA

  • Property copyright set to
    Software name : XIOS (Xml I/O Server)
    http://forge.ipsl.jussieu.fr/ioserver
    Creation date : January 2009
    Licence : CeCCIL version2
    see license file in root directory : Licence_CeCILL_V2-en.txt
    or http://www.cecill.info/licences/Licence_CeCILL_V2-en.html
    Holder : CEA/LSCE (Laboratoire des Sciences du CLimat et de l'Environnement)
    CNRS/IPSL (Institut Pierre Simon Laplace)
    Project Manager : Yann Meurdesoif
    yann.meurdesoif@cea.fr
  • Property svn:eol-style set to native
File size: 1.4 KB
Line 
1#include "timer.hpp"
2//#include "mpi_std.hpp"
3#include "mpi.hpp"
4#include <string>
5#include <map>
6#include <iostream>
7#include <sstream>
8#include "tracer.hpp"
9//extern ::MPI_Comm MPI_COMM_WORLD;
10
11namespace xios
12{
13  std::map<std::string,CTimer> CTimer::allTimer;
14 
15  CTimer::CTimer(const std::string& name_) : name(name_) 
16  { 
17    reset();
18  }
19
20  double CTimer::getTime(void)
21  {
22    MPI_COMM_WORLD;
23    return MPI_Wtime();
24  }
25 
26  void CTimer::suspend(void)
27  {
28    if (!suspended) 
29    {
30      traceEnd(name);
31      cumulatedTime += getTime() - lastTime;
32    }
33    suspended = true;
34  }
35 
36  void CTimer::resume(void)
37  {
38    if (suspended) 
39    {
40      lastTime = getTime();
41      traceBegin(name);
42    }
43    suspended = false;
44  }
45 
46  void CTimer::reset(void)
47  {
48    cumulatedTime = 0.;
49    suspended = true;
50  }
51 
52  double CTimer::getCumulatedTime(void)
53  {
54    return cumulatedTime;
55  }
56 
57  CTimer& CTimer::get(const std::string name)
58  {
59    std::map<std::string,CTimer>::iterator it = allTimer.find(name);
60    if (it == allTimer.end())
61      it = allTimer.insert(std::make_pair(name, CTimer(name))).first;
62    return it->second;
63  }
64
65  string CTimer::getAllCumulatedTime(void)
66  {
67    std::ostringstream strOut ;
68    for(std::map<std::string,CTimer>::iterator it=allTimer.begin();it!=allTimer.end();++it)
69      strOut<<"Timer : "<<it->first<<"    -->   cumulated time : "<<it->second.getCumulatedTime()<<std::endl ;
70    return strOut.str() ;
71  }
72}
Note: See TracBrowser for help on using the repository browser.