JKQtPlotter/lib/jkqtplottertools/jkqtphighrestimer.cpp
jkriege2 69ad2a0182 - added styling system for JKQTPlotter (+example app)
- improved documentation
- changed: using static const variables instead of \c #define for fixed default values (e.g. JKQTPImageTools::LUTSIZE, JKQTPImageTools::PALETTE_ICON_WIDTH, JKQTPlotterDrawinTools::ABS_MIN_LINEWIDTH, JKQTMathText::ABS_MIN_LINEWIDTH ...)
- new: added debugging option, which surrounds different regions with visible rectangles (JKQTBasePlotter::enableDebugShowRegionBoxes() )
- fixed: colorbars at top were positioned over the plot label
- new: frames (plot viewport, key/legend ...) may be rounded off at the corners
- new: diverse new styling options (default font name/size ...)
- speed improvements to JKQTMathText::useSTIX()
2019-02-09 12:43:12 +01:00

115 lines
3.3 KiB
C++

/*
Copyright (c) 2008-2015 Jan W. Krieger (<jan@jkrieger.de>, <j.krieger@dkfz.de>) (DKFZ) & IWR, University of Heidelberg
last modification: $LastChangedDate: 2015-06-10 19:19:10 +0200 (Mi, 10 Jun 2015) $ (revision $Rev: 3976 $)
This software is free software: you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License (LGPL) as published by
the Free Software Foundation, either version 2.1 of the License, or
(at your option) any later version.
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 Lesser General Public License (LGPL) for more details.
You should have received a copy of the GNU Lesser General Public License (LGPL)
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
/*
Name: jkqtphighrestimer.cpp
Copyright: (c) 2007
Author: Jan krieger <jan@jkrieger.de>, http://www.jkrieger.de/
*/
#include "jkqtphighrestimer.h" // class's header file
JKQTPHighResTimer::JKQTPHighResTimer() {
start();
}
JKQTPHighResTimer::~JKQTPHighResTimer() = default;
void JKQTPHighResTimer::start(){
#ifdef __LINUX__
#endif
#ifdef __WINDOWS__
LARGE_INTEGER fr;
QueryPerformanceFrequency(&fr);
freq=static_cast<double>(fr.QuadPart);
QueryPerformanceCounter(&last);
#else
gettimeofday(&last,0);
#endif
};
double JKQTPHighResTimer::getTime(){
#ifdef __LINUX__
#endif
#ifdef __WINDOWS__
LARGE_INTEGER now;
QueryPerformanceCounter(&now);
return (static_cast<double>(now.QuadPart-last.QuadPart)/freq)*1e6;
#else
struct timeval tv;
gettimeofday(&tv,0);
int t1, t2;
t1 = last.tv_sec * 1000000 + last.tv_usec;
t2 = tv.tv_sec * 1000000 + tv.tv_usec;
return abs(t2 - t1);
#endif
};
void JKQTPHighResTimer::test(double* mean, double* stddev, unsigned long* histogram, double* histogram_x, unsigned long histogram_size){
unsigned long runs=1000000;
double* h=static_cast<double*>(malloc(runs*sizeof(double)));
*mean = 0;
*stddev = 0;
/* time measurement */
double l=getTime(), n;
for (unsigned long i=0; i<runs; i++) {
n=getTime();
h[i]=n-l;
l=n;
//printf("%lf\n",h[i]);
}
/* end measurement */
/* compute mean value */
double mymin=h[0];
double mymax=h[0];
for (unsigned long i=1; i<runs; i++) {
*mean+=h[i]/(runs-1);
if (h[i]>mymax) mymax=h[i];
if (h[i]<mymin) mymin=h[i];
}
//printf("%lf %lf\n", mymin, mymax);
double binwidth=0;
if (histogram_size>0) {
binwidth=(mymax-mymin)/(histogram_size-1);
for (unsigned int i=0; i<histogram_size; i++) {
histogram[i]=0;
histogram_x[i]=mymin+i*binwidth;
}
}
/* compute standard deviation */
for (unsigned long i=1; i<runs; i++) {
(*stddev)=(*stddev)+(static_cast<double>(h[i])-*mean)*(static_cast<double>(h[i])-*mean)/static_cast<double>(runs-2);
if (histogram_size>0) {
unsigned long bin=(unsigned int)floor((h[i]-mymin)/binwidth);
if (/*bin>=0 &&*/ bin<histogram_size) histogram[bin]++;
}
}
*stddev=sqrt(*stddev);
free(h);
};