Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved. | 2 * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license | 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 | 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 | 6 * tree. An additional intellectual property rights grant can be found |
| 7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
| 8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
| 9 */ | 9 */ |
| 10 | 10 |
| 11 #ifndef WEBRTC_MODULES_VIDEO_CODING_CODEC_TIMER_H_ | 11 #ifndef WEBRTC_MODULES_VIDEO_CODING_CODEC_TIMER_H_ |
| 12 #define WEBRTC_MODULES_VIDEO_CODING_CODEC_TIMER_H_ | 12 #define WEBRTC_MODULES_VIDEO_CODING_CODEC_TIMER_H_ |
| 13 | 13 |
| 14 #include <queue> | |
| 15 | |
| 14 #include "webrtc/modules/include/module_common_types.h" | 16 #include "webrtc/modules/include/module_common_types.h" |
| 17 #include "webrtc/modules/video_coding/percentile_filter.h" | |
| 15 #include "webrtc/typedefs.h" | 18 #include "webrtc/typedefs.h" |
| 16 | 19 |
| 17 namespace webrtc { | 20 namespace webrtc { |
| 18 | 21 |
| 19 // MAX_HISTORY_SIZE * SHORT_FILTER_MS defines the window size in milliseconds | |
| 20 #define MAX_HISTORY_SIZE 10 | |
| 21 #define SHORT_FILTER_MS 1000 | |
| 22 | |
| 23 class VCMShortMaxSample { | |
| 24 public: | |
| 25 VCMShortMaxSample() : shortMax(0), timeMs(-1) {} | |
| 26 | |
| 27 int32_t shortMax; | |
| 28 int64_t timeMs; | |
| 29 }; | |
| 30 | |
| 31 class VCMCodecTimer { | 22 class VCMCodecTimer { |
| 32 public: | 23 public: |
| 33 VCMCodecTimer(); | 24 VCMCodecTimer(); |
| 34 | 25 |
| 35 // Updates the max filtered decode time. | 26 // Updates the max filtered decode time. |
| 36 void MaxFilter(int32_t newDecodeTimeMs, int64_t nowMs); | 27 void MaxFilter(int32_t new_decode_time_ms, int64_t now_ms); |
|
philipel
2016/03/03 13:34:31
Is MaxFilter still the correct term to use now? Ma
philipel
2016/03/03 13:34:31
Always use int64_t when storing time intervals or
magjed_webrtc
2016/03/04 14:19:41
Done.
magjed_webrtc
2016/03/04 14:19:41
MaxFilter is a strange name indeed, even before my
| |
| 37 | 28 |
| 38 // Empty the list of timers. | 29 // Restore to the ctor state. |
| 39 void Reset(); | 30 void Reset(); |
| 40 | 31 |
| 41 // Get the required decode time in ms. | 32 // Get the required decode time in ms. |
| 42 int32_t RequiredDecodeTimeMs(FrameType frameType) const; | 33 int32_t RequiredDecodeTimeMs(FrameType frameType) const; |
|
magjed_webrtc
2016/03/04 14:19:41
Since I'm changing the interface now, I took the o
philipel
2016/03/04 15:20:13
Good.
| |
| 43 | 34 |
| 44 private: | 35 private: |
| 45 void UpdateMaxHistory(int32_t decodeTime, int64_t now); | 36 struct Sample { |
| 46 void ProcessHistory(int64_t nowMs); | 37 Sample(int32_t decode_time_ms, int64_t sample_time_ms); |
| 38 int32_t decode_time_ms; | |
|
philipel
2016/03/03 13:34:31
int64_t decode_time_ms;
magjed_webrtc
2016/03/04 14:19:41
Done.
| |
| 39 int64_t sample_time_ms; | |
| 40 }; | |
| 47 | 41 |
| 48 int32_t _filteredMax; | |
| 49 // The number of samples ignored so far. | 42 // The number of samples ignored so far. |
| 50 int32_t _ignoredSampleCount; | 43 int32_t ignoredSampleCount_; |
|
philipel
2016/03/03 13:34:31
Change int32_t to int.
magjed_webrtc
2016/03/04 14:19:41
Done.
| |
| 51 int32_t _shortMax; | 44 // Queue with history of latest decode time values. |
| 52 VCMShortMaxSample _history[MAX_HISTORY_SIZE]; | 45 std::queue<Sample> history_; |
| 46 // |filter_| contains the same values as |history_|, but in a data structure | |
| 47 // that allows efficient retrieval of the percentile value. | |
| 48 PercentileFilter filter_; | |
| 53 }; | 49 }; |
| 54 | 50 |
| 55 } // namespace webrtc | 51 } // namespace webrtc |
| 56 | 52 |
| 57 #endif // WEBRTC_MODULES_VIDEO_CODING_CODEC_TIMER_H_ | 53 #endif // WEBRTC_MODULES_VIDEO_CODING_CODEC_TIMER_H_ |
| OLD | NEW |