blob: 4098e33f6232dac3bc1fb44b7d11c60f576bff5a [file] [log] [blame]
sprang@webrtc.orgccd42842014-01-07 09:54:34 +00001/*
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ömf2f82832015-05-01 13:00:41 +020016#include "webrtc/base/criticalsection.h"
asapersson1aa420b2015-12-07 03:12:22 -080017#include "webrtc/base/exp_filter.h"
perkj@webrtc.orgaf612d52015-03-18 09:51:05 +000018#include "webrtc/base/ratetracker.h"
kwiberg@webrtc.org00b8f6b2015-02-26 14:34:55 +000019#include "webrtc/base/scoped_ptr.h"
pbos@webrtc.org38344ed2014-09-24 06:05:00 +000020#include "webrtc/base/thread_annotations.h"
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000021#include "webrtc/common_types.h"
Henrik Kjellander2557b862015-11-18 22:00:21 +010022#include "webrtc/modules/video_coding/include/video_codec_interface.h"
23#include "webrtc/modules/video_coding/include/video_coding_defines.h"
Henrik Kjellander98f53512015-10-28 18:17:40 +010024#include "webrtc/system_wrappers/include/clock.h"
Peter Boström300eeb62015-05-12 16:51:11 +020025#include "webrtc/video_engine/overuse_frame_detector.h"
26#include "webrtc/video_engine/vie_encoder.h"
pbos@webrtc.org273a4142014-12-01 15:23:21 +000027#include "webrtc/video_send_stream.h"
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000028
29namespace webrtc {
30
pbos@webrtc.org3e6e2712015-02-26 12:19:31 +000031class SendStatisticsProxy : public CpuOveruseMetricsObserver,
32 public RtcpStatisticsCallback,
pbos@webrtc.org1d0fa5d2015-02-19 12:47:00 +000033 public RtcpPacketTypeCounterObserver,
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000034 public StreamDataCountersCallback,
35 public BitrateStatisticsObserver,
36 public FrameCountObserver,
pbos@webrtc.org891d4832015-02-26 13:15:22 +000037 public VideoEncoderRateObserver,
stefan@webrtc.org168f23f2014-07-11 13:44:02 +000038 public SendSideDelayObserver {
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000039 public:
pbos@webrtc.org273a4142014-12-01 15:23:21 +000040 static const int kStatsTimeoutMs;
41
sprangb4a1ae52015-12-03 08:10:08 -080042 SendStatisticsProxy(Clock* clock,
43 const VideoSendStream::Config& config,
44 VideoEncoderConfig::ContentType content_type);
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000045 virtual ~SendStatisticsProxy();
46
pbos@webrtc.org273a4142014-12-01 15:23:21 +000047 VideoSendStream::Stats GetStats();
48
49 virtual void OnSendEncodedImage(const EncodedImage& encoded_image,
50 const RTPVideoHeader* rtp_video_header);
perkj@webrtc.orgaf612d52015-03-18 09:51:05 +000051 // Used to update incoming frame rate.
asaperssond89920b2015-07-22 06:52:00 -070052 void OnIncomingFrame(int width, int height);
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000053
asapersson6718e972015-07-24 00:20:58 -070054 // Used to update encode time of frames.
55 void OnEncodedFrame(int encode_time_ms);
56
pbos@webrtc.org891d4832015-02-26 13:15:22 +000057 // From VideoEncoderRateObserver.
58 void OnSetRates(uint32_t bitrate_bps, int framerate) override;
59
Peter Boström7083e112015-09-22 16:28:51 +020060 void OnOutgoingRate(uint32_t framerate, uint32_t bitrate);
61 void OnSuspendChange(bool is_suspended);
Peter Boström20f3f942015-05-15 11:33:39 +020062 void OnInactiveSsrc(uint32_t ssrc);
63
sprangb4a1ae52015-12-03 08:10:08 -080064 // Used to indicate change in content type, which may require a change in
65 // how stats are collected.
66 void SetContentType(VideoEncoderConfig::ContentType content_type);
67
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000068 protected:
pbos@webrtc.org3e6e2712015-02-26 12:19:31 +000069 // From CpuOveruseMetricsObserver.
kjellander@webrtc.org14665ff2015-03-04 12:58:35 +000070 void CpuOveruseMetricsUpdated(const CpuOveruseMetrics& metrics) override;
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000071 // From RtcpStatisticsCallback.
kjellander@webrtc.org14665ff2015-03-04 12:58:35 +000072 void StatisticsUpdated(const RtcpStatistics& statistics,
73 uint32_t ssrc) override;
74 void CNameChanged(const char* cname, uint32_t ssrc) override;
asaperssond89920b2015-07-22 06:52:00 -070075 // From RtcpPacketTypeCounterObserver.
kjellander@webrtc.org14665ff2015-03-04 12:58:35 +000076 void RtcpPacketTypesCounterUpdated(
pbos@webrtc.org1d0fa5d2015-02-19 12:47:00 +000077 uint32_t ssrc,
kjellander@webrtc.org14665ff2015-03-04 12:58:35 +000078 const RtcpPacketTypeCounter& packet_counter) override;
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000079 // From StreamDataCountersCallback.
kjellander@webrtc.org14665ff2015-03-04 12:58:35 +000080 void DataCountersUpdated(const StreamDataCounters& counters,
81 uint32_t ssrc) override;
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000082
83 // From BitrateStatisticsObserver.
kjellander@webrtc.org14665ff2015-03-04 12:58:35 +000084 void Notify(const BitrateStatistics& total_stats,
85 const BitrateStatistics& retransmit_stats,
86 uint32_t ssrc) override;
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000087
88 // From FrameCountObserver.
kjellander@webrtc.org14665ff2015-03-04 12:58:35 +000089 void FrameCountUpdated(const FrameCounts& frame_counts,
90 uint32_t ssrc) override;
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000091
kjellander@webrtc.org14665ff2015-03-04 12:58:35 +000092 void SendSideDelayUpdated(int avg_delay_ms,
93 int max_delay_ms,
94 uint32_t ssrc) override;
stefan@webrtc.org168f23f2014-07-11 13:44:02 +000095
sprang@webrtc.orgccd42842014-01-07 09:54:34 +000096 private:
asaperssonda535c42015-10-19 23:32:41 -070097 class SampleCounter {
98 public:
asaperssond89920b2015-07-22 06:52:00 -070099 SampleCounter() : sum(0), num_samples(0) {}
asaperssonda535c42015-10-19 23:32:41 -0700100 ~SampleCounter() {}
asaperssond89920b2015-07-22 06:52:00 -0700101 void Add(int sample);
102 int Avg(int min_required_samples) const;
103
104 private:
105 int sum;
106 int num_samples;
107 };
asaperssonda535c42015-10-19 23:32:41 -0700108 class BoolSampleCounter {
109 public:
asaperssondec5ebf2015-10-05 02:36:17 -0700110 BoolSampleCounter() : sum(0), num_samples(0) {}
asaperssonda535c42015-10-19 23:32:41 -0700111 ~BoolSampleCounter() {}
asaperssondec5ebf2015-10-05 02:36:17 -0700112 void Add(bool sample);
113 int Percent(int min_required_samples) const;
114 int Permille(int min_required_samples) const;
115
116 private:
117 int Fraction(int min_required_samples, float multiplier) const;
118 int sum;
119 int num_samples;
120 };
pbos@webrtc.org273a4142014-12-01 15:23:21 +0000121 struct StatsUpdateTimes {
sprangb4a1ae52015-12-03 08:10:08 -0800122 StatsUpdateTimes() : resolution_update_ms(0), bitrate_update_ms(0) {}
pbos@webrtc.org273a4142014-12-01 15:23:21 +0000123 int64_t resolution_update_ms;
Peter Boström20f3f942015-05-15 11:33:39 +0200124 int64_t bitrate_update_ms;
pbos@webrtc.org273a4142014-12-01 15:23:21 +0000125 };
126 void PurgeOldStats() EXCLUSIVE_LOCKS_REQUIRED(crit_);
pbos@webrtc.org09c77b92015-02-25 10:42:16 +0000127 VideoSendStream::StreamStats* GetStatsEntry(uint32_t ssrc)
128 EXCLUSIVE_LOCKS_REQUIRED(crit_);
sprang@webrtc.orgccd42842014-01-07 09:54:34 +0000129
pbos@webrtc.org273a4142014-12-01 15:23:21 +0000130 Clock* const clock_;
sprang@webrtc.orgccd42842014-01-07 09:54:34 +0000131 const VideoSendStream::Config config_;
Peter Boströmf2f82832015-05-01 13:00:41 +0200132 mutable rtc::CriticalSection crit_;
sprangb4a1ae52015-12-03 08:10:08 -0800133 VideoEncoderConfig::ContentType content_type_ GUARDED_BY(crit_);
pbos@webrtc.orgde1429e2014-04-28 13:00:21 +0000134 VideoSendStream::Stats stats_ GUARDED_BY(crit_);
Åsa Persson24b4eda2015-06-16 10:17:01 +0200135 uint32_t last_sent_frame_timestamp_ GUARDED_BY(crit_);
pbos@webrtc.org273a4142014-12-01 15:23:21 +0000136 std::map<uint32_t, StatsUpdateTimes> update_times_ GUARDED_BY(crit_);
asapersson1aa420b2015-12-07 03:12:22 -0800137 rtc::ExpFilter encode_time_ GUARDED_BY(crit_);
asaperssond89920b2015-07-22 06:52:00 -0700138
sprangb4a1ae52015-12-03 08:10:08 -0800139 // Contains stats used for UMA histograms. These stats will be reset if
140 // content type changes between real-time video and screenshare, since these
141 // will be reported separately.
142 struct UmaSamplesContainer {
143 explicit UmaSamplesContainer(const char* prefix);
144 ~UmaSamplesContainer();
145
146 void UpdateHistograms();
147
148 const std::string uma_prefix_;
149 int max_sent_width_per_timestamp_;
150 int max_sent_height_per_timestamp_;
151 SampleCounter input_width_counter_;
152 SampleCounter input_height_counter_;
153 SampleCounter sent_width_counter_;
154 SampleCounter sent_height_counter_;
155 SampleCounter encode_time_counter_;
156 BoolSampleCounter key_frame_counter_;
157 BoolSampleCounter quality_limited_frame_counter_;
158 SampleCounter quality_downscales_counter_;
159 BoolSampleCounter bw_limited_frame_counter_;
160 SampleCounter bw_resolutions_disabled_counter_;
161 SampleCounter delay_counter_;
162 SampleCounter max_delay_counter_;
163 rtc::RateTracker input_frame_rate_tracker_;
164 rtc::RateTracker sent_frame_rate_tracker_;
165 };
166
167 rtc::scoped_ptr<UmaSamplesContainer> uma_container_ GUARDED_BY(crit_);
sprang@webrtc.orgccd42842014-01-07 09:54:34 +0000168};
169
170} // namespace webrtc
171#endif // WEBRTC_VIDEO_SEND_STATISTICS_PROXY_H_