blob: 31d07810f6d2216030a3c2ee6bb51fa5baa42b2f [file] [log] [blame]
Åsa Perssonf3d828e2019-05-06 12:22:49 +02001/*
2 * Copyright 2019 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 RTC_BASE_EXPERIMENTS_BALANCED_DEGRADATION_SETTINGS_H_
12#define RTC_BASE_EXPERIMENTS_BALANCED_DEGRADATION_SETTINGS_H_
13
14#include <vector>
15
Åsa Persson12314192019-06-20 15:45:07 +020016#include "absl/types/optional.h"
17#include "api/video_codecs/video_encoder.h"
18
Åsa Perssonf3d828e2019-05-06 12:22:49 +020019namespace webrtc {
20
21class BalancedDegradationSettings {
22 public:
Åsa Perssonf5e5d252019-08-16 17:24:59 +020023 static constexpr int kNoFpsDiff = -100;
24
Åsa Perssonf3d828e2019-05-06 12:22:49 +020025 BalancedDegradationSettings();
26 ~BalancedDegradationSettings();
27
Åsa Persson48284b82019-07-08 10:01:12 +020028 struct CodecTypeSpecific {
29 CodecTypeSpecific() {}
30 CodecTypeSpecific(int qp_low, int qp_high, int fps)
31 : qp_low(qp_low), qp_high(qp_high), fps(fps) {}
Åsa Perssonf3d828e2019-05-06 12:22:49 +020032
Åsa Persson48284b82019-07-08 10:01:12 +020033 bool operator==(const CodecTypeSpecific& o) const {
34 return qp_low == o.qp_low && qp_high == o.qp_high && fps == o.fps;
Åsa Perssonf3d828e2019-05-06 12:22:49 +020035 }
36
Åsa Persson48284b82019-07-08 10:01:12 +020037 absl::optional<int> GetQpLow() const;
38 absl::optional<int> GetQpHigh() const;
39 absl::optional<int> GetFps() const;
40 int qp_low = 0;
41 int qp_high = 0;
42 int fps = 0;
Åsa Persson12314192019-06-20 15:45:07 +020043 };
44
45 struct Config {
46 Config();
47 Config(int pixels,
48 int fps,
Åsa Persson1b247f12019-08-14 17:26:39 +020049 int kbps,
Åsa Persson30ab0152019-08-27 12:22:33 +020050 int kbps_res,
Åsa Perssonf5e5d252019-08-16 17:24:59 +020051 int fps_diff,
Åsa Persson48284b82019-07-08 10:01:12 +020052 CodecTypeSpecific vp8,
53 CodecTypeSpecific vp9,
54 CodecTypeSpecific h264,
55 CodecTypeSpecific generic);
Åsa Persson12314192019-06-20 15:45:07 +020056
57 bool operator==(const Config& o) const {
Åsa Persson1b247f12019-08-14 17:26:39 +020058 return pixels == o.pixels && fps == o.fps && kbps == o.kbps &&
Åsa Persson30ab0152019-08-27 12:22:33 +020059 kbps_res == o.kbps_res && fps_diff == o.fps_diff && vp8 == o.vp8 &&
60 vp9 == o.vp9 && h264 == o.h264 && generic == o.generic;
Åsa Persson12314192019-06-20 15:45:07 +020061 }
62
Åsa Persson1b247f12019-08-14 17:26:39 +020063 int pixels = 0; // Video frame size.
64 // If the frame size is less than or equal to |pixels|:
65 int fps = 0; // Min framerate to be used.
Åsa Persson30ab0152019-08-27 12:22:33 +020066 int kbps = 0; // Min bitrate needed to adapt up (resolution/fps).
67 int kbps_res = 0; // Min bitrate needed to adapt up in resolution.
Åsa Perssonf5e5d252019-08-16 17:24:59 +020068 int fps_diff = kNoFpsDiff; // Min fps reduction needed (input fps - |fps|)
69 // w/o triggering a new subsequent downgrade
70 // check.
Åsa Persson1b247f12019-08-14 17:26:39 +020071 CodecTypeSpecific vp8;
Åsa Persson48284b82019-07-08 10:01:12 +020072 CodecTypeSpecific vp9;
73 CodecTypeSpecific h264;
74 CodecTypeSpecific generic;
Åsa Perssonf3d828e2019-05-06 12:22:49 +020075 };
76
77 // Returns configurations from field trial on success (default on failure).
78 std::vector<Config> GetConfigs() const;
79
80 // Gets the min/max framerate from |configs_| based on |pixels|.
Åsa Persson48284b82019-07-08 10:01:12 +020081 int MinFps(VideoCodecType type, int pixels) const;
82 int MaxFps(VideoCodecType type, int pixels) const;
Åsa Perssonf3d828e2019-05-06 12:22:49 +020083
Åsa Persson1b247f12019-08-14 17:26:39 +020084 // Gets the bitrate for the first resolution above |pixels|.
85 absl::optional<int> NextHigherBitrateKbps(int pixels) const;
Åsa Persson30ab0152019-08-27 12:22:33 +020086 absl::optional<int> ResolutionNextHigherBitrateKbps(int pixels) const;
Åsa Persson1b247f12019-08-14 17:26:39 +020087
Åsa Persson4869bd62019-08-23 16:20:06 +020088 // Checks if quality can be increased based on |pixels| and |bitrate_bps|.
89 bool CanAdaptUp(int pixels, uint32_t bitrate_bps) const;
Åsa Persson30ab0152019-08-27 12:22:33 +020090 bool CanAdaptUpResolution(int pixels, uint32_t bitrate_bps) const;
Åsa Persson4869bd62019-08-23 16:20:06 +020091
Åsa Perssonf5e5d252019-08-16 17:24:59 +020092 // Gets the min framerate diff from |configs_| based on |pixels|.
93 absl::optional<int> MinFpsDiff(int pixels) const;
94
Åsa Persson12314192019-06-20 15:45:07 +020095 // Gets QpThresholds for the codec |type| based on |pixels|.
96 absl::optional<VideoEncoder::QpThresholds> GetQpThresholds(
97 VideoCodecType type,
98 int pixels) const;
99
Åsa Perssonf3d828e2019-05-06 12:22:49 +0200100 private:
Åsa Persson48284b82019-07-08 10:01:12 +0200101 absl::optional<Config> GetMinFpsConfig(int pixels) const;
102 absl::optional<Config> GetMaxFpsConfig(int pixels) const;
Åsa Persson12314192019-06-20 15:45:07 +0200103 Config GetConfig(int pixels) const;
104
Åsa Perssonf3d828e2019-05-06 12:22:49 +0200105 std::vector<Config> configs_;
106};
107
108} // namespace webrtc
109
110#endif // RTC_BASE_EXPERIMENTS_BALANCED_DEGRADATION_SETTINGS_H_