Index: remoting/base/running_average.cc |
diff --git a/remoting/base/running_average.cc b/remoting/base/running_average.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..d43dc1cecc3c3dc0932aaa4fb91c2efe5e280416 |
--- /dev/null |
+++ b/remoting/base/running_average.cc |
@@ -0,0 +1,73 @@ |
+// Copyright (c) 2011 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 "base/logging.h" |
+#include "remoting/base/running_average.h" |
+ |
+namespace remoting { |
+ |
+RunningAverage::RunningAverage(int window_size) |
+ : window_size_(window_size), |
+ sum_(0) { |
+ CHECK(window_size_); |
+} |
+ |
+RunningAverage::~RunningAverage() { |
+} |
+ |
+void RunningAverage::Record(int64 value) { |
+ base::AutoLock auto_lock(lock_); |
+ |
+ data_points_.push_back(value); |
+ sum_ += value; |
+ |
+ if (data_points_.size() > window_size_) { |
+ sum_ -= data_points_[0]; |
+ data_points_.pop_front(); |
+ } |
+} |
+ |
+int64 RunningAverage::Average() { |
+ base::AutoLock auto_lock(lock_); |
+ |
+ if (data_points_.empty()) |
+ return 0; |
+ return sum_ / data_points_.size(); |
+} |
+ |
+TimedRunningAverage::TimedRunningAverage(int window_size) |
+ : counter_(window_size), |
+ window_size_(window_size) { |
+} |
+ |
+TimedRunningAverage::~TimedRunningAverage() { |
+} |
+ |
+void TimedRunningAverage::Record(int64 value) { |
+ { |
+ base::AutoLock auto_lock(lock_); |
+ time_.push_back(base::Time::Now()); |
+ |
+ if (time_.size() > window_size_) |
+ time_.pop_front(); |
+ } |
+ counter_.Record(value); |
+} |
+ |
+double TimedRunningAverage::Rate() { |
+ int64 average = counter_.Average(); |
+ base::TimeDelta delta; |
+ |
+ { |
+ base::AutoLock auto_lock(lock_); |
+ if (!time_.empty()) |
+ delta = *time_.rbegin() - *time_.begin(); |
+ } |
+ |
+ if (delta.InMilliseconds()) |
+ return 1000.0 * average / delta.InMilliseconds(); |
simonmorris
2011/03/25 09:24:59
I'm not sure the math is right here. For a rate, d
Wez
2011/03/25 10:43:19
Yes. The rate (bandwidth in our case) would norma
|
+ return 0; |
+} |
+ |
+} // namespace remoting |