1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
-
-
-
-
-
-
- #ifndef TIMER_H_INC
- #define TIMER_H_INC
-
- #include <iostream>
- #include <fstream>
- #include <ctime>
- #ifdef LEMMAUSEOMP
- #include "omp.h"
- #endif
-
- #include "lemma.h"
-
- namespace Lemma {
-
-
- class jsw_timer {
-
- public:
-
-
-
- jsw_timer(): start ( std::clock() ), elapsed ( 0.0 ) {
-
- }
-
-
-
- void begin() {
- #ifdef LEMMAUSEOMP
- start = omp_get_wtime();
- #else
- start = std::clock();
- #endif
- elapsed = 0.0;
- }
-
-
-
- Real end() {
-
- #ifdef LEMMAUSEOMP
- elapsed = static_cast<Real> (omp_get_wtime()) - start;
- return elapsed;
- #else
- elapsed = static_cast<Real> ( std::clock() ) - start;
- return elapsed /= CLOCKS_PER_SEC;
- #endif
-
- }
-
-
-
- Real last() const { return elapsed; }
-
- private:
- #ifdef LEMMAUSEOMP
- Real start;
- #else
- std::clock_t start;
- #endif
- Real elapsed;
- };
-
- }
-
- #endif
|