blob: f28ffe7ac3a282b403666fb63bd04d4c0152c95f [file] [log] [blame]
Yaowu Xuc27fc142016-08-22 16:08:15 -07001/*
Yaowu Xu2ab7ff02016-09-02 12:04:54 -07002 * Copyright (c) 2016, Alliance for Open Media. All rights reserved
Yaowu Xuc27fc142016-08-22 16:08:15 -07003 *
Yaowu Xu2ab7ff02016-09-02 12:04:54 -07004 * This source code is subject to the terms of the BSD 2 Clause License and
5 * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License
6 * was not distributed with this source code in the LICENSE file, you can
7 * obtain it at www.aomedia.org/license/software. If the Alliance for Open
8 * Media Patent License 1.0 was not distributed with this source code in the
9 * PATENTS file, you can obtain it at www.aomedia.org/license/patent.
Yaowu Xuc27fc142016-08-22 16:08:15 -070010 */
11
Yaowu Xuf883b422016-08-30 14:01:10 -070012#ifndef AV1_COMMON_QUANT_COMMON_H_
13#define AV1_COMMON_QUANT_COMMON_H_
Yaowu Xuc27fc142016-08-22 16:08:15 -070014
Yaowu Xuf883b422016-08-30 14:01:10 -070015#include "aom/aom_codec.h"
Yaowu Xuc27fc142016-08-22 16:08:15 -070016#include "av1/common/seg_common.h"
17#include "av1/common/enums.h"
Debargha Mukherjee3c42c092016-09-29 09:17:36 -070018#include "av1/common/entropy.h"
Yaowu Xuc27fc142016-08-22 16:08:15 -070019
20#ifdef __cplusplus
21extern "C" {
22#endif
23
24#define MINQ 0
25#define MAXQ 255
26#define QINDEX_RANGE (MAXQ - MINQ + 1)
27#define QINDEX_BITS 8
28#if CONFIG_AOM_QM
29// Total number of QM sets stored
30#define QM_LEVEL_BITS 4
31#define NUM_QM_LEVELS (1 << QM_LEVEL_BITS)
Thomas Davies6675adf2017-05-04 17:39:21 +010032/* Range of QMS is between first and last value, with offset applied to inter
33 * blocks*/
34#define DEFAULT_QM_FIRST 5
35#define DEFAULT_QM_LAST 9
36#define DEFAULT_QM_INTER_OFFSET 0
Yaowu Xuc27fc142016-08-22 16:08:15 -070037#endif
38
Yaowu Xuf883b422016-08-30 14:01:10 -070039struct AV1Common;
Yaowu Xuc27fc142016-08-22 16:08:15 -070040
Yaowu Xuf883b422016-08-30 14:01:10 -070041int16_t av1_dc_quant(int qindex, int delta, aom_bit_depth_t bit_depth);
42int16_t av1_ac_quant(int qindex, int delta, aom_bit_depth_t bit_depth);
Rostislav Pehlivanov002e7b72017-02-15 19:45:54 +000043int16_t av1_qindex_from_ac(int ac, aom_bit_depth_t bit_depth);
Yaowu Xuc27fc142016-08-22 16:08:15 -070044
Yaowu Xuf883b422016-08-30 14:01:10 -070045int av1_get_qindex(const struct segmentation *seg, int segment_id,
46 int base_qindex);
Yaowu Xuc27fc142016-08-22 16:08:15 -070047#if CONFIG_AOM_QM
48// Reduce the large number of quantizers to a smaller number of levels for which
49// different matrices may be defined
Debargha Mukherjee3c42c092016-09-29 09:17:36 -070050static INLINE int aom_get_qmlevel(int qindex, int first, int last) {
Yaowu Xuc27fc142016-08-22 16:08:15 -070051 int qmlevel = (qindex * (last + 1 - first) + QINDEX_RANGE / 2) / QINDEX_RANGE;
Yaowu Xuf883b422016-08-30 14:01:10 -070052 qmlevel = AOMMIN(qmlevel + first, NUM_QM_LEVELS - 1);
Yaowu Xuc27fc142016-08-22 16:08:15 -070053 return qmlevel;
54}
Yaowu Xuf883b422016-08-30 14:01:10 -070055void aom_qm_init(struct AV1Common *cm);
56qm_val_t *aom_iqmatrix(struct AV1Common *cm, int qindex, int comp,
Thomas Davies6675adf2017-05-04 17:39:21 +010057 TX_SIZE tx_size, int is_intra);
Yaowu Xuf883b422016-08-30 14:01:10 -070058qm_val_t *aom_qmatrix(struct AV1Common *cm, int qindex, int comp,
Thomas Davies6675adf2017-05-04 17:39:21 +010059 TX_SIZE tx_size, int is_intra);
Yaowu Xuc27fc142016-08-22 16:08:15 -070060#endif
61
62#if CONFIG_NEW_QUANT
63
Debargha Mukherjee3c42c092016-09-29 09:17:36 -070064#define QUANT_PROFILES 4
Yaowu Xuc27fc142016-08-22 16:08:15 -070065#define QUANT_RANGES 2
66#define NUQ_KNOTS 3
67
68typedef tran_low_t dequant_val_type_nuq[NUQ_KNOTS + 1];
69typedef tran_low_t cuml_bins_type_nuq[NUQ_KNOTS];
Debargha Mukherjee3c42c092016-09-29 09:17:36 -070070void av1_get_dequant_val_nuq(int q, int band, tran_low_t *dq,
Yaowu Xuf883b422016-08-30 14:01:10 -070071 tran_low_t *cuml_bins, int dq_off_index);
72tran_low_t av1_dequant_abscoeff_nuq(int v, int q, const tran_low_t *dq);
73tran_low_t av1_dequant_coeff_nuq(int v, int q, const tran_low_t *dq);
Yaowu Xuc27fc142016-08-22 16:08:15 -070074
Debargha Mukherjee3c42c092016-09-29 09:17:36 -070075static INLINE int qindex_to_qrange(int qindex) {
76 return (qindex < 140 ? 1 : 0);
77}
78
79static INLINE int get_dq_profile_from_ctx(int qindex, int q_ctx, int is_inter,
Debargha Mukherjee9324d382016-09-23 10:52:13 -070080 PLANE_TYPE plane_type) {
Debargha Mukherjee3c42c092016-09-29 09:17:36 -070081 // intra/inter, Y/UV, ctx, qrange
82 static const int
83 def_dq_profile_lookup[REF_TYPES][PLANE_TYPES][COEFF_CONTEXTS0]
84 [QUANT_RANGES] = {
85 {
86 // intra
87 { { 2, 1 }, { 2, 1 }, { 2, 1 } }, // Y
88 { { 3, 1 }, { 3, 1 }, { 3, 1 } }, // UV
89 },
90 {
91 // inter
92 { { 3, 1 }, { 2, 1 }, { 2, 1 } }, // Y
93 { { 3, 1 }, { 3, 1 }, { 3, 1 } }, // UV
94 },
95 };
96 if (!qindex) return 0; // lossless
97 return def_dq_profile_lookup[is_inter][plane_type][q_ctx]
98 [qindex_to_qrange(qindex)];
Yaowu Xuc27fc142016-08-22 16:08:15 -070099}
100#endif // CONFIG_NEW_QUANT
101
Yushin Cho7a428ba2017-01-12 16:28:49 -0800102#if CONFIG_PVQ || CONFIG_DAALA_DIST
103extern const int OD_QM8_Q4_FLAT[];
104extern const int OD_QM8_Q4_HVS[];
105#endif
106
Yaowu Xuc27fc142016-08-22 16:08:15 -0700107#ifdef __cplusplus
108} // extern "C"
109#endif
110
Yaowu Xuf883b422016-08-30 14:01:10 -0700111#endif // AV1_COMMON_QUANT_COMMON_H_