fsfw/timemanager/Stopwatch.cpp

58 lines
1.6 KiB
C++
Raw Normal View History

2020-04-08 19:33:01 +02:00
#include <framework/timemanager/Stopwatch.h>
#include <framework/serviceinterface/ServiceInterfaceStream.h>
#include <iomanip>
Stopwatch::Stopwatch(bool displayOnDestruction,
2020-05-29 17:43:06 +02:00
StopwatchDisplayMode displayMode): displayOnDestruction(
displayOnDestruction), displayMode(displayMode) {
2020-04-08 19:33:01 +02:00
// Measures start time on initialization.
2020-05-29 17:43:06 +02:00
Clock::getClock_timeval(&startTime);
2020-04-08 19:33:01 +02:00
}
void Stopwatch::start() {
2020-05-29 17:43:06 +02:00
Clock::getClock_timeval(&startTime);
2020-04-08 19:33:01 +02:00
}
2020-06-04 13:01:59 +02:00
dur_millis_t Stopwatch::stop() {
2020-04-08 19:33:01 +02:00
stopInternal();
return elapsedTime.tv_sec * 1000 + elapsedTime.tv_usec / 1000;
}
2020-06-04 13:01:59 +02:00
dur_seconds_t Stopwatch::stopSeconds() {
2020-04-08 19:33:01 +02:00
stopInternal();
return timevalOperations::toDouble(elapsedTime);
}
void Stopwatch::display() {
if(displayMode == StopwatchDisplayMode::MILLIS) {
sif::info << "Stopwatch: Operation took " << (elapsedTime.tv_sec * 1000 +
2020-04-09 18:02:42 +02:00
elapsedTime.tv_usec / 1000) << " milliseconds" << std::endl;
2020-04-08 19:33:01 +02:00
}
else if(displayMode == StopwatchDisplayMode::SECONDS) {
sif::info <<"Stopwatch: Operation took " << std::setprecision(3)
2020-04-08 19:33:01 +02:00
<< std::fixed << timevalOperations::toDouble(elapsedTime)
<< " seconds" << std::endl;
}
}
Stopwatch::~Stopwatch() {
if(displayOnDestruction) {
stopInternal();
display();
}
}
void Stopwatch::setDisplayMode(StopwatchDisplayMode displayMode) {
this->displayMode = displayMode;
}
StopwatchDisplayMode Stopwatch::getDisplayMode() const {
return displayMode;
}
void Stopwatch::stopInternal() {
2020-05-29 17:43:06 +02:00
timeval endTime;
Clock::getClock_timeval(&endTime);
elapsedTime = endTime - startTime;
2020-04-08 19:33:01 +02:00
}