 Chromium Code Reviews
 Chromium Code Reviews Issue 1742323002:
  VCMCodecTimer: Change filter from max to 95th percentile  (Closed) 
  Base URL: https://chromium.googlesource.com/external/webrtc.git@master
    
  
    Issue 1742323002:
  VCMCodecTimer: Change filter from max to 95th percentile  (Closed) 
  Base URL: https://chromium.googlesource.com/external/webrtc.git@master| 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 // Add a new decode time to the filter. | 
| 36 void MaxFilter(int32_t newDecodeTimeMs, int64_t nowMs); | 27 void AddTiming(int64_t new_decode_time_ms, int64_t now_ms); | 
| 37 | 28 | 
| 38 // Empty the list of timers. | 29 // Restore to the ctor state. | 
| 39 void Reset(); | 30 void Reset(); | 
| 
stefan-webrtc
2016/03/07 14:48:59
Maybe we should remove this method and instead rec
 
magjed_webrtc
2016/03/08 15:49:42
I agree. Done.
 | |
| 40 | 31 | 
| 41 // Get the required decode time in ms. | 32 // Get the required decode time in ms. It is the 95th percentile observed | 
| 42 int32_t RequiredDecodeTimeMs(FrameType frameType) const; | 33 // decode time within a time window. | 
| 34 int64_t RequiredDecodeTimeMs() const; | |
| 43 | 35 | 
| 44 private: | 36 private: | 
| 45 void UpdateMaxHistory(int32_t decodeTime, int64_t now); | 37 struct Sample { | 
| 46 void ProcessHistory(int64_t nowMs); | 38 Sample(int64_t decode_time_ms, int64_t sample_time_ms); | 
| 39 int64_t decode_time_ms; | |
| 40 int64_t sample_time_ms; | |
| 41 }; | |
| 47 | 42 | 
| 48 int32_t _filteredMax; | |
| 49 // The number of samples ignored so far. | 43 // The number of samples ignored so far. | 
| 50 int32_t _ignoredSampleCount; | 44 int ignoredSampleCount_; | 
| 
stefan-webrtc
2016/03/07 14:48:59
ignored_sample_count_
 
magjed_webrtc
2016/03/08 15:49:42
Done.
 | |
| 51 int32_t _shortMax; | 45 // Queue with history of latest decode time values. | 
| 52 VCMShortMaxSample _history[MAX_HISTORY_SIZE]; | 46 std::queue<Sample> history_; | 
| 47 // |filter_| contains the same values as |history_|, but in a data structure | |
| 48 // that allows efficient retrieval of the percentile value. | |
| 49 PercentileFilter filter_; | |
| 53 }; | 50 }; | 
| 54 | 51 | 
| 55 } // namespace webrtc | 52 } // namespace webrtc | 
| 56 | 53 | 
| 57 #endif // WEBRTC_MODULES_VIDEO_CODING_CODEC_TIMER_H_ | 54 #endif // WEBRTC_MODULES_VIDEO_CODING_CODEC_TIMER_H_ | 
| OLD | NEW |