Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(53)

Unified Diff: remoting/host/capture_scheduler.cc

Issue 8342040: Gather history of capture and encode time determine next recoring delay (Closed) Base URL: http://git.chromium.org/git/chromium.git@trunk
Patch Set: done Created 9 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: remoting/host/capture_scheduler.cc
diff --git a/remoting/host/capture_scheduler.cc b/remoting/host/capture_scheduler.cc
new file mode 100644
index 0000000000000000000000000000000000000000..1a26b8511f9c7e8904232884d8d68425eeacc0b2
--- /dev/null
+++ b/remoting/host/capture_scheduler.cc
@@ -0,0 +1,61 @@
+// 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 "remoting/host/capture_scheduler.h"
+
+#include <algorithm>
+
+#include "base/logging.h"
+#include "base/sys_info.h"
+#include "base/time.h"
+
+namespace {
+
+// Number of samples to average the most recent capture and encode time.
Wez 2011/10/31 22:05:53 nit: You need "over" at the end of the sentence. :
+const int kStatisticsWindow = 3;
+
+// The hard limit is 20fps or 50ms per recording cycle.
+const int64 kMinimumRecordingDelay = 50;
+
+// Controls how much CPU time we can use for encode and capture.
+// Range of this value is between 0 to 1.
Wez 2011/10/31 22:05:53 This comment still doesn't make it clear whether t
+const double kRecordingCpuConsumption = 0.5;
+
+} // namespace
+
+namespace remoting {
+
+// Number of processors is read when this class is constructed so it doesn't
+// change dynamically.
Wez 2011/10/31 22:05:53 Is the comment to address my nit? If so then plea
+CaptureScheduler::CaptureScheduler()
+ : num_of_processors_(base::SysInfo::NumberOfProcessors()),
+ capture_time_(kStatisticsWindow),
+ encode_time_(kStatisticsWindow) {
+ DCHECK(num_of_processors_);
+}
+
+CaptureScheduler::~CaptureScheduler() {
+}
+
+base::TimeDelta CaptureScheduler::NextCaptureDelay() {
+ // The algorithm only uses CPU time spent in capture and encode,
+ // and number of processors to determine the next capture interval.
Wez 2011/10/31 22:05:53 Could this comment indicate the intended behaviour
+ double delay =
+ (capture_time_.Average() + encode_time_.Average()) /
+ (kRecordingCpuConsumption * num_of_processors_);
+
+ if (delay < kMinimumRecordingDelay)
+ return base::TimeDelta::FromMilliseconds(kMinimumRecordingDelay);
+ return base::TimeDelta::FromMilliseconds(delay);
+}
+
+void CaptureScheduler::RecordCaptureTime(base::TimeDelta capture_time) {
+ capture_time_.Record(capture_time.InMilliseconds());
+}
+
+void CaptureScheduler::RecordEncodeTime(base::TimeDelta encode_time) {
+ encode_time_.Record(encode_time.InMilliseconds());
+}
+
+} // namespace remoting

Powered by Google App Engine
This is Rietveld 408576698