BEM++  2.0
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Groups Pages
auto_timer.hpp
1 // Copyright (C) 2011-2012 by the Fiber Authors
2 //
3 // Permission is hereby granted, free of charge, to any person obtaining a copy
4 // of this software and associated documentation files (the "Software"), to deal
5 // in the Software without restriction, including without limitation the rights
6 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
7 // copies of the Software, and to permit persons to whom the Software is
8 // furnished to do so, subject to the following conditions:
9 //
10 // The above copyright notice and this permission notice shall be included in
11 // all copies or substantial portions of the Software.
12 //
13 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
18 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
19 // THE SOFTWARE.
20 
21 #ifndef bempp_auto_timer_hpp
22 #define bempp_auto_timer_hpp
23 
24 #include <string>
25 #include <iostream>
26 
27 #include <tbb/tick_count.h>
28 
29 namespace Bempp
30 {
31 
34 class AutoTimer
35 {
36 public:
40  explicit AutoTimer(const char* text = 0) :
41  m_text(text), m_start(tbb::tick_count::now())
42  {}
43 
45  explicit AutoTimer(const std::string& text = std::string()) :
46  m_text(text), m_start(tbb::tick_count::now())
47  {}
48 
51  {
52  tbb::tick_count end = tbb::tick_count::now();
53  std::cout << m_text << (end - m_start).seconds() << " s" << std::endl;
54  }
55 
56 private:
57  std::string m_text;
58  tbb::tick_count m_start;
59 };
60 
61 } // namespace Bempp
62 
63 #endif
AutoTimer(const std::string &text=std::string())
Definition: auto_timer.hpp:45
AutoTimer(const char *text=0)
Constructor.
Definition: auto_timer.hpp:40
Timer that on destruction outputs the time elapsed since construction.
Definition: auto_timer.hpp:34
~AutoTimer()
Destructor. Print the previously specified message.
Definition: auto_timer.hpp:50