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

Side by Side Diff: webrtc/test/drifting_clock.cc

Issue 1674413004: Added A/V sync tests with drifting clocks. (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: drift replaced by speed Created 4 years, 10 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 unified diff | Download patch
OLDNEW
(Empty)
1 /*
2 * Copyright (c) 2016 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11 #include "webrtc/test/drifting_clock.h"
12 #include "webrtc/base/checks.h"
13
14 namespace webrtc {
15 namespace test {
16 const float DriftingClock::kDoubleSpeed = 2.0f;
17 const float DriftingClock::kNoDrift = 1.0f;
18 const float DriftingClock::kHalfSpeed = 0.5f;
19
20 DriftingClock::DriftingClock(Clock* clock, float speed)
21 : clock_(clock),
22 drift_(speed - 1.0f),
23 start_time_(clock_->TimeInMicroseconds()) {
24 RTC_CHECK(clock);
pbos-webrtc 2016/02/10 13:28:13 Not necessary since it crashes on line 23 before t
danilchap 2016/02/10 15:50:19 Would like to keep this line to explicitly note nu
25 RTC_CHECK_GT(drift_, -1.0f);
26 }
27
28 float DriftingClock::Drift() const {
29 int64_t now = clock_->TimeInMicroseconds();
30 RTC_DCHECK_GE(now, start_time_);
31 return (now - start_time_) * drift_;
32 }
33
34 int64_t DriftingClock::TimeInMilliseconds() const {
35 return clock_->TimeInMilliseconds() + Drift() / 1000.;
36 }
37
38 int64_t DriftingClock::TimeInMicroseconds() const {
39 return clock_->TimeInMicroseconds() + Drift();
40 }
41
42 void DriftingClock::CurrentNtp(uint32_t& seconds, uint32_t& fractions) const {
43 // NTP precision is 1/2^32 seconds, i.e. 2^32 ntp fractions = 1 second.
44 const double kNtpFracPerMicroSecond = 4294.967296; // = 2^32 / 10^6
45
46 clock_->CurrentNtp(seconds, fractions);
47 uint64_t total_fractions = (static_cast<uint64_t>(seconds) << 32) | fractions;
48 total_fractions += Drift() * kNtpFracPerMicroSecond;
49 seconds = total_fractions >> 32;
50 fractions = static_cast<uint32_t>(total_fractions);
51 }
52
53 int64_t DriftingClock::CurrentNtpInMilliseconds() const {
54 return clock_->CurrentNtpInMilliseconds() + Drift() / 1000.;
55 }
56 } // namespace test
57 } // namespace webrtc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698