source: XIOS/dev/branch_yushan/src/timer.cpp @ 1103

Last change on this file since 1103 was 1103, checked in by yushan, 7 years ago

save modif. Todo: axis, domain, mesh, scalar, transformation

  • 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.hpp"
3#include <string>
4#include <map>
5#include "tracer.hpp"
6
7namespace xios
8{
9  std::map<std::string,CTimer> CTimer::allTimer;
10  std::map<std::string,CTimer> *CTimer::allTimer_ptr = 0;
11 
12  CTimer::CTimer(const std::string& name_) : name(name_) 
13  { 
14    reset();
15  }
16
17  double CTimer::getTime(void)
18  {
19    return MPI_Wtime();
20  }
21 
22  void CTimer::suspend(void)
23  {
24    if (!suspended) 
25    {
26      traceEnd(name);
27      cumulatedTime += getTime() - lastTime;
28    }
29    suspended = true;
30  }
31 
32  void CTimer::resume(void)
33  {
34    if (suspended) 
35    {
36      lastTime = getTime();
37      traceBegin(name);
38    }
39    suspended = false;
40  }
41 
42  void CTimer::reset(void)
43  {
44    cumulatedTime = 0.;
45    suspended = true;
46  }
47 
48  double CTimer::getCumulatedTime(void)
49  {
50    return cumulatedTime;
51  }
52 
53  CTimer& CTimer::get(const std::string name)
54  {
55    // bkp
56    // std::map<std::string,CTimer>::iterator it = allTimer.find(name);
57    // if (it == allTimer.end())
58    //   it = allTimer.insert(std::make_pair(name, CTimer(name))).first;
59    // return it->second;
60
61    if(allTimer_ptr == NULL) allTimer_ptr = new std::map<std::string,CTimer>;
62
63    std::map<std::string,CTimer>::iterator it = (*allTimer_ptr).find(name);
64    if (it == (*allTimer_ptr).end())
65      it = (*allTimer_ptr).insert(std::make_pair(name, CTimer(name))).first;
66    return it->second;
67  }
68}
Note: See TracBrowser for help on using the repository browser.