| /* | 
 |  * Copyright (c) 2021, Alliance for Open Media. All rights reserved. | 
 |  * | 
 |  * This source code is subject to the terms of the BSD 2 Clause License and | 
 |  * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License | 
 |  * was not distributed with this source code in the LICENSE file, you can | 
 |  * obtain it at www.aomedia.org/license/software. If the Alliance for Open | 
 |  * Media Patent License 1.0 was not distributed with this source code in the | 
 |  * PATENTS file, you can obtain it at www.aomedia.org/license/patent. | 
 |  */ | 
 |  | 
 | #ifndef AOM_AV1_RATECTRL_RTC_H_ | 
 | #define AOM_AV1_RATECTRL_RTC_H_ | 
 |  | 
 | #ifdef __cplusplus | 
 | #include <cstddef> | 
 | #include <cstdint> | 
 | #include <memory> | 
 | #else | 
 | #include <stdbool.h> | 
 | #include <stddef.h> | 
 | #include <stdint.h> | 
 | #endif  // __cplusplus | 
 |  | 
 | struct AV1_COMP; | 
 |  | 
 | typedef struct AomAV1LoopfilterLevel { | 
 |   int filter_level[2]; | 
 |   int filter_level_u; | 
 |   int filter_level_v; | 
 | } AomAV1LoopfilterLevel; | 
 |  | 
 | typedef struct AomAV1CdefInfo { | 
 |   int cdef_strength_y; | 
 |   int cdef_strength_uv; | 
 |   int damping; | 
 | } AomAV1CdefInfo; | 
 |  | 
 | typedef struct AomAV1SegmentationData { | 
 |   const uint8_t *segmentation_map; | 
 |   size_t segmentation_map_size; | 
 |   const int *delta_q; | 
 |   size_t delta_q_size; | 
 | } AomAV1SegmentationData; | 
 |  | 
 | typedef enum AomFrameType { kAomKeyFrame, kAomInterFrame } AomFrameType; | 
 |  | 
 | typedef struct AomAV1FrameParamsRTC { | 
 |   AomFrameType frame_type; | 
 |   int spatial_layer_id; | 
 |   int temporal_layer_id; | 
 | } AomAV1FrameParamsRTC; | 
 |  | 
 | typedef enum AomFrameDropDecision { | 
 |   kAomFrameDropDecisionOk,    // Frame is encoded. | 
 |   kAomFrameDropDecisionDrop,  // Frame is dropped. | 
 | } AomFrameDropDecision; | 
 |  | 
 | // These constants come from AV1 spec. | 
 | enum { | 
 |   kAomAV1MaxLayers = 32, | 
 |   kAomAV1MaxTemporalLayers = 8, | 
 |   kAomAV1MaxSpatialLayers = 4, | 
 | }; | 
 |  | 
 | typedef struct AomAV1RateControlRtcConfig { | 
 | #ifdef __cplusplus | 
 |   AomAV1RateControlRtcConfig(); | 
 | #endif | 
 |  | 
 |   int width; | 
 |   int height; | 
 |   // Flag indicating if the content is screen or not. | 
 |   bool is_screen; | 
 |   // 0-63 | 
 |   int max_quantizer; | 
 |   int min_quantizer; | 
 |   int64_t target_bandwidth; | 
 |   int64_t buf_initial_sz; | 
 |   int64_t buf_optimal_sz; | 
 |   int64_t buf_sz; | 
 |   int undershoot_pct; | 
 |   int overshoot_pct; | 
 |   int max_intra_bitrate_pct; | 
 |   int max_inter_bitrate_pct; | 
 |   int frame_drop_thresh; | 
 |   int max_consec_drop_ms; | 
 |   double framerate; | 
 |   int layer_target_bitrate[kAomAV1MaxLayers]; | 
 |   int ts_rate_decimator[kAomAV1MaxTemporalLayers]; | 
 |   int aq_mode; | 
 |   // Number of spatial layers | 
 |   int ss_number_layers; | 
 |   // Number of temporal layers | 
 |   int ts_number_layers; | 
 |   int max_quantizers[kAomAV1MaxLayers]; | 
 |   int min_quantizers[kAomAV1MaxLayers]; | 
 |   int scaling_factor_num[kAomAV1MaxSpatialLayers]; | 
 |   int scaling_factor_den[kAomAV1MaxSpatialLayers]; | 
 | } AomAV1RateControlRtcConfig; | 
 |  | 
 | struct AomAV1RateControlRTC; | 
 | typedef struct AomAV1RateControlRTC AomAV1RateControlRTC; | 
 |  | 
 | #ifdef __cplusplus | 
 | namespace aom { | 
 |  | 
 | using AV1LoopfilterLevel = AomAV1LoopfilterLevel; | 
 | using AV1CdefInfo = AomAV1CdefInfo; | 
 | using AV1SegmentationData = AomAV1SegmentationData; | 
 | using AV1FrameParamsRTC = AomAV1FrameParamsRTC; | 
 | using AV1RateControlRtcConfig = AomAV1RateControlRtcConfig; | 
 |  | 
 | using FrameType = AomFrameType; | 
 | constexpr FrameType kKeyFrame = kAomKeyFrame; | 
 | constexpr FrameType kInterFrame = kAomInterFrame; | 
 |  | 
 | using FrameDropDecision = AomFrameDropDecision; | 
 | constexpr FrameDropDecision kFrameDropDecisionOk = kAomFrameDropDecisionOk; | 
 | constexpr FrameDropDecision kFrameDropDecisionDrop = kAomFrameDropDecisionDrop; | 
 |  | 
 | class AV1RateControlRTC { | 
 |  public: | 
 |   static std::unique_ptr<AV1RateControlRTC> Create( | 
 |       const AV1RateControlRtcConfig &cfg); | 
 |   ~AV1RateControlRTC(); | 
 |  | 
 |   bool UpdateRateControl(const AV1RateControlRtcConfig &rc_cfg); | 
 |   // GetQP() needs to be called after ComputeQP() to get the latest QP | 
 |   int GetQP() const; | 
 |   // GetLoopfilterLevel() needs to be called after ComputeQP() | 
 |   AV1LoopfilterLevel GetLoopfilterLevel() const; | 
 |   // GetCdefInfo() needs to be called after ComputeQP() | 
 |   AV1CdefInfo GetCdefInfo() const; | 
 |   // Returns the segmentation map used for cyclic refresh, based on 4x4 blocks. | 
 |   bool GetSegmentationData(AV1SegmentationData *segmentation_data) const; | 
 |   // ComputeQP returns the QP if the frame is not dropped (kOk return), | 
 |   // otherwise it returns kDrop and subsequent GetQP and PostEncodeUpdate | 
 |   // are not to be called (av1_rc_postencode_update_drop_frame is already | 
 |   // called via ComputeQP if drop is decided). | 
 |   FrameDropDecision ComputeQP(const AV1FrameParamsRTC &frame_params); | 
 |   // Feedback to rate control with the size of current encoded frame | 
 |   void PostEncodeUpdate(uint64_t encoded_frame_size); | 
 |  | 
 |  private: | 
 |   AV1RateControlRTC() = default; | 
 |   bool InitRateControl(const AV1RateControlRtcConfig &cfg); | 
 |   AV1_COMP *cpi_; | 
 |   int initial_width_; | 
 |   int initial_height_; | 
 | }; | 
 | }  // namespace aom | 
 | #endif  // __cplusplus | 
 |  | 
 | #ifdef __cplusplus | 
 | extern "C" { | 
 | #endif | 
 | AomAV1RateControlRTC *av1_ratecontrol_rtc_create( | 
 |     const AomAV1RateControlRtcConfig *rc_cfg); | 
 | void av1_ratecontrol_rtc_destroy(AomAV1RateControlRTC *controller); | 
 | bool av1_ratecontrol_rtc_update(AomAV1RateControlRTC *controller, | 
 |                                 const AomAV1RateControlRtcConfig *rc_cfg); | 
 | int av1_ratecontrol_rtc_get_qp(const AomAV1RateControlRTC *controller); | 
 |  | 
 | AomAV1LoopfilterLevel av1_ratecontrol_rtc_get_loop_filter_level( | 
 |     const AomAV1RateControlRTC *controller); | 
 | AomFrameDropDecision av1_ratecontrol_rtc_compute_qp( | 
 |     AomAV1RateControlRTC *controller, const AomAV1FrameParamsRTC *frame_params); | 
 |  | 
 | void av1_ratecontrol_rtc_post_encode_update(AomAV1RateControlRTC *controller, | 
 |                                             uint64_t encoded_frame_size); | 
 |  | 
 | bool av1_ratecontrol_rtc_get_segmentation( | 
 |     const AomAV1RateControlRTC *controller, | 
 |     AomAV1SegmentationData *segmentation_data); | 
 |  | 
 | AomAV1CdefInfo av1_ratecontrol_rtc_get_cdef_info( | 
 |     const AomAV1RateControlRTC *controller); | 
 |  | 
 | void av1_ratecontrol_rtc_init_ratecontrol_config( | 
 |     AomAV1RateControlRtcConfig *config); | 
 | #ifdef __cplusplus | 
 | }  // extern "C" | 
 | #endif | 
 |  | 
 | #endif  // AOM_AV1_RATECTRL_RTC_H_ |