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

Side by Side Diff: webrtc/modules/video_coding/main/source/jitter_estimator.h

Issue 1417283007: modules/video_coding refactorings (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@master
Patch Set: Fix the other copy of the mock include header Created 5 years, 1 month 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) 2011 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 #ifndef WEBRTC_MODULES_VIDEO_CODING_JITTER_ESTIMATOR_H_
12 #define WEBRTC_MODULES_VIDEO_CODING_JITTER_ESTIMATOR_H_
13
14 #include "webrtc/base/rollingaccumulator.h"
15 #include "webrtc/modules/video_coding/main/source/rtt_filter.h"
16 #include "webrtc/typedefs.h"
17
18 namespace webrtc
19 {
20
21 class Clock;
22
23 class VCMJitterEstimator
24 {
25 public:
26 VCMJitterEstimator(const Clock* clock,
27 int32_t vcmId = 0,
28 int32_t receiverId = 0);
29 virtual ~VCMJitterEstimator();
30 VCMJitterEstimator& operator=(const VCMJitterEstimator& rhs);
31
32 // Resets the estimate to the initial state
33 void Reset();
34 void ResetNackCount();
35
36 // Updates the jitter estimate with the new data.
37 //
38 // Input:
39 // - frameDelay : Delay-delta calculated by UTILDelayEstimate in milliseconds
40 // - frameSize : Frame size of the current frame.
41 // - incompleteFrame : Flags if the frame is used to update the est imate before it
42 // was complete. Default is false.
43 void UpdateEstimate(int64_t frameDelayMS,
44 uint32_t frameSizeBytes,
45 bool incompleteFrame = false);
46
47 // Returns the current jitter estimate in milliseconds and adds
48 // also adds an RTT dependent term in cases of retransmission.
49 // Input:
50 // - rttMultiplier : RTT param multiplier (when applicable).
51 //
52 // Return value : Jitter estimate in milliseconds
53 int GetJitterEstimate(double rttMultiplier);
54
55 // Updates the nack counter.
56 void FrameNacked();
57
58 // Updates the RTT filter.
59 //
60 // Input:
61 // - rttMs : RTT in ms
62 void UpdateRtt(int64_t rttMs);
63
64 void UpdateMaxFrameSize(uint32_t frameSizeBytes);
65
66 // A constant describing the delay from the jitter buffer
67 // to the delay on the receiving side which is not accounted
68 // for by the jitter buffer nor the decoding delay estimate.
69 static const uint32_t OPERATING_SYSTEM_JITTER = 10;
70
71 protected:
72 // These are protected for better testing possibilities
73 double _theta[2]; // Estimated line parameters (slope, offset)
74 double _varNoise; // Variance of the time-deviation from the li ne
75
76 virtual bool LowRateExperimentEnabled();
77
78 private:
79 // Updates the Kalman filter for the line describing
80 // the frame size dependent jitter.
81 //
82 // Input:
83 // - frameDelayMS : Delay-delta calculated by UTILDelayEstimate in milliseconds
84 // - deltaFSBytes : Frame size delta, i.e.
85 // : frame size at time T minus frame size at tim e T-1
86 void KalmanEstimateChannel(int64_t frameDelayMS, int32_t deltaFSBytes);
87
88 // Updates the random jitter estimate, i.e. the variance
89 // of the time deviations from the line given by the Kalman filter.
90 //
91 // Input:
92 // - d_dT : The deviation from the kalman estimate
93 // - incompleteFrame : True if the frame used to update the estim ate
94 // with was incomplete
95 void EstimateRandomJitter(double d_dT, bool incompleteFrame);
96
97 double NoiseThreshold() const;
98
99 // Calculates the current jitter estimate.
100 //
101 // Return value : The current jitter estimate in millisecond s
102 double CalculateEstimate();
103
104 // Post process the calculated estimate
105 void PostProcessEstimate();
106
107 // Calculates the difference in delay between a sample and the
108 // expected delay estimated by the Kalman filter.
109 //
110 // Input:
111 // - frameDelayMS : Delay-delta calculated by UTILDelayEstimate in milliseconds
112 // - deltaFS : Frame size delta, i.e. frame size at time
113 // T minus frame size at time T-1
114 //
115 // Return value : The difference in milliseconds
116 double DeviationFromExpectedDelay(int64_t frameDelayMS,
117 int32_t deltaFSBytes) const;
118
119 double GetFrameRate() const;
120
121 // Constants, filter parameters
122 int32_t _vcmId;
123 int32_t _receiverId;
124 const double _phi;
125 const double _psi;
126 const uint32_t _alphaCountMax;
127 const double _thetaLow;
128 const uint32_t _nackLimit;
129 const int32_t _numStdDevDelayOutlier;
130 const int32_t _numStdDevFrameSizeOutlier;
131 const double _noiseStdDevs;
132 const double _noiseStdDevOffset;
133
134 double _thetaCov[2][2]; // Estimate covariance
135 double _Qcov[2][2]; // Process noise covariance
136 double _avgFrameSize; // Average frame size
137 double _varFrameSize; // Frame size variance
138 double _maxFrameSize; // Largest frame size received (desce nding
139 // with a factor _psi)
140 uint32_t _fsSum;
141 uint32_t _fsCount;
142
143 int64_t _lastUpdateT;
144 double _prevEstimate; // The previously returned jitt er estimate
145 uint32_t _prevFrameSize; // Frame size of the previous frame
146 double _avgNoise; // Average of the random jitter
147 uint32_t _alphaCount;
148 double _filterJitterEstimate; // The filtered sum of jitter e stimates
149
150 uint32_t _startupCount;
151
152 int64_t _latestNackTimestamp; // Timestamp in ms when the latest na ck was seen
153 uint32_t _nackCount; // Keeps track of the number of nacks received,
154 // but never goes above _nackLi mit
155 VCMRttFilter _rttFilter;
156
157 rtc::RollingAccumulator<uint64_t> fps_counter_;
158 enum ExperimentFlag { kInit, kEnabled, kDisabled };
159 ExperimentFlag low_rate_experiment_;
160 const Clock* clock_;
161 };
162
163 } // namespace webrtc
164
165 #endif // WEBRTC_MODULES_VIDEO_CODING_JITTER_ESTIMATOR_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698