📄 tnt_stopwatch.h
字号:
/*
*
* Mathematical and Computational Sciences Division
* National Institute of Technology,
* Gaithersburg, MD USA
*
*
* This software was developed at the National Institute of Standards and
* Technology (NIST) by employees of the Federal Government in the course
* of their official duties. Pursuant to title 17 Section 105 of the
* United States Code, this software is not subject to copyright protection
* and is in the public domain. NIST assumes no responsibility whatsoever for
* its use by other parties, and makes no guarantees, expressed or implied,
* about its quality, reliability, or any other characteristic.
*
*/
#ifndef STOPWATCH_H
#define STOPWATCH_H
// for clock() and CLOCKS_PER_SEC
#include <time.h>
namespace TNT
{
inline static double seconds(void)
{
const double secs_per_tick = 1.0 / CLOCKS_PER_SEC;
return ( (double) clock() ) * secs_per_tick;
}
/**
Performance Stopwatch used for benchmarking codes.
Measure seconds elapsed.
*/
class Stopwatch {
private:
int running_;
double start_time_;
double total_;
public:
Stopwatch();
inline void start();
inline double stop();
inline double read();
inline void resume();
inline int running();
};
/**
Create an instance of a Stopwatch, with its own internal
counter.
*/
inline
Stopwatch::Stopwatch() : running_(0), start_time_(0.0), total_(0.0) {}
/**
Start timing from 0.00.
*/
inline
void Stopwatch::start()
{
running_ = 1;
total_ = 0.0;
start_time_ = seconds();
}
/**
Stop timing and return elapsed time (in seconds).
*/
inline
double Stopwatch::stop()
{
if (running_)
{
total_ += (seconds() - start_time_);
running_ = 0;
}
return total_;
}
/**
Resume timing, if currently stopped. Operation
has no effect if Stopwatch is already running_.
*/
inline
void Stopwatch::resume()
{
if (!running_)
{
start_time_ = seconds();
running_ = 1;
}
}
/**
Read current time (in seconds).
*/
inline
double Stopwatch::read()
{
if (running_)
{
stop();
resume();
}
return total_;
}
}
#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -