source:
src/benchmark/bench.h@
5f95b5f
      
      | Last change on this file since 5f95b5f was 0cf5b79, checked in by , 8 years ago | |
|---|---|
| 
 | |
| File size: 997 bytes | |
| Rev | Line | |
|---|---|---|
| [8cb6fcd] | 1 | #pragma once | 
| 2 | ||
| [0cf5b79] | 3 | #if defined(__cforall) | 
| [8cb6fcd] | 4 | extern "C" { | 
| [d67cdb7] | 5 | #endif | 
| [034165a] | 6 | #include <stdlib.h> | 
| [8cb6fcd] | 7 | #include <unistd.h> // sysconf | 
| 8 | #include <sys/times.h> // times | |
| 9 | #include <time.h> | |
| [0cf5b79] | 10 | #if defined(__cforall) | 
| [8cb6fcd] | 11 | } | 
| [d67cdb7] | 12 | #endif | 
| [8cb6fcd] | 13 | |
| [d67cdb7] | 14 | static inline unsigned long long int Time() { | 
| 15 | struct timespec ts; | |
| [8cb6fcd] | 16 | clock_gettime( | 
| 17 | #if defined( __linux__ ) | |
| 18 | CLOCK_THREAD_CPUTIME_ID, | |
| 19 | #elif defined( __freebsd__ ) | |
| 20 | CLOCK_PROF, | |
| 21 | #elif defined( __solaris__ ) | |
| 22 | CLOCK_HIGHRES, | |
| 23 | #else | |
| 24 | #error uC++ : internal error, unsupported architecture | |
| 25 | #endif | |
| 26 | &ts ); | |
| 27 | return 1000000000LL * ts.tv_sec + ts.tv_nsec; | |
| 28 | } // Time | |
| 29 | ||
| [034165a] | 30 | #ifndef BENCH_N | 
| 31 | #define BENCH_N 500 //10000000 | |
| [7286a40] | 32 | #endif | 
| 33 | ||
| [034165a] | 34 | #define BENCH(statement, output) \ | 
| [b7170a64] | 35 | size_t n = BENCH_N; \ | 
| 36 | if( argc > 2 ) return 1; \ | |
| 37 | if( argc == 2 ) { \ | |
| 38 | n = atoi(argv[1]); \ | |
| 39 | } \ | |
| [034165a] | 40 | long long int StartTime, EndTime; \ | 
| [b7170a64] | 41 | StartTime = Time(); \ | 
| 42 | statement; \ | |
| 43 | EndTime = Time(); \ | |
| [034165a] | 44 | unsigned long long int output = \ | 
| [b7170a64] | 45 | ( EndTime - StartTime ) / n; | 
| [034165a] | 46 | |
| [7286a40] | 47 | unsigned int default_preemption() { | 
| 48 | return 0; | |
| 49 | } | 
  Note:
 See   TracBrowser
 for help on using the repository browser.
    