blob: 448dea602dd9ca804b10d4eab969ee2bf531ff61 [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:
23 BalancedDegradationSettings();
24 ~BalancedDegradationSettings();
25
Åsa Persson48284b82019-07-08 10:01:12 +020026 struct CodecTypeSpecific {
27 CodecTypeSpecific() {}
28 CodecTypeSpecific(int qp_low, int qp_high, int fps)
29 : qp_low(qp_low), qp_high(qp_high), fps(fps) {}
Åsa Perssonf3d828e2019-05-06 12:22:49 +020030
Åsa Persson48284b82019-07-08 10:01:12 +020031 bool operator==(const CodecTypeSpecific& o) const {
32 return qp_low == o.qp_low && qp_high == o.qp_high && fps == o.fps;
Åsa Perssonf3d828e2019-05-06 12:22:49 +020033 }
34
Åsa Persson48284b82019-07-08 10:01:12 +020035 absl::optional<int> GetQpLow() const;
36 absl::optional<int> GetQpHigh() const;
37 absl::optional<int> GetFps() const;
38 int qp_low = 0;
39 int qp_high = 0;
40 int fps = 0;
Åsa Persson12314192019-06-20 15:45:07 +020041 };
42
43 struct Config {
44 Config();
45 Config(int pixels,
46 int fps,
Åsa Persson48284b82019-07-08 10:01:12 +020047 CodecTypeSpecific vp8,
48 CodecTypeSpecific vp9,
49 CodecTypeSpecific h264,
50 CodecTypeSpecific generic);
Åsa Persson12314192019-06-20 15:45:07 +020051
52 bool operator==(const Config& o) const {
53 return pixels == o.pixels && fps == o.fps && vp8 == o.vp8 &&
54 vp9 == o.vp9 && h264 == o.h264 && generic == o.generic;
55 }
56
Åsa Persson48284b82019-07-08 10:01:12 +020057 int pixels = 0; // The video frame size.
58 int fps = 0; // The framerate and thresholds to be used if the
59 CodecTypeSpecific vp8; // frame size is less than or equal to |pixels|.
60 CodecTypeSpecific vp9;
61 CodecTypeSpecific h264;
62 CodecTypeSpecific generic;
Åsa Perssonf3d828e2019-05-06 12:22:49 +020063 };
64
65 // Returns configurations from field trial on success (default on failure).
66 std::vector<Config> GetConfigs() const;
67
68 // Gets the min/max framerate from |configs_| based on |pixels|.
Åsa Persson48284b82019-07-08 10:01:12 +020069 int MinFps(VideoCodecType type, int pixels) const;
70 int MaxFps(VideoCodecType type, int pixels) const;
Åsa Perssonf3d828e2019-05-06 12:22:49 +020071
Åsa Persson12314192019-06-20 15:45:07 +020072 // Gets QpThresholds for the codec |type| based on |pixels|.
73 absl::optional<VideoEncoder::QpThresholds> GetQpThresholds(
74 VideoCodecType type,
75 int pixels) const;
76
Åsa Perssonf3d828e2019-05-06 12:22:49 +020077 private:
Åsa Persson48284b82019-07-08 10:01:12 +020078 absl::optional<Config> GetMinFpsConfig(int pixels) const;
79 absl::optional<Config> GetMaxFpsConfig(int pixels) const;
Åsa Persson12314192019-06-20 15:45:07 +020080 Config GetConfig(int pixels) const;
81
Åsa Perssonf3d828e2019-05-06 12:22:49 +020082 std::vector<Config> configs_;
83};
84
85} // namespace webrtc
86
87#endif // RTC_BASE_EXPERIMENTS_BALANCED_DEGRADATION_SETTINGS_H_