2012-03-22 01:36:20 +08:00
|
|
|
/* -*-c++-*- OpenSceneGraph - Copyright (C) 1998-2006 Robert Osfield
|
2003-01-22 00:45:36 +08:00
|
|
|
*
|
2012-03-22 01:36:20 +08:00
|
|
|
* This library is open source and may be redistributed and/or modified under
|
|
|
|
* the terms of the OpenSceneGraph Public License (OSGPL) version 0.0 or
|
2003-01-22 00:45:36 +08:00
|
|
|
* (at your option) any later version. The full license is in LICENSE file
|
|
|
|
* included with this distribution, and on the openscenegraph.org website.
|
2012-03-22 01:36:20 +08:00
|
|
|
*
|
2003-01-22 00:45:36 +08:00
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2012-03-22 01:36:20 +08:00
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
2003-01-22 00:45:36 +08:00
|
|
|
* OpenSceneGraph Public License for more details.
|
|
|
|
*/
|
2001-10-04 23:12:57 +08:00
|
|
|
|
2001-01-11 00:32:10 +08:00
|
|
|
#ifndef OSG_TIMER
|
|
|
|
#define OSG_TIMER 1
|
|
|
|
|
|
|
|
#include <osg/Export>
|
|
|
|
|
2005-02-25 16:38:05 +08:00
|
|
|
namespace osg {
|
2001-09-20 05:08:56 +08:00
|
|
|
|
2020-07-18 00:01:05 +08:00
|
|
|
#if defined(_MSC_VER) && !defined(__clang__)
|
2018-05-23 13:32:42 +08:00
|
|
|
typedef unsigned __int64 Timer_t;
|
2001-01-11 00:32:10 +08:00
|
|
|
#else
|
2005-02-25 16:38:05 +08:00
|
|
|
typedef unsigned long long Timer_t;
|
2001-01-11 00:32:10 +08:00
|
|
|
#endif
|
|
|
|
|
2006-12-27 01:37:06 +08:00
|
|
|
/** Timer class is used for measuring elapsed time or time between two points. */
|
2005-04-12 01:14:17 +08:00
|
|
|
class OSG_EXPORT Timer {
|
2001-01-11 00:32:10 +08:00
|
|
|
|
|
|
|
public:
|
|
|
|
|
2001-09-22 10:42:08 +08:00
|
|
|
Timer();
|
|
|
|
~Timer() {}
|
|
|
|
|
2006-12-27 01:37:06 +08:00
|
|
|
static Timer* instance();
|
2003-07-16 05:19:03 +08:00
|
|
|
|
2006-12-27 01:37:06 +08:00
|
|
|
/** Get the timers tick value.*/
|
2005-02-25 16:38:05 +08:00
|
|
|
Timer_t tick() const;
|
2006-12-27 01:37:06 +08:00
|
|
|
|
|
|
|
/** Set the start.*/
|
|
|
|
void setStartTick() { _startTick = tick(); }
|
|
|
|
void setStartTick(Timer_t t) { _startTick = t; }
|
|
|
|
Timer_t getStartTick() const { return _startTick; }
|
|
|
|
|
2012-03-22 01:36:20 +08:00
|
|
|
|
2006-12-27 01:37:06 +08:00
|
|
|
/** Get elapsed time in seconds.*/
|
|
|
|
inline double time_s() const { return delta_s(_startTick, tick()); }
|
|
|
|
|
|
|
|
/** Get elapsed time in milliseconds.*/
|
|
|
|
inline double time_m() const { return delta_m(_startTick, tick()); }
|
|
|
|
|
2010-09-24 22:53:10 +08:00
|
|
|
/** Get elapsed time in microseconds.*/
|
2006-12-27 01:37:06 +08:00
|
|
|
inline double time_u() const { return delta_u(_startTick, tick()); }
|
|
|
|
|
|
|
|
/** Get elapsed time in nanoseconds.*/
|
|
|
|
inline double time_n() const { return delta_n(_startTick, tick()); }
|
2012-03-22 01:36:20 +08:00
|
|
|
|
2006-12-27 01:37:06 +08:00
|
|
|
/** Get the time in seconds between timer ticks t1 and t2.*/
|
2017-08-23 22:26:07 +08:00
|
|
|
inline double delta_s( Timer_t t1, Timer_t t2 ) const { return (t2>t1) ? (double)(t2 - t1)*_secsPerTick : -(double)(t1 - t2)*_secsPerTick; }
|
2006-12-27 01:37:06 +08:00
|
|
|
|
|
|
|
/** Get the time in milliseconds between timer ticks t1 and t2.*/
|
2001-09-22 10:42:08 +08:00
|
|
|
inline double delta_m( Timer_t t1, Timer_t t2 ) const { return delta_s(t1,t2)*1e3; }
|
2006-12-27 01:37:06 +08:00
|
|
|
|
|
|
|
/** Get the time in microseconds between timer ticks t1 and t2.*/
|
2001-09-22 10:42:08 +08:00
|
|
|
inline double delta_u( Timer_t t1, Timer_t t2 ) const { return delta_s(t1,t2)*1e6; }
|
2006-12-27 01:37:06 +08:00
|
|
|
|
|
|
|
/** Get the time in nanoseconds between timer ticks t1 and t2.*/
|
2001-09-22 10:42:08 +08:00
|
|
|
inline double delta_n( Timer_t t1, Timer_t t2 ) const { return delta_s(t1,t2)*1e9; }
|
2012-03-22 01:36:20 +08:00
|
|
|
|
2015-06-01 21:11:49 +08:00
|
|
|
/** Get the number of seconds per tick. */
|
2003-08-20 20:51:40 +08:00
|
|
|
inline double getSecondsPerTick() const { return _secsPerTick; }
|
2001-09-22 10:42:08 +08:00
|
|
|
|
2003-08-18 23:14:09 +08:00
|
|
|
protected :
|
2001-09-22 10:42:08 +08:00
|
|
|
|
2006-12-27 01:37:06 +08:00
|
|
|
Timer_t _startTick;
|
|
|
|
double _secsPerTick;
|
2009-09-26 02:05:54 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
/** Helper class for timing sections of code. */
|
|
|
|
class ElapsedTime
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
inline ElapsedTime(double* elapsedTime, osg::Timer* timer = 0):
|
|
|
|
_time(elapsedTime)
|
|
|
|
{
|
|
|
|
init(timer);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline ElapsedTime(osg::Timer* timer = 0):
|
|
|
|
_time(0)
|
|
|
|
{
|
|
|
|
init(timer);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline ~ElapsedTime()
|
|
|
|
{
|
|
|
|
finish();
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void reset()
|
|
|
|
{
|
|
|
|
_startTick = _timer->tick();
|
|
|
|
}
|
|
|
|
|
2010-02-10 01:38:02 +08:00
|
|
|
/** elapsed time in seconds. */
|
2009-09-26 02:05:54 +08:00
|
|
|
inline double elapsedTime() const
|
|
|
|
{
|
|
|
|
return _timer->delta_s(_startTick, _timer->tick());
|
|
|
|
}
|
|
|
|
|
2010-02-10 01:38:02 +08:00
|
|
|
/** elapsed time in milliseconds. */
|
|
|
|
inline double elapsedTime_m() const
|
|
|
|
{
|
|
|
|
return _timer->delta_m(_startTick, _timer->tick());
|
|
|
|
}
|
|
|
|
|
|
|
|
/** elapsed time in microseconds. */
|
|
|
|
inline double elapsedTime_u() const
|
|
|
|
{
|
|
|
|
return _timer->delta_u(_startTick, _timer->tick());
|
|
|
|
}
|
|
|
|
|
|
|
|
/** elapsed time in nanoseconds. */
|
|
|
|
inline double elapsedTime_n() const
|
|
|
|
{
|
|
|
|
return _timer->delta_n(_startTick, _timer->tick());
|
|
|
|
}
|
|
|
|
|
2009-09-26 02:05:54 +08:00
|
|
|
inline void finish()
|
|
|
|
{
|
|
|
|
Timer_t endTick = _timer->tick();
|
|
|
|
if (_time) *_time += _timer->delta_s(_startTick, endTick);
|
|
|
|
_startTick = endTick;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
inline void init(osg::Timer* timer)
|
|
|
|
{
|
|
|
|
if (timer) _timer = timer;
|
|
|
|
else _timer = osg::Timer::instance();
|
|
|
|
|
|
|
|
_startTick = _timer->tick();
|
|
|
|
}
|
|
|
|
|
|
|
|
double* _time;
|
|
|
|
Timer* _timer;
|
|
|
|
Timer_t _startTick;
|
2001-01-11 00:32:10 +08:00
|
|
|
|
2005-02-25 16:38:05 +08:00
|
|
|
};
|
2004-11-14 06:04:26 +08:00
|
|
|
|
|
|
|
}
|
2001-01-11 00:32:10 +08:00
|
|
|
#endif
|