| /* |
| * Copyright (c) 2019, 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_ENCODER_SVC_LAYERCONTEXT_H_ |
| #define AOM_AV1_ENCODER_SVC_LAYERCONTEXT_H_ |
| |
| #include "aom_scale/yv12config.h" |
| #include "av1/encoder/aq_cyclicrefresh.h" |
| #include "av1/encoder/encoder.h" |
| #include "av1/encoder/ratectrl.h" |
| |
| #ifdef __cplusplus |
| extern "C" { |
| #endif |
| |
| /*! |
| * \brief The stucture of quantities related to each spatial and temporal layer. |
| * \ingroup SVC |
| */ |
| typedef struct { |
| /*!\cond */ |
| RATE_CONTROL rc; |
| PRIMARY_RATE_CONTROL p_rc; |
| int framerate_factor; |
| int64_t layer_target_bitrate; // In bits per second. |
| int scaling_factor_num; |
| int scaling_factor_den; |
| int64_t target_bandwidth; |
| int64_t spatial_layer_target_bandwidth; |
| double framerate; |
| int avg_frame_size; |
| int max_q; |
| int min_q; |
| int frames_from_key_frame; |
| /*!\endcond */ |
| |
| /*! |
| * Cyclic refresh parameters (aq-mode=3), that need to be updated per-frame. |
| */ |
| int sb_index; |
| /*! |
| * Segmentation map |
| */ |
| int8_t *map; |
| /*! |
| * Number of blocks on segment 1 |
| */ |
| int actual_num_seg1_blocks; |
| |
| /*! |
| * Number of blocks on segment 2 |
| */ |
| int actual_num_seg2_blocks; |
| /*! |
| * Counter used to detect scene change. |
| */ |
| int counter_encode_maxq_scene_change; |
| |
| /*! |
| * Speed settings for each layer. |
| */ |
| uint8_t speed; |
| /*! |
| * GF group index. |
| */ |
| unsigned char group_index; |
| /*! |
| * If current layer is key frame. |
| */ |
| int is_key_frame; |
| /*! |
| * Maximum motion magnitude of previous encoded layer. |
| */ |
| int max_mv_magnitude; |
| } LAYER_CONTEXT; |
| |
| /*! |
| * \brief The stucture of SVC. |
| * \ingroup SVC |
| */ |
| typedef struct SVC { |
| /*!\cond */ |
| int spatial_layer_id; |
| int temporal_layer_id; |
| int number_spatial_layers; |
| int number_temporal_layers; |
| int prev_number_spatial_layers; |
| int use_flexible_mode; |
| int ksvc_fixed_mode; |
| /*!\endcond */ |
| |
| /*!\cond */ |
| double base_framerate; |
| unsigned int current_superframe; |
| int skip_mvsearch_last; |
| int skip_mvsearch_gf; |
| int skip_mvsearch_altref; |
| int spatial_layer_fb[REF_FRAMES]; |
| int temporal_layer_fb[REF_FRAMES]; |
| int num_encoded_top_layer; |
| int first_layer_denoise; |
| YV12_BUFFER_CONFIG source_last_TL0; |
| int mi_cols_full_resoln; |
| int mi_rows_full_resoln; |
| /*!\endcond */ |
| |
| /*! |
| * Layer context used for rate control in CBR mode. |
| * An array. The index for spatial layer `sl` and temporal layer `tl` is |
| * sl * number_temporal_layers + tl. |
| */ |
| LAYER_CONTEXT *layer_context; |
| |
| /*! |
| * Number of layers allocated for layer_context. If nonzero, must be greater |
| * than or equal to number_spatial_layers * number_temporal_layers. |
| */ |
| int num_allocated_layers; |
| |
| /*! |
| * EIGHTTAP_SMOOTH or BILINEAR |
| */ |
| InterpFilter downsample_filter_type[AOM_MAX_SS_LAYERS]; |
| |
| /*! |
| * Downsample_filter_phase: = 0 will do sub-sampling (no weighted average), |
| * = 8 will center the target pixel and get a symmetric averaging filter. |
| */ |
| int downsample_filter_phase[AOM_MAX_SS_LAYERS]; |
| |
| /*! |
| * Force zero-mv in mode search for the spatial/inter-layer reference. |
| */ |
| int force_zero_mode_spatial_ref; |
| |
| /*! |
| * Flag to indicate that current spatial layer has a lower quality layer |
| * (at the same timestamp) that can be used as a reference. |
| * Lower quality layer refers to the same resolution but encoded at |
| * different/lower bitrate. |
| */ |
| int has_lower_quality_layer; |
| |
| /*! |
| * Flag to indicate the frame drop mode for SVC: one of the two settings: |
| * AOM_LAYER_DROP (default) or AOM_FULL_SUPERFRAME_DROP. |
| */ |
| AOM_SVC_FRAME_DROP_MODE framedrop_mode; |
| |
| /*! |
| * Flag to indicate if frame was dropped for a given spatial_layer_id on |
| * previous superframe. |
| */ |
| bool last_layer_dropped[AOM_MAX_SS_LAYERS]; |
| |
| /*! |
| * Flag to indicate if a previous spatial was dropped for the same superframe. |
| */ |
| bool drop_spatial_layer[AOM_MAX_SS_LAYERS]; |
| } SVC; |
| |
| struct AV1_COMP; |
| struct EncodeFrameInput; |
| |
| /*!\brief Initialize layer context data from init_config(). |
| * |
| * \ingroup SVC |
| * \callgraph |
| * \callergraph |
| * |
| * \param[in] cpi Top level encoder structure |
| * |
| * \remark Nothing returned. Set cpi->svc. |
| */ |
| void av1_init_layer_context(struct AV1_COMP *const cpi); |
| |
| /*!\brief Allocate layer context data. |
| * |
| * \ingroup SVC |
| * \callgraph |
| * \callergraph |
| * |
| * \param[in] cpi Top level encoder structure |
| * \param[in] num_layers Number of layers to be allocated |
| * |
| * \remark Allocates memory for cpi->svc.layer_context. |
| * \return True on success, false on allocation failure. |
| */ |
| bool av1_alloc_layer_context(struct AV1_COMP *cpi, int num_layers); |
| |
| /*!\brief Update the layer context from a change_config() call. |
| * |
| * \ingroup SVC |
| * \callgraph |
| * \callergraph |
| * |
| * \param[in] cpi Top level encoder structure |
| * \param[in] target_bandwidth Total target bandwidth |
| * |
| * \remark Nothing returned. Buffer level for each layer is set. |
| */ |
| void av1_update_layer_context_change_config(struct AV1_COMP *const cpi, |
| const int64_t target_bandwidth); |
| |
| /*!\brief Prior to encoding the frame, update framerate-related quantities |
| for the current temporal layer. |
| * |
| * \ingroup SVC |
| * \callgraph |
| * \callergraph |
| * |
| * \param[in] cpi Top level encoder structure |
| * |
| * \remark Nothing returned. Frame related quantities for current temporal |
| layer are updated. |
| */ |
| void av1_update_temporal_layer_framerate(struct AV1_COMP *const cpi); |
| |
| /*!\brief Prior to check if reference is lower spatial layer at the same |
| * timestamp/superframe. |
| * |
| * \ingroup SVC |
| * \callgraph |
| * \callergraph |
| * |
| * \param[in] cpi Top level encoder structure |
| * \param[in] ref_frame Reference frame |
| * |
| * \return True if the ref_frame if lower spatial layer, otherwise false. |
| */ |
| bool av1_check_ref_is_low_spatial_res_super_frame(struct AV1_COMP *const cpi, |
| int ref_frame); |
| |
| /*!\brief Prior to encoding the frame, set the layer context, for the current |
| layer to be encoded, to the cpi struct. |
| * |
| * \ingroup SVC |
| * \callgraph |
| * \callergraph |
| * |
| * \param[in] cpi Top level encoder structure |
| * |
| * \remark Nothing returned. Layer context for current layer is set. |
| */ |
| void av1_restore_layer_context(struct AV1_COMP *const cpi); |
| |
| /*!\brief Save the layer context after encoding the frame. |
| * |
| * \ingroup SVC |
| * \callgraph |
| * \callergraph |
| * |
| * \param[in] cpi Top level encoder structure |
| */ |
| void av1_save_layer_context(struct AV1_COMP *const cpi); |
| |
| /*!\brief Free the memory used for cyclic refresh in layer context. |
| * |
| * \ingroup SVC |
| * \callgraph |
| * \callergraph |
| * |
| * \param[in] cpi Top level encoder structure |
| */ |
| void av1_free_svc_cyclic_refresh(struct AV1_COMP *const cpi); |
| |
| /*!\brief Reset on key frame: reset counters, references and buffer updates. |
| * |
| * \ingroup SVC |
| * \callgraph |
| * \callergraph |
| * |
| * \param[in] cpi Top level encoder structure |
| * \param[in] is_key Whether current layer is key frame |
| */ |
| void av1_svc_reset_temporal_layers(struct AV1_COMP *const cpi, int is_key); |
| |
| /*!\brief Before encoding, set resolutions and allocate compressor data. |
| * |
| * \ingroup SVC |
| * \callgraph |
| * \callergraph |
| * |
| * \param[in] cpi Top level encoder structure |
| */ |
| void av1_one_pass_cbr_svc_start_layer(struct AV1_COMP *const cpi); |
| |
| /*!\brief Get primary reference frame for current layer |
| * |
| * \ingroup SVC |
| * \callgraph |
| * \callergraph |
| * |
| * \param[in] cpi Top level encoder structure |
| * |
| * \return The primary reference frame for current layer. |
| */ |
| int av1_svc_primary_ref_frame(const struct AV1_COMP *const cpi); |
| |
| /*!\brief Get resolution for current layer. |
| * |
| * \ingroup SVC |
| * \param[in] width_org Original width, unscaled |
| * \param[in] height_org Original height, unscaled |
| * \param[in] num Numerator for the scale ratio |
| * \param[in] den Denominator for the scale ratio |
| * \param[in] width_out Output width, scaled for current layer |
| * \param[in] height_out Output height, scaled for current layer |
| * |
| * \remark Nothing is returned. Instead the scaled width and height are set. |
| */ |
| void av1_get_layer_resolution(const int width_org, const int height_org, |
| const int num, const int den, int *width_out, |
| int *height_out); |
| |
| void av1_set_svc_fixed_mode(struct AV1_COMP *const cpi); |
| |
| void av1_svc_check_reset_layer_rc_flag(struct AV1_COMP *const cpi); |
| |
| void av1_svc_set_last_source(struct AV1_COMP *const cpi, |
| struct EncodeFrameInput *frame_input, |
| YV12_BUFFER_CONFIG *prev_source); |
| |
| void av1_svc_update_buffer_slot_refreshed(struct AV1_COMP *const cpi); |
| |
| int av1_svc_get_min_ref_dist(const struct AV1_COMP *cpi); |
| |
| void av1_svc_set_reference_was_previous(struct AV1_COMP *cpi); |
| #ifdef __cplusplus |
| } // extern "C" |
| #endif |
| |
| #endif // AOM_AV1_ENCODER_SVC_LAYERCONTEXT_H_ |