/****************************************************************************** * * Copyright (C) 2018 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at: * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ***************************************************************************** * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore */ /** ****************************************************************************** * * @file ihevce_global_tables.c * * @brief * This file contains definitions of global tables used by the encoder * * @author * Ittiam * ****************************************************************************** */ /*****************************************************************************/ /* File Includes */ /*****************************************************************************/ /* System include files */ #include #include #include #include #include #include /* User include files */ #include "ihevc_typedefs.h" #include "itt_video_api.h" #include "ihevce_api.h" #include "rc_cntrl_param.h" #include "rc_frame_info_collector.h" #include "rc_look_ahead_params.h" #include "ihevc_defs.h" #include "ihevc_structs.h" #include "ihevc_platform_macros.h" #include "ihevc_deblk.h" #include "ihevc_itrans_recon.h" #include "ihevc_chroma_itrans_recon.h" #include "ihevc_chroma_intra_pred.h" #include "ihevc_intra_pred.h" #include "ihevc_inter_pred.h" #include "ihevc_mem_fns.h" #include "ihevc_padding.h" #include "ihevc_weighted_pred.h" #include "ihevc_sao.h" #include "ihevc_resi_trans.h" #include "ihevc_quant_iquant_ssd.h" #include "ihevc_cabac_tables.h" #include "ihevce_defs.h" #include "ihevce_lap_enc_structs.h" #include "ihevce_multi_thrd_structs.h" #include "ihevce_multi_thrd_funcs.h" #include "ihevce_me_common_defs.h" #include "ihevce_had_satd.h" #include "ihevce_error_codes.h" #include "ihevce_bitstream.h" #include "ihevce_cabac.h" #include "ihevce_rdoq_macros.h" #include "ihevce_function_selector.h" #include "ihevce_enc_structs.h" #include "ihevce_cmn_utils_instr_set_router.h" #include "hme_datatype.h" #include "hme_common_defs.h" #include "hme_common_utils.h" #include "hme_interface.h" #include "hme_defs.h" #include "ihevce_me_instr_set_router.h" #include "hme_err_compute.h" #include "hme_globals.h" #include "ihevce_entropy_structs.h" #include "ihevce_enc_loop_structs.h" #include "ihevce_enc_loop_utils.h" #include "ihevce_enc_loop_pass.h" #include "ihevce_global_tables.h" /*****************************************************************************/ /* Globals */ /*****************************************************************************/ const level_data_t g_as_level_data[TOTAL_NUM_LEVELS] = { /* LEVEL1 */ { LEVEL1, 552960, 36864, { 128, 0 }, { 350, 0 }, 2, 16, 1, 1 }, /* LEVEL2 */ { LEVEL2, 3686400, 122880, { 1500, 0 }, { 1500, 0 }, 2, 16, 1, 1 }, /* LEVEL2_1 */ { LEVEL2_1, 7372800, 245760, { 3000, 0 }, { 3000, 0 }, 2, 20, 1, 1 }, /* LEVEL3 */ { LEVEL3, 16588800, 552960, { 6000, 0 }, { 6000, 0 }, 2, 30, 2, 2 }, /* LEVEL3_1 */ { LEVEL3_1, 33177600, 983040, { 10000, 0 }, { 10000, 0 }, 2, 40, 3, 3 }, /* LEVEL4 */ { LEVEL4, 66846720, 2228224, { 12000, 30000 }, { 12000, 30000 }, 4, 75, 5, 5 }, /* LEVEL4_1 */ { LEVEL4_1, 133693440, 2228224, { 20000, 50000 }, { 20000, 50000 }, 4, 75, 5, 5 }, /* LEVEL5 */ { LEVEL5, 267386880, 8912896, { 25000, 100000 }, { 25000, 100000 }, 6, 200, 11, 10 }, /* LEVEL5_1 */ { LEVEL5_1, 534773760, 8912896, { 40000, 160000 }, { 40000, 160000 }, 8, 200, 11, 10 }, /* LEVEL5_2 */ { LEVEL5_2, 1069547520, 8912896, { 60000, 240000 }, { 60000, 240000 }, 8, 200, 11, 10 }, /* LEVEL6 */ { LEVEL6, 1069547520, 35651584, { 60000, 240000 }, { 60000, 240000 }, 8, 600, 22, 20 }, /* LEVEL6_1 */ { LEVEL6_1, 2139095040, 35651584, { 120000, 480000 }, { 120000, 480000 }, 8, 600, 22, 20 }, /* LEVEL6_2 */ { LEVEL6_2, 4278190080, 35651584, { 240000, 800000 }, { 240000, 800000 }, 6, 600, 22, 20 }, }; /** \brief Default flat Scaling matrix for 4x4 transform */ const WORD16 gi2_flat_scale_mat_4x4[] = { 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16 }; /** \brief Default flat Scaling matrix for 8x8 transform */ const WORD16 gi2_flat_scale_mat_8x8[] = { 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16 }; /** \brief Default flat Scaling matrix for 16x16 transform */ const WORD16 gi2_flat_scale_mat_16x16[] = { 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16 }; /** \brief Default flat ReScaling matrix for 4x4 transform */ const WORD16 gi2_flat_rescale_mat_4x4[] = { 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048 }; /** \brief Default flat ReScaling matrix for 8x8 transform */ const WORD16 gi2_flat_rescale_mat_8x8[] = { 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048 }; /** \brief Default flat ReScaling matrix for 16x16 transform */ const WORD16 gi2_flat_rescale_mat_16x16[] = { 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048, 2048 }; /** * @brief Give the scanning order of csb in a 32x32 TU * based on first idx. 0 - upright_diagonal, 1 - horizontal, 2 - vertical scan */ const UWORD8 g_u1_scan_table_8x8[3][64] = { /* diag up right scan */ { 0, 8, 1, 16, 9, 2, 24, 17, 10, 3, 32, 25, 18, 11, 4, 40, 33, 26, 19, 12, 5, 48, 41, 34, 27, 20, 13, 6, 56, 49, 42, 35, 28, 21, 14, 7, 57, 50, 43, 36, 29, 22, 15, 58, 51, 44, 37, 30, 23, 59, 52, 45, 38, 31, 60, 53, 46, 39, 61, 54, 47, 62, 55, 63 }, /* horizontal scan */ { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63 }, /* vertical scan */ { 0, 8, 16, 24, 32, 40, 48, 56, 1, 9, 17, 25, 33, 41, 49, 57, 2, 10, 18, 26, 34, 42, 50, 58, 3, 11, 19, 27, 35, 43, 51, 59, 4, 12, 20, 28, 36, 44, 52, 60, 5, 13, 21, 29, 37, 45, 53, 61, 6, 14, 22, 30, 38, 46, 54, 62, 7, 15, 23, 31, 39, 47, 55, 63 } }; /** * @brief Give the scanning order of csb in a 16x16 TU or 4x4 csb * based on first idx. 0 - upright_diagonal, 1 - horizontal, 2 - vertical scan */ const UWORD8 g_u1_scan_table_4x4[3][16] = { /* diag up right scan */ { 0, 4, 1, 8, 5, 2, 12, 9, 6, 3, 13, 10, 7, 14, 11, 15 }, /* horizontal scan */ { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 }, /* vertical scan */ { 0, 4, 8, 12, 1, 5, 9, 13, 2, 6, 10, 14, 3, 7, 11, 15 } }; /** * @brief Give the scanning order of csb in a 8x8 TU * based on first idx. 0 - upright_diagonal, 1 - horizontal, 2 - vertical scan */ const UWORD8 g_u1_scan_table_2x2[3][4] = { /* diag up right scan */ { 0, 2, 1, 3 }, /* horizontal scan */ { 0, 1, 2, 3 }, /* vertical scan */ { 0, 2, 1, 3 } }; /** * @brief Give the scanning order of csb in a 4x4 TU * scan idx. doesn't matter as it's 0 for all cases */ const UWORD8 g_u1_scan_table_1x1[1] = { 0 }; /** ****************************************************************************** * @brief For a given frac pt, fracx, fracy, this module figures out the * corresponding fpel/hpel buffers along with x and y offsets if any. The * grid used is shown as follows: * A j E k B * l m n o p * F q G r H * s t u v w * C x I y D * * In this grid capital letters are fpel/hpel bufs. ****************************************************************************** */ qpel_input_buf_cfg_t gas_qpel_inp_buf_cfg[4][4] = { { /* 0, 0 pt: both buf id would be fxfy = 0 */ { 0, 0, 0, 0, 0, 0 }, /* 1, 0 pt: pt j; avg of A and E */ { 0, 0, 0, 1, 0, 0 }, /* 2, 0 pt: pt E, buf id 0 and 1 would be hxfy = 1 */ { 1, 0, 0, 1, 0, 0 }, /* 3, 0 pt: pt k, avg of E and B */ { 1, 0, 0, 0, 1, 0 }, }, { /* 0, 1 pt: pt l: avg of A and F */ { 0, 0, 0, 2, 0, 0 }, /* 1, 1 pt: pt m : avg of E and F */ { 1, 0, 0, 2, 0, 0 }, /* 2, 2 pt: pt n: avg of E and G */ { 1, 0, 0, 3, 0, 0 }, /* 3, 2 pt : pt o: avg of E and H */ { 1, 0, 0, 2, 1, 0 }, }, { /* 0, 2 pt: pt F; both buf id would be fxhy = 2 */ { 2, 0, 0, 2, 0, 0 }, /* 1, 2 pt: pt q; avg of F and G */ { 2, 0, 0, 3, 0, 0 }, /* 2, 2 pt: pt G: both buf id would be hxhy = 3 */ { 3, 0, 0, 3, 0, 0 }, /* 2, 3 pt: pt r: avg of G and H */ { 3, 0, 0, 2, 1, 0 }, }, { /* 0, 3 pt: pt s; avg of F and C */ { 2, 0, 0, 0, 0, 1 }, /* 1, 3 ot: pt t; avg of F and I */ { 2, 0, 0, 1, 0, 1 }, /* 2, 3 pt: pt u, avg of G and I */ { 3, 0, 0, 1, 0, 1 }, /* 3, 3 pt; pt v, avg of H and I */ { 2, 1, 0, 1, 0, 1 }, } }; /** * @brief is partition vertical */ const WORD8 gai1_is_part_vertical[TOT_NUM_PARTS] = { 0, 1, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0 }; /** * @brief partition dimensions */ const WORD8 gai1_part_wd_and_ht[TOT_NUM_PARTS][2] = { { 16, 16 }, { 16, 8 }, { 16, 8 }, { 8, 16 }, { 8, 16 }, { 8, 8 }, { 8, 8 }, { 8, 8 }, { 8, 8 }, { 16, 4 }, { 16, 12 }, { 16, 12 }, { 16, 4 }, { 4, 16 }, { 12, 16 }, { 12, 16 }, { 4, 16 } }; /** ****************************************************************************** * @brief bits to code given ref id assuming more than 2 ref ids active ****************************************************************************** */ UWORD8 gau1_ref_bits[16] = { 1, 3, 3, 5, 5, 5, 5, 7, 7, 7, 7, 7, 7, 7, 7, 9 }; /** * @brief raster to zscan lookup table */ const UWORD8 gau1_ctb_raster_to_zscan[256] = { 0, 1, 4, 5, 16, 17, 20, 21, 64, 65, 68, 69, 80, 81, 84, 85, 2, 3, 6, 7, 18, 19, 22, 23, 66, 67, 70, 71, 82, 83, 86, 87, 8, 9, 12, 13, 24, 25, 28, 29, 72, 73, 76, 77, 88, 89, 92, 93, 10, 11, 14, 15, 26, 27, 30, 31, 74, 75, 78, 79, 90, 91, 94, 95, 32, 33, 36, 37, 48, 49, 52, 53, 96, 97, 100, 101, 112, 113, 116, 117, 34, 35, 38, 39, 50, 51, 54, 55, 98, 99, 102, 103, 114, 115, 118, 119, 40, 41, 44, 45, 56, 57, 60, 61, 104, 105, 108, 109, 120, 121, 124, 125, 42, 43, 46, 47, 58, 59, 62, 63, 106, 107, 110, 111, 122, 123, 126, 127, 128, 129, 132, 133, 144, 145, 148, 149, 192, 193, 196, 197, 208, 209, 212, 213, 130, 131, 134, 135, 146, 147, 150, 151, 194, 195, 198, 199, 210, 211, 214, 215, 136, 137, 140, 141, 152, 153, 156, 157, 200, 201, 204, 205, 216, 217, 220, 221, 138, 139, 142, 143, 154, 155, 158, 159, 202, 203, 206, 207, 218, 219, 222, 223, 160, 161, 164, 165, 176, 177, 180, 181, 224, 225, 228, 229, 240, 241, 244, 245, 162, 163, 166, 167, 178, 179, 182, 183, 226, 227, 230, 231, 242, 243, 246, 247, 168, 169, 172, 173, 184, 185, 188, 189, 232, 233, 236, 237, 248, 249, 252, 253, 170, 171, 174, 175, 186, 187, 190, 191, 234, 235, 238, 239, 250, 251, 254, 255 }; /** * @brief */ UWORD32 gau4_frame_qstep_multiplier[54] = { 16, 16, 16, 15, 15, 15, 15, 15, 15, 13, 13, 13, 13, 12, 12, 11, 11, 10, 10, 9, 9, 8, 8, 8, 7, 7, 7, 6, 6, 5, 5, 5, 4, 4, 3, 3, 3, 2, 2, 2, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; /** ****************************************************************************** * @brief Look up table for choosing the appropriate function for * Intra prediction * * @remarks Same look up table enums are used for luma & chroma but each * have seperate functions implemented ****************************************************************************** */ WORD32 g_i4_ip_funcs[MAX_NUM_IP_MODES] = { IP_FUNC_MODE_0, /* Mode 0 */ IP_FUNC_MODE_1, /* Mode 1 */ IP_FUNC_MODE_2, /* Mode 2 */ IP_FUNC_MODE_3TO9, /* Mode 3 */ IP_FUNC_MODE_3TO9, /* Mode 4 */ IP_FUNC_MODE_3TO9, /* Mode 5 */ IP_FUNC_MODE_3TO9, /* Mode 6 */ IP_FUNC_MODE_3TO9, /* Mode 7 */ IP_FUNC_MODE_3TO9, /* Mode 8 */ IP_FUNC_MODE_3TO9, /* Mode 9 */ IP_FUNC_MODE_10, /* Mode 10 */ IP_FUNC_MODE_11TO17, /* Mode 11 */ IP_FUNC_MODE_11TO17, /* Mode 12 */ IP_FUNC_MODE_11TO17, /* Mode 13 */ IP_FUNC_MODE_11TO17, /* Mode 14 */ IP_FUNC_MODE_11TO17, /* Mode 15 */ IP_FUNC_MODE_11TO17, /* Mode 16 */ IP_FUNC_MODE_11TO17, /* Mode 17 */ IP_FUNC_MODE_18_34, /* Mode 18 */ IP_FUNC_MODE_19TO25, /* Mode 19 */ IP_FUNC_MODE_19TO25, /* Mode 20 */ IP_FUNC_MODE_19TO25, /* Mode 21 */ IP_FUNC_MODE_19TO25, /* Mode 22 */ IP_FUNC_MODE_19TO25, /* Mode 23 */ IP_FUNC_MODE_19TO25, /* Mode 24 */ IP_FUNC_MODE_19TO25, /* Mode 25 */ IP_FUNC_MODE_26, /* Mode 26 */ IP_FUNC_MODE_27TO33, /* Mode 27 */ IP_FUNC_MODE_27TO33, /* Mode 26 */ IP_FUNC_MODE_27TO33, /* Mode 29 */ IP_FUNC_MODE_27TO33, /* Mode 30 */ IP_FUNC_MODE_27TO33, /* Mode 31 */ IP_FUNC_MODE_27TO33, /* Mode 32 */ IP_FUNC_MODE_27TO33, /* Mode 33 */ IP_FUNC_MODE_18_34, /* Mode 34 */ }; /** ****************************************************************************** * @brief Look up table for calculating the TU size for all the TUs in a CU * if CU part mode is one of SIZE_2Nx2N, SIZE_2NxN, SIZE_Nx2N * * i ranging (0 to 3) * tu_size[i] = cu_size >> gau1_inter_tu_shft_amt[i]; * * @remarks For non AMP cases only TU size = CU/2 is used * and number of TU partitions in these CU will be 4 ****************************************************************************** */ UWORD8 gau1_inter_tu_shft_amt[4] = { /* SIZE_2Nx2N, SIZE_2NxN, SIZE_Nx2N cases */ 1, 1, 1, 1 }; /** ****************************************************************************** * @brief Look up table for calculating the TU size for all the TUs in a CU * if CU part mode is one of SIZE_2NxnU, SIZE_2NxnD, SIZE_nLx2N * SIZE_nRx2N (AMP motion partition cases) * * part_mode = {SIZE_2NxnU,SIZE_2NxnD,SIZE_nLx2N,SIZE_nRx2N} * i ranging (0 to 9) * tu_size[i] = cu_size >> gau1_inter_tu_shft_amt_amp[part_mode-4][i]; * * @remarks For AMP cases a mixture of TU size = CU/2 & CU/4 is used * based on motion partition orientation, number of TU partitions * in these CU will be 10 ****************************************************************************** */ UWORD8 gau1_inter_tu_shft_amt_amp[4][10] = { /* SIZE_2NxnU case */ { 2, 2, 2, 2, 2, 2, 2, 2, 1, 1 }, /* SIZE_2NxnD case */ { 1, 1, 2, 2, 2, 2, 2, 2, 2, 2 }, /* SIZE_nLx2N case */ { 2, 2, 2, 2, 1, 2, 2, 2, 2, 1 }, /* SIZE_nRx2N case */ { 1, 2, 2, 2, 2, 1, 2, 2, 2, 2 } }; /** ****************************************************************************** * @brief Look up table for calculating the TU position in horizontal * for all the TUs in a CU, if CU part mode is one of * SIZE_2Nx2N, SIZE_2NxN, SIZE_Nx2N * * i ranging (0 to 3) * tu_posx[i](in pixels in cu) = * ((cusize >> 2) * gau1_inter_tu_posx_scl_amt[i]); ****************************************************************************** */ UWORD8 gau1_inter_tu_posx_scl_amt[4] = { /* SIZE_2Nx2N, SIZE_2NxN, SIZE_Nx2N cases */ 0, 2, 0, 2 }; /** ****************************************************************************** * @brief Look up table for calculating the TU position in horizontal * for all the TUs in a CU, if CU part mode is one of * SIZE_2NxnU, SIZE_2NxnD, SIZE_nLx2N,SIZE_nRx2N (AMP motion partition cases) * * part_mode = {SIZE_2NxnU,SIZE_2NxnD,SIZE_nLx2N,SIZE_nRx2N} * i ranging (0 to 9) * tu_posx[i](in pixels in cu) = * ((cusize >> 2) * gau1_inter_tu_posx_scl_amt_amp[part_mode-4][i]); ****************************************************************************** */ UWORD8 gau1_inter_tu_posx_scl_amt_amp[4][10] = { /* SIZE_2NxnU case */ { 0, 1, 0, 1, 2, 3, 2, 3, 0, 2 }, /* SIZE_2NxnD case */ { 0, 2, 0, 1, 0, 1, 2, 3, 2, 3 }, /* SIZE_nLx2N case */ { 0, 1, 0, 1, 2, 0, 1, 0, 1, 2 }, /* SIZE_nRx2N case */ { 0, 2, 3, 2, 3, 0, 2, 3, 2, 3 } }; /** ****************************************************************************** * @brief Look up table for calculating the TU position in vertical * for all the TUs in a CU, if CU part mode is one of * SIZE_2Nx2N, SIZE_2NxN, SIZE_Nx2N * * i ranging (0 to 3) * tu_posy[i](in pixels in cu) = * ((cusize >> 2) * gau1_inter_tu_posy_scl_amt[i]); ****************************************************************************** */ UWORD8 gau1_inter_tu_posy_scl_amt[4] = { /* SIZE_2Nx2N, SIZE_2NxN, SIZE_Nx2N cases */ 0, 0, 2, 2 }; /** ****************************************************************************** * @brief Look up table for calculating the TU position in vertical * for all the TUs in a CU, if CU part mode is one of * SIZE_2NxnU, SIZE_2NxnD, SIZE_nLx2N,SIZE_nRx2N (AMP motion partition cases) * * part_mode = {SIZE_2NxnU,SIZE_2NxnD,SIZE_nLx2N,SIZE_nRx2N} * i ranging (0 to 9) * tu_posy[i](in pixels in cu) = * ((cusize >> 2) * gau1_inter_tu_posy_scl_amt_amp[part_mode-4][i]); ****************************************************************************** */ UWORD8 gau1_inter_tu_posy_scl_amt_amp[4][10] = { /* SIZE_2NxnU case */ { 0, 0, 1, 1, 0, 0, 1, 1, 2, 2 }, /* SIZE_2NxnD case */ { 0, 0, 2, 2, 3, 3, 2, 2, 3, 3 }, /* SIZE_nLx2N case */ { 0, 0, 1, 1, 0, 2, 2, 3, 3, 2 }, /* SIZE_nRx2N case */ { 0, 0, 0, 1, 1, 2, 2, 2, 3, 3 } }; /** * @brief transform shift. Initialized in ihevce_enc_loop_init() */ WORD32 ga_trans_shift[5]; /** * @brief chroma 422 intra angle mapping */ const UWORD8 gau1_chroma422_intra_angle_mapping[36] = { 0, 1, 2, 2, 2, 2, 3, 5, 7, 8, 10, 12, 13, 15, 17, 18, 19, 20, 21, 22, 23, 23, 24, 24, 25, 25, 26, 27, 27, 28, 28, 29, 29, 30, 31, DM_CHROMA_IDX }; // clang-format off /** ****************************************************************************** * @breif LUT for returning the fractional bits(Q12) to encode a bin based on * probability state and the encoded bin (MPS / LPS). The fractional * bits are computed as -log2(probabililty of symbol) * * Probabilites of the cabac states (0-63) are explained in section C * of ieee paper by Detlev Marpe et al (VOL. 13, NO. 7, JULY 2003) * alpha = (0.01875/0.5) ^ (1/63), p0 = 0.5 and p63 = 0.01875 * * Note that HEVC and AVC use the same cabac tables * * input : curpState[bits7-1] | (curMPS ^ encoded bin)[bit0] * * output : fractionnal bits to encode the bin * ****************************************************************************** */ UWORD16 gau2_ihevce_cabac_bin_to_bits[64 * 2] = { /* bits for mps */ /* bits for lps */ ROUND_Q12(1.000000000), ROUND_Q12(1.000000000), ROUND_Q12(0.928535439), ROUND_Q12(1.075189930), ROUND_Q12(0.863825936), ROUND_Q12(1.150379860), ROUND_Q12(0.804976479), ROUND_Q12(1.225569790), ROUND_Q12(0.751252392), ROUND_Q12(1.300759720), ROUND_Q12(0.702043265), ROUND_Q12(1.375949650), ROUND_Q12(0.656836490), ROUND_Q12(1.451139580), ROUND_Q12(0.615197499), ROUND_Q12(1.526329510), ROUND_Q12(0.576754745), ROUND_Q12(1.601519441), ROUND_Q12(0.541188141), ROUND_Q12(1.676709371), ROUND_Q12(0.508220033), ROUND_Q12(1.751899301), ROUND_Q12(0.477608072), ROUND_Q12(1.827089231), ROUND_Q12(0.449139524), ROUND_Q12(1.902279161), ROUND_Q12(0.422626680), ROUND_Q12(1.977469091), ROUND_Q12(0.397903130), ROUND_Q12(2.052659021), ROUND_Q12(0.374820697), ROUND_Q12(2.127848951), ROUND_Q12(0.353246914), ROUND_Q12(2.203038881), ROUND_Q12(0.333062915), ROUND_Q12(2.278228811), ROUND_Q12(0.314161674), ROUND_Q12(2.353418741), ROUND_Q12(0.296446520), ROUND_Q12(2.428608671), ROUND_Q12(0.279829872), ROUND_Q12(2.503798601), ROUND_Q12(0.264232174), ROUND_Q12(2.578988531), ROUND_Q12(0.249580966), ROUND_Q12(2.654178461), ROUND_Q12(0.235810099), ROUND_Q12(2.729368392), ROUND_Q12(0.222859049), ROUND_Q12(2.804558322), ROUND_Q12(0.210672321), ROUND_Q12(2.879748252), ROUND_Q12(0.199198934), ROUND_Q12(2.954938182), ROUND_Q12(0.188391967), ROUND_Q12(3.030128112), ROUND_Q12(0.178208162), ROUND_Q12(3.105318042), ROUND_Q12(0.168607572), ROUND_Q12(3.180507972), ROUND_Q12(0.159553254), ROUND_Q12(3.255697902), ROUND_Q12(0.151010993), ROUND_Q12(3.330887832), ROUND_Q12(0.142949058), ROUND_Q12(3.406077762), ROUND_Q12(0.135337985), ROUND_Q12(3.481267692), ROUND_Q12(0.128150381), ROUND_Q12(3.556457622), ROUND_Q12(0.121360753), ROUND_Q12(3.631647552), ROUND_Q12(0.114945349), ROUND_Q12(3.706837482), ROUND_Q12(0.108882016), ROUND_Q12(3.782027412), ROUND_Q12(0.103150076), ROUND_Q12(3.857217343), ROUND_Q12(0.097730208), ROUND_Q12(3.932407273), ROUND_Q12(0.092604344), ROUND_Q12(4.007597203), ROUND_Q12(0.087755577), ROUND_Q12(4.082787133), ROUND_Q12(0.083168071), ROUND_Q12(4.157977063), ROUND_Q12(0.078826986), ROUND_Q12(4.233166993), ROUND_Q12(0.074718402), ROUND_Q12(4.308356923), ROUND_Q12(0.070829259), ROUND_Q12(4.383546853), ROUND_Q12(0.067147292), ROUND_Q12(4.458736783), ROUND_Q12(0.063660977), ROUND_Q12(4.533926713), ROUND_Q12(0.060359483), ROUND_Q12(4.609116643), ROUND_Q12(0.057232622), ROUND_Q12(4.684306573), ROUND_Q12(0.054270808), ROUND_Q12(4.759496503), ROUND_Q12(0.051465018), ROUND_Q12(4.834686433), ROUND_Q12(0.048806753), ROUND_Q12(4.909876363), ROUND_Q12(0.046288005), ROUND_Q12(4.985066294), ROUND_Q12(0.043901228), ROUND_Q12(5.060256224), ROUND_Q12(0.041639305), ROUND_Q12(5.135446154), ROUND_Q12(0.039495525), ROUND_Q12(5.210636084), ROUND_Q12(0.037463555), ROUND_Q12(5.285826014), ROUND_Q12(0.035537418), ROUND_Q12(5.361015944), ROUND_Q12(0.033711472), ROUND_Q12(5.436205874), ROUND_Q12(0.031980387), ROUND_Q12(5.511395804), ROUND_Q12(0.030339132), ROUND_Q12(5.586585734), ROUND_Q12(0.028782950), ROUND_Q12(5.661775664), ROUND_Q12(0.027307346), ROUND_Q12(5.736965594) }; // clang-format on /** * @brief */ WORD32 gai4_subBlock2csbfId_map4x4TU[1]; WORD32 gai4_subBlock2csbfId_map8x8TU[4]; WORD32 gai4_subBlock2csbfId_map16x16TU[16]; WORD32 gai4_subBlock2csbfId_map32x32TU[64]; /** * @brief the neighbor flags for a general ctb (ctb inside the frame; not any corners). * The table gau4_nbr_flags_8x8_4x4blks generated for 16x16 4x4 blocks(ctb_size = 64). * But the same table holds good for other 4x4 blocks 2d arrays(eg 8x8 4x4 blks,4x4 4x4blks). * But the flags must be accessed with stride of 16 since the table has been generated for * ctb_size = 64. For odd 4x4 2d arrays(eg 3x3 4x4 blks) the flags needs modification. * The flags also need modification for corner ctbs. */ const UWORD32 gau4_nbr_flags_8x8_4x4blks[64] = { 0x11188, 0x11180, 0x11188, 0x11180, 0x11188, 0x11180, 0x11188, 0x11180, 0x11188, 0x10180, 0x11180, 0x10180, 0x11188, 0x10180, 0x11180, 0x10180, 0x11188, 0x11180, 0x11188, 0x10180, 0x11188, 0x11180, 0x11188, 0x10180, 0x11188, 0x10180, 0x11180, 0x10180, 0x11180, 0x10180, 0x11180, 0x10180, 0x11188, 0x11180, 0x11188, 0x11180, 0x11188, 0x11180, 0x11188, 0x10180, 0x11188, 0x10180, 0x11180, 0x10180, 0x11188, 0x10180, 0x11180, 0x10180, 0x11188, 0x11180, 0x11188, 0x10180, 0x11188, 0x11180, 0x11188, 0x10180, 0x11180, 0x10180, 0x11180, 0x10180, 0x11180, 0x10180, 0x11180, 0x10180 }; /** * @brief subset of intra modes to be evaluated during pre enc intra process */ const UWORD8 gau1_modes_to_eval[11] = { 0, 1, 26, 2, 6, 10, 14, 18, 22, 30, 34 }; const float gad_look_up_activity[TOT_QP_MOD_OFFSET] = { 0.314980262f, 0.353553391f, 0.396850263f, 0.445449359f, 0.5f, 0.561231024f, 0.629960525f, 0.707106781f, 0.793700526f, 0.890898718f, 1.0f, 1.122462048f, 1.25992105f, 1.414213562f };