2012-04-30 14:24:11 +00:00
|
|
|
/*
|
2008-04-16 22:40:48 +00:00
|
|
|
* ***** BEGIN GPL LICENSE BLOCK *****
|
2002-10-12 11:37:38 +00:00
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
2008-04-16 22:40:48 +00:00
|
|
|
* of the License, or (at your option) any later version.
|
2002-10-12 11:37:38 +00:00
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software Foundation,
|
2010-02-12 13:34:04 +00:00
|
|
|
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
2002-10-12 11:37:38 +00:00
|
|
|
*
|
|
|
|
* The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* The Original Code is: all of this file.
|
|
|
|
*
|
2012-11-09 08:28:14 +00:00
|
|
|
* Contributor(s): Campbell Barton
|
2002-10-12 11:37:38 +00:00
|
|
|
*
|
2008-04-16 22:40:48 +00:00
|
|
|
* ***** END GPL LICENSE BLOCK *****
|
2002-10-12 11:37:38 +00:00
|
|
|
*/
|
2011-02-27 20:37:56 +00:00
|
|
|
|
|
|
|
/** \file blender/blenlib/PIL_time.h
|
|
|
|
* \ingroup bli
|
2012-04-30 14:24:11 +00:00
|
|
|
* \brief Platform independent time functions.
|
2011-02-27 20:37:56 +00:00
|
|
|
*/
|
|
|
|
|
2012-02-17 18:59:41 +00:00
|
|
|
#ifndef __PIL_TIME_H__
|
|
|
|
#define __PIL_TIME_H__
|
2002-10-12 11:37:38 +00:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
extern
|
2012-05-12 20:39:39 +00:00
|
|
|
/** Return an indication of time, expressed as
|
|
|
|
* seconds since some fixed point. Successive calls
|
|
|
|
* are guaranteed to generate values greater than or
|
|
|
|
* equal to the last call.
|
|
|
|
*/
|
|
|
|
double PIL_check_seconds_timer(void);
|
2002-10-12 11:37:38 +00:00
|
|
|
|
2012-05-12 20:39:39 +00:00
|
|
|
/**
|
|
|
|
* Platform-independent sleep function.
|
|
|
|
* \param ms Number of milliseconds to sleep
|
|
|
|
*/
|
|
|
|
void PIL_sleep_ms(int ms);
|
2002-10-12 11:37:38 +00:00
|
|
|
|
2011-03-05 04:35:36 +00:00
|
|
|
/** Utility defines for timing.
|
|
|
|
* requires BLI_utildefines.h for 'AT'
|
|
|
|
* TIMEIT_VALUE returns the time since TIMEIT_START was called.
|
|
|
|
*/
|
2012-05-12 20:39:39 +00:00
|
|
|
#define TIMEIT_START(var) \
|
|
|
|
{ \
|
|
|
|
double _timeit_##var = PIL_check_seconds_timer(); \
|
|
|
|
printf("time start (" #var "): " AT "\n"); \
|
|
|
|
fflush(stdout); \
|
2012-10-20 10:37:15 +00:00
|
|
|
{ (void)0
|
2011-03-05 04:35:36 +00:00
|
|
|
|
|
|
|
#define TIMEIT_VALUE(var) (float)(PIL_check_seconds_timer() - _timeit_##var)
|
|
|
|
|
2012-10-20 10:37:15 +00:00
|
|
|
#define TIMEIT_VALUE_PRINT(var) \
|
|
|
|
{ \
|
|
|
|
printf("time update(" #var "): %.6f" " " AT "\n", TIMEIT_VALUE(var));\
|
|
|
|
fflush(stdout); \
|
|
|
|
} (void)0
|
2011-03-05 04:35:36 +00:00
|
|
|
|
2012-05-12 20:39:39 +00:00
|
|
|
#define TIMEIT_END(var) \
|
|
|
|
} \
|
2012-10-20 10:37:15 +00:00
|
|
|
printf("time end (" #var "): %.6f" " " AT "\n", TIMEIT_VALUE(var)); \
|
2012-05-12 20:39:39 +00:00
|
|
|
fflush(stdout); \
|
2012-10-20 10:37:15 +00:00
|
|
|
} (void)0
|
2011-03-05 04:35:36 +00:00
|
|
|
|
2012-11-09 08:28:14 +00:00
|
|
|
/**
|
|
|
|
* Given some function/expression:
|
|
|
|
* TIMEIT_BENCH(some_function(), some_unique_description);
|
|
|
|
*/
|
2012-11-09 04:01:19 +00:00
|
|
|
#define TIMEIT_BENCH(expr, id) \
|
|
|
|
{ \
|
|
|
|
TIMEIT_START(id); \
|
|
|
|
(expr); \
|
|
|
|
TIMEIT_END(id); \
|
|
|
|
} (void)0
|
|
|
|
|
2013-08-19 10:16:23 +00:00
|
|
|
#define TIMEIT_BLOCK_INIT(what) \
|
|
|
|
double _timeit_var_##what = 0; \
|
|
|
|
(void) 0
|
|
|
|
|
|
|
|
#define TIMEIT_BLOCK_BEGIN(what) \
|
|
|
|
{ \
|
|
|
|
double _timeit_block_start_##what = PIL_check_seconds_timer(); \
|
|
|
|
{ (void)0
|
|
|
|
|
|
|
|
#define TIMEIT_BLOCK_END(what) \
|
|
|
|
} \
|
|
|
|
_timeit_var_##what += PIL_check_seconds_timer() - _timeit_block_start_##what; \
|
|
|
|
} (void)0
|
|
|
|
|
|
|
|
#define TIMEIT_BLOCK_STATS(what) \
|
|
|
|
{ \
|
|
|
|
printf("%s time (in seconds): %f\n", #what, _timeit_var_##what); \
|
|
|
|
fflush(stdout); \
|
|
|
|
} (void)0
|
|
|
|
|
2002-10-12 11:37:38 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2012-10-20 10:37:15 +00:00
|
|
|
#endif /* !__PIL_TIME_H__ */
|