You've already forked UnrealEngineUWP
mirror of
https://github.com/izzy2lost/UnrealEngineUWP.git
synced 2026-03-26 18:15:20 -07:00
#jira #rb none #ROBOMERGE-OWNER: ryan.vance #ROBOMERGE-AUTHOR: ben.marsh #ROBOMERGE-SOURCE: CL 5993252 via CL 5993257 via CL 5995286 via CL 5995562 #ROBOMERGE-BOT: DEVVR (Main -> Dev-VR) [CL 6004844 by ben marsh in Dev-VR branch]
50 lines
883 B
C++
50 lines
883 B
C++
// Copyright 2011-2019 Molecular Matters GmbH, all rights reserved.
|
|
|
|
#pragma once
|
|
|
|
#include "CoreTypes.h"
|
|
#include <chrono>
|
|
#include "LC_CriticalSection.h"
|
|
|
|
namespace telemetry
|
|
{
|
|
// scoped timing information
|
|
class Scope
|
|
{
|
|
public:
|
|
explicit Scope(const char* name);
|
|
~Scope(void);
|
|
|
|
double ReadSeconds(void) const;
|
|
double ReadMilliSeconds(void) const;
|
|
double ReadMicroSeconds(void) const;
|
|
void Restart(void);
|
|
void End(void);
|
|
|
|
private:
|
|
const char* m_name;
|
|
std::chrono::high_resolution_clock::time_point m_start;
|
|
CriticalSection m_cs;
|
|
};
|
|
|
|
|
|
class Accumulator
|
|
{
|
|
public:
|
|
explicit Accumulator(const char* name);
|
|
|
|
void Accumulate(uint64_t value);
|
|
void ResetCurrent(void);
|
|
|
|
uint64_t ReadCurrent(void) const;
|
|
uint64_t ReadAccumulated(void) const;
|
|
|
|
void Print(void);
|
|
|
|
private:
|
|
const char* m_name;
|
|
uint64_t m_current;
|
|
uint64_t m_accumulated;
|
|
};
|
|
}
|