mirror of
https://github.com/swift-project/pilotclient.git
synced 2026-04-26 02:35:38 +08:00
Ref T570 Measure sortHint using true CPU time routines.
This commit is contained in:
76
src/blackmisc/cputime.cpp
Normal file
76
src/blackmisc/cputime.cpp
Normal file
@@ -0,0 +1,76 @@
|
|||||||
|
/* Copyright (C) 2019
|
||||||
|
* swift Project Community / Contributors
|
||||||
|
*
|
||||||
|
* This file is part of swift project. It is subject to the license terms in the LICENSE file found in the top-level
|
||||||
|
* directory of this distribution. No part of swift project, including this file, may be copied, modified, propagated,
|
||||||
|
* or distributed except according to the terms contained in the LICENSE file.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "blackmisc/cputime.h"
|
||||||
|
#include <QtGlobal>
|
||||||
|
|
||||||
|
#if defined(Q_OS_WIN32)
|
||||||
|
#include <windows.h>
|
||||||
|
#elif defined(Q_OS_UNIX)
|
||||||
|
#include <time.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
namespace BlackMisc
|
||||||
|
{
|
||||||
|
|
||||||
|
#if defined(Q_OS_WIN32)
|
||||||
|
|
||||||
|
static int getCpuTimeMs(const FILETIME &kernelTime, const FILETIME &userTime)
|
||||||
|
{
|
||||||
|
const ULARGE_INTEGER kernel { { kernelTime.dwLowDateTime, kernelTime.dwHighDateTime } };
|
||||||
|
const ULARGE_INTEGER user { { userTime.dwLowDateTime, userTime.dwHighDateTime } };
|
||||||
|
const quint64 usecs = (kernel.QuadPart + user.QuadPart) / 10ull;
|
||||||
|
return static_cast<int>(usecs / 1000ull);
|
||||||
|
}
|
||||||
|
int getProcessCpuTimeMs()
|
||||||
|
{
|
||||||
|
FILETIME creationTime, exitTime, kernelTime, userTime;
|
||||||
|
GetProcessTimes(GetCurrentProcess(), &creationTime, &exitTime, &kernelTime, &userTime);
|
||||||
|
return getCpuTimeMs(kernelTime, userTime);
|
||||||
|
}
|
||||||
|
int getThreadCpuTimeMs()
|
||||||
|
{
|
||||||
|
FILETIME creationTime, exitTime, kernelTime, userTime;
|
||||||
|
GetThreadTimes(GetCurrentThread(), &creationTime, &exitTime, &kernelTime, &userTime);
|
||||||
|
return getCpuTimeMs(kernelTime, userTime);
|
||||||
|
}
|
||||||
|
|
||||||
|
#elif defined(Q_OS_UNIX)
|
||||||
|
|
||||||
|
static int getCpuTimeMs(const timespec &ts)
|
||||||
|
{
|
||||||
|
const double secs = static_cast<double>(ts.tv_sec) + static_cast<double>(ts.tv_nsec) / 1e9;
|
||||||
|
return static_cast<int>(secs * 1000);
|
||||||
|
}
|
||||||
|
int getProcessCpuTimeMs()
|
||||||
|
{
|
||||||
|
timespec ts {};
|
||||||
|
clock_gettime(CLOCK_PROCESS_CPUTIME_ID, &ts);
|
||||||
|
return getCpuTimeMs(ts);
|
||||||
|
}
|
||||||
|
int getThreadCpuTimeMs()
|
||||||
|
{
|
||||||
|
timespec ts {};
|
||||||
|
clock_gettime(CLOCK_THREAD_CPUTIME_ID, &ts);
|
||||||
|
return getCpuTimeMs(ts);
|
||||||
|
}
|
||||||
|
|
||||||
|
#else // Q_OS_UNIX
|
||||||
|
|
||||||
|
int getProcessCpuTimeMs()
|
||||||
|
{
|
||||||
|
return 0; // not implemented
|
||||||
|
}
|
||||||
|
int getThreadCpuTimeMs()
|
||||||
|
{
|
||||||
|
return 0; // not implemented
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
}
|
||||||
30
src/blackmisc/cputime.h
Normal file
30
src/blackmisc/cputime.h
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
/* Copyright (C) 2019
|
||||||
|
* swift Project Community / Contributors
|
||||||
|
*
|
||||||
|
* This file is part of swift project. It is subject to the license terms in the LICENSE file found in the top-level
|
||||||
|
* directory of this distribution. No part of swift project, including this file, may be copied, modified, propagated,
|
||||||
|
* or distributed except according to the terms contained in the LICENSE file.
|
||||||
|
*/
|
||||||
|
|
||||||
|
//! \file
|
||||||
|
|
||||||
|
#ifndef BLACKMISC_CPUTIME_H
|
||||||
|
#define BLACKMISC_CPUTIME_H
|
||||||
|
|
||||||
|
#include "blackmisc/blackmiscexport.h"
|
||||||
|
|
||||||
|
namespace BlackMisc
|
||||||
|
{
|
||||||
|
/*!
|
||||||
|
* Get the time in milliseconds that the CPU has spent executing the current process.
|
||||||
|
* This is the sum of getThreadCpuTimeMs() for all threads.
|
||||||
|
*/
|
||||||
|
BLACKMISC_EXPORT int getProcessCpuTimeMs();
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Get the time in milliseconds that the CPU has spent executing the current thread.
|
||||||
|
*/
|
||||||
|
BLACKMISC_EXPORT int getThreadCpuTimeMs();
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
@@ -14,6 +14,7 @@
|
|||||||
#include "blackmisc/aviation/aircraftsituationchange.h"
|
#include "blackmisc/aviation/aircraftsituationchange.h"
|
||||||
#include "blackmisc/aviation/aircraftsituationlist.h"
|
#include "blackmisc/aviation/aircraftsituationlist.h"
|
||||||
#include "blackmisc/network/fsdsetup.h"
|
#include "blackmisc/network/fsdsetup.h"
|
||||||
|
#include "blackmisc/cputime.h"
|
||||||
// #include "blackmisc/math/mathutils.h"
|
// #include "blackmisc/math/mathutils.h"
|
||||||
// #include "blackmisc/stringutils.h"
|
// #include "blackmisc/stringutils.h"
|
||||||
#include "test.h"
|
#include "test.h"
|
||||||
@@ -244,6 +245,7 @@ namespace BlackMiscTest
|
|||||||
}
|
}
|
||||||
|
|
||||||
QTime time;
|
QTime time;
|
||||||
|
int cpuTime = getThreadCpuTimeMs();
|
||||||
time.start();
|
time.start();
|
||||||
for (int i = 0; i < Loops; ++i)
|
for (int i = 0; i < Loops; ++i)
|
||||||
{
|
{
|
||||||
@@ -254,8 +256,9 @@ namespace BlackMiscTest
|
|||||||
QVERIFY(s1.getAdjustedMSecsSinceEpoch() < s2.getAdjustedMSecsSinceEpoch());
|
QVERIFY(s1.getAdjustedMSecsSinceEpoch() < s2.getAdjustedMSecsSinceEpoch());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
const int noHint = time.elapsed();
|
const auto noHint = std::make_pair(time.elapsed(), getThreadCpuTimeMs() - cpuTime);
|
||||||
|
|
||||||
|
cpuTime = getThreadCpuTimeMs();
|
||||||
time.start();
|
time.start();
|
||||||
for (int i = 0; i < Loops; ++i)
|
for (int i = 0; i < Loops; ++i)
|
||||||
{
|
{
|
||||||
@@ -266,12 +269,12 @@ namespace BlackMiscTest
|
|||||||
QVERIFY(s1.getAdjustedMSecsSinceEpoch() < s2.getAdjustedMSecsSinceEpoch());
|
QVERIFY(s1.getAdjustedMSecsSinceEpoch() < s2.getAdjustedMSecsSinceEpoch());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
const int hint = time.elapsed();
|
const auto hint = std::make_pair(time.elapsed(), getThreadCpuTimeMs() - cpuTime);
|
||||||
const double ratio = static_cast<double>(hint) / static_cast<double>(noHint); // expected <1.0
|
const double ratio = static_cast<double>(hint.second) / static_cast<double>(noHint.second); // expected <1.0
|
||||||
|
|
||||||
//qDebug() << "MacOS:" << boolToYesNo(CBuildConfig::isRunningOnMacOSPlatform());
|
//qDebug() << "MacOS:" << boolToYesNo(CBuildConfig::isRunningOnMacOSPlatform());
|
||||||
qDebug() << "Access without hint" << noHint << "ms";
|
qDebug() << "Access without hint" << noHint.first << "ms (CPU time" << noHint.second << "ms)";
|
||||||
qDebug() << "Access with hint" << hint << "ms";
|
qDebug() << "Access with hint" << hint.first << "ms (CPU time" << hint.second << "ms)";
|
||||||
qDebug() << "Access ratio" << ratio;
|
qDebug() << "Access ratio" << ratio;
|
||||||
|
|
||||||
#if 0
|
#if 0
|
||||||
|
|||||||
Reference in New Issue
Block a user