sprang@webrtc.org | ccd4284 | 2014-01-07 09:54:34 +0000 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (c) 2013 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_VIDEO_SEND_STATISTICS_PROXY_H_ |
| 12 | #define WEBRTC_VIDEO_SEND_STATISTICS_PROXY_H_ |
| 13 | |
| 14 | #include <string> |
| 15 | |
Peter Boström | f2f8283 | 2015-05-01 13:00:41 +0200 | [diff] [blame] | 16 | #include "webrtc/base/criticalsection.h" |
perkj@webrtc.org | af612d5 | 2015-03-18 09:51:05 +0000 | [diff] [blame] | 17 | #include "webrtc/base/ratetracker.h" |
kwiberg@webrtc.org | 00b8f6b | 2015-02-26 14:34:55 +0000 | [diff] [blame] | 18 | #include "webrtc/base/scoped_ptr.h" |
pbos@webrtc.org | 38344ed | 2014-09-24 06:05:00 +0000 | [diff] [blame] | 19 | #include "webrtc/base/thread_annotations.h" |
sprang@webrtc.org | ccd4284 | 2014-01-07 09:54:34 +0000 | [diff] [blame] | 20 | #include "webrtc/common_types.h" |
Henrik Kjellander | 2557b86 | 2015-11-18 22:00:21 +0100 | [diff] [blame] | 21 | #include "webrtc/modules/video_coding/include/video_codec_interface.h" |
| 22 | #include "webrtc/modules/video_coding/include/video_coding_defines.h" |
Henrik Kjellander | 98f5351 | 2015-10-28 18:17:40 +0100 | [diff] [blame] | 23 | #include "webrtc/system_wrappers/include/clock.h" |
Peter Boström | 300eeb6 | 2015-05-12 16:51:11 +0200 | [diff] [blame] | 24 | #include "webrtc/video_engine/overuse_frame_detector.h" |
| 25 | #include "webrtc/video_engine/vie_encoder.h" |
pbos@webrtc.org | 273a414 | 2014-12-01 15:23:21 +0000 | [diff] [blame] | 26 | #include "webrtc/video_send_stream.h" |
sprang@webrtc.org | ccd4284 | 2014-01-07 09:54:34 +0000 | [diff] [blame] | 27 | |
| 28 | namespace webrtc { |
| 29 | |
pbos@webrtc.org | 3e6e271 | 2015-02-26 12:19:31 +0000 | [diff] [blame] | 30 | class SendStatisticsProxy : public CpuOveruseMetricsObserver, |
| 31 | public RtcpStatisticsCallback, |
pbos@webrtc.org | 1d0fa5d | 2015-02-19 12:47:00 +0000 | [diff] [blame] | 32 | public RtcpPacketTypeCounterObserver, |
sprang@webrtc.org | ccd4284 | 2014-01-07 09:54:34 +0000 | [diff] [blame] | 33 | public StreamDataCountersCallback, |
| 34 | public BitrateStatisticsObserver, |
| 35 | public FrameCountObserver, |
pbos@webrtc.org | 891d483 | 2015-02-26 13:15:22 +0000 | [diff] [blame] | 36 | public VideoEncoderRateObserver, |
stefan@webrtc.org | 168f23f | 2014-07-11 13:44:02 +0000 | [diff] [blame] | 37 | public SendSideDelayObserver { |
sprang@webrtc.org | ccd4284 | 2014-01-07 09:54:34 +0000 | [diff] [blame] | 38 | public: |
pbos@webrtc.org | 273a414 | 2014-12-01 15:23:21 +0000 | [diff] [blame] | 39 | static const int kStatsTimeoutMs; |
| 40 | |
sprang | b4a1ae5 | 2015-12-03 08:10:08 -0800 | [diff] [blame] | 41 | SendStatisticsProxy(Clock* clock, |
| 42 | const VideoSendStream::Config& config, |
| 43 | VideoEncoderConfig::ContentType content_type); |
sprang@webrtc.org | ccd4284 | 2014-01-07 09:54:34 +0000 | [diff] [blame] | 44 | virtual ~SendStatisticsProxy(); |
| 45 | |
pbos@webrtc.org | 273a414 | 2014-12-01 15:23:21 +0000 | [diff] [blame] | 46 | VideoSendStream::Stats GetStats(); |
| 47 | |
| 48 | virtual void OnSendEncodedImage(const EncodedImage& encoded_image, |
| 49 | const RTPVideoHeader* rtp_video_header); |
perkj@webrtc.org | af612d5 | 2015-03-18 09:51:05 +0000 | [diff] [blame] | 50 | // Used to update incoming frame rate. |
asapersson | d89920b | 2015-07-22 06:52:00 -0700 | [diff] [blame] | 51 | void OnIncomingFrame(int width, int height); |
sprang@webrtc.org | ccd4284 | 2014-01-07 09:54:34 +0000 | [diff] [blame] | 52 | |
asapersson | 6718e97 | 2015-07-24 00:20:58 -0700 | [diff] [blame] | 53 | // Used to update encode time of frames. |
| 54 | void OnEncodedFrame(int encode_time_ms); |
| 55 | |
pbos@webrtc.org | 891d483 | 2015-02-26 13:15:22 +0000 | [diff] [blame] | 56 | // From VideoEncoderRateObserver. |
| 57 | void OnSetRates(uint32_t bitrate_bps, int framerate) override; |
| 58 | |
Peter Boström | 7083e11 | 2015-09-22 16:28:51 +0200 | [diff] [blame] | 59 | void OnOutgoingRate(uint32_t framerate, uint32_t bitrate); |
| 60 | void OnSuspendChange(bool is_suspended); |
Peter Boström | 20f3f94 | 2015-05-15 11:33:39 +0200 | [diff] [blame] | 61 | void OnInactiveSsrc(uint32_t ssrc); |
| 62 | |
sprang | b4a1ae5 | 2015-12-03 08:10:08 -0800 | [diff] [blame] | 63 | // Used to indicate change in content type, which may require a change in |
| 64 | // how stats are collected. |
| 65 | void SetContentType(VideoEncoderConfig::ContentType content_type); |
| 66 | |
sprang@webrtc.org | ccd4284 | 2014-01-07 09:54:34 +0000 | [diff] [blame] | 67 | protected: |
pbos@webrtc.org | 3e6e271 | 2015-02-26 12:19:31 +0000 | [diff] [blame] | 68 | // From CpuOveruseMetricsObserver. |
kjellander@webrtc.org | 14665ff | 2015-03-04 12:58:35 +0000 | [diff] [blame] | 69 | void CpuOveruseMetricsUpdated(const CpuOveruseMetrics& metrics) override; |
sprang@webrtc.org | ccd4284 | 2014-01-07 09:54:34 +0000 | [diff] [blame] | 70 | // From RtcpStatisticsCallback. |
kjellander@webrtc.org | 14665ff | 2015-03-04 12:58:35 +0000 | [diff] [blame] | 71 | void StatisticsUpdated(const RtcpStatistics& statistics, |
| 72 | uint32_t ssrc) override; |
| 73 | void CNameChanged(const char* cname, uint32_t ssrc) override; |
asapersson | d89920b | 2015-07-22 06:52:00 -0700 | [diff] [blame] | 74 | // From RtcpPacketTypeCounterObserver. |
kjellander@webrtc.org | 14665ff | 2015-03-04 12:58:35 +0000 | [diff] [blame] | 75 | void RtcpPacketTypesCounterUpdated( |
pbos@webrtc.org | 1d0fa5d | 2015-02-19 12:47:00 +0000 | [diff] [blame] | 76 | uint32_t ssrc, |
kjellander@webrtc.org | 14665ff | 2015-03-04 12:58:35 +0000 | [diff] [blame] | 77 | const RtcpPacketTypeCounter& packet_counter) override; |
sprang@webrtc.org | ccd4284 | 2014-01-07 09:54:34 +0000 | [diff] [blame] | 78 | // From StreamDataCountersCallback. |
kjellander@webrtc.org | 14665ff | 2015-03-04 12:58:35 +0000 | [diff] [blame] | 79 | void DataCountersUpdated(const StreamDataCounters& counters, |
| 80 | uint32_t ssrc) override; |
sprang@webrtc.org | ccd4284 | 2014-01-07 09:54:34 +0000 | [diff] [blame] | 81 | |
| 82 | // From BitrateStatisticsObserver. |
kjellander@webrtc.org | 14665ff | 2015-03-04 12:58:35 +0000 | [diff] [blame] | 83 | void Notify(const BitrateStatistics& total_stats, |
| 84 | const BitrateStatistics& retransmit_stats, |
| 85 | uint32_t ssrc) override; |
sprang@webrtc.org | ccd4284 | 2014-01-07 09:54:34 +0000 | [diff] [blame] | 86 | |
| 87 | // From FrameCountObserver. |
kjellander@webrtc.org | 14665ff | 2015-03-04 12:58:35 +0000 | [diff] [blame] | 88 | void FrameCountUpdated(const FrameCounts& frame_counts, |
| 89 | uint32_t ssrc) override; |
sprang@webrtc.org | ccd4284 | 2014-01-07 09:54:34 +0000 | [diff] [blame] | 90 | |
kjellander@webrtc.org | 14665ff | 2015-03-04 12:58:35 +0000 | [diff] [blame] | 91 | void SendSideDelayUpdated(int avg_delay_ms, |
| 92 | int max_delay_ms, |
| 93 | uint32_t ssrc) override; |
stefan@webrtc.org | 168f23f | 2014-07-11 13:44:02 +0000 | [diff] [blame] | 94 | |
sprang@webrtc.org | ccd4284 | 2014-01-07 09:54:34 +0000 | [diff] [blame] | 95 | private: |
asapersson | da535c4 | 2015-10-19 23:32:41 -0700 | [diff] [blame] | 96 | class SampleCounter { |
| 97 | public: |
asapersson | d89920b | 2015-07-22 06:52:00 -0700 | [diff] [blame] | 98 | SampleCounter() : sum(0), num_samples(0) {} |
asapersson | da535c4 | 2015-10-19 23:32:41 -0700 | [diff] [blame] | 99 | ~SampleCounter() {} |
asapersson | d89920b | 2015-07-22 06:52:00 -0700 | [diff] [blame] | 100 | void Add(int sample); |
| 101 | int Avg(int min_required_samples) const; |
| 102 | |
| 103 | private: |
| 104 | int sum; |
| 105 | int num_samples; |
| 106 | }; |
asapersson | da535c4 | 2015-10-19 23:32:41 -0700 | [diff] [blame] | 107 | class BoolSampleCounter { |
| 108 | public: |
asapersson | dec5ebf | 2015-10-05 02:36:17 -0700 | [diff] [blame] | 109 | BoolSampleCounter() : sum(0), num_samples(0) {} |
asapersson | da535c4 | 2015-10-19 23:32:41 -0700 | [diff] [blame] | 110 | ~BoolSampleCounter() {} |
asapersson | dec5ebf | 2015-10-05 02:36:17 -0700 | [diff] [blame] | 111 | void Add(bool sample); |
| 112 | int Percent(int min_required_samples) const; |
| 113 | int Permille(int min_required_samples) const; |
| 114 | |
| 115 | private: |
| 116 | int Fraction(int min_required_samples, float multiplier) const; |
| 117 | int sum; |
| 118 | int num_samples; |
| 119 | }; |
pbos@webrtc.org | 273a414 | 2014-12-01 15:23:21 +0000 | [diff] [blame] | 120 | struct StatsUpdateTimes { |
sprang | b4a1ae5 | 2015-12-03 08:10:08 -0800 | [diff] [blame] | 121 | StatsUpdateTimes() : resolution_update_ms(0), bitrate_update_ms(0) {} |
pbos@webrtc.org | 273a414 | 2014-12-01 15:23:21 +0000 | [diff] [blame] | 122 | int64_t resolution_update_ms; |
Peter Boström | 20f3f94 | 2015-05-15 11:33:39 +0200 | [diff] [blame] | 123 | int64_t bitrate_update_ms; |
pbos@webrtc.org | 273a414 | 2014-12-01 15:23:21 +0000 | [diff] [blame] | 124 | }; |
| 125 | void PurgeOldStats() EXCLUSIVE_LOCKS_REQUIRED(crit_); |
pbos@webrtc.org | 09c77b9 | 2015-02-25 10:42:16 +0000 | [diff] [blame] | 126 | VideoSendStream::StreamStats* GetStatsEntry(uint32_t ssrc) |
| 127 | EXCLUSIVE_LOCKS_REQUIRED(crit_); |
sprang@webrtc.org | ccd4284 | 2014-01-07 09:54:34 +0000 | [diff] [blame] | 128 | |
pbos@webrtc.org | 273a414 | 2014-12-01 15:23:21 +0000 | [diff] [blame] | 129 | Clock* const clock_; |
sprang@webrtc.org | ccd4284 | 2014-01-07 09:54:34 +0000 | [diff] [blame] | 130 | const VideoSendStream::Config config_; |
Peter Boström | f2f8283 | 2015-05-01 13:00:41 +0200 | [diff] [blame] | 131 | mutable rtc::CriticalSection crit_; |
sprang | b4a1ae5 | 2015-12-03 08:10:08 -0800 | [diff] [blame] | 132 | VideoEncoderConfig::ContentType content_type_ GUARDED_BY(crit_); |
pbos@webrtc.org | de1429e | 2014-04-28 13:00:21 +0000 | [diff] [blame] | 133 | VideoSendStream::Stats stats_ GUARDED_BY(crit_); |
Åsa Persson | 24b4eda | 2015-06-16 10:17:01 +0200 | [diff] [blame] | 134 | uint32_t last_sent_frame_timestamp_ GUARDED_BY(crit_); |
pbos@webrtc.org | 273a414 | 2014-12-01 15:23:21 +0000 | [diff] [blame] | 135 | std::map<uint32_t, StatsUpdateTimes> update_times_ GUARDED_BY(crit_); |
asapersson | d89920b | 2015-07-22 06:52:00 -0700 | [diff] [blame] | 136 | |
sprang | b4a1ae5 | 2015-12-03 08:10:08 -0800 | [diff] [blame] | 137 | // Contains stats used for UMA histograms. These stats will be reset if |
| 138 | // content type changes between real-time video and screenshare, since these |
| 139 | // will be reported separately. |
| 140 | struct UmaSamplesContainer { |
| 141 | explicit UmaSamplesContainer(const char* prefix); |
| 142 | ~UmaSamplesContainer(); |
| 143 | |
| 144 | void UpdateHistograms(); |
| 145 | |
| 146 | const std::string uma_prefix_; |
| 147 | int max_sent_width_per_timestamp_; |
| 148 | int max_sent_height_per_timestamp_; |
| 149 | SampleCounter input_width_counter_; |
| 150 | SampleCounter input_height_counter_; |
| 151 | SampleCounter sent_width_counter_; |
| 152 | SampleCounter sent_height_counter_; |
| 153 | SampleCounter encode_time_counter_; |
| 154 | BoolSampleCounter key_frame_counter_; |
| 155 | BoolSampleCounter quality_limited_frame_counter_; |
| 156 | SampleCounter quality_downscales_counter_; |
| 157 | BoolSampleCounter bw_limited_frame_counter_; |
| 158 | SampleCounter bw_resolutions_disabled_counter_; |
| 159 | SampleCounter delay_counter_; |
| 160 | SampleCounter max_delay_counter_; |
| 161 | rtc::RateTracker input_frame_rate_tracker_; |
| 162 | rtc::RateTracker sent_frame_rate_tracker_; |
| 163 | }; |
| 164 | |
| 165 | rtc::scoped_ptr<UmaSamplesContainer> uma_container_ GUARDED_BY(crit_); |
sprang@webrtc.org | ccd4284 | 2014-01-07 09:54:34 +0000 | [diff] [blame] | 166 | }; |
| 167 | |
| 168 | } // namespace webrtc |
| 169 | #endif // WEBRTC_VIDEO_SEND_STATISTICS_PROXY_H_ |