12 #ifndef AOM_AV1_COMMON_BLOCKD_H_ 13 #define AOM_AV1_COMMON_BLOCKD_H_ 15 #include "config/aom_config.h" 17 #include "aom_dsp/aom_dsp_common.h" 18 #include "aom_ports/mem.h" 19 #include "aom_scale/yv12config.h" 21 #include "av1/common/common_data.h" 22 #include "av1/common/quant_common.h" 23 #include "av1/common/entropy.h" 24 #include "av1/common/entropymode.h" 25 #include "av1/common/mv.h" 26 #include "av1/common/scale.h" 27 #include "av1/common/seg_common.h" 28 #include "av1/common/tile_common.h" 34 #define USE_B_QUANT_NO_TRELLIS 1 36 #define MAX_MB_PLANE 3 38 #define MAX_DIFFWTD_MASK_BITS 1 40 #define INTERINTRA_WEDGE_SIGN 0 49 } UENUM1BYTE(DIFFWTD_MASK_TYPE);
57 } UENUM1BYTE(FRAME_TYPE);
59 static INLINE
int is_comp_ref_allowed(BLOCK_SIZE bsize) {
60 return AOMMIN(block_size_wide[bsize], block_size_high[bsize]) >= 8;
63 static INLINE
int is_inter_mode(PREDICTION_MODE mode) {
64 return mode >= INTER_MODE_START && mode < INTER_MODE_END;
68 uint8_t *plane[MAX_MB_PLANE];
69 int stride[MAX_MB_PLANE];
72 static INLINE
int is_inter_singleref_mode(PREDICTION_MODE mode) {
73 return mode >= SINGLE_INTER_MODE_START && mode < SINGLE_INTER_MODE_END;
75 static INLINE
int is_inter_compound_mode(PREDICTION_MODE mode) {
76 return mode >= COMP_INTER_MODE_START && mode < COMP_INTER_MODE_END;
79 static INLINE PREDICTION_MODE compound_ref0_mode(PREDICTION_MODE mode) {
80 static const PREDICTION_MODE lut[] = {
107 assert(NELEMENTS(lut) == MB_MODE_COUNT);
108 assert(is_inter_compound_mode(mode) || is_inter_singleref_mode(mode));
112 static INLINE PREDICTION_MODE compound_ref1_mode(PREDICTION_MODE mode) {
113 static const PREDICTION_MODE lut[] = {
140 assert(NELEMENTS(lut) == MB_MODE_COUNT);
141 assert(is_inter_compound_mode(mode));
145 static INLINE
int have_nearmv_in_inter_mode(PREDICTION_MODE mode) {
146 return (mode == NEARMV || mode == NEAR_NEARMV || mode == NEAR_NEWMV ||
150 static INLINE
int have_newmv_in_inter_mode(PREDICTION_MODE mode) {
151 return (mode == NEWMV || mode == NEW_NEWMV || mode == NEAREST_NEWMV ||
152 mode == NEW_NEARESTMV || mode == NEAR_NEWMV || mode == NEW_NEARMV);
155 static INLINE
int is_masked_compound_type(COMPOUND_TYPE type) {
156 return (type == COMPOUND_WEDGE || type == COMPOUND_DIFFWTD);
165 uint16_t palette_colors[3 * PALETTE_MAX_SIZE];
167 uint8_t palette_size[2];
171 FILTER_INTRA_MODE filter_intra_mode;
172 uint8_t use_filter_intra;
173 } FILTER_INTRA_MODE_INFO;
175 static const PREDICTION_MODE fimode_to_intradir[FILTER_INTRA_MODES] = {
176 DC_PRED, V_PRED, H_PRED, D157_PRED, DC_PRED
180 #define TXB_COEFF_COST_MAP_SIZE (MAX_MIB_SIZE) 183 typedef struct RD_STATS {
196 int txb_coeff_cost[MAX_MB_PLANE];
197 #endif // CONFIG_RD_DEBUG 206 DIFFWTD_MASK_TYPE mask_type;
208 } INTERINTER_COMPOUND_DATA;
210 #define INTER_TX_SIZE_BUF_LEN 16 211 #define TXK_TYPE_BUF_LEN 64 331 #if CONFIG_INSPECTION 333 int16_t tx_skip[TXK_TYPE_BUF_LEN];
339 static INLINE
int is_intrabc_block(
const MB_MODE_INFO *mbmi) {
343 static INLINE PREDICTION_MODE get_uv_mode(UV_PREDICTION_MODE mode) {
344 assert(mode < UV_INTRA_MODES);
345 static const PREDICTION_MODE uv2y[] = {
366 static INLINE
int is_inter_block(
const MB_MODE_INFO *mbmi) {
367 return is_intrabc_block(mbmi) || mbmi->
ref_frame[0] > INTRA_FRAME;
370 static INLINE
int has_second_ref(
const MB_MODE_INFO *mbmi) {
374 static INLINE
int has_uni_comp_refs(
const MB_MODE_INFO *mbmi) {
375 return has_second_ref(mbmi) && (!((mbmi->
ref_frame[0] >= BWDREF_FRAME) ^
379 static INLINE MV_REFERENCE_FRAME comp_ref0(
int ref_idx) {
380 static const MV_REFERENCE_FRAME lut[] = {
391 assert(NELEMENTS(lut) == TOTAL_UNIDIR_COMP_REFS);
395 static INLINE MV_REFERENCE_FRAME comp_ref1(
int ref_idx) {
396 static const MV_REFERENCE_FRAME lut[] = {
407 assert(NELEMENTS(lut) == TOTAL_UNIDIR_COMP_REFS);
411 PREDICTION_MODE av1_left_block_mode(
const MB_MODE_INFO *left_mi);
413 PREDICTION_MODE av1_above_block_mode(
const MB_MODE_INFO *above_mi);
415 static INLINE
int is_global_mv_block(
const MB_MODE_INFO *
const mbmi,
416 TransformationType type) {
417 const PREDICTION_MODE mode = mbmi->
mode;
418 const BLOCK_SIZE bsize = mbmi->
bsize;
419 const int block_size_allowed =
420 AOMMIN(block_size_wide[bsize], block_size_high[bsize]) >= 8;
421 return (mode == GLOBALMV || mode == GLOBAL_GLOBALMV) && type > TRANSLATION &&
425 #if CONFIG_MISMATCH_DEBUG 426 static INLINE
void mi_to_pixel_loc(
int *pixel_c,
int *pixel_r,
int mi_col,
427 int mi_row,
int tx_blk_col,
int tx_blk_row,
428 int subsampling_x,
int subsampling_y) {
429 *pixel_c = ((mi_col >> subsampling_x) << MI_SIZE_LOG2) +
430 (tx_blk_col << MI_SIZE_LOG2);
431 *pixel_r = ((mi_row >> subsampling_y) << MI_SIZE_LOG2) +
432 (tx_blk_row << MI_SIZE_LOG2);
436 enum { MV_PRECISION_Q3, MV_PRECISION_Q4 } UENUM1BYTE(mv_precision);
446 typedef struct eob_info {
448 uint16_t max_scan_line;
452 DECLARE_ALIGNED(32, tran_low_t, dqcoeff[MAX_MB_PLANE][MAX_SB_SQUARE]);
453 eob_info eob_data[MAX_MB_PLANE]
454 [MAX_SB_SQUARE / (TX_SIZE_W_MIN * TX_SIZE_H_MIN)];
455 DECLARE_ALIGNED(16, uint8_t, color_index_map[2][MAX_SB_SQUARE]);
458 typedef struct macroblockd_plane {
459 PLANE_TYPE plane_type;
463 struct buf_2d pre[2];
464 ENTROPY_CONTEXT *above_entropy_context;
465 ENTROPY_CONTEXT *left_entropy_context;
470 int16_t seg_dequant_QTX[MAX_SEGMENTS][2];
474 uint8_t *color_index_map;
477 uint8_t width, height;
479 qm_val_t *seg_iqmatrix[MAX_SEGMENTS][TX_SIZES_ALL];
480 qm_val_t *seg_qmatrix[MAX_SEGMENTS][TX_SIZES_ALL];
483 #define BLOCK_OFFSET(i) ((i) << 4) 492 DECLARE_ALIGNED(16, InterpKernel, vfilter);
497 DECLARE_ALIGNED(16, InterpKernel, hfilter);
516 #define CFL_SUB8X8_VAL_MI_SIZE (4) 517 #define CFL_SUB8X8_VAL_MI_SQUARE \ 518 (CFL_SUB8X8_VAL_MI_SIZE * CFL_SUB8X8_VAL_MI_SIZE) 519 #endif // CONFIG_DEBUG 520 #define CFL_MAX_BLOCK_SIZE (BLOCK_32X32) 521 #define CFL_BUF_LINE (32) 522 #define CFL_BUF_LINE_I128 (CFL_BUF_LINE >> 3) 523 #define CFL_BUF_LINE_I256 (CFL_BUF_LINE >> 4) 524 #define CFL_BUF_SQUARE (CFL_BUF_LINE * CFL_BUF_LINE) 525 typedef struct cfl_ctx {
528 uint16_t recon_buf_q3[CFL_BUF_SQUARE];
530 int16_t ac_buf_q3[CFL_BUF_SQUARE];
534 int dc_pred_is_cached[CFL_PRED_PLANES];
536 int use_dc_pred_cache;
538 int16_t dc_pred_cache[CFL_PRED_PLANES][CFL_BUF_LINE];
541 int buf_height, buf_width;
543 int are_parameters_computed;
546 int subsampling_x, subsampling_y;
552 typedef struct dist_wtd_comp_params {
553 int use_dist_wtd_comp_avg;
556 } DIST_WTD_COMP_PARAMS;
558 struct scale_factors;
604 struct macroblockd_plane
plane[MAX_MB_PLANE];
779 uint16_t
weight[MODE_CTX_REF_FRAMES][MAX_REF_MV_STACK_SIZE];
930 static INLINE
int is_cur_buf_hbd(
const MACROBLOCKD *xd) {
931 return xd->
cur_buf->flags & YV12_FLAG_HIGHBITDEPTH ? 1 : 0;
934 static INLINE uint8_t *get_buf_by_bd(
const MACROBLOCKD *xd, uint8_t *buf16) {
935 return (xd->
cur_buf->flags & YV12_FLAG_HIGHBITDEPTH)
936 ? CONVERT_TO_BYTEPTR(buf16)
940 static INLINE
int get_sqr_bsize_idx(BLOCK_SIZE bsize) {
942 case BLOCK_4X4:
return 0;
943 case BLOCK_8X8:
return 1;
944 case BLOCK_16X16:
return 2;
945 case BLOCK_32X32:
return 3;
946 case BLOCK_64X64:
return 4;
947 case BLOCK_128X128:
return 5;
948 default:
return SQR_BLOCK_SIZES;
959 static INLINE BLOCK_SIZE get_partition_subsize(BLOCK_SIZE bsize,
960 PARTITION_TYPE partition) {
961 if (partition == PARTITION_INVALID) {
962 return BLOCK_INVALID;
964 const int sqr_bsize_idx = get_sqr_bsize_idx(bsize);
965 return sqr_bsize_idx >= SQR_BLOCK_SIZES
967 : subsize_lookup[partition][sqr_bsize_idx];
971 static TX_TYPE intra_mode_to_tx_type(
const MB_MODE_INFO *mbmi,
972 PLANE_TYPE plane_type) {
973 static const TX_TYPE _intra_mode_to_tx_type[INTRA_MODES] = {
988 const PREDICTION_MODE mode =
989 (plane_type == PLANE_TYPE_Y) ? mbmi->
mode : get_uv_mode(mbmi->
uv_mode);
990 assert(mode < INTRA_MODES);
991 return _intra_mode_to_tx_type[mode];
994 static INLINE
int is_rect_tx(TX_SIZE tx_size) {
return tx_size >= TX_SIZES; }
996 static INLINE
int block_signals_txsize(BLOCK_SIZE bsize) {
997 return bsize > BLOCK_4X4;
1001 static const int av1_num_ext_tx_set[EXT_TX_SET_TYPES] = {
1005 static const int av1_ext_tx_used[EXT_TX_SET_TYPES][TX_TYPES] = {
1006 { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 },
1007 { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0 },
1008 { 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0 },
1009 { 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0 },
1010 { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0 },
1011 { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1 },
1020 static const uint16_t av1_derived_intra_tx_used_flag[INTRA_MODES] = {
1036 static const uint16_t av1_reduced_intra_tx_used_flag[INTRA_MODES] = {
1052 static const uint16_t av1_ext_tx_used_flag[EXT_TX_SET_TYPES] = {
1061 static const TxSetType av1_ext_tx_set_lookup[2][2] = {
1062 { EXT_TX_SET_DTT4_IDTX_1DDCT, EXT_TX_SET_DTT4_IDTX },
1063 { EXT_TX_SET_ALL16, EXT_TX_SET_DTT9_IDTX_1DDCT },
1066 static INLINE TxSetType av1_get_ext_tx_set_type(TX_SIZE tx_size,
int is_inter,
1067 int use_reduced_set) {
1068 const TX_SIZE tx_size_sqr_up = txsize_sqr_up_map[tx_size];
1069 if (tx_size_sqr_up > TX_32X32)
return EXT_TX_SET_DCTONLY;
1070 if (tx_size_sqr_up == TX_32X32)
1071 return is_inter ? EXT_TX_SET_DCT_IDTX : EXT_TX_SET_DCTONLY;
1072 if (use_reduced_set)
1073 return is_inter ? EXT_TX_SET_DCT_IDTX : EXT_TX_SET_DTT4_IDTX;
1074 const TX_SIZE tx_size_sqr = txsize_sqr_map[tx_size];
1075 return av1_ext_tx_set_lookup[is_inter][tx_size_sqr == TX_16X16];
1079 static const int ext_tx_set_index[2][EXT_TX_SET_TYPES] = {
1081 0, -1, 2, 1, -1, -1 },
1083 0, 3, -1, -1, 2, 1 },
1086 static INLINE
int get_ext_tx_set(TX_SIZE tx_size,
int is_inter,
1087 int use_reduced_set) {
1088 const TxSetType set_type =
1089 av1_get_ext_tx_set_type(tx_size, is_inter, use_reduced_set);
1090 return ext_tx_set_index[is_inter][set_type];
1093 static INLINE
int get_ext_tx_types(TX_SIZE tx_size,
int is_inter,
1094 int use_reduced_set) {
1095 const int set_type =
1096 av1_get_ext_tx_set_type(tx_size, is_inter, use_reduced_set);
1097 return av1_num_ext_tx_set[set_type];
1100 #define TXSIZEMAX(t1, t2) (tx_size_2d[(t1)] >= tx_size_2d[(t2)] ? (t1) : (t2)) 1101 #define TXSIZEMIN(t1, t2) (tx_size_2d[(t1)] <= tx_size_2d[(t2)] ? (t1) : (t2)) 1103 static INLINE TX_SIZE tx_size_from_tx_mode(BLOCK_SIZE bsize, TX_MODE tx_mode) {
1104 const TX_SIZE largest_tx_size = tx_mode_to_biggest_tx_size[tx_mode];
1105 const TX_SIZE max_rect_tx_size = max_txsize_rect_lookup[bsize];
1106 if (bsize == BLOCK_4X4)
1107 return AOMMIN(max_txsize_lookup[bsize], largest_tx_size);
1108 if (txsize_sqr_map[max_rect_tx_size] <= largest_tx_size)
1109 return max_rect_tx_size;
1111 return largest_tx_size;
1114 static const uint8_t mode_to_angle_map[] = {
1115 0, 90, 180, 45, 135, 113, 157, 203, 67, 0, 0, 0, 0,
1120 static INLINE
int av1_block_index_to_raster_order(TX_SIZE tx_size,
1127 return (tx_size == TX_4X8 && block_idx == 2) ? 1 : block_idx;
1132 static INLINE
int av1_raster_order_to_block_index(TX_SIZE tx_size,
1134 assert(tx_size == TX_4X4 || tx_size == TX_4X8 || tx_size == TX_8X4);
1136 return (tx_size == TX_4X4) ? raster_order : (raster_order > 0) ? 2 : 0;
1139 static INLINE TX_TYPE get_default_tx_type(PLANE_TYPE plane_type,
1142 int use_screen_content_tools) {
1145 if (is_inter_block(mbmi) || plane_type != PLANE_TYPE_Y ||
1147 use_screen_content_tools)
1150 return intra_mode_to_tx_type(mbmi, plane_type);
1155 static INLINE BLOCK_SIZE get_plane_block_size(BLOCK_SIZE bsize,
1157 int subsampling_y) {
1158 assert(bsize < BLOCK_SIZES_ALL);
1159 assert(subsampling_x >= 0 && subsampling_x < 2);
1160 assert(subsampling_y >= 0 && subsampling_y < 2);
1161 return ss_size_lookup[bsize][subsampling_x][subsampling_y];
1175 static INLINE
int av1_get_txb_size_index(BLOCK_SIZE bsize,
int blk_row,
1177 static const uint8_t tw_w_log2_table[BLOCK_SIZES_ALL] = {
1178 0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 3, 3, 3, 0, 1, 1, 2, 2, 3,
1180 static const uint8_t tw_h_log2_table[BLOCK_SIZES_ALL] = {
1181 0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 3, 3, 3, 1, 0, 2, 1, 3, 2,
1183 static const uint8_t stride_log2_table[BLOCK_SIZES_ALL] = {
1184 0, 0, 1, 1, 0, 1, 1, 0, 1, 1, 0, 1, 1, 1, 2, 2, 0, 1, 0, 1, 0, 1,
1187 ((blk_row >> tw_h_log2_table[bsize]) << stride_log2_table[bsize]) +
1188 (blk_col >> tw_w_log2_table[bsize]);
1189 assert(index < INTER_TX_SIZE_BUF_LEN);
1193 #if CONFIG_INSPECTION 1205 static INLINE
int av1_get_txk_type_index(BLOCK_SIZE bsize,
int blk_row,
1207 static const uint8_t tw_w_log2_table[BLOCK_SIZES_ALL] = {
1208 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 2, 2, 2, 0, 0, 1, 1, 2, 2,
1210 static const uint8_t tw_h_log2_table[BLOCK_SIZES_ALL] = {
1211 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 2, 2, 2, 0, 0, 1, 1, 2, 2,
1213 static const uint8_t stride_log2_table[BLOCK_SIZES_ALL] = {
1214 0, 0, 1, 1, 1, 2, 2, 1, 2, 2, 1, 2, 2, 2, 3, 3, 0, 2, 0, 2, 0, 2,
1217 ((blk_row >> tw_h_log2_table[bsize]) << stride_log2_table[bsize]) +
1218 (blk_col >> tw_w_log2_table[bsize]);
1219 assert(index < TXK_TYPE_BUF_LEN);
1222 #endif // CONFIG_INSPECTION 1224 static INLINE
void update_txk_array(
MACROBLOCKD *
const xd,
int blk_row,
1225 int blk_col, TX_SIZE tx_size,
1228 xd->
tx_type_map[blk_row * stride + blk_col] = tx_type;
1230 const int txw = tx_size_wide_unit[tx_size];
1231 const int txh = tx_size_high_unit[tx_size];
1236 if (txw == tx_size_wide_unit[TX_64X64] ||
1237 txh == tx_size_high_unit[TX_64X64]) {
1238 const int tx_unit = tx_size_wide_unit[TX_16X16];
1239 for (
int idy = 0; idy < txh; idy += tx_unit) {
1240 for (
int idx = 0; idx < txw; idx += tx_unit) {
1241 xd->
tx_type_map[(blk_row + idy) * stride + blk_col + idx] = tx_type;
1247 static INLINE TX_TYPE av1_get_tx_type(
const MACROBLOCKD *xd,
1248 PLANE_TYPE plane_type,
int blk_row,
1249 int blk_col, TX_SIZE tx_size,
1250 int reduced_tx_set) {
1257 if (plane_type == PLANE_TYPE_Y) {
1260 if (is_inter_block(mbmi)) {
1262 const struct macroblockd_plane *
const pd = &xd->
plane[plane_type];
1263 blk_row <<= pd->subsampling_y;
1264 blk_col <<= pd->subsampling_x;
1269 tx_type = intra_mode_to_tx_type(mbmi, PLANE_TYPE_UV);
1271 const TxSetType tx_set_type =
1272 av1_get_ext_tx_set_type(tx_size, is_inter_block(mbmi), reduced_tx_set);
1273 if (!av1_ext_tx_used[tx_set_type][tx_type]) tx_type = DCT_DCT;
1275 assert(tx_type < TX_TYPES);
1276 assert(av1_ext_tx_used[av1_get_ext_tx_set_type(tx_size, is_inter_block(mbmi),
1277 reduced_tx_set)][tx_type]);
1281 void av1_setup_block_planes(
MACROBLOCKD *xd,
int ss_x,
int ss_y,
1282 const int num_planes);
1294 static INLINE
int bsize_to_max_depth(BLOCK_SIZE bsize) {
1295 static const uint8_t bsize_to_max_depth_table[BLOCK_SIZES_ALL] = {
1296 0, 1, 1, 1, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
1298 return bsize_to_max_depth_table[bsize];
1313 static INLINE
int bsize_to_tx_size_cat(BLOCK_SIZE bsize) {
1314 assert(bsize < BLOCK_SIZES_ALL);
1315 static const uint8_t bsize_to_tx_size_depth_table[BLOCK_SIZES_ALL] = {
1316 0, 1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4, 4, 4, 4, 2, 2, 3, 3, 4, 4,
1318 const int depth = bsize_to_tx_size_depth_table[bsize];
1319 assert(depth <= MAX_TX_CATS);
1323 static INLINE TX_SIZE depth_to_tx_size(
int depth, BLOCK_SIZE bsize) {
1324 TX_SIZE max_tx_size = max_txsize_rect_lookup[bsize];
1325 TX_SIZE tx_size = max_tx_size;
1326 for (
int d = 0; d < depth; ++d) tx_size = sub_tx_size_map[tx_size];
1330 static INLINE TX_SIZE av1_get_adjusted_tx_size(TX_SIZE tx_size) {
1334 case TX_32X64:
return TX_32X32;
1335 case TX_64X16:
return TX_32X16;
1336 case TX_16X64:
return TX_16X32;
1337 default:
return tx_size;
1341 static INLINE TX_SIZE av1_get_max_uv_txsize(BLOCK_SIZE bsize,
int subsampling_x,
1342 int subsampling_y) {
1343 const BLOCK_SIZE plane_bsize =
1344 get_plane_block_size(bsize, subsampling_x, subsampling_y);
1345 assert(plane_bsize < BLOCK_SIZES_ALL);
1346 const TX_SIZE uv_tx = max_txsize_rect_lookup[plane_bsize];
1347 return av1_get_adjusted_tx_size(uv_tx);
1350 static INLINE TX_SIZE av1_get_tx_size(
int plane,
const MACROBLOCKD *xd) {
1353 if (plane == 0)
return mbmi->
tx_size;
1354 const MACROBLOCKD_PLANE *pd = &xd->
plane[plane];
1355 return av1_get_max_uv_txsize(mbmi->
bsize, pd->subsampling_x,
1359 void av1_reset_entropy_context(
MACROBLOCKD *xd, BLOCK_SIZE bsize,
1360 const int num_planes);
1362 void av1_reset_loop_filter_delta(
MACROBLOCKD *xd,
int num_planes);
1364 void av1_reset_loop_restoration(
MACROBLOCKD *xd,
const int num_planes);
1366 typedef void (*foreach_transformed_block_visitor)(
int plane,
int block,
1367 int blk_row,
int blk_col,
1368 BLOCK_SIZE plane_bsize,
1369 TX_SIZE tx_size,
void *arg);
1371 void av1_set_entropy_contexts(
const MACROBLOCKD *xd,
1372 struct macroblockd_plane *pd,
int plane,
1373 BLOCK_SIZE plane_bsize, TX_SIZE tx_size,
1374 int has_eob,
int aoff,
int loff);
1376 #define MAX_INTERINTRA_SB_SQUARE 32 * 32 1377 static INLINE
int is_interintra_mode(
const MB_MODE_INFO *mbmi) {
1378 return (mbmi->
ref_frame[0] > INTRA_FRAME &&
1382 static INLINE
int is_interintra_allowed_bsize(
const BLOCK_SIZE bsize) {
1383 return (bsize >= BLOCK_8X8) && (bsize <= BLOCK_32X32);
1386 static INLINE
int is_interintra_allowed_mode(
const PREDICTION_MODE mode) {
1387 return (mode >= SINGLE_INTER_MODE_START) && (mode < SINGLE_INTER_MODE_END);
1390 static INLINE
int is_interintra_allowed_ref(
const MV_REFERENCE_FRAME rf[2]) {
1391 return (rf[0] > INTRA_FRAME) && (rf[1] <= INTRA_FRAME);
1394 static INLINE
int is_interintra_allowed(
const MB_MODE_INFO *mbmi) {
1395 return is_interintra_allowed_bsize(mbmi->
bsize) &&
1396 is_interintra_allowed_mode(mbmi->
mode) &&
1397 is_interintra_allowed_ref(mbmi->
ref_frame);
1400 static INLINE
int is_interintra_allowed_bsize_group(
int group) {
1402 for (i = 0; i < BLOCK_SIZES_ALL; i++) {
1403 if (size_group_lookup[i] == group &&
1404 is_interintra_allowed_bsize((BLOCK_SIZE)i)) {
1411 static INLINE
int is_interintra_pred(
const MB_MODE_INFO *mbmi) {
1412 return mbmi->
ref_frame[0] > INTRA_FRAME &&
1413 mbmi->
ref_frame[1] == INTRA_FRAME && is_interintra_allowed(mbmi);
1416 static INLINE
int get_vartx_max_txsize(
const MACROBLOCKD *xd, BLOCK_SIZE bsize,
1419 const TX_SIZE max_txsize = max_txsize_rect_lookup[bsize];
1420 if (plane == 0)
return max_txsize;
1421 return av1_get_adjusted_tx_size(max_txsize);
1424 static INLINE
int is_motion_variation_allowed_bsize(BLOCK_SIZE bsize) {
1425 assert(bsize < BLOCK_SIZES_ALL);
1426 return AOMMIN(block_size_wide[bsize], block_size_high[bsize]) >= 8;
1429 static INLINE
int is_motion_variation_allowed_compound(
1431 return !has_second_ref(mbmi);
1435 static const int max_neighbor_obmc[6] = { 0, 1, 2, 3, 4, 4 };
1437 static INLINE
int check_num_overlappable_neighbors(
const MB_MODE_INFO *mbmi) {
1441 static INLINE MOTION_MODE
1442 motion_mode_allowed(
const WarpedMotionParams *gm_params,
const MACROBLOCKD *xd,
1444 if (!check_num_overlappable_neighbors(mbmi))
return SIMPLE_TRANSLATION;
1446 const TransformationType gm_type = gm_params[mbmi->
ref_frame[0]].wmtype;
1447 if (is_global_mv_block(mbmi, gm_type))
return SIMPLE_TRANSLATION;
1449 if (is_motion_variation_allowed_bsize(mbmi->
bsize) &&
1450 is_inter_mode(mbmi->
mode) && mbmi->
ref_frame[1] != INTRA_FRAME &&
1451 is_motion_variation_allowed_compound(mbmi)) {
1452 assert(!has_second_ref(mbmi));
1456 return WARPED_CAUSAL;
1460 return SIMPLE_TRANSLATION;
1463 static INLINE
int is_neighbor_overlappable(
const MB_MODE_INFO *mbmi) {
1464 return (is_inter_block(mbmi));
1467 static INLINE
int av1_allow_palette(
int allow_screen_content_tools,
1468 BLOCK_SIZE sb_type) {
1469 assert(sb_type < BLOCK_SIZES_ALL);
1470 return allow_screen_content_tools && block_size_wide[sb_type] <= 64 &&
1471 block_size_high[sb_type] <= 64 && sb_type >= BLOCK_8X8;
1479 static INLINE
void av1_get_block_dimensions(BLOCK_SIZE bsize,
int plane,
1482 int *rows_within_bounds,
1483 int *cols_within_bounds) {
1484 const int block_height = block_size_high[bsize];
1485 const int block_width = block_size_wide[bsize];
1492 const struct macroblockd_plane *
const pd = &xd->
plane[plane];
1493 assert(IMPLIES(plane == PLANE_TYPE_Y, pd->subsampling_x == 0));
1494 assert(IMPLIES(plane == PLANE_TYPE_Y, pd->subsampling_y == 0));
1495 assert(block_width >= block_cols);
1496 assert(block_height >= block_rows);
1497 const int plane_block_width = block_width >> pd->subsampling_x;
1498 const int plane_block_height = block_height >> pd->subsampling_y;
1500 const int is_chroma_sub8_x = plane > 0 && plane_block_width < 4;
1501 const int is_chroma_sub8_y = plane > 0 && plane_block_height < 4;
1503 *width = plane_block_width + 2 * is_chroma_sub8_x;
1504 assert(*width >= 0);
1507 *height = plane_block_height + 2 * is_chroma_sub8_y;
1508 assert(*height >= 0);
1510 if (rows_within_bounds) {
1511 *rows_within_bounds =
1512 (block_rows >> pd->subsampling_y) + 2 * is_chroma_sub8_y;
1513 assert(*rows_within_bounds >= 0);
1515 if (cols_within_bounds) {
1516 *cols_within_bounds =
1517 (block_cols >> pd->subsampling_x) + 2 * is_chroma_sub8_x;
1518 assert(*cols_within_bounds >= 0);
1524 typedef aom_cdf_prob (*MapCdf)[PALETTE_COLOR_INDEX_CONTEXTS]
1525 [CDF_SIZE(PALETTE_COLORS)];
1528 typedef const int (*ColorCost)[PALETTE_COLOR_INDEX_CONTEXTS][PALETTE_COLORS];
1539 ColorCost color_cost;
1542 static INLINE
int is_nontrans_global_motion(
const MACROBLOCKD *xd,
1547 if (mbmi->
mode != GLOBALMV && mbmi->
mode != GLOBAL_GLOBALMV)
return 0;
1549 if (AOMMIN(mi_size_wide[mbmi->
bsize], mi_size_high[mbmi->
bsize]) < 2)
1553 for (ref = 0; ref < 1 + has_second_ref(mbmi); ++ref) {
1559 static INLINE PLANE_TYPE get_plane_type(
int plane) {
1560 return (plane == 0) ? PLANE_TYPE_Y : PLANE_TYPE_UV;
1563 static INLINE
int av1_get_max_eob(TX_SIZE tx_size) {
1564 if (tx_size == TX_64X64 || tx_size == TX_64X32 || tx_size == TX_32X64) {
1567 if (tx_size == TX_16X64 || tx_size == TX_64X16) {
1570 return tx_size_2d[tx_size];
1579 #endif // AOM_AV1_COMMON_BLOCKD_H_ TileInfo tile
Definition: blockd.h:609
int8_t angle_delta[PLANE_TYPES]
Directional mode delta: the angle is base angle + (angle_delta * step).
Definition: blockd.h:266
int8_t interintra_wedge_index
The type of wedge used in interintra mode.
Definition: blockd.h:255
Parameters related to Wiener Filter.
Definition: blockd.h:488
MV_REFERENCE_FRAME ref_frame[2]
The reference frames for the MV.
Definition: blockd.h:240
SgrprojInfo sgrproj_info[3]
Definition: blockd.h:756
int mb_to_left_edge
Definition: blockd.h:675
CONV_BUF_TYPE * tmp_conv_dst
Definition: blockd.h:914
int8_t delta_lf[FRAME_LF_COUNT]
Definition: blockd.h:296
uint8_t ref_mv_idx
Which ref_mv to use.
Definition: blockd.h:308
uint8_t overlappable_neighbors
The number of overlapped neighbors above/left for obmc/warp motion mode.
Definition: blockd.h:249
int mi_row
Definition: blockd.h:573
FILTER_INTRA_MODE_INFO filter_intra_mode_info
The type of filter intra mode used (if applicable).
Definition: blockd.h:268
uint8_t * seg_mask
Definition: blockd.h:887
TXFM_CONTEXT left_txfm_context_buffer[MAX_MIB_SIZE]
Definition: blockd.h:745
bool is_chroma_ref
Definition: blockd.h:599
const YV12_BUFFER_CONFIG * cur_buf
Definition: blockd.h:693
struct macroblockd_plane plane[3]
Definition: blockd.h:604
PREDICTION_MODE mode
The prediction mode used.
Definition: blockd.h:226
int qindex[8]
Definition: blockd.h:811
uint8_t * tx_type_map
Definition: blockd.h:664
int current_base_qindex
Definition: blockd.h:826
PARTITION_TYPE partition
The partition type of the current coding block.
Definition: blockd.h:224
uint8_t segment_id
The segment id.
Definition: blockd.h:304
bool left_available
Definition: blockd.h:624
uint8_t compound_idx
Indicates whether dist_wtd_comp(0) is used or not (0).
Definition: blockd.h:316
TXFM_CONTEXT * left_txfm_context
Definition: blockd.h:738
uint8_t use_intrabc
Whether intrabc is used.
Definition: blockd.h:312
bool is_first_horizontal_rect
Definition: blockd.h:790
uint8_t * tmp_obmc_bufs[2]
Definition: blockd.h:925
int8_t cdef_strength
CDEF strength per BLOCK_64X64.
Definition: blockd.h:320
int_mv mv[2]
The motion vectors used by the current inter mode.
Definition: blockd.h:238
int mb_to_right_edge
Definition: blockd.h:676
int lossless[8]
Definition: blockd.h:815
bool up_available
Definition: blockd.h:620
uint8_t comp_group_idx
Indicates if masked compound is used(1) or not (0).
Definition: blockd.h:314
struct aom_internal_error_info * error_info
Definition: blockd.h:836
uint8_t seg_id_predicted
Only valid when temporal update if off.
Definition: blockd.h:306
PARTITION_CONTEXT * above_partition_context
Definition: blockd.h:716
int mi_col
Definition: blockd.h:574
MB_MODE_INFO * chroma_left_mbmi
Definition: blockd.h:650
CANDIDATE_MV ref_mv_stack[MODE_CTX_REF_FRAMES][MAX_REF_MV_STACK_SIZE]
Definition: blockd.h:774
const WarpedMotionParams * global_motion
Definition: blockd.h:841
Parameters related to Sgrproj Filter.
Definition: blockd.h:501
PALETTE_MODE_INFO palette_mode_info
Stores the size and colors of palette mode.
Definition: blockd.h:274
WienerInfo wiener_info[3]
Definition: blockd.h:755
bool cdef_transmitted[4]
Definition: blockd.h:882
uint8_t skip_mode
Inter skip mode.
Definition: blockd.h:310
ENTROPY_CONTEXT * above_entropy_context[3]
Definition: blockd.h:701
uint8_t cfl_alpha_idx
Chroma from Luma: Index of the alpha Cb and alpha Cr combination.
Definition: blockd.h:272
const struct scale_factors * block_ref_scale_factors[2]
Definition: blockd.h:685
uint8_t neighbors_ref_counts[REF_FRAMES]
Definition: blockd.h:796
int mb_to_bottom_edge
Definition: blockd.h:678
MOTION_MODE motion_mode
The motion mode used by the inter prediction.
Definition: blockd.h:244
int8_t delta_lf_from_base
Definition: blockd.h:851
MB_MODE_INFO * above_mbmi
Definition: blockd.h:643
bool chroma_left_available
Definition: blockd.h:632
uint8_t width
Definition: blockd.h:763
int current_qindex
The q index for the current coding block.
Definition: blockd.h:230
YV12 frame buffer data structure.
Definition: yv12config.h:38
UV_PREDICTION_MODE uv_mode
The UV mode when intra is used.
Definition: blockd.h:228
CFL_CTX cfl
Definition: blockd.h:892
bool is_last_vertical_rect
Definition: blockd.h:785
MB_MODE_INFO ** mi
Definition: blockd.h:615
ENTROPY_CONTEXT left_entropy_context[3][MAX_MIB_SIZE]
Definition: blockd.h:708
int ep
Definition: blockd.h:505
Variables related to current coding block.
Definition: blockd.h:568
WarpedMotionParams wm_params
The parameters used in warp motion mode.
Definition: blockd.h:251
int8_t skip_txfm
Whether to skip transforming and sending.
Definition: blockd.h:282
bool chroma_up_available
Definition: blockd.h:628
uint8_t height
Definition: blockd.h:764
INTERINTER_COMPOUND_DATA interinter_comp
Struct that stores the data used in interinter compound mode.
Definition: blockd.h:257
BLOCK_SIZE bsize
The block size of the current coding block.
Definition: blockd.h:222
uint8_t num_proj_ref
Number of samples used by warp causal.
Definition: blockd.h:246
Stores the prediction/txfm mode of the current coding block.
Definition: blockd.h:216
int8_t delta_lf_from_base
Definition: blockd.h:294
int tx_type_map_stride
Definition: blockd.h:669
int8_t delta_lf[FRAME_LF_COUNT]
Definition: blockd.h:866
FRAME_CONTEXT * tile_ctx
Definition: blockd.h:801
TX_SIZE tx_size
Transform size when fixed size txfm is used (e.g. intra modes).
Definition: blockd.h:284
TXFM_CONTEXT * above_txfm_context
Definition: blockd.h:731
TX_SIZE inter_tx_size[INTER_TX_SIZE_BUF_LEN]
Transform size when recursive txfm tree is on.
Definition: blockd.h:286
MB_MODE_INFO * left_mbmi
Definition: blockd.h:638
MB_MODE_INFO * chroma_above_mbmi
Definition: blockd.h:657
int bd
Definition: blockd.h:806
uint16_t color_index_map_offset[2]
Definition: blockd.h:903
INTERINTRA_MODE interintra_mode
The type of intra mode used by inter-intra.
Definition: blockd.h:253
int mb_to_top_edge
Definition: blockd.h:677
uint8_t use_wedge_interintra
Whether to use interintra wedge.
Definition: blockd.h:318
uint16_t weight[MODE_CTX_REF_FRAMES][MAX_REF_MV_STACK_SIZE]
Definition: blockd.h:779
int mi_stride
Definition: blockd.h:580
int_interpfilters interp_filters
Filter used in subpel interpolation.
Definition: blockd.h:242
int cur_frame_force_integer_mv
Definition: blockd.h:831
int8_t cfl_alpha_signs
Chroma from Luma: Joint sign of alpha Cb and alpha Cr.
Definition: blockd.h:270
PARTITION_CONTEXT left_partition_context[MAX_MIB_SIZE]
Definition: blockd.h:723