AOMedia AV1 Codec
|
Files | |
file | aom_external_partition.h |
Provides function pointer definitions for the external partition. | |
file | aomcx.h |
Provides definitions for using AOM or AV1 encoder algorithm within the aom Codec Interface. | |
Data Structures | |
struct | aom_ext_part_config |
Config information sent to the external partition model. More... | |
struct | aom_partition_features_before_none |
Features pass to the external model to make partition decisions. Specifically, features collected before NONE partition. Features "f" are used to determine: partition_none_allowed, partition_horz_allowed, partition_vert_allowed, do_rectangular_split, do_square_split Features "f_part2" are used to determine: prune_horz, prune_vert. More... | |
struct | aom_partition_features_none |
Features pass to the external model to make partition decisions. Specifically, features collected after NONE partition. More... | |
struct | aom_partition_features_split |
Features pass to the external model to make partition decisions. Specifically, features collected after SPLIT partition. More... | |
struct | aom_partition_features_rect |
Features pass to the external model to make partition decisions. Specifically, features collected after RECTANGULAR partition. More... | |
struct | aom_partition_features_ab |
Features pass to the external model to make partition decisions. Specifically, features collected after AB partition: HORZ_A, HORZ_B, VERT_A, VERT_B. More... | |
struct | aom_sb_tpl_features |
Features collected from the tpl process. More... | |
struct | aom_sb_simple_motion_features |
Features collected from the simple motion process. More... | |
struct | aom_sb_features |
Features of each super block. More... | |
struct | aom_partition_features |
Features pass to the external model to make partition decisions. More... | |
struct | aom_partition_decision |
Partition decisions received from the external model. More... | |
struct | aom_partition_stats |
Encoding stats for the given partition decision. More... | |
struct | aom_ext_part_funcs |
Callback function set for external partition model. More... | |
struct | aom_roi_map |
aom region of interest map More... | |
struct | aom_active_map |
aom active region map More... | |
struct | aom_scaling_mode |
aom image scaling mode More... | |
struct | aom_svc_layer_id |
struct | aom_svc_params |
struct | aom_svc_ref_frame_config |
struct | aom_svc_ref_frame_comp_pred |
Macros | |
#define | AOM_EXT_PART_ABI_VERSION 8 |
Current ABI version number. | |
#define | AOM_EXT_PART_SIZE_DIRECT_SPLIT 17 |
Number of features to determine whether to skip partition none and do partition split directly. The same as "FEATURE_SIZE_SMS_SPLIT". | |
#define | AOM_EXT_PART_SIZE_PRUNE_PART 25 |
Number of features to use simple motion search to prune out rectangular partition in some direction. The same as "FEATURE_SIZE_SMS_PRUNE_PART". | |
#define | AOM_EXT_PART_SIZE_PRUNE_NONE 4 |
Number of features to prune split and rectangular partition after PARTITION_NONE. | |
#define | AOM_EXT_PART_SIZE_TERM_NONE 28 |
Number of features to terminates partition after partition none using simple_motion_search features and the rate, distortion, and rdcost of PARTITION_NONE. The same as "FEATURE_SIZE_SMS_TERM_NONE". | |
#define | AOM_EXT_PART_SIZE_TERM_SPLIT 31 |
Number of features to terminates partition after partition split. | |
#define | AOM_EXT_PART_SIZE_PRUNE_RECT 9 |
Number of features to prune rectangular partition using stats collected after partition split. | |
#define | AOM_EXT_PART_SIZE_PRUNE_AB 10 |
Number of features to prune AB partition using stats collected after rectangular partition.. | |
#define | AOM_EXT_PART_SIZE_PRUNE_4_WAY 18 |
Number of features to prune 4-way partition using stats collected after AB partition. | |
#define | AOM_EFLAG_NO_REF_LAST (1 << 16) |
Don't reference the last frame. | |
#define | AOM_EFLAG_NO_REF_LAST2 (1 << 17) |
Don't reference the last2 frame. | |
#define | AOM_EFLAG_NO_REF_LAST3 (1 << 18) |
Don't reference the last3 frame. | |
#define | AOM_EFLAG_NO_REF_GF (1 << 19) |
Don't reference the golden frame. | |
#define | AOM_EFLAG_NO_REF_ARF (1 << 20) |
Don't reference the alternate reference frame. | |
#define | AOM_EFLAG_NO_REF_BWD (1 << 21) |
Don't reference the bwd reference frame. | |
#define | AOM_EFLAG_NO_REF_ARF2 (1 << 22) |
Don't reference the alt2 reference frame. | |
#define | AOM_EFLAG_NO_UPD_LAST (1 << 23) |
Don't update the last frame. | |
#define | AOM_EFLAG_NO_UPD_GF (1 << 24) |
Don't update the golden frame. | |
#define | AOM_EFLAG_NO_UPD_ARF (1 << 25) |
Don't update the alternate reference frame. | |
#define | AOM_EFLAG_NO_UPD_ENTROPY (1 << 26) |
Disable entropy update. | |
#define | AOM_EFLAG_NO_REF_FRAME_MVS (1 << 27) |
Disable ref frame mvs. | |
#define | AOM_EFLAG_ERROR_RESILIENT (1 << 28) |
Enable error resilient frame. | |
#define | AOM_EFLAG_SET_S_FRAME (1 << 29) |
Enable s frame mode. | |
#define | AOM_EFLAG_SET_PRIMARY_REF_NONE (1 << 30) |
Force primary_ref_frame to PRIMARY_REF_NONE. | |
#define | AOM_MAX_SEGMENTS 8 |
Max number of segments. | |
#define | AOM_MAX_LAYERS 32 |
#define | AOM_MAX_SS_LAYERS 4 |
#define | AOM_MAX_TS_LAYERS 8 |
Typedefs | |
typedef void * | aom_ext_part_model_t |
Abstract external partition model handler. | |
typedef enum aom_ext_part_decision_mode | aom_ext_part_decision_mode_t |
Decision mode of the external partition model. AOM_EXT_PART_WHOLE_TREE: the external partition model should provide the whole partition tree for the superblock. | |
typedef struct aom_ext_part_config | aom_ext_part_config_t |
Config information sent to the external partition model. | |
typedef struct aom_partition_features_before_none | aom_partition_features_before_none_t |
Features pass to the external model to make partition decisions. Specifically, features collected before NONE partition. Features "f" are used to determine: partition_none_allowed, partition_horz_allowed, partition_vert_allowed, do_rectangular_split, do_square_split Features "f_part2" are used to determine: prune_horz, prune_vert. | |
typedef struct aom_partition_features_none | aom_partition_features_none_t |
Features pass to the external model to make partition decisions. Specifically, features collected after NONE partition. | |
typedef struct aom_partition_features_split | aom_partition_features_split_t |
Features pass to the external model to make partition decisions. Specifically, features collected after SPLIT partition. | |
typedef struct aom_partition_features_rect | aom_partition_features_rect_t |
Features pass to the external model to make partition decisions. Specifically, features collected after RECTANGULAR partition. | |
typedef struct aom_partition_features_ab | aom_partition_features_ab_t |
Features pass to the external model to make partition decisions. Specifically, features collected after AB partition: HORZ_A, HORZ_B, VERT_A, VERT_B. | |
typedef struct aom_sb_tpl_features | aom_sb_tpl_features_t |
Features collected from the tpl process. | |
typedef struct aom_sb_simple_motion_features | aom_sb_simple_motion_features_t |
Features collected from the simple motion process. | |
typedef struct aom_sb_features | aom_sb_features_t |
Features of each super block. | |
typedef struct aom_partition_features | aom_partition_features_t |
Features pass to the external model to make partition decisions. | |
typedef struct aom_partition_decision | aom_partition_decision_t |
Partition decisions received from the external model. | |
typedef struct aom_partition_stats | aom_partition_stats_t |
Encoding stats for the given partition decision. | |
typedef enum aom_ext_part_status | aom_ext_part_status_t |
Enum for return status. | |
typedef aom_ext_part_status_t(* | aom_ext_part_create_model_fn_t) (void *priv, const aom_ext_part_config_t *part_config, aom_ext_part_model_t *ext_part_model) |
Callback of creating an external partition model. | |
typedef aom_ext_part_status_t(* | aom_ext_part_send_features_fn_t) (aom_ext_part_model_t ext_part_model, const aom_partition_features_t *part_features) |
Callback of sending features to the external partition model. | |
typedef aom_ext_part_status_t(* | aom_ext_part_get_decision_fn_t) (aom_ext_part_model_t ext_part_model, aom_partition_decision_t *ext_part_decision) |
Callback of receiving partition decisions from the external partition model. | |
typedef aom_ext_part_status_t(* | aom_ext_part_send_partition_stats_fn_t) (aom_ext_part_model_t ext_part_model, const aom_partition_stats_t *ext_part_stats) |
Callback of sending stats to the external partition model. | |
typedef aom_ext_part_status_t(* | aom_ext_part_delete_model_fn_t) (aom_ext_part_model_t ext_part_model) |
Callback of deleting the external partition model. | |
typedef struct aom_ext_part_funcs | aom_ext_part_funcs_t |
Callback function set for external partition model. | |
typedef enum aom_scaling_mode_1d | AOM_SCALING_MODE |
aom 1-D scaling mode | |
typedef struct aom_roi_map | aom_roi_map_t |
aom region of interest map | |
typedef struct aom_active_map | aom_active_map_t |
aom active region map | |
typedef struct aom_scaling_mode | aom_scaling_mode_t |
aom image scaling mode | |
typedef struct aom_svc_layer_id | aom_svc_layer_id_t |
typedef struct aom_svc_params | aom_svc_params_t |
typedef struct aom_svc_ref_frame_config | aom_svc_ref_frame_config_t |
typedef struct aom_svc_ref_frame_comp_pred | aom_svc_ref_frame_comp_pred_t |
Algorithm interface for AV1 | |
This interface provides the capability to encode raw AV1 streams. | |
aom_codec_iface_t | aom_codec_av1_cx_algo |
A single instance of the AV1 encoder. | |
aom_codec_iface_t * | aom_codec_av1_cx (void) |
The interface to the AV1 encoder. | |
#define AOM_EFLAG_NO_REF_LAST (1 << 16) |
Don't reference the last frame.
When this flag is set, the encoder will not use the last frame as a predictor. When not set, the encoder will choose whether to use the last frame or not automatically.
#define AOM_EFLAG_NO_REF_LAST2 (1 << 17) |
Don't reference the last2 frame.
When this flag is set, the encoder will not use the last2 frame as a predictor. When not set, the encoder will choose whether to use the last2 frame or not automatically.
#define AOM_EFLAG_NO_REF_LAST3 (1 << 18) |
Don't reference the last3 frame.
When this flag is set, the encoder will not use the last3 frame as a predictor. When not set, the encoder will choose whether to use the last3 frame or not automatically.
#define AOM_EFLAG_NO_REF_GF (1 << 19) |
Don't reference the golden frame.
When this flag is set, the encoder will not use the golden frame as a predictor. When not set, the encoder will choose whether to use the golden frame or not automatically.
#define AOM_EFLAG_NO_REF_ARF (1 << 20) |
Don't reference the alternate reference frame.
When this flag is set, the encoder will not use the alt ref frame as a predictor. When not set, the encoder will choose whether to use the alt ref frame or not automatically.
#define AOM_EFLAG_NO_REF_BWD (1 << 21) |
Don't reference the bwd reference frame.
When this flag is set, the encoder will not use the bwd ref frame as a predictor. When not set, the encoder will choose whether to use the bwd ref frame or not automatically.
#define AOM_EFLAG_NO_REF_ARF2 (1 << 22) |
Don't reference the alt2 reference frame.
When this flag is set, the encoder will not use the alt2 ref frame as a predictor. When not set, the encoder will choose whether to use the alt2 ref frame or not automatically.
#define AOM_EFLAG_NO_UPD_LAST (1 << 23) |
Don't update the last frame.
When this flag is set, the encoder will not update the last frame with the contents of the current frame.
#define AOM_EFLAG_NO_UPD_GF (1 << 24) |
Don't update the golden frame.
When this flag is set, the encoder will not update the golden frame with the contents of the current frame.
#define AOM_EFLAG_NO_UPD_ARF (1 << 25) |
Don't update the alternate reference frame.
When this flag is set, the encoder will not update the alt ref frame with the contents of the current frame.
#define AOM_EFLAG_NO_UPD_ENTROPY (1 << 26) |
Disable entropy update.
When this flag is set, the encoder will not update its internal entropy model based on the entropy of this frame.
#define AOM_EFLAG_NO_REF_FRAME_MVS (1 << 27) |
Disable ref frame mvs.
When this flag is set, the encoder will not allow frames to be encoded using mfmv.
#define AOM_EFLAG_ERROR_RESILIENT (1 << 28) |
Enable error resilient frame.
When this flag is set, the encoder will code frames as error resilient.
#define AOM_EFLAG_SET_S_FRAME (1 << 29) |
Enable s frame mode.
When this flag is set, the encoder will code frames as an s frame.
#define AOM_EFLAG_SET_PRIMARY_REF_NONE (1 << 30) |
Force primary_ref_frame to PRIMARY_REF_NONE.
When this flag is set, the encoder will set a frame's primary_ref_frame to PRIMARY_REF_NONE
#define AOM_MAX_SEGMENTS 8 |
Max number of segments.
This is the limit of number of segments allowed within a frame.
Currently same as "MAX_SEGMENTS" in AV1, the maximum that AV1 supports.
#define AOM_MAX_LAYERS 32 |
Max number of layers
#define AOM_MAX_SS_LAYERS 4 |
Max number of spatial layers
#define AOM_MAX_TS_LAYERS 8 |
Max number of temporal layers
typedef enum aom_ext_part_decision_mode aom_ext_part_decision_mode_t |
Decision mode of the external partition model. AOM_EXT_PART_WHOLE_TREE: the external partition model should provide the whole partition tree for the superblock.
AOM_EXT_PART_RECURSIVE: the external partition model provides the partition decision of the current block only. The decision process starts from the superblock size, down to the smallest block size (4x4) recursively.
typedef struct aom_ext_part_config aom_ext_part_config_t |
Config information sent to the external partition model.
For example, the maximum superblock size determined by the sequence header.
typedef struct aom_sb_tpl_features aom_sb_tpl_features_t |
Features collected from the tpl process.
The tpl process collects information that help measure the inter-frame dependency. The tpl process is computed in the unit of tpl_bsize_1d (16x16). Therefore, the max number of units inside a superblock is 128x128 / (16x16) = 64. Change it if the tpl process changes.
typedef struct aom_sb_simple_motion_features aom_sb_simple_motion_features_t |
Features collected from the simple motion process.
The simple motion process collects information by applying motion compensated prediction on each block. The block size is 16x16, which could be changed. If it is changed, update comments and the array size here.
typedef struct aom_sb_features aom_sb_features_t |
Features of each super block.
Features collected for each super block before partition search.
typedef struct aom_partition_features aom_partition_features_t |
Features pass to the external model to make partition decisions.
The encoder sends these features to the external model through "func()" defined in .....
NOTE: new member variables may be added to this structure in the future. Once new features are finalized, bump the major version of libaom.
typedef struct aom_partition_decision aom_partition_decision_t |
Partition decisions received from the external model.
The encoder receives partition decisions and encodes the superblock with the given partition type. The encoder receives it from "func()" define in ....
NOTE: new member variables may be added to this structure in the future. Once new features are finalized, bump the major version of libaom.
typedef struct aom_partition_stats aom_partition_stats_t |
Encoding stats for the given partition decision.
The encoding stats collected by encoding the superblock with the given partition types. The encoder sends the stats to the external model for training or inference through "func()" defined in ....
typedef aom_ext_part_status_t(* aom_ext_part_create_model_fn_t) (void *priv, const aom_ext_part_config_t *part_config, aom_ext_part_model_t *ext_part_model) |
Callback of creating an external partition model.
The callback is invoked by the encoder to create an external partition model.
[in] | priv | Callback's private data |
[in] | part_config | Config information pointer for model creation |
[out] | ext_part_model | Pointer to the model |
typedef aom_ext_part_status_t(* aom_ext_part_send_features_fn_t) (aom_ext_part_model_t ext_part_model, const aom_partition_features_t *part_features) |
Callback of sending features to the external partition model.
The callback is invoked by the encoder to send features to the external partition model.
[in] | ext_part_model | The external model |
[in] | part_features | Pointer to the features |
typedef aom_ext_part_status_t(* aom_ext_part_get_decision_fn_t) (aom_ext_part_model_t ext_part_model, aom_partition_decision_t *ext_part_decision) |
Callback of receiving partition decisions from the external partition model.
The callback is invoked by the encoder to receive partition decisions from the external partition model.
[in] | ext_part_model | The external model |
[in] | ext_part_decision | Pointer to the partition decisions |
typedef aom_ext_part_status_t(* aom_ext_part_send_partition_stats_fn_t) (aom_ext_part_model_t ext_part_model, const aom_partition_stats_t *ext_part_stats) |
Callback of sending stats to the external partition model.
The callback is invoked by the encoder to send encoding stats to the external partition model.
[in] | ext_part_model | The external model |
[in] | ext_part_stats | Pointer to the encoding stats |
typedef aom_ext_part_status_t(* aom_ext_part_delete_model_fn_t) (aom_ext_part_model_t ext_part_model) |
Callback of deleting the external partition model.
The callback is invoked by the encoder to delete the external partition model.
[in] | ext_part_model | The external model |
typedef struct aom_ext_part_funcs aom_ext_part_funcs_t |
Callback function set for external partition model.
Uses can enable external partition model by registering a set of callback functions with the flag: AV1E_SET_EXTERNAL_PARTITION_MODEL
typedef enum aom_scaling_mode_1d AOM_SCALING_MODE |
aom 1-D scaling mode
This set of constants define 1-D aom scaling modes
typedef struct aom_roi_map aom_roi_map_t |
aom region of interest map
These defines the data structures for the region of interest map
TODO(yaowu): create a unit test for ROI map related APIs
typedef struct aom_active_map aom_active_map_t |
aom active region map
These defines the data structures for active region map
typedef struct aom_scaling_mode aom_scaling_mode_t |
aom image scaling mode
This defines the data structure for image scaling mode
typedef struct aom_svc_layer_id aom_svc_layer_id_t |
brief Struct for spatial and temporal layer ID
typedef struct aom_svc_params aom_svc_params_t |
brief Parameter type for SVC
In the arrays of size AOM_MAX_LAYERS, the index for spatial layer sl
and temporal layer tl
is sl * number_temporal_layers + tl.
typedef struct aom_svc_ref_frame_config aom_svc_ref_frame_config_t |
brief Parameters for setting ref frame config
typedef struct aom_svc_ref_frame_comp_pred aom_svc_ref_frame_comp_pred_t |
brief Parameters for setting ref frame compound prediction
Decision mode of the external partition model. AOM_EXT_PART_WHOLE_TREE: the external partition model should provide the whole partition tree for the superblock.
AOM_EXT_PART_RECURSIVE: the external partition model provides the partition decision of the current block only. The decision process starts from the superblock size, down to the smallest block size (4x4) recursively.
enum aom_ext_part_status |
enum aome_enc_control_id |
AVx encoder control functions.
This set of macros define the control functions available for AVx encoder interface. The range of encode control ID is 7-229(max).
Enumerator | |
---|---|
AOME_USE_REFERENCE | Codec control function to set which reference frame encoder can use, int parameter. |
AOME_SET_ROI_MAP | Codec control function to pass an ROI map to encoder, aom_roi_map_t* parameter. |
AOME_SET_ACTIVEMAP | Codec control function to pass an Active map to encoder, aom_active_map_t* parameter. |
AOME_SET_SCALEMODE | Codec control function to set encoder scaling mode for the next frame to be coded, aom_scaling_mode_t* parameter. |
AOME_SET_SPATIAL_LAYER_ID | Codec control function to set encoder spatial layer id, int parameter. |
AOME_SET_CPUUSED | Codec control function to set encoder internal speed settings, int parameter. Changes in this value influences the complexity of algorithms used in encoding process, values greater than 0 will increase encoder speed at the expense of quality. Valid range: 0..11. 0 runs the slowest, and 11 runs the fastest; quality improves as speed decreases (since more compression possibilities are explored). NOTE: 10 and 11 are only allowed in AOM_USAGE_REALTIME. In AOM_USAGE_GOOD_QUALITY and AOM_USAGE_ALL_INTRA, 9 is the highest allowed value. However, AOM_USAGE_GOOD_QUALITY treats 7..9 the same as 6. Also, AOM_USAGE_REALTIME treats 0..4 the same as 5. |
AOME_SET_ENABLEAUTOALTREF | Codec control function to enable automatic set and use alf frames, unsigned int parameter.
|
AOME_SET_SHARPNESS | Codec control function to set the sharpness parameter, unsigned int parameter. This parameter controls the level at which rate-distortion optimization of transform coefficients favours sharpness in the block. Valid range: 0..7. The default is 0. Values 1-7 will avoid eob and skip block optimization and will change rdmult in favour of block sharpness. |
AOME_SET_STATIC_THRESHOLD | Codec control function to set the threshold for MBs treated static, unsigned int parameter. |
AOME_GET_LAST_QUANTIZER | Codec control function to get last quantizer chosen by the encoder, int* parameter. Return value uses internal quantizer scale defined by the codec. |
AOME_GET_LAST_QUANTIZER_64 | Codec control function to get last quantizer chosen by the encoder, int* parameter. Return value uses the 0..63 scale as used by the rc_*_quantizer config parameters. |
AOME_SET_ARNR_MAXFRAMES | Codec control function to set the max no of frames to create arf, unsigned int parameter. |
AOME_SET_ARNR_STRENGTH | Codec control function to set the filter strength for the arf, unsigned int parameter. |
AOME_SET_TUNING | Codec control function to set visual tuning, aom_tune_metric (int) parameter. The default is AOM_TUNE_PSNR. |
AOME_SET_CQ_LEVEL | Codec control function to set constrained / constant quality level, unsigned int parameter. Valid range: 0..63
|
AOME_SET_MAX_INTRA_BITRATE_PCT | Codec control function to set max data rate for intra frames, unsigned int parameter. This value controls additional clamping on the maximum size of a keyframe. It is expressed as a percentage of the average per-frame bitrate, with the special (and default) value 0 meaning unlimited, or no additional clamping beyond the codec's built-in algorithm. For example, to allocate no more than 4.5 frames worth of bitrate to a keyframe, set this to 450. |
AOME_SET_NUMBER_SPATIAL_LAYERS | Codec control function to set number of spatial layers, int parameter. |
AV1E_SET_MAX_INTER_BITRATE_PCT | Codec control function to set max data rate for inter frames, unsigned int parameter. This value controls additional clamping on the maximum size of an inter frame. It is expressed as a percentage of the average per-frame bitrate, with the special (and default) value 0 meaning unlimited, or no additional clamping beyond the codec's built-in algorithm. For example, to allow no more than 4.5 frames worth of bitrate to an inter frame, set this to 450. |
AV1E_SET_GF_CBR_BOOST_PCT | Boost percentage for Golden Frame in CBR mode, unsigned int parameter. This value controls the amount of boost given to Golden Frame in CBR mode. It is expressed as a percentage of the average per-frame bitrate, with the special (and default) value 0 meaning the feature is off, i.e., no golden frame boost in CBR mode and average bitrate target is used. For example, to allow 100% more bits, i.e, 2X, in a golden frame than average frame, set this to 100. |
AV1E_SET_LOSSLESS | Codec control function to set lossless encoding mode, unsigned int parameter. AV1 can operate in lossless encoding mode, in which the bitstream produced will be able to decode and reconstruct a perfect copy of input source.
|
AV1E_SET_ROW_MT | Codec control function to enable the row based multi-threading of the encoder, unsigned int parameter.
|
AV1E_SET_TILE_COLUMNS | Codec control function to set number of tile columns. unsigned int parameter. In encoding and decoding, AV1 allows an input image frame be partitioned into separate vertical tile columns, which can be encoded or decoded independently. This enables easy implementation of parallel encoding and decoding. The parameter for this control describes the number of tile columns (in log2 units), which has a valid range of [0, 6]: 0 = 1 tile column 1 = 2 tile columns 2 = 4 tile columns ..... n = 2**n tile columns By default, the value is 0, i.e. one single column tile for entire image. |
AV1E_SET_TILE_ROWS | Codec control function to set number of tile rows, unsigned int parameter. In encoding and decoding, AV1 allows an input image frame be partitioned into separate horizontal tile rows, which can be encoded or decoded independently. The parameter for this control describes the number of tile rows (in log2 units), which has a valid range of [0, 6]: 0 = 1 tile row 1 = 2 tile rows 2 = 4 tile rows ..... n = 2**n tile rows By default, the value is 0, i.e. one single row tile for entire image. |
AV1E_SET_ENABLE_TPL_MODEL | Codec control function to enable RDO modulated by frame temporal dependency, unsigned int parameter.
|
AV1E_SET_ENABLE_KEYFRAME_FILTERING | Codec control function to enable temporal filtering on key frame, unsigned int parameter.
|
AV1E_SET_FRAME_PARALLEL_DECODING | Codec control function to enable frame parallel decoding feature, unsigned int parameter. AV1 has a bitstream feature to reduce decoding dependency between frames by turning off backward update of probability context used in encoding and decoding. This allows staged parallel processing of more than one video frames in the decoder. This control function provides a means to turn this feature on or off for bitstreams produced by encoder.
|
AV1E_SET_ERROR_RESILIENT_MODE | Codec control function to enable error_resilient_mode, int parameter. AV1 has a bitstream feature to guarantee parsability of a frame by turning on the error_resilient_decoding mode, even though the reference buffers are unreliable or not received.
|
AV1E_SET_S_FRAME_MODE | Codec control function to enable s_frame_mode, int parameter. AV1 has a bitstream feature to designate certain frames as S-frames, from where we can switch to a different stream, even though the reference buffers may not be exactly identical.
|
AV1E_SET_AQ_MODE | Codec control function to set adaptive quantization mode, unsigned int parameter. AV1 has a segment based feature that allows encoder to adaptively change quantization parameter for each segment within a frame to improve the subjective quality. This control makes encoder operate in one of the several AQ modes supported.
|
AV1E_SET_FRAME_PERIODIC_BOOST | Codec control function to enable/disable periodic Q boost, unsigned int parameter. One AV1 encoder speed feature is to enable quality boost by lowering frame level Q periodically. This control function provides a means to turn on/off this feature.
|
AV1E_SET_NOISE_SENSITIVITY | Codec control function to set noise sensitivity, unsigned int parameter.
|
AV1E_SET_TUNE_CONTENT | Codec control function to set content type, aom_tune_content parameter.
|
AV1E_SET_CDF_UPDATE_MODE | Codec control function to set CDF update mode, unsigned int parameter.
|
AV1E_SET_COLOR_PRIMARIES | Codec control function to set color space info, int parameter.
|
AV1E_SET_TRANSFER_CHARACTERISTICS | Codec control function to set transfer function info, int parameter.
|
AV1E_SET_MATRIX_COEFFICIENTS | Codec control function to set transfer function info, int parameter.
|
AV1E_SET_CHROMA_SAMPLE_POSITION | Codec control function to set chroma 4:2:0 sample position info, aom_chroma_sample_position_t parameter. AOM_CSP_UNKNOWN is default |
AV1E_SET_MIN_GF_INTERVAL | Codec control function to set minimum interval between GF/ARF frames, unsigned int parameter. By default the value is set as 4. |
AV1E_SET_MAX_GF_INTERVAL | Codec control function to set minimum interval between GF/ARF frames, unsigned int parameter. By default the value is set as 16. |
AV1E_GET_ACTIVEMAP | Codec control function to get an active map back from the encoder, aom_active_map_t* parameter. |
AV1E_SET_COLOR_RANGE | Codec control function to set color range bit, int parameter.
|
AV1E_SET_RENDER_SIZE | Codec control function to set intended rendering image size, int32_t[2] parameter. By default, this is identical to the image size in pixels. |
AV1E_SET_TARGET_SEQ_LEVEL_IDX | Control to set target sequence level index for a certain operating point (OP), int parameter Possible values are in the form of "ABxy".
E.g.:
If the target level is not specified for an OP, the maximum parameters level of 31 is used as default. |
AV1E_GET_SEQ_LEVEL_IDX | Codec control function to get sequence level index for each operating point. int* parameter. There can be at most 32 operating points. The results will be written into a provided integer array of sufficient size. |
AV1E_SET_SUPERBLOCK_SIZE | Codec control function to set intended superblock size, unsigned int parameter. By default, the superblock size is determined separately for each frame by the encoder. |
AOME_SET_ENABLEAUTOBWDREF | Codec control function to enable automatic set and use of bwd-pred frames, unsigned int parameter.
|
AV1E_SET_ENABLE_CDEF | Codec control function to encode with CDEF, unsigned int parameter. CDEF is the constrained directional enhancement filter which is an in-loop filter aiming to remove coding artifacts
|
AV1E_SET_ENABLE_RESTORATION | Codec control function to encode with Loop Restoration Filter, unsigned int parameter.
|
AV1E_SET_FORCE_VIDEO_MODE | Codec control function to force video mode, unsigned int parameter.
|
AV1E_SET_ENABLE_OBMC | Codec control function to predict with OBMC mode, unsigned int parameter.
|
AV1E_SET_DISABLE_TRELLIS_QUANT | Codec control function to encode without trellis quantization, unsigned int parameter.
|
AV1E_SET_ENABLE_QM | Codec control function to encode with quantisation matrices, unsigned int parameter. AOM can operate with default quantisation matrices dependent on quantisation level and block type.
|
AV1E_SET_QM_MIN | Codec control function to set the min quant matrix flatness, unsigned int parameter. AOM can operate with different ranges of quantisation matrices. As quantisation levels increase, the matrices get flatter. This control sets the minimum level of flatness from which the matrices are determined. By default, the encoder sets this minimum at half the available range. |
AV1E_SET_QM_MAX | Codec control function to set the max quant matrix flatness, unsigned int parameter. AOM can operate with different ranges of quantisation matrices. As quantisation levels increase, the matrices get flatter. This control sets the maximum level of flatness possible. By default, the encoder sets this maximum at the top of the available range. |
AV1E_SET_QM_Y | Codec control function to set the min quant matrix flatness, unsigned int parameter. AOM can operate with different ranges of quantisation matrices. As quantisation levels increase, the matrices get flatter. This control sets the flatness for luma (Y). By default, the encoder sets this minimum at half the available range. |
AV1E_SET_QM_U | Codec control function to set the min quant matrix flatness, unsigned int parameter. AOM can operate with different ranges of quantisation matrices. As quantisation levels increase, the matrices get flatter. This control sets the flatness for chroma (U). By default, the encoder sets this minimum at half the available range. |
AV1E_SET_QM_V | Codec control function to set the min quant matrix flatness, unsigned int parameter. AOM can operate with different ranges of quantisation matrices. As quantisation levels increase, the matrices get flatter. This control sets the flatness for chrome (V). By default, the encoder sets this minimum at half the available range. |
AV1E_SET_NUM_TG | Codec control function to set a maximum number of tile groups, unsigned int parameter. This will set the maximum number of tile groups. This will be overridden if an MTU size is set. The default value is 1. |
AV1E_SET_MTU | Codec control function to set an MTU size for a tile group, unsigned int parameter. This will set the maximum number of bytes in a tile group. This can be exceeded only if a single tile is larger than this amount. By default, the value is 0, in which case a fixed number of tile groups is used. |
AV1E_SET_ENABLE_RECT_PARTITIONS | Codec control function to enable/disable rectangular partitions, int parameter.
|
AV1E_SET_ENABLE_AB_PARTITIONS | Codec control function to enable/disable AB partitions, int parameter.
|
AV1E_SET_ENABLE_1TO4_PARTITIONS | Codec control function to enable/disable 1:4 and 4:1 partitions, int parameter.
|
AV1E_SET_MIN_PARTITION_SIZE | Codec control function to set min partition size, int parameter. min_partition_size is applied to both width and height of the partition. i.e, both width and height of a partition can not be smaller than the min_partition_size, except the partition at the picture boundary. Valid values: [4, 8, 16, 32, 64, 128]. The default value is 4 for 4x4. |
AV1E_SET_MAX_PARTITION_SIZE | Codec control function to set max partition size, int parameter. max_partition_size is applied to both width and height of the partition. i.e, both width and height of a partition can not be larger than the max_partition_size. Valid values:[4, 8, 16, 32, 64, 128] The default value is 128 for 128x128. |
AV1E_SET_ENABLE_INTRA_EDGE_FILTER | Codec control function to turn on / off intra edge filter at sequence level, int parameter.
|
AV1E_SET_ENABLE_ORDER_HINT | Codec control function to turn on / off frame order hint (int parameter). Affects: joint compound mode, motion field motion vector, ref frame sign bias.
|
AV1E_SET_ENABLE_TX64 | Codec control function to turn on / off 64-length transforms, int parameter. This will enable or disable usage of length 64 transforms in any direction.
|
AV1E_SET_ENABLE_FLIP_IDTX | Codec control function to turn on / off flip and identity transforms, int parameter. This will enable or disable usage of flip and identity transform types in any direction. If enabled, this includes:
Valid values:
|
AV1E_SET_ENABLE_RECT_TX | Codec control function to turn on / off rectangular transforms, int parameter. This will enable or disable usage of rectangular transforms. NOTE: Rectangular transforms only enabled when corresponding rectangular partitions are.
|
AV1E_SET_ENABLE_DIST_WTD_COMP | Codec control function to turn on / off dist-wtd compound mode at sequence level, int parameter. This will enable or disable distance-weighted compound mode.
|
AV1E_SET_ENABLE_REF_FRAME_MVS | Codec control function to turn on / off ref frame mvs (mfmv) usage at sequence level, int parameter.
|
AV1E_SET_ALLOW_REF_FRAME_MVS | Codec control function to set temporal mv prediction enabling/disabling at frame level, int parameter.
|
AV1E_SET_ENABLE_DUAL_FILTER | Codec control function to turn on / off dual interpolation filter for a sequence, int parameter.
|
AV1E_SET_ENABLE_CHROMA_DELTAQ | Codec control function to turn on / off delta quantization in chroma planes for a sequence, int parameter.
|
AV1E_SET_ENABLE_MASKED_COMP | Codec control function to turn on / off masked compound usage (wedge and diff-wtd compound modes) for a sequence, int parameter.
|
AV1E_SET_ENABLE_ONESIDED_COMP | Codec control function to turn on / off one sided compound usage for a sequence, int parameter.
|
AV1E_SET_ENABLE_INTERINTRA_COMP | Codec control function to turn on / off interintra compound for a sequence, int parameter.
|
AV1E_SET_ENABLE_SMOOTH_INTERINTRA | Codec control function to turn on / off smooth inter-intra mode for a sequence, int parameter.
|
AV1E_SET_ENABLE_DIFF_WTD_COMP | Codec control function to turn on / off difference weighted compound, int parameter.
|
AV1E_SET_ENABLE_INTERINTER_WEDGE | Codec control function to turn on / off interinter wedge compound, int parameter.
|
AV1E_SET_ENABLE_INTERINTRA_WEDGE | Codec control function to turn on / off interintra wedge compound, int parameter.
|
AV1E_SET_ENABLE_GLOBAL_MOTION | Codec control function to turn on / off global motion usage for a sequence, int parameter.
|
AV1E_SET_ENABLE_WARPED_MOTION | Codec control function to turn on / off warped motion usage at sequence level, int parameter.
|
AV1E_SET_ALLOW_WARPED_MOTION | Codec control function to turn on / off warped motion usage at frame level, int parameter.
|
AV1E_SET_ENABLE_FILTER_INTRA | Codec control function to turn on / off filter intra usage at sequence level, int parameter.
|
AV1E_SET_ENABLE_SMOOTH_INTRA | Codec control function to turn on / off smooth intra modes usage, int parameter. This will enable or disable usage of smooth, smooth_h and smooth_v intra modes.
|
AV1E_SET_ENABLE_PAETH_INTRA | Codec control function to turn on / off Paeth intra mode usage, int parameter.
|
AV1E_SET_ENABLE_CFL_INTRA | Codec control function to turn on / off CFL uv intra mode usage, int parameter. This will enable or disable usage of chroma-from-luma intra mode.
|
AV1E_SET_ENABLE_SUPERRES | Codec control function to turn on / off frame superresolution, int parameter.
|
AV1E_SET_ENABLE_OVERLAY | Codec control function to turn on / off overlay frames for filtered ALTREF frames, int parameter. This will enable or disable coding of overlay frames for filtered ALTREF frames. When set to 0, overlay frames are not used but show existing frame is used to display the filtered ALTREF frame as is. As a result the decoded frame rate remains the same as the display frame rate. The default is 1. |
AV1E_SET_ENABLE_PALETTE | Codec control function to turn on/off palette mode, int parameter. |
AV1E_SET_ENABLE_INTRABC | Codec control function to turn on/off intra block copy mode, int parameter. |
AV1E_SET_ENABLE_ANGLE_DELTA | Codec control function to turn on/off intra angle delta, int parameter. |
AV1E_SET_DELTAQ_MODE | Codec control function to set the delta q mode, unsigned int parameter. AV1 supports a delta q mode feature, that allows modulating q per superblock.
|
AV1E_SET_DELTALF_MODE | Codec control function to turn on/off loopfilter modulation when delta q modulation is enabled, unsigned int parameter.
|
AV1E_SET_SINGLE_TILE_DECODING | Codec control function to set the single tile decoding mode, unsigned int parameter.
|
AV1E_ENABLE_MOTION_VECTOR_UNIT_TEST | Codec control function to enable the extreme motion vector unit test, unsigned int parameter.
|
AV1E_SET_TIMING_INFO_TYPE | Codec control function to signal picture timing info in the bitstream, aom_timing_info_type_t parameter. Default is AOM_TIMING_UNSPECIFIED. |
AV1E_SET_FILM_GRAIN_TEST_VECTOR | Codec control function to add film grain parameters (one of several preset types) info in the bitstream, int parameter. Valid range: 0..16, 0 is unknown, 1..16 are test vectors |
AV1E_SET_FILM_GRAIN_TABLE | Codec control function to set the path to the film grain parameters, const char* parameter. |
AV1E_SET_DENOISE_NOISE_LEVEL | Sets the noise level, int parameter. |
AV1E_SET_DENOISE_BLOCK_SIZE | Sets the denoisers block size, unsigned int parameter. |
AV1E_SET_CHROMA_SUBSAMPLING_X | Sets the chroma subsampling x value, unsigned int parameter. |
AV1E_SET_CHROMA_SUBSAMPLING_Y | Sets the chroma subsampling y value, unsigned int parameter. |
AV1E_SET_REDUCED_TX_TYPE_SET | Control to use a reduced tx type set, int parameter. |
AV1E_SET_INTRA_DCT_ONLY | Control to use dct only for intra modes, int parameter. |
AV1E_SET_INTER_DCT_ONLY | Control to use dct only for inter modes, int parameter. |
AV1E_SET_INTRA_DEFAULT_TX_ONLY | Control to use default tx type only for intra modes, int parameter. |
AV1E_SET_QUANT_B_ADAPT | Control to use adaptive quantize_b, int parameter. |
AV1E_SET_GF_MAX_PYRAMID_HEIGHT | Control to select maximum height for the GF group pyramid structure, unsigned int parameter. Valid range: 0..5 |
AV1E_SET_MAX_REFERENCE_FRAMES | Control to select maximum reference frames allowed per frame, int parameter. Valid range: 3..7 |
AV1E_SET_REDUCED_REFERENCE_SET | Control to use reduced set of single and compound references, int parameter. |
AV1E_SET_COEFF_COST_UPD_FREQ | Control to set frequency of the cost updates for coefficients, unsigned int parameter.
|
AV1E_SET_MODE_COST_UPD_FREQ | Control to set frequency of the cost updates for mode, unsigned int parameter.
|
AV1E_SET_MV_COST_UPD_FREQ | Control to set frequency of the cost updates for motion vectors, unsigned int parameter.
|
AV1E_SET_TIER_MASK | Control to set bit mask that specifies which tier each of the 32 possible operating points conforms to, unsigned int parameter.
|
AV1E_SET_MIN_CR | Control to set minimum compression ratio, unsigned int parameter Take integer values. If non-zero, encoder will try to keep the compression ratio of each frame to be higher than the given value divided by 100. E.g. 850 means minimum compression ratio of 8.5. |
AV1E_SET_SVC_LAYER_ID | Codec control function to set the layer id, aom_svc_layer_id_t* parameter. |
AV1E_SET_SVC_PARAMS | Codec control function to set SVC parameters, aom_svc_params_t* parameter. |
AV1E_SET_SVC_REF_FRAME_CONFIG | Codec control function to set the reference frame config, aom_svc_ref_frame_config_t* parameter. |
AV1E_SET_VMAF_MODEL_PATH | Codec control function to set the path to the VMAF model used when tuning the encoder for VMAF, const char* parameter. |
AV1E_ENABLE_EXT_TILE_DEBUG | Codec control function to enable EXT_TILE_DEBUG in AV1 encoder, unsigned int parameter.
|
AV1E_ENABLE_SB_MULTIPASS_UNIT_TEST | Codec control function to enable the superblock multipass unit test in AV1 to ensure that the encoder does not leak state between different passes. unsigned int parameter.
|
AV1E_SET_GF_MIN_PYRAMID_HEIGHT | Control to select minimum height for the GF group pyramid structure, unsigned int parameter. Valid values: 0..5 |
AV1E_SET_VBR_CORPUS_COMPLEXITY_LAP | Control to set average complexity of the corpus in the case of single pass vbr based on LAP, unsigned int parameter. |
AV1E_GET_BASELINE_GF_INTERVAL | Control to get baseline gf interval. |
AV1E_SET_ENABLE_DIAGONAL_INTRA | Codec control function to turn on / off D45 to D203 intra mode usage, int parameter. This will enable or disable usage of D45 to D203 intra modes, which are a subset of directional modes. This control has no effect if directional modes are disabled (AV1E_SET_ENABLE_DIRECTIONAL_INTRA set to 0).
|
AV1E_SET_DV_COST_UPD_FREQ | Control to set frequency of the cost updates for intrabc motion vectors, unsigned int parameter.
|
AV1E_SET_PARTITION_INFO_PATH | Codec control to set the path for partition stats read and write. const char * parameter. |
AV1E_SET_EXTERNAL_PARTITION | Codec control to use an external partition model A set of callback functions is passed through this control to let the encoder encode with given partitions. |
AV1E_SET_ENABLE_DIRECTIONAL_INTRA | Codec control function to turn on / off directional intra mode usage, int parameter.
|
AV1E_SET_ENABLE_TX_SIZE_SEARCH | Control to turn on / off transform size search. Note: it can not work with non RD pick mode in real-time encoding, where the max transform size is only 16x16. It will be ignored if non RD pick mode is set.
|
AV1E_SET_SVC_REF_FRAME_COMP_PRED | Codec control function to set reference frame compound prediction. aom_svc_ref_frame_comp_pred_t* parameter. |
AV1E_SET_DELTAQ_STRENGTH | Set –deltaq-mode strength. Valid range: [0, 1000] |
AV1E_SET_LOOPFILTER_CONTROL | Codec control to control loop filter.
|
AOME_GET_LOOPFILTER_LEVEL | Codec control function to get the loopfilter chosen by the encoder, int* parameter. |
AV1E_SET_AUTO_INTRA_TOOLS_OFF | Codec control to automatically turn off several intra coding tools, unsigned int parameter.
|
AV1E_SET_RTC_EXTERNAL_RC | Codec control function to set flag for rate control used by external encoders.
|
AV1E_SET_FP_MT | Codec control function to enable frame parallel multi-threading of the encoder, unsigned int parameter.
|
AV1E_SET_FP_MT_UNIT_TEST | Codec control to enable actual frame parallel encode or simulation of frame parallel encode in FPMT unit test, unsigned int parameter.
|
AV1E_GET_TARGET_SEQ_LEVEL_IDX | Codec control function to get the target sequence level index for each operating point. int* parameter. There can be at most 32 operating points. The results will be written into a provided integer array of sufficient size. If a target level is not set, the result will be 31. Please refer to https://aomediacodec.github.io/av1-spec/#levels for more details on level definitions and indices. |
AV1E_GET_NUM_OPERATING_POINTS | Codec control function to get the number of operating points. int* parameter. |
AV1E_SET_SKIP_POSTPROC_FILTERING | Codec control function to skip the application of post-processing filters on reconstructed frame, unsigned int parameter.
|
AV1E_ENABLE_SB_QP_SWEEP | Codec control function to enable the superblock level qp sweep in AV1 to ensure that end-to-end test runs well, unsigned int parameter.
|
AV1E_SET_QUANTIZER_ONE_PASS | Codec control to set quantizer for the next frame, int parameter.
This will turn off cyclic refresh. Only applicable to 1-pass. |
AV1E_ENABLE_RATE_GUIDE_DELTAQ | Codec control to enable the rate distribution guided delta quantization in all intra mode, unsigned int parameter.
|
AV1E_SET_RATE_DISTRIBUTION_INFO | Codec control to set the input file for rate distribution used in all intra mode, const char * parameter The input should be the name of a text file, which contains (rows x cols) float values separated by space. Each float value represent the number of bits for each 16x16 block. rows = (frame_height + 15) / 16 cols = (frame_width + 15) / 16.
|
AV1E_GET_LUMA_CDEF_STRENGTH | Codec control to get the CDEF strength for Y / luma plane, int * parameter. Returns an integer array of CDEF_MAX_STRENGTHS elements. |
AV1E_SET_BITRATE_ONE_PASS_CBR | Codec control to set the target bitrate in kilobits per second, unsigned int parameter. For 1 pass CBR mode, single layer encoding. This controls replaces the call aom_codec_enc_config_set(&codec, &cfg) when only target bitrate is changed, and so is much cheaper as it bypasses a lot of unneeded code checks. |
AV1E_SET_MAX_CONSEC_FRAME_DROP_CBR | Codec control to set the maximum number of consecutive frame drops, in units of frames, allowed for the frame dropper in 1 pass CBR mode, int parameter. Value of zero has no effect.
|
AV1E_SET_SVC_FRAME_DROP_MODE | Codec control to set the frame drop mode for SVC, unsigned int parameter. The valid values are constants of the AOM_SVC_FRAME_DROP_MODE enum: AOM_LAYER_DROP or AOM_FULL_SUPERFRAME_DROP. |
AV1E_SET_AUTO_TILES | Codec control to set auto tiling, unsigned int parameter. Value of 1 means encoder will set number of tile_columns and tile_rows, based on the number of threads and resolution. This will override any settings set via SET_TILE_COLUMNS/ROWS. If the value is 0 no change is done, the previous setting (if any) for tile_columns/rows is preserved. |
AV1E_GET_HIGH_MOTION_CONTENT_SCREEN_RTC | Codec control to get the high motion content flag, used for screen content realtime (RTC) encoding, int * parameter. Returns an integer. 1 means high motion content flag is set to 1, 0 means set to 0. |
AV1E_SET_POSTENCODE_DROP_RTC | Codec control to enable post encode frame drop for RTC encoding, int parameter. Value of 1 means encoder will enable post encode drop. Default is 0 (not enabled). Post encode drop is only allowed when frame dropping is enabled (aom_codec_enc_cfg::rc_dropframe_thresh > 0). |
AV1E_SET_MAX_CONSEC_FRAME_DROP_MS_CBR | Codec control to set the maximum number of consecutive frame drops, in units of time (milliseconds), allowed for the frame dropper in 1 pass CBR mode, int parameter. Value of zero has no effect. |
enum aom_scaling_mode_1d |
aom 1-D scaling mode
This set of constants define 1-D aom scaling modes
enum aom_tune_content |
brief AV1 encoder content type
brief AV1 encoder timing info type signaling
enum aom_tune_metric |
Model tuning parameters.
Changes the encoder to tune for certain types of input material.
enum aom_dist_metric |
Distortion metric to use for RD optimization.
Changes the encoder to use a different distortion metric for RD search. Note that this value operates on a "lower level" compared to aom_tune_metric - it affects the distortion metric inside a block, while aom_tune_metric only affects RD across blocks.
brief Frame drop modes for spatial/quality layer SVC
Enumerator | |
---|---|
AOM_LAYER_DROP | Any spatial layer can drop. |
AOM_FULL_SUPERFRAME_DROP | Only full superframe can drop. |
|
extern |
A single instance of the AV1 encoder.