blob: eb6900c460a7403c7abdaaf882c8a3b25ba89e3a (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
|
// Copyright 2014 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "cc/debug/lap_timer.h"
#include "base/logging.h"
namespace cc {
namespace {
// Returns the offset from the origin from the ThreadTicks time source.
// TimeTicks is used as a fallback if ThreadTicks is not available on the
// current platform.
base::TimeDelta Now() {
return base::ThreadTicks::IsSupported()
? base::ThreadTicks::Now() - base::ThreadTicks()
: base::TimeTicks::Now() - base::TimeTicks();
}
// Default values.
static const int kTimeLimitMillis = 3000;
static const int kWarmupRuns = 5;
static const int kTimeCheckInterval = 10;
} // namespace
LapTimer::LapTimer(int warmup_laps,
base::TimeDelta time_limit,
int check_interval)
: warmup_laps_(warmup_laps),
remaining_warmups_(0),
remaining_no_check_laps_(0),
time_limit_(time_limit),
check_interval_(check_interval) {
DCHECK_GT(check_interval, 0);
Reset();
}
LapTimer::LapTimer()
: LapTimer(kWarmupRuns,
base::TimeDelta::FromMilliseconds(kTimeLimitMillis),
kTimeCheckInterval) {
}
void LapTimer::Reset() {
accumulator_ = base::TimeDelta();
num_laps_ = 0;
remaining_warmups_ = warmup_laps_;
remaining_no_check_laps_ = check_interval_;
Start();
}
void LapTimer::Start() {
start_time_ = Now();
}
bool LapTimer::IsWarmedUp() { return remaining_warmups_ <= 0; }
void LapTimer::NextLap() {
if (!IsWarmedUp()) {
--remaining_warmups_;
if (IsWarmedUp()) {
Start();
}
return;
}
++num_laps_;
--remaining_no_check_laps_;
if (!remaining_no_check_laps_) {
base::TimeDelta now = Now();
accumulator_ += now - start_time_;
start_time_ = now;
remaining_no_check_laps_ = check_interval_;
}
}
bool LapTimer::HasTimeLimitExpired() { return accumulator_ >= time_limit_; }
bool LapTimer::HasTimedAllLaps() { return !(num_laps_ % check_interval_); }
float LapTimer::MsPerLap() {
DCHECK(HasTimedAllLaps());
return accumulator_.InMillisecondsF() / num_laps_;
}
float LapTimer::LapsPerSecond() {
DCHECK(HasTimedAllLaps());
return num_laps_ / accumulator_.InSecondsF();
}
int LapTimer::NumLaps() { return num_laps_; }
} // namespace cc
|