2014-01-24 10:37:15 +00:00
|
|
|
/*****************************************************************************
|
|
|
|
* This file is part of Kvazaar HEVC encoder.
|
2014-02-21 13:00:20 +00:00
|
|
|
*
|
2015-02-23 11:18:48 +00:00
|
|
|
* Copyright (C) 2013-2015 Tampere University of Technology and others (see
|
2014-01-24 10:37:15 +00:00
|
|
|
* COPYING file).
|
|
|
|
*
|
2015-02-23 11:18:48 +00:00
|
|
|
* Kvazaar is free software: you can redistribute it and/or modify it under
|
|
|
|
* the terms of the GNU Lesser General Public License as published by the
|
|
|
|
* Free Software Foundation; either version 2.1 of the License, or (at your
|
|
|
|
* option) any later version.
|
2014-01-24 10:37:15 +00:00
|
|
|
*
|
2015-02-23 11:18:48 +00:00
|
|
|
* Kvazaar is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
|
|
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
|
|
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for
|
|
|
|
* more details.
|
2014-01-24 10:37:15 +00:00
|
|
|
*
|
2015-02-23 11:18:48 +00:00
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with Kvazaar. If not, see <http://www.gnu.org/licenses/>.
|
2014-01-24 10:37:15 +00:00
|
|
|
****************************************************************************/
|
|
|
|
|
2013-09-18 09:16:03 +00:00
|
|
|
#include "context.h"
|
|
|
|
|
2016-04-01 14:14:23 +00:00
|
|
|
#include "tables.h"
|
2013-09-18 09:16:03 +00:00
|
|
|
|
2012-08-15 10:22:31 +00:00
|
|
|
|
2014-02-06 15:57:41 +00:00
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
static const uint8_t INIT_SPLIT_FLAG[4][9] = {
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 18, 27, 15, 18, 28, 45, 26, 7, 23, },
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 11, 35, 53, 12, 6, 30, 13, 15, 31, },
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 19, 28, 38, 27, 29, 38, 20, 30, 31, },
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 12, 13, 8, 8, 13, 12, 5, 9, 9, },
|
2014-02-06 15:57:41 +00:00
|
|
|
};
|
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
static const uint8_t INIT_QT_SPLIT_FLAG[4][6] = {
|
2020-03-30 11:34:50 +00:00
|
|
|
{ 26, 36, 38, 18, 34, 21, },
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 20, 14, 23, 18, 19, 6, },
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 27, 6, 15, 25, 19, 37, },
|
|
|
|
{ 0, 8, 8, 12, 12, 8, },
|
2014-02-06 15:57:41 +00:00
|
|
|
};
|
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
static const uint8_t INIT_SKIP_FLAG[4][3] = {
|
2020-03-30 11:34:50 +00:00
|
|
|
{ 57, 60, 46, },
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 57, 59, 45, },
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 0, 26, 28, },
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 5, 4, 8, },
|
2014-02-06 15:57:41 +00:00
|
|
|
};
|
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
static const uint8_t INIT_MERGE_FLAG_EXT[4][1] = {
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 6, },
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 21, },
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 26, },
|
|
|
|
{ 4, },
|
2014-02-06 15:57:41 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
static const uint8_t INIT_MERGE_IDX_EXT[4][1] = {
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 18, },
|
|
|
|
{ 20, },
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 34, },
|
|
|
|
{ 4, },
|
2016-05-30 07:41:53 +00:00
|
|
|
};
|
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
static const uint8_t INIT_PART_SIZE[4][4] = {
|
|
|
|
{ CNU, CNU, CNU, CNU,},
|
|
|
|
{ CNU, CNU, CNU, CNU,},
|
|
|
|
{ CNU, CNU, CNU, CNU,},
|
|
|
|
{ DWS, DWS, DWS, DWS, }
|
2014-02-06 15:57:41 +00:00
|
|
|
};
|
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
static const uint8_t INIT_PRED_MODE[4][2] = {
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 40, 35, },
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 40, 35, },
|
2019-03-27 10:38:19 +00:00
|
|
|
{ CNU, CNU, },
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 5, 1, },
|
2014-02-06 15:57:41 +00:00
|
|
|
};
|
|
|
|
|
2019-08-19 06:39:59 +00:00
|
|
|
static const uint8_t MULTI_REF_LINE_MODE[4][2] = {
|
2020-08-17 15:18:35 +00:00
|
|
|
{ 25, 59, },
|
|
|
|
{ 25, 58, },
|
|
|
|
{ 25, 60, },
|
|
|
|
{ 5, 8, },
|
2019-05-29 10:00:19 +00:00
|
|
|
};
|
|
|
|
|
2019-08-19 12:17:25 +00:00
|
|
|
static const uint8_t INIT_INTRA_LUMA_MPM_FLAG[4] = {
|
2020-08-17 11:23:26 +00:00
|
|
|
44, 36, 45, 6
|
2014-02-06 15:57:41 +00:00
|
|
|
};
|
|
|
|
|
2019-05-21 09:28:05 +00:00
|
|
|
static const uint8_t INIT_INTRA_LUMA_PLANAR_MODE[4][2] = {
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 13, 6, },
|
|
|
|
{ 12, 20, },
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 13, 28, },
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 1, 5, },
|
2019-05-21 09:28:05 +00:00
|
|
|
};
|
|
|
|
|
2019-08-22 07:44:47 +00:00
|
|
|
static const uint8_t INIT_CHROMA_PRED_MODE[4] = {
|
2019-11-14 11:46:51 +00:00
|
|
|
25,
|
2020-03-30 11:34:50 +00:00
|
|
|
25,
|
2019-11-14 11:46:51 +00:00
|
|
|
34,
|
|
|
|
5,
|
2019-03-20 07:06:57 +00:00
|
|
|
};
|
|
|
|
|
2019-08-19 06:39:59 +00:00
|
|
|
static const uint8_t INIT_CU_QP_DELTA_ABS[4][2] = {
|
|
|
|
{ CNU, CNU, },
|
|
|
|
{ CNU, CNU, },
|
|
|
|
{ CNU, CNU, },
|
|
|
|
{ DWS, DWS, },
|
2018-08-14 12:26:42 +00:00
|
|
|
};
|
|
|
|
|
2019-11-14 11:46:51 +00:00
|
|
|
static const uint8_t INIT_INTER_DIR[4][6] = {
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 14, 13, 5, 4, 3, 40, },
|
2020-03-30 11:34:50 +00:00
|
|
|
{ 7, 6, 5, 12, 4, 40, },
|
2019-11-14 11:46:51 +00:00
|
|
|
{ CNU, CNU, CNU, CNU, CNU, CNU, },
|
2020-03-30 11:34:50 +00:00
|
|
|
{ 0, 0, 1, 4, 4, 0, },
|
2014-02-06 15:57:41 +00:00
|
|
|
};
|
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
static const uint8_t INIT_REF_PIC[4][2] = {
|
2020-03-30 11:34:50 +00:00
|
|
|
{ 5, 35, },
|
|
|
|
{ 20, 35, },
|
2019-03-27 10:38:19 +00:00
|
|
|
{ CNU, CNU, },
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 0, 4, },
|
2019-03-20 07:06:57 +00:00
|
|
|
};
|
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
static const uint8_t INIT_MVD[4][2] = {
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 51, 36, },
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 44, 43, },
|
|
|
|
{ 14, 45, },
|
|
|
|
{ 9, 5, },
|
2014-02-06 15:57:41 +00:00
|
|
|
};
|
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
static const uint8_t INIT_QT_ROOT_CBF[4][1] = {
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 12, },
|
|
|
|
{ 5, },
|
|
|
|
{ 6, },
|
|
|
|
{ 4, },
|
2014-02-06 15:57:41 +00:00
|
|
|
};
|
|
|
|
|
2019-05-13 12:30:43 +00:00
|
|
|
|
2020-03-30 11:34:50 +00:00
|
|
|
static const uint8_t INIT_QT_CBF[4][9] = {
|
2020-08-17 15:18:35 +00:00
|
|
|
{ 15, 6, 5, 14, 25, 37, 9, 36, 45},
|
|
|
|
{ 23, 5, 20, 7, 25, 28, 25, 29, 45},
|
|
|
|
{ 15, 12, 5, 7, 12, 21, 33, 28, 36},
|
2020-03-30 11:34:50 +00:00
|
|
|
{ 5, 1, 8, 9, 5, 0, 2, 1, 0},
|
2014-02-06 15:57:41 +00:00
|
|
|
};
|
|
|
|
|
2020-08-17 11:23:26 +00:00
|
|
|
static const uint8_t BDPCM_MODE_INIT[4][4] = {
|
|
|
|
{ 19, 21, 0, 28, },
|
|
|
|
{ 40, 36, 0, 13, },
|
|
|
|
{ 19, 35, 1, 27, },
|
|
|
|
{ 1, 4, 1, 0, },
|
2019-05-29 10:00:19 +00:00
|
|
|
};
|
|
|
|
|
2019-08-19 06:39:59 +00:00
|
|
|
static const uint8_t INIT_SIG_COEFF_GROUP[4][4] = {
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 25, 45, 25, 14},
|
|
|
|
{ 25, 30, 25, 45},
|
|
|
|
{ 18, 31, 25, 15},
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 8, 5, 5, 8},
|
2016-08-21 04:36:13 +00:00
|
|
|
};
|
|
|
|
|
2019-08-19 06:39:59 +00:00
|
|
|
static const uint8_t INIT_SIG_FLAG[6][4][12] = {
|
2018-08-29 12:57:40 +00:00
|
|
|
{
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 17, 41, 49, 36, 1, 49, 50, 37, 48, 51, 58, 45, },
|
2020-03-30 11:34:50 +00:00
|
|
|
{ 17, 41, 42, 29, 25, 49, 43, 37, 33, 58, 51, 30, },
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 25, 19, 28, 14, 25, 20, 29, 30, 19, 37, 30, 38, },
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 12, 9, 9, 10, 9, 9, 9, 10, 8, 8, 8, 10, },
|
2018-08-29 12:57:40 +00:00
|
|
|
},
|
|
|
|
{
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 9, 49, 50, 36, 48, 59, 59, 38, },
|
|
|
|
{ 17, 34, 35, 21, 41, 59, 60, 38, },
|
|
|
|
{ 25, 27, 28, 37, 34, 53, 53, 46, },
|
|
|
|
{ 12, 12, 9, 13, 4, 5, 8, 9, },
|
2018-08-29 12:57:40 +00:00
|
|
|
},
|
|
|
|
{
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 26, 45, 53, 46, 49, 54, 61, 39, 35, 39, 39, 39, },
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 19, 38, 38, 46, 34, 54, 54, 39, 6, 39, 39, 39, },
|
2020-03-30 11:34:50 +00:00
|
|
|
{ 11, 38, 46, 54, 27, 39, 39, 39, 44, 39, 39, 39, },
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 9, 13, 8, 8, 8, 8, 8, 5, 8, 0, 0, 0, },
|
2018-08-29 12:57:40 +00:00
|
|
|
},
|
|
|
|
{
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 34, 45, 38, 31, 58, 39, 39, 39, },
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 35, 45, 53, 54, 44, 39, 39, 39, },
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 19, 46, 38, 39, 52, 39, 39, 39, },
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 8, 12, 12, 8, 4, 0, 0, 0, },
|
2018-08-29 12:57:40 +00:00
|
|
|
},
|
|
|
|
{
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 19, 54, 39, 39, 50, 39, 39, 39, 0, 39, 39, 39, },
|
|
|
|
{ 19, 39, 54, 39, 19, 39, 39, 39, 56, 39, 39, 39, },
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 18, 39, 39, 39, 27, 39, 39, 39, 0, 39, 39, 39, },
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 8, 8, 8, 8, 8, 0, 4, 4, 0, 0, 0, 0, },
|
2018-08-29 12:57:40 +00:00
|
|
|
},
|
|
|
|
{
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 34, 38, 54, 39, 41, 39, 39, 39, },
|
|
|
|
{ 34, 38, 62, 39, 26, 39, 39, 39, },
|
2020-03-30 11:34:50 +00:00
|
|
|
{ 11, 39, 39, 39, 19, 39, 39, 39, },
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 8, 8, 8, 8, 4, 0, 0, 0, },
|
2018-08-29 12:57:40 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
static const uint8_t INIT_PARITY_FLAG[2][4][21] =
|
2018-08-29 12:57:40 +00:00
|
|
|
{
|
|
|
|
{
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 33, 40, 25, 41, 26, 42, 25, 33, 26, 34, 27, 25, 41, 42, 42, 35, 33, 27, 35, 42, 43, },
|
2020-03-30 11:34:50 +00:00
|
|
|
{ 18, 17, 33, 18, 26, 42, 25, 33, 26, 42, 27, 25, 34, 42, 42, 35, 26, 27, 42, 20, 20, },
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 33, 25, 18, 26, 34, 27, 25, 26, 19, 42, 35, 33, 19, 27, 35, 35, 34, 42, 20, 43, 20, },
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 8, 9, 12, 13, 13, 13, 10, 13, 13, 13, 13, 13, 13, 13, 13, 13, 10, 13, 13, 13, 13, },
|
2018-08-29 12:57:40 +00:00
|
|
|
},
|
|
|
|
{
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 33, 25, 26, 34, 19, 27, 33, 42, 43, 35, 43, },
|
|
|
|
{ 25, 25, 26, 11, 19, 27, 33, 42, 35, 35, 43, },
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 33, 25, 26, 42, 19, 27, 26, 50, 35, 20, 43, },
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 8, 12, 12, 12, 13, 13, 13, 13, 13, 13, 13, },
|
2018-08-29 12:57:40 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
static const uint8_t INIT_GTX_FLAG[4][4][21] =
|
2018-08-29 12:57:40 +00:00
|
|
|
{
|
|
|
|
{
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 25, 0, 0, 17, 25, 26, 0, 9, 25, 33, 19, 0, 25, 33, 26, 20, 25, 33, 27, 35, 22, },
|
|
|
|
{ 17, 0, 1, 17, 25, 18, 0, 9, 25, 33, 34, 9, 25, 18, 26, 20, 25, 18, 19, 27, 29, },
|
|
|
|
{ 25, 1, 40, 25, 33, 11, 17, 25, 25, 18, 4, 17, 33, 26, 19, 13, 33, 19, 20, 28, 22, },
|
|
|
|
{ 1, 5, 9, 9, 9, 6, 5, 9, 10, 10, 9, 9, 9, 9, 9, 9, 6, 8, 9, 9, 10, },
|
2018-08-29 12:57:40 +00:00
|
|
|
},
|
|
|
|
{
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 25, 1, 25, 33, 26, 12, 25, 33, 27, 28, 37, },
|
|
|
|
{ 17, 9, 25, 10, 18, 4, 17, 33, 19, 20, 29, },
|
|
|
|
{ 40, 9, 25, 18, 26, 35, 25, 26, 35, 28, 37, },
|
|
|
|
{ 1, 5, 8, 8, 9, 6, 6, 9, 8, 8, 9, },
|
2018-08-29 12:57:40 +00:00
|
|
|
},
|
|
|
|
{
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 0, 0, 33, 34, 35, 21, 25, 34, 35, 28, 29, 40, 42, 43, 29, 30, 49, 36, 37, 45, 38, },
|
2020-03-30 11:34:50 +00:00
|
|
|
{ 0, 17, 26, 19, 35, 21, 25, 34, 20, 28, 29, 33, 27, 28, 29, 22, 34, 28, 44, 37, 38, },
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 25, 25, 11, 27, 20, 21, 33, 12, 28, 21, 22, 34, 28, 29, 29, 30, 36, 29, 45, 30, 23, },
|
|
|
|
{ 9, 5, 10, 13, 13, 10, 9, 10, 13, 13, 13, 9, 10, 10, 10, 13, 8, 9, 10, 10, 13, },
|
2018-08-29 12:57:40 +00:00
|
|
|
},
|
|
|
|
{
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 0, 40, 34, 43, 36, 37, 57, 52, 45, 38, 46, },
|
|
|
|
{ 0, 25, 19, 20, 13, 14, 57, 44, 30, 30, 23, },
|
|
|
|
{ 40, 33, 27, 28, 21, 37, 36, 37, 45, 38, 46, },
|
|
|
|
{ 8, 8, 9, 12, 12, 10, 5, 9, 9, 9, 13, },
|
2018-08-29 12:57:40 +00:00
|
|
|
}
|
2014-02-06 15:57:41 +00:00
|
|
|
};
|
|
|
|
|
2019-08-19 06:39:59 +00:00
|
|
|
static const uint8_t INIT_LAST_X[4][23] = {
|
2020-08-17 15:18:35 +00:00
|
|
|
{ 6, 6, 12, 14, 6, 4, 14, 7, 6, 4, 29, 7, 6, 6, 12, 28, 7, 13, 13, 35, 19, 5, 4, },
|
|
|
|
{ 6, 13, 12, 6, 6, 12, 14, 14, 13, 12, 29, 7, 6, 13, 36, 28, 14, 13, 5, 26, 12, 4, 18, },
|
|
|
|
{ 13, 5, 4, 21, 14, 4, 6, 14, 21, 11, 14, 7, 14, 5, 11, 21, 30, 22, 13, 42, 12, 4, 3, },
|
|
|
|
{ 8, 5, 4, 5, 4, 4, 5, 4, 1, 0, 4, 1, 0, 0, 0, 0, 1, 0, 0, 0, 5, 4, 4, },
|
2014-02-06 15:57:41 +00:00
|
|
|
};
|
|
|
|
|
2019-08-19 06:39:59 +00:00
|
|
|
static const uint8_t INIT_LAST_Y[4][23] = {
|
2020-08-17 15:18:35 +00:00
|
|
|
{ 5, 5, 20, 13, 13, 19, 21, 6, 12, 12, 14, 14, 5, 4, 12, 13, 7, 13, 12, 41, 11, 5, 27, },
|
|
|
|
{ 5, 5, 12, 6, 6, 4, 6, 14, 5, 12, 14, 7, 13, 5, 13, 21, 14, 20, 12, 34, 11, 4, 18, },
|
|
|
|
{ 13, 5, 4, 6, 13, 11, 14, 6, 5, 3, 14, 22, 6, 4, 3, 6, 22, 29, 20, 34, 12, 4, 3, },
|
|
|
|
{ 8, 5, 8, 5, 5, 4, 5, 5, 4, 0, 5, 4, 1, 0, 0, 1, 4, 0, 0, 0, 6, 5, 5, },
|
2019-03-27 10:38:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
static const uint8_t INIT_MVP_IDX[4][1] = {
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 34, },
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 34, },
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 42, },
|
|
|
|
{ 12, },
|
2014-04-02 07:54:03 +00:00
|
|
|
};
|
|
|
|
|
2020-03-30 11:34:50 +00:00
|
|
|
|
|
|
|
static const uint8_t INIT_SAO_MERGE_FLAG[4] = { 2, 60, 60, 0 };
|
|
|
|
|
|
|
|
static const uint8_t INIT_SAO_TYPE_IDX[4] = { 2, 5, 13, 4 };
|
|
|
|
|
|
|
|
static const uint8_t INIT_JOINT_CB_CR_FLAG[4][3] = {
|
2020-08-17 11:23:26 +00:00
|
|
|
{ 42, 43, 52, },
|
|
|
|
{ 27, 36, 45, },
|
|
|
|
{ 12, 21, 35, },
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 1, 1, 0, },
|
2019-08-19 06:39:59 +00:00
|
|
|
};
|
2019-06-07 10:37:45 +00:00
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
|
2019-10-02 09:25:02 +00:00
|
|
|
static const INIT_ALF_CTB_ALTERNATIVE[4][2] = {
|
|
|
|
{ 18, 18, },
|
|
|
|
{ 20, 12, },
|
|
|
|
{ 44, 44, },
|
|
|
|
{ 0, 0, },
|
|
|
|
};
|
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
static const uint8_t INIT_CU_TRANSQUANT_BYPASS[4][1] = {
|
2019-05-13 12:30:43 +00:00
|
|
|
{ CNU, },
|
|
|
|
{ CNU, },
|
|
|
|
{ CNU, },
|
|
|
|
{ DWS, },
|
2019-03-27 10:38:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
static const uint8_t INIT_INTRA_SUBPART_MODE[4][2] = {
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 33, 43, },
|
2019-11-14 11:46:51 +00:00
|
|
|
{ 33, 36, },
|
2019-08-19 06:39:59 +00:00
|
|
|
{ 33, 43, },
|
|
|
|
{ 9, 2, },
|
2019-03-27 10:38:19 +00:00
|
|
|
};
|
2014-02-06 15:57:41 +00:00
|
|
|
|
2019-08-19 10:57:31 +00:00
|
|
|
/*
|
2019-03-20 07:06:57 +00:00
|
|
|
static const uint16_t g_inistateToCount[128] = {
|
|
|
|
614, 647, 681, 718, 756, 797, 839, 884, 932, 982, 1034, 1089, 1148, 1209, 1274, 1342,
|
|
|
|
1414, 1490, 1569, 1653, 1742, 1835, 1933, 2037, 2146, 2261, 2382, 2509, 2643, 2785, 2934, 3091,
|
|
|
|
3256, 3430, 3614, 3807, 4011, 4225, 4452, 4690, 4941, 5205, 5483, 5777, 6086, 6412, 6755, 7116,
|
|
|
|
7497, 7898, 8320, 8766, 9235, 9729, 10249, 10798, 11375, 11984, 12625, 13300, 14012, 14762, 15551, 16384,
|
|
|
|
16384, 17216, 18005, 18755, 19467, 20142, 20783, 21392, 21969, 22518, 23038, 23532, 24001, 24447, 24869, 25270,
|
|
|
|
25651, 26012, 26355, 26681, 26990, 27284, 27562, 27826, 28077, 28315, 28542, 28756, 28960, 29153, 29337, 29511,
|
|
|
|
29676, 29833, 29982, 30124, 30258, 30385, 30506, 30621, 30730, 30834, 30932, 31025, 31114, 31198, 31277, 31353,
|
|
|
|
31425, 31493, 31558, 31619, 31678, 31733, 31785, 31835, 31883, 31928, 31970, 32011, 32049, 32086, 32120, 32153
|
2019-08-19 10:57:31 +00:00
|
|
|
};*/
|
2014-02-06 15:57:41 +00:00
|
|
|
|
|
|
|
|
2013-09-19 09:47:39 +00:00
|
|
|
/**
|
|
|
|
* \brief Initialize struct cabac_ctx.
|
|
|
|
*/
|
2019-08-19 11:33:55 +00:00
|
|
|
void kvz_ctx_init(cabac_ctx_t *ctx, int32_t qp, int32_t init_value, uint8_t rate)
|
2013-09-19 09:47:39 +00:00
|
|
|
{
|
2019-08-19 10:57:31 +00:00
|
|
|
|
|
|
|
int slope = (init_value >> 3) - 4;
|
|
|
|
int offset = ((init_value & 7) * 18) + 1;
|
|
|
|
int inistate = ((slope * (qp - 16)) >> 1) + offset;
|
|
|
|
int state_clip = inistate < 1 ? 1 : inistate > 127 ? 127 : inistate;
|
|
|
|
const int p1 = (state_clip << 8);
|
|
|
|
/*
|
2013-09-19 09:47:39 +00:00
|
|
|
int slope = (init_value >> 4) * 5 - 45;
|
|
|
|
int offset = ((init_value & 15) << 3) - 16;
|
2019-05-29 13:17:02 +00:00
|
|
|
int init_state = ((slope * (int)qp) >> 4) + offset;
|
2019-03-20 07:06:57 +00:00
|
|
|
|
|
|
|
const int p1 = g_inistateToCount[init_state < 0 ? 0 : init_state > 127 ? 127 : init_state];
|
2019-08-19 10:57:31 +00:00
|
|
|
*/
|
2013-09-19 09:47:39 +00:00
|
|
|
|
2019-03-20 07:06:57 +00:00
|
|
|
ctx->state[0] = p1 & CTX_MASK_0;
|
|
|
|
ctx->state[1] = p1 & CTX_MASK_1;
|
2019-03-27 10:38:19 +00:00
|
|
|
|
|
|
|
CTX_SET_LOG2_WIN(ctx, rate);
|
|
|
|
|
2013-09-19 09:47:39 +00:00
|
|
|
}
|
|
|
|
|
2013-09-19 09:20:34 +00:00
|
|
|
/**
|
|
|
|
* \brief Initialize cabac context to be used for coding
|
|
|
|
* \param encoder encoder control struct
|
|
|
|
* \param slice type of slice we are coding (P/B/I)
|
|
|
|
*/
|
2014-04-04 08:50:07 +00:00
|
|
|
|
2015-08-26 08:50:27 +00:00
|
|
|
void kvz_init_contexts(encoder_state_t *state, int8_t QP, int8_t slice)
|
2012-08-15 10:22:31 +00:00
|
|
|
{
|
2015-03-04 15:00:23 +00:00
|
|
|
cabac_data_t * const cabac = &state->cabac;
|
2018-08-29 12:57:40 +00:00
|
|
|
uint16_t i, ii;
|
2013-09-09 09:11:09 +00:00
|
|
|
|
2013-09-19 09:20:34 +00:00
|
|
|
// Initialize contexts
|
2019-03-27 10:38:19 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.sao_merge_flag_model, QP, INIT_SAO_MERGE_FLAG[slice], INIT_SAO_MERGE_FLAG[3]);
|
|
|
|
kvz_ctx_init(&cabac->ctx.sao_type_idx_model, QP, INIT_SAO_TYPE_IDX[slice], INIT_SAO_TYPE_IDX[3]);
|
2019-08-15 08:01:38 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.alf_latest_filt, QP, INIT_ALF_LATEST_FILT[slice], INIT_ALF_LATEST_FILT[3]);
|
|
|
|
kvz_ctx_init(&cabac->ctx.alf_temporal_filt, QP, INIT_ALF_TEMPORAL_FILT[slice], INIT_ALF_TEMPORAL_FILT[3]);
|
2014-04-02 07:54:03 +00:00
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.cu_merge_flag_ext_model, QP, INIT_MERGE_FLAG_EXT[slice][0], INIT_MERGE_FLAG_EXT[3][0]);
|
|
|
|
kvz_ctx_init(&cabac->ctx.cu_merge_idx_ext_model, QP, INIT_MERGE_IDX_EXT[slice][0], INIT_MERGE_IDX_EXT[3][0]);
|
2020-10-13 09:04:31 +00:00
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.cu_transquant_bypass, QP, INIT_CU_TRANSQUANT_BYPASS[slice][0], INIT_CU_TRANSQUANT_BYPASS[3][0]);
|
|
|
|
|
2019-08-19 12:17:25 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.intra_luma_mpm_flag_model, QP, INIT_INTRA_LUMA_MPM_FLAG[slice], INIT_INTRA_LUMA_MPM_FLAG[3]);
|
2013-10-23 16:51:39 +00:00
|
|
|
|
2013-04-19 07:56:40 +00:00
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.intra_subpart_model[0], QP, INIT_INTRA_SUBPART_MODE[slice][0], INIT_INTRA_SUBPART_MODE[3][0]);
|
|
|
|
kvz_ctx_init(&cabac->ctx.intra_subpart_model[1], QP, INIT_INTRA_SUBPART_MODE[slice][1], INIT_INTRA_SUBPART_MODE[3][1]);
|
|
|
|
|
2019-08-19 06:39:59 +00:00
|
|
|
|
|
|
|
|
|
|
|
kvz_ctx_init(&cabac->ctx.multi_ref_line[0], QP, MULTI_REF_LINE_MODE[slice][0], MULTI_REF_LINE_MODE[3][0]);
|
|
|
|
kvz_ctx_init(&cabac->ctx.multi_ref_line[1], QP, MULTI_REF_LINE_MODE[slice][1], MULTI_REF_LINE_MODE[3][1]);
|
|
|
|
|
2019-08-22 07:44:47 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.chroma_pred_model, QP, INIT_CHROMA_PRED_MODE[slice], INIT_CHROMA_PRED_MODE[3]);
|
2019-08-19 06:39:59 +00:00
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
|
|
|
|
for (i = 0; i < 3; i++) {
|
|
|
|
kvz_ctx_init(&cabac->ctx.cu_skip_flag_model[i], QP, INIT_SKIP_FLAG[slice][i], INIT_SKIP_FLAG[3][i]);
|
2019-08-19 06:39:59 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.joint_bc_br[i], QP, INIT_JOINT_CB_CR_FLAG[slice][i], INIT_JOINT_CB_CR_FLAG[3][i]);
|
2019-03-27 10:38:19 +00:00
|
|
|
}
|
2019-08-19 06:39:59 +00:00
|
|
|
|
|
|
|
for (i = 0; i < 4; i++) {
|
|
|
|
kvz_ctx_init(&cabac->ctx.sig_coeff_group_model[i], QP, INIT_SIG_COEFF_GROUP[slice][i], INIT_SIG_COEFF_GROUP[3][i]);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-03-20 07:06:57 +00:00
|
|
|
for (i = 0; i < 6; i++) {
|
2019-03-27 10:38:19 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.qt_split_flag_model[i], QP, INIT_QT_SPLIT_FLAG[slice][i], INIT_QT_SPLIT_FLAG[3][i]);
|
2019-03-20 07:06:57 +00:00
|
|
|
}
|
2013-04-19 07:56:40 +00:00
|
|
|
|
2019-08-19 06:39:59 +00:00
|
|
|
|
2018-08-14 12:26:42 +00:00
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
for (i = 0; i < 9; i++) {
|
|
|
|
kvz_ctx_init(&cabac->ctx.split_flag_model[i], QP, INIT_SPLIT_FLAG[slice][i], INIT_SPLIT_FLAG[3][i]);
|
2019-07-04 12:26:01 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.alf_ctb_flag_model[i], QP, INIT_ALF_CTB_FLAG[slice][i], INIT_ALF_CTB_FLAG[3][i]);
|
2018-08-29 12:58:09 +00:00
|
|
|
}
|
2019-03-27 10:38:19 +00:00
|
|
|
|
2014-02-21 13:00:20 +00:00
|
|
|
|
2013-09-09 11:22:53 +00:00
|
|
|
//TODO: ignore P/B contexts on intra frame
|
2020-10-13 09:04:31 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.cu_pred_mode_model[0], QP, INIT_PRED_MODE[slice][0], INIT_PRED_MODE[3][0]);
|
|
|
|
kvz_ctx_init(&cabac->ctx.cu_pred_mode_model[1], QP, INIT_PRED_MODE[slice][1], INIT_PRED_MODE[3][1]);
|
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.cu_qt_root_cbf_model, QP, INIT_QT_ROOT_CBF[slice][0], INIT_QT_ROOT_CBF[3][0]);
|
2019-07-05 11:10:11 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.mvp_idx_model, QP, INIT_MVP_IDX[slice][0], INIT_MVP_IDX[3][0]);
|
2016-08-21 04:36:13 +00:00
|
|
|
|
2020-03-30 11:34:50 +00:00
|
|
|
for (i = 0; i < 2; i++) {
|
|
|
|
kvz_ctx_init(&cabac->ctx.qt_cbf_model_cb[i], QP, INIT_QT_CBF[slice][i+4], INIT_QT_CBF[3][i+4]);
|
2019-03-27 10:38:19 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.cu_mvd_model[i], QP, INIT_MVD[slice][i], INIT_MVD[3][i]);
|
2019-07-05 11:10:11 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.cu_ref_pic_model[i], QP, INIT_REF_PIC[slice][i], INIT_REF_PIC[3][i]);
|
2019-05-21 09:28:05 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.luma_planar_model[i], QP, INIT_INTRA_LUMA_PLANAR_MODE[slice][i], INIT_INTRA_LUMA_PLANAR_MODE[3][i]);
|
2019-08-19 06:39:59 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.cu_qp_delta_abs[i], QP, INIT_CU_QP_DELTA_ABS[slice][i], INIT_CU_QP_DELTA_ABS[3][i]);
|
2019-10-02 09:25:02 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.alf_ctb_alternatives[i], QP, INIT_ALF_CTB_ALTERNATIVE[slice][i], INIT_ALF_CTB_ALTERNATIVE[3][i]);
|
2018-08-30 06:08:08 +00:00
|
|
|
}
|
2019-03-27 10:38:19 +00:00
|
|
|
|
2013-09-19 09:20:34 +00:00
|
|
|
for (i = 0; i < 3; i++) {
|
2020-03-30 11:34:50 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.qt_cbf_model_cr[i], QP, INIT_QT_CBF[slice][i + 6], INIT_QT_CBF[3][i + 6]);
|
2019-08-19 06:39:59 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.cu_ctx_last_y_chroma[i], QP, INIT_LAST_Y[slice][i + 20], INIT_LAST_Y[3][i + 20]);
|
|
|
|
kvz_ctx_init(&cabac->ctx.cu_ctx_last_x_chroma[i], QP, INIT_LAST_X[slice][i + 20], INIT_LAST_X[3][i + 20]);
|
2013-02-05 13:48:06 +00:00
|
|
|
}
|
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
for (i = 0; i < 4; i++) {
|
2019-05-21 09:28:05 +00:00
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.part_size_model[i], QP, INIT_PART_SIZE[slice][i], INIT_PART_SIZE[3][i]);
|
2020-08-17 11:23:26 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.bdpcm_mode[i], QP, BDPCM_MODE_INIT[slice][i], BDPCM_MODE_INIT[3][i]);
|
2019-08-19 06:39:59 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.qt_cbf_model_luma[i], QP, INIT_QT_CBF[slice][i], INIT_QT_CBF[3][i]);
|
2015-03-06 14:26:16 +00:00
|
|
|
}
|
|
|
|
|
2019-11-14 11:46:51 +00:00
|
|
|
for (i = 0; i < 6; i++) {
|
2013-02-05 13:48:06 +00:00
|
|
|
|
2019-03-27 10:38:19 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.inter_dir[i], QP, INIT_INTER_DIR[slice][i], INIT_INTER_DIR[3][i]);
|
|
|
|
}
|
2012-08-15 10:22:31 +00:00
|
|
|
|
2019-08-19 06:39:59 +00:00
|
|
|
for (i = 0; i < 20; i++) {
|
2019-03-27 10:38:19 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.cu_ctx_last_y_luma[i], QP, INIT_LAST_Y[slice][i], INIT_LAST_Y[3][i]);
|
|
|
|
kvz_ctx_init(&cabac->ctx.cu_ctx_last_x_luma[i], QP, INIT_LAST_X[slice][i], INIT_LAST_X[3][i]);
|
2012-08-15 10:22:31 +00:00
|
|
|
}
|
2014-02-21 13:00:20 +00:00
|
|
|
|
2018-08-29 12:57:40 +00:00
|
|
|
for (ii = 0; ii < 3; ii++) {
|
2019-08-19 06:39:59 +00:00
|
|
|
for (i = 0; i < 12; i++) {
|
2019-03-27 10:38:19 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.cu_sig_model_luma[ii][i], QP, INIT_SIG_FLAG[ii*2][slice][i], INIT_SIG_FLAG[ii * 2][3][i]);
|
2019-08-19 06:39:59 +00:00
|
|
|
if (i < 8) kvz_ctx_init(&cabac->ctx.cu_sig_model_chroma[ii][i], QP, INIT_SIG_FLAG[ii*2+1][slice][i], INIT_SIG_FLAG[ii * 2 + 1][3][i]);
|
2018-08-29 12:57:40 +00:00
|
|
|
}
|
|
|
|
}
|
2019-03-27 10:38:19 +00:00
|
|
|
|
2018-08-29 12:57:40 +00:00
|
|
|
for (i = 0; i < 21; i++) {
|
2019-03-27 10:38:19 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.cu_parity_flag_model_luma[i], QP, INIT_PARITY_FLAG[0][slice][i], INIT_PARITY_FLAG[0][3][i]);
|
|
|
|
if (i < 11) kvz_ctx_init(&cabac->ctx.cu_parity_flag_model_chroma[i], QP, INIT_PARITY_FLAG[1][slice][i], INIT_PARITY_FLAG[1][3][i]);
|
2018-08-29 12:57:40 +00:00
|
|
|
}
|
|
|
|
for (ii = 0; ii < 2; ii++) {
|
|
|
|
for (i = 0; i < 21; i++) {
|
2019-03-27 10:38:19 +00:00
|
|
|
kvz_ctx_init(&cabac->ctx.cu_gtx_flag_model_luma[ii][i], QP, INIT_GTX_FLAG[ii * 2][slice][i], INIT_GTX_FLAG[ii * 2][3][i]);
|
|
|
|
if (i < 11) kvz_ctx_init(&cabac->ctx.cu_gtx_flag_model_chroma[ii][i], QP, INIT_GTX_FLAG[ii * 2 + 1][slice][i], INIT_GTX_FLAG[ii * 2 + 1][3][i]);
|
2018-08-29 12:57:40 +00:00
|
|
|
}
|
2012-08-15 10:22:31 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-08-26 08:50:27 +00:00
|
|
|
void kvz_context_copy(encoder_state_t * const target_state, const encoder_state_t * const source_state) {
|
2015-03-04 15:00:23 +00:00
|
|
|
cabac_data_t * const target_cabac = &target_state->cabac;
|
|
|
|
const cabac_data_t * const source_cabac = &source_state->cabac;
|
2014-05-08 08:12:57 +00:00
|
|
|
|
2014-09-23 22:04:12 +00:00
|
|
|
if (target_cabac == source_cabac) return;
|
|
|
|
|
|
|
|
target_cabac->ctx = source_cabac->ctx;
|
2014-05-08 08:12:57 +00:00
|
|
|
}
|
|
|
|
|
2013-09-19 09:20:34 +00:00
|
|
|
|
2015-08-26 08:50:27 +00:00
|
|
|
uint32_t kvz_context_get_sig_coeff_group( uint32_t *sig_coeff_group_flag,
|
2013-09-19 09:20:34 +00:00
|
|
|
uint32_t pos_x,
|
|
|
|
uint32_t pos_y,
|
|
|
|
int32_t width)
|
2013-02-05 13:48:06 +00:00
|
|
|
{
|
|
|
|
uint32_t uiRight = 0;
|
|
|
|
uint32_t uiLower = 0;
|
2019-06-20 11:43:03 +00:00
|
|
|
uint32_t position = pos_y * width + pos_x;
|
2019-07-01 10:00:43 +00:00
|
|
|
if (pos_x + 1 < (uint32_t)width) uiRight = sig_coeff_group_flag[position + 1];
|
|
|
|
if (pos_y + 1 < (uint32_t)width) uiLower = sig_coeff_group_flag[position + width];
|
2013-02-05 13:48:06 +00:00
|
|
|
|
2013-09-19 09:20:34 +00:00
|
|
|
return uiRight || uiLower;
|
2013-02-05 13:48:06 +00:00
|
|
|
}
|
2012-08-15 10:22:31 +00:00
|
|
|
|
|
|
|
|
2014-02-21 13:00:20 +00:00
|
|
|
/**
|
2013-09-19 09:20:34 +00:00
|
|
|
* \brief Pattern decision for context derivation process of significant_coeff_flag
|
|
|
|
* \param sig_coeff_group_flag pointer to prior coded significant coeff group
|
|
|
|
* \param pos_x column of current coefficient group
|
|
|
|
* \param pos_y row of current coefficient group
|
|
|
|
* \param width width of the block
|
|
|
|
* \returns pattern for current coefficient group
|
|
|
|
*/
|
2014-02-21 13:00:20 +00:00
|
|
|
|
2015-08-26 08:50:27 +00:00
|
|
|
int32_t kvz_context_calc_pattern_sig_ctx(const uint32_t *sig_coeff_group_flag, uint32_t pos_x, uint32_t pos_y, int32_t width)
|
2012-08-15 10:22:31 +00:00
|
|
|
{
|
2013-02-05 13:48:06 +00:00
|
|
|
uint32_t sigRight = 0;
|
|
|
|
uint32_t sigLower = 0;
|
2013-09-19 09:20:34 +00:00
|
|
|
|
|
|
|
if (width == 4) return -1;
|
|
|
|
|
2012-08-15 10:22:31 +00:00
|
|
|
width >>= 2;
|
2013-09-19 09:20:34 +00:00
|
|
|
if (pos_x < (uint32_t)width - 1) sigRight = (sig_coeff_group_flag[pos_y * width + pos_x + 1] != 0);
|
|
|
|
if (pos_y < (uint32_t)width - 1) sigLower = (sig_coeff_group_flag[(pos_y + 1 ) * width + pos_x] != 0);
|
2014-02-21 13:00:20 +00:00
|
|
|
|
2012-08-15 10:22:31 +00:00
|
|
|
return sigRight + (sigLower<<1);
|
|
|
|
}
|
2013-02-05 13:48:06 +00:00
|
|
|
|
2012-08-15 10:22:31 +00:00
|
|
|
|
2013-09-19 09:20:34 +00:00
|
|
|
/**
|
|
|
|
* \brief Context derivation process of coeff_abs_significant_flag
|
|
|
|
* \param pattern_sig_ctx pattern for current coefficient group
|
|
|
|
* \param scan_idx pixel scan type in use
|
|
|
|
* \param pos_x column of current scan position
|
|
|
|
* \param pos_y row of current scan position
|
|
|
|
* \param block_type log2 value of block size if square block, or 4 otherwise
|
|
|
|
* \param width width of the block
|
|
|
|
* \param texture_type texture type (TEXT_LUMA...)
|
|
|
|
* \returns ctx_inc for current scan position
|
|
|
|
*/
|
|
|
|
|
2015-08-26 08:50:27 +00:00
|
|
|
int32_t kvz_context_get_sig_ctx_inc(int32_t pattern_sig_ctx, uint32_t scan_idx, int32_t pos_x,
|
2014-04-04 08:32:56 +00:00
|
|
|
int32_t pos_y, int32_t block_type, int8_t texture_type)
|
2012-08-15 10:22:31 +00:00
|
|
|
{
|
2013-09-18 11:21:03 +00:00
|
|
|
const int32_t ctx_ind_map[16] =
|
2012-08-15 10:22:31 +00:00
|
|
|
{
|
|
|
|
0, 1, 4, 5,
|
|
|
|
2, 3, 4, 5,
|
|
|
|
6, 6, 8, 8,
|
|
|
|
7, 7, 8, 8
|
|
|
|
};
|
|
|
|
|
2013-09-19 09:20:34 +00:00
|
|
|
int32_t cnt,offset,pos_x_in_subset,pos_y_in_subset;
|
2012-08-15 10:22:31 +00:00
|
|
|
|
2013-09-19 09:20:34 +00:00
|
|
|
if (pos_x + pos_y == 0) return 0;
|
2012-08-15 10:22:31 +00:00
|
|
|
|
2013-09-19 09:20:34 +00:00
|
|
|
if (block_type == 2) return ctx_ind_map[4 * pos_y + pos_x];
|
|
|
|
|
|
|
|
offset = (block_type == 3) ? ((scan_idx == SCAN_DIAG) ? 9 : 15) : ((texture_type == 0) ? 21 : 12);
|
|
|
|
pos_x_in_subset = pos_x - ((pos_x>>2)<<2);
|
|
|
|
pos_y_in_subset = pos_y - ((pos_y>>2)<<2);
|
2014-02-21 13:00:20 +00:00
|
|
|
|
2013-09-19 09:20:34 +00:00
|
|
|
if (pattern_sig_ctx == 0) {
|
2014-02-21 13:00:20 +00:00
|
|
|
cnt = (pos_x_in_subset + pos_y_in_subset <= 2) ? ((pos_x_in_subset + pos_y_in_subset==0) ? 2 : 1) : 0;
|
2013-09-19 09:20:34 +00:00
|
|
|
} else if (pattern_sig_ctx==1) {
|
|
|
|
cnt = (pos_y_in_subset <= 1) ? ((pos_y_in_subset == 0) ? 2 : 1) : 0;
|
|
|
|
} else if (pattern_sig_ctx==2) {
|
|
|
|
cnt = (pos_x_in_subset <= 1) ? ((pos_x_in_subset == 0) ? 2 : 1) : 0;
|
|
|
|
} else {
|
2012-08-15 10:22:31 +00:00
|
|
|
cnt = 2;
|
|
|
|
}
|
2013-09-18 11:21:03 +00:00
|
|
|
return (( texture_type == 0 && ((pos_x>>2) + (pos_y>>2)) > 0 ) ? 3 : 0) + offset + cnt;
|
2012-08-15 10:22:31 +00:00
|
|
|
}
|
2018-08-30 08:09:42 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Context derivation process of coeff_abs_significant_flag
|
|
|
|
* \param coeff pointer to the current coefficient
|
|
|
|
* \param pos_x column of current scan position
|
|
|
|
* \param pos_y row of current scan position
|
|
|
|
* \param width width of the block
|
|
|
|
* \param height height of the block
|
|
|
|
* \param type texture type (TEXT_LUMA...)
|
2018-08-30 11:24:03 +00:00
|
|
|
* \param temp_diag temporary output value used in the next steps
|
|
|
|
* \param temp_sum temporary output value used in the next steps
|
2018-08-30 08:09:42 +00:00
|
|
|
* \returns context index for current scan position
|
|
|
|
*/
|
2018-08-30 11:24:03 +00:00
|
|
|
uint32_t kvz_context_get_sig_ctx_idx_abs(const coeff_t* coeff, int32_t pos_x, int32_t pos_y,
|
|
|
|
uint32_t height, uint32_t width, int8_t type,
|
|
|
|
int32_t* temp_diag, int32_t* temp_sum)
|
2018-08-30 08:09:42 +00:00
|
|
|
{
|
|
|
|
const coeff_t* data = coeff + pos_x + pos_y * width;
|
|
|
|
const int diag = pos_x + pos_y;
|
|
|
|
int num_pos = 0;
|
|
|
|
int sum_abs = 0;
|
2019-07-01 10:00:43 +00:00
|
|
|
#define UPDATE(x) {int a=abs(x);sum_abs+=MIN(4+(a&1),a);num_pos+=(a?1:0);}
|
2018-08-30 08:09:42 +00:00
|
|
|
if (pos_x < width - 1)
|
|
|
|
{
|
|
|
|
UPDATE(data[1]);
|
|
|
|
if (pos_x < width - 2)
|
|
|
|
{
|
|
|
|
UPDATE(data[2]);
|
|
|
|
}
|
|
|
|
if (pos_y < height - 1)
|
|
|
|
{
|
|
|
|
UPDATE(data[width + 1]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (pos_y < height - 1)
|
|
|
|
{
|
|
|
|
UPDATE(data[width]);
|
|
|
|
if (pos_y < height - 2)
|
|
|
|
{
|
|
|
|
UPDATE(data[width << 1]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#undef UPDATE
|
2019-08-22 07:57:50 +00:00
|
|
|
int ctx_ofs = MIN((sum_abs+1)>>1, 3) + (diag < 2 ? 4 : 0);
|
2018-08-30 08:09:42 +00:00
|
|
|
if (type == 0 /* Luma */)
|
|
|
|
{
|
2019-08-22 07:57:50 +00:00
|
|
|
ctx_ofs += diag < 5 ? 4 : 0;
|
2018-08-30 08:09:42 +00:00
|
|
|
}
|
|
|
|
|
2018-08-30 11:24:03 +00:00
|
|
|
*temp_diag = diag;
|
|
|
|
*temp_sum = sum_abs - num_pos;
|
2018-08-30 08:09:42 +00:00
|
|
|
return ctx_ofs;
|
2018-08-30 11:24:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-05-13 12:30:43 +00:00
|
|
|
* \brief Calculate slot of Go rice parameter for remainder coefficient value coding
|
2018-08-30 11:24:03 +00:00
|
|
|
* \param coeff pointer to the current coefficient
|
|
|
|
* \param pos_x column of current scan position
|
|
|
|
* \param pos_y row of current scan position
|
|
|
|
* \param width width of the block
|
|
|
|
* \param height height of the block
|
|
|
|
* \returns context go rice parameter
|
|
|
|
*/
|
2019-05-13 12:30:43 +00:00
|
|
|
uint32_t kvz_abs_sum(const coeff_t* coeff, int32_t pos_x, int32_t pos_y,
|
|
|
|
uint32_t height, uint32_t width, uint32_t baselevel)
|
2018-08-30 11:24:03 +00:00
|
|
|
{
|
2019-05-13 12:30:43 +00:00
|
|
|
#define UPDATE(x) sum+=abs(x)/*-(x?1:0)*/
|
2018-08-30 11:24:03 +00:00
|
|
|
|
2019-07-01 10:00:43 +00:00
|
|
|
|
2018-08-30 11:24:03 +00:00
|
|
|
const coeff_t* data = coeff + pos_x + pos_y * width;
|
|
|
|
int sum = 0;
|
|
|
|
if (pos_x < width - 1)
|
|
|
|
{
|
|
|
|
UPDATE(data[1]);
|
|
|
|
if (pos_x < width - 2)
|
|
|
|
{
|
|
|
|
UPDATE(data[2]);
|
|
|
|
}
|
|
|
|
if (pos_y < height - 1)
|
|
|
|
{
|
|
|
|
UPDATE(data[width + 1]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (pos_y < height - 1)
|
|
|
|
{
|
|
|
|
UPDATE(data[width]);
|
|
|
|
if (pos_y < height - 2)
|
|
|
|
{
|
|
|
|
UPDATE(data[width << 1]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#undef UPDATE
|
2019-06-05 12:57:18 +00:00
|
|
|
return MAX(MIN(sum - 5 * (int32_t)baselevel, 31),0);
|
2019-05-13 12:30:43 +00:00
|
|
|
/*return MIN(sum, 31);*/
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \brief Calculate Go rice parameter for remainder coefficient value coding
|
|
|
|
* \param coeff pointer to the current coefficient
|
|
|
|
* \param pos_x column of current scan position
|
|
|
|
* \param pos_y row of current scan position
|
|
|
|
* \param width width of the block
|
|
|
|
* \param height height of the block
|
|
|
|
* \returns context go rice parameter
|
|
|
|
*/
|
|
|
|
uint32_t kvz_go_rice_par_abs(const coeff_t* coeff, int32_t pos_x, int32_t pos_y,
|
|
|
|
uint32_t height, uint32_t width, uint32_t baselevel)
|
|
|
|
{
|
|
|
|
//#define UPDATE(x) sum+=abs(x)/*-(x?1:0)*/
|
|
|
|
//
|
|
|
|
// const coeff_t* data = coeff + pos_x + pos_y * width;
|
|
|
|
// int sum = 0;
|
|
|
|
// if (pos_x < width - 1)
|
|
|
|
// {
|
|
|
|
// UPDATE(data[1]);
|
|
|
|
// if (pos_x < width - 2)
|
|
|
|
// {
|
|
|
|
// UPDATE(data[2]);
|
|
|
|
// }
|
|
|
|
// if (pos_y < height - 1)
|
|
|
|
// {
|
|
|
|
// UPDATE(data[width + 1]);
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
// if (pos_y < height - 1)
|
|
|
|
// {
|
|
|
|
// UPDATE(data[width]);
|
|
|
|
// if (pos_y < height - 2)
|
|
|
|
// {
|
|
|
|
// UPDATE(data[width << 1]);
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
//#undef UPDATE
|
2019-06-05 12:57:18 +00:00
|
|
|
uint32_t check = kvz_abs_sum(coeff, pos_x, pos_y, height, width, baselevel);
|
|
|
|
return g_go_rice_pars[check];
|
2019-05-13 12:30:43 +00:00
|
|
|
/*return g_go_rice_pars[kvz_abs_sum(coeff, pos_x, pos_y, height, width, baselevel)];*/
|
2018-08-30 08:09:42 +00:00
|
|
|
}
|