xref: /aosp_15_r20/external/libvpx/vp9/common/vp9_entropy.h (revision fb1b10ab9aebc7c7068eedab379b749d7e3900be)
1*fb1b10abSAndroid Build Coastguard Worker /*
2*fb1b10abSAndroid Build Coastguard Worker  *  Copyright (c) 2010 The WebM project authors. All Rights Reserved.
3*fb1b10abSAndroid Build Coastguard Worker  *
4*fb1b10abSAndroid Build Coastguard Worker  *  Use of this source code is governed by a BSD-style license
5*fb1b10abSAndroid Build Coastguard Worker  *  that can be found in the LICENSE file in the root of the source
6*fb1b10abSAndroid Build Coastguard Worker  *  tree. An additional intellectual property rights grant can be found
7*fb1b10abSAndroid Build Coastguard Worker  *  in the file PATENTS.  All contributing project authors may
8*fb1b10abSAndroid Build Coastguard Worker  *  be found in the AUTHORS file in the root of the source tree.
9*fb1b10abSAndroid Build Coastguard Worker  */
10*fb1b10abSAndroid Build Coastguard Worker 
11*fb1b10abSAndroid Build Coastguard Worker #ifndef VPX_VP9_COMMON_VP9_ENTROPY_H_
12*fb1b10abSAndroid Build Coastguard Worker #define VPX_VP9_COMMON_VP9_ENTROPY_H_
13*fb1b10abSAndroid Build Coastguard Worker 
14*fb1b10abSAndroid Build Coastguard Worker #include "vpx/vpx_integer.h"
15*fb1b10abSAndroid Build Coastguard Worker #include "vpx_dsp/prob.h"
16*fb1b10abSAndroid Build Coastguard Worker 
17*fb1b10abSAndroid Build Coastguard Worker #include "vp9/common/vp9_common.h"
18*fb1b10abSAndroid Build Coastguard Worker #include "vp9/common/vp9_enums.h"
19*fb1b10abSAndroid Build Coastguard Worker 
20*fb1b10abSAndroid Build Coastguard Worker #ifdef __cplusplus
21*fb1b10abSAndroid Build Coastguard Worker extern "C" {
22*fb1b10abSAndroid Build Coastguard Worker #endif
23*fb1b10abSAndroid Build Coastguard Worker 
24*fb1b10abSAndroid Build Coastguard Worker #define DIFF_UPDATE_PROB 252
25*fb1b10abSAndroid Build Coastguard Worker 
26*fb1b10abSAndroid Build Coastguard Worker // Coefficient token alphabet
27*fb1b10abSAndroid Build Coastguard Worker #define ZERO_TOKEN 0        // 0     Extra Bits 0+0
28*fb1b10abSAndroid Build Coastguard Worker #define ONE_TOKEN 1         // 1     Extra Bits 0+1
29*fb1b10abSAndroid Build Coastguard Worker #define TWO_TOKEN 2         // 2     Extra Bits 0+1
30*fb1b10abSAndroid Build Coastguard Worker #define THREE_TOKEN 3       // 3     Extra Bits 0+1
31*fb1b10abSAndroid Build Coastguard Worker #define FOUR_TOKEN 4        // 4     Extra Bits 0+1
32*fb1b10abSAndroid Build Coastguard Worker #define CATEGORY1_TOKEN 5   // 5-6   Extra Bits 1+1
33*fb1b10abSAndroid Build Coastguard Worker #define CATEGORY2_TOKEN 6   // 7-10  Extra Bits 2+1
34*fb1b10abSAndroid Build Coastguard Worker #define CATEGORY3_TOKEN 7   // 11-18 Extra Bits 3+1
35*fb1b10abSAndroid Build Coastguard Worker #define CATEGORY4_TOKEN 8   // 19-34 Extra Bits 4+1
36*fb1b10abSAndroid Build Coastguard Worker #define CATEGORY5_TOKEN 9   // 35-66 Extra Bits 5+1
37*fb1b10abSAndroid Build Coastguard Worker #define CATEGORY6_TOKEN 10  // 67+   Extra Bits 14+1
38*fb1b10abSAndroid Build Coastguard Worker #define EOB_TOKEN 11        // EOB   Extra Bits 0+0
39*fb1b10abSAndroid Build Coastguard Worker 
40*fb1b10abSAndroid Build Coastguard Worker #define ENTROPY_TOKENS 12
41*fb1b10abSAndroid Build Coastguard Worker 
42*fb1b10abSAndroid Build Coastguard Worker #define ENTROPY_NODES 11
43*fb1b10abSAndroid Build Coastguard Worker 
44*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_pt_energy_class[ENTROPY_TOKENS]);
45*fb1b10abSAndroid Build Coastguard Worker 
46*fb1b10abSAndroid Build Coastguard Worker #define CAT1_MIN_VAL 5
47*fb1b10abSAndroid Build Coastguard Worker #define CAT2_MIN_VAL 7
48*fb1b10abSAndroid Build Coastguard Worker #define CAT3_MIN_VAL 11
49*fb1b10abSAndroid Build Coastguard Worker #define CAT4_MIN_VAL 19
50*fb1b10abSAndroid Build Coastguard Worker #define CAT5_MIN_VAL 35
51*fb1b10abSAndroid Build Coastguard Worker #define CAT6_MIN_VAL 67
52*fb1b10abSAndroid Build Coastguard Worker 
53*fb1b10abSAndroid Build Coastguard Worker // Extra bit probabilities.
54*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat1_prob[1]);
55*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat2_prob[2]);
56*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat3_prob[3]);
57*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat4_prob[4]);
58*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat5_prob[5]);
59*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat6_prob[14]);
60*fb1b10abSAndroid Build Coastguard Worker 
61*fb1b10abSAndroid Build Coastguard Worker #if CONFIG_VP9_HIGHBITDEPTH
62*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat1_prob_high10[1]);
63*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat2_prob_high10[2]);
64*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat3_prob_high10[3]);
65*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat4_prob_high10[4]);
66*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat5_prob_high10[5]);
67*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat6_prob_high10[16]);
68*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat1_prob_high12[1]);
69*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat2_prob_high12[2]);
70*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat3_prob_high12[3]);
71*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat4_prob_high12[4]);
72*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat5_prob_high12[5]);
73*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_cat6_prob_high12[18]);
74*fb1b10abSAndroid Build Coastguard Worker #endif  // CONFIG_VP9_HIGHBITDEPTH
75*fb1b10abSAndroid Build Coastguard Worker 
76*fb1b10abSAndroid Build Coastguard Worker #define EOB_MODEL_TOKEN 3
77*fb1b10abSAndroid Build Coastguard Worker 
78*fb1b10abSAndroid Build Coastguard Worker #define DCT_MAX_VALUE 16384
79*fb1b10abSAndroid Build Coastguard Worker #if CONFIG_VP9_HIGHBITDEPTH
80*fb1b10abSAndroid Build Coastguard Worker #define DCT_MAX_VALUE_HIGH10 65536
81*fb1b10abSAndroid Build Coastguard Worker #define DCT_MAX_VALUE_HIGH12 262144
82*fb1b10abSAndroid Build Coastguard Worker #endif  // CONFIG_VP9_HIGHBITDEPTH
83*fb1b10abSAndroid Build Coastguard Worker 
84*fb1b10abSAndroid Build Coastguard Worker /* Coefficients are predicted via a 3-dimensional probability table. */
85*fb1b10abSAndroid Build Coastguard Worker 
86*fb1b10abSAndroid Build Coastguard Worker #define REF_TYPES 2  // intra=0, inter=1
87*fb1b10abSAndroid Build Coastguard Worker 
88*fb1b10abSAndroid Build Coastguard Worker /* Middle dimension reflects the coefficient position within the transform. */
89*fb1b10abSAndroid Build Coastguard Worker #define COEF_BANDS 6
90*fb1b10abSAndroid Build Coastguard Worker 
91*fb1b10abSAndroid Build Coastguard Worker /* Inside dimension is measure of nearby complexity, that reflects the energy
92*fb1b10abSAndroid Build Coastguard Worker    of nearby coefficients are nonzero.  For the first coefficient (DC, unless
93*fb1b10abSAndroid Build Coastguard Worker    block type is 0), we look at the (already encoded) blocks above and to the
94*fb1b10abSAndroid Build Coastguard Worker    left of the current block.  The context index is then the number (0,1,or 2)
95*fb1b10abSAndroid Build Coastguard Worker    of these blocks having nonzero coefficients.
96*fb1b10abSAndroid Build Coastguard Worker    After decoding a coefficient, the measure is determined by the size of the
97*fb1b10abSAndroid Build Coastguard Worker    most recently decoded coefficient.
98*fb1b10abSAndroid Build Coastguard Worker    Note that the intuitive meaning of this measure changes as coefficients
99*fb1b10abSAndroid Build Coastguard Worker    are decoded, e.g., prior to the first token, a zero means that my neighbors
100*fb1b10abSAndroid Build Coastguard Worker    are empty while, after the first token, because of the use of end-of-block,
101*fb1b10abSAndroid Build Coastguard Worker    a zero means we just decoded a zero and hence guarantees that a non-zero
102*fb1b10abSAndroid Build Coastguard Worker    coefficient will appear later in this block.  However, this shift
103*fb1b10abSAndroid Build Coastguard Worker    in meaning is perfectly OK because our context depends also on the
104*fb1b10abSAndroid Build Coastguard Worker    coefficient band (and since zigzag positions 0, 1, and 2 are in
105*fb1b10abSAndroid Build Coastguard Worker    distinct bands). */
106*fb1b10abSAndroid Build Coastguard Worker 
107*fb1b10abSAndroid Build Coastguard Worker #define COEFF_CONTEXTS 6
108*fb1b10abSAndroid Build Coastguard Worker #define BAND_COEFF_CONTEXTS(band) ((band) == 0 ? 3 : COEFF_CONTEXTS)
109*fb1b10abSAndroid Build Coastguard Worker 
110*fb1b10abSAndroid Build Coastguard Worker // #define ENTROPY_STATS
111*fb1b10abSAndroid Build Coastguard Worker 
112*fb1b10abSAndroid Build Coastguard Worker typedef unsigned int vp9_coeff_count[REF_TYPES][COEF_BANDS][COEFF_CONTEXTS]
113*fb1b10abSAndroid Build Coastguard Worker                                     [ENTROPY_TOKENS];
114*fb1b10abSAndroid Build Coastguard Worker typedef unsigned int vp9_coeff_stats[REF_TYPES][COEF_BANDS][COEFF_CONTEXTS]
115*fb1b10abSAndroid Build Coastguard Worker                                     [ENTROPY_NODES][2];
116*fb1b10abSAndroid Build Coastguard Worker 
117*fb1b10abSAndroid Build Coastguard Worker #define SUBEXP_PARAM 4   /* Subexponential code parameter */
118*fb1b10abSAndroid Build Coastguard Worker #define MODULUS_PARAM 13 /* Modulus parameter */
119*fb1b10abSAndroid Build Coastguard Worker 
120*fb1b10abSAndroid Build Coastguard Worker struct VP9Common;
121*fb1b10abSAndroid Build Coastguard Worker void vp9_default_coef_probs(struct VP9Common *cm);
122*fb1b10abSAndroid Build Coastguard Worker void vp9_adapt_coef_probs(struct VP9Common *cm);
123*fb1b10abSAndroid Build Coastguard Worker 
124*fb1b10abSAndroid Build Coastguard Worker // This is the index in the scan order beyond which all coefficients for
125*fb1b10abSAndroid Build Coastguard Worker // 8x8 transform and above are in the top band.
126*fb1b10abSAndroid Build Coastguard Worker // This macro is currently unused but may be used by certain implementations
127*fb1b10abSAndroid Build Coastguard Worker #define MAXBAND_INDEX 21
128*fb1b10abSAndroid Build Coastguard Worker 
129*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_coefband_trans_8x8plus[1024]);
130*fb1b10abSAndroid Build Coastguard Worker DECLARE_ALIGNED(16, extern const uint8_t, vp9_coefband_trans_4x4[16]);
131*fb1b10abSAndroid Build Coastguard Worker 
get_band_translate(TX_SIZE tx_size)132*fb1b10abSAndroid Build Coastguard Worker static INLINE const uint8_t *get_band_translate(TX_SIZE tx_size) {
133*fb1b10abSAndroid Build Coastguard Worker   return tx_size == TX_4X4 ? vp9_coefband_trans_4x4
134*fb1b10abSAndroid Build Coastguard Worker                            : vp9_coefband_trans_8x8plus;
135*fb1b10abSAndroid Build Coastguard Worker }
136*fb1b10abSAndroid Build Coastguard Worker 
137*fb1b10abSAndroid Build Coastguard Worker // 128 lists of probabilities are stored for the following ONE node probs:
138*fb1b10abSAndroid Build Coastguard Worker // 1, 3, 5, 7, ..., 253, 255
139*fb1b10abSAndroid Build Coastguard Worker // In between probabilities are interpolated linearly
140*fb1b10abSAndroid Build Coastguard Worker #define COEFF_PROB_MODELS 255
141*fb1b10abSAndroid Build Coastguard Worker 
142*fb1b10abSAndroid Build Coastguard Worker #define UNCONSTRAINED_NODES 3
143*fb1b10abSAndroid Build Coastguard Worker 
144*fb1b10abSAndroid Build Coastguard Worker #define PIVOT_NODE 2  // which node is pivot
145*fb1b10abSAndroid Build Coastguard Worker 
146*fb1b10abSAndroid Build Coastguard Worker #define MODEL_NODES (ENTROPY_NODES - UNCONSTRAINED_NODES)
147*fb1b10abSAndroid Build Coastguard Worker extern const vpx_tree_index vp9_coef_con_tree[TREE_SIZE(ENTROPY_TOKENS)];
148*fb1b10abSAndroid Build Coastguard Worker extern const vpx_prob vp9_pareto8_full[COEFF_PROB_MODELS][MODEL_NODES];
149*fb1b10abSAndroid Build Coastguard Worker 
150*fb1b10abSAndroid Build Coastguard Worker typedef vpx_prob vp9_coeff_probs_model[REF_TYPES][COEF_BANDS][COEFF_CONTEXTS]
151*fb1b10abSAndroid Build Coastguard Worker                                       [UNCONSTRAINED_NODES];
152*fb1b10abSAndroid Build Coastguard Worker 
153*fb1b10abSAndroid Build Coastguard Worker typedef unsigned int vp9_coeff_count_model[REF_TYPES][COEF_BANDS]
154*fb1b10abSAndroid Build Coastguard Worker                                           [COEFF_CONTEXTS]
155*fb1b10abSAndroid Build Coastguard Worker                                           [UNCONSTRAINED_NODES + 1];
156*fb1b10abSAndroid Build Coastguard Worker 
157*fb1b10abSAndroid Build Coastguard Worker void vp9_model_to_full_probs(const vpx_prob *model, vpx_prob *full);
158*fb1b10abSAndroid Build Coastguard Worker 
159*fb1b10abSAndroid Build Coastguard Worker typedef char ENTROPY_CONTEXT;
160*fb1b10abSAndroid Build Coastguard Worker 
combine_entropy_contexts(ENTROPY_CONTEXT a,ENTROPY_CONTEXT b)161*fb1b10abSAndroid Build Coastguard Worker static INLINE int combine_entropy_contexts(ENTROPY_CONTEXT a,
162*fb1b10abSAndroid Build Coastguard Worker                                            ENTROPY_CONTEXT b) {
163*fb1b10abSAndroid Build Coastguard Worker   return (a != 0) + (b != 0);
164*fb1b10abSAndroid Build Coastguard Worker }
165*fb1b10abSAndroid Build Coastguard Worker 
get_entropy_context(TX_SIZE tx_size,const ENTROPY_CONTEXT * a,const ENTROPY_CONTEXT * l)166*fb1b10abSAndroid Build Coastguard Worker static INLINE int get_entropy_context(TX_SIZE tx_size, const ENTROPY_CONTEXT *a,
167*fb1b10abSAndroid Build Coastguard Worker                                       const ENTROPY_CONTEXT *l) {
168*fb1b10abSAndroid Build Coastguard Worker   ENTROPY_CONTEXT above_ec = 0, left_ec = 0;
169*fb1b10abSAndroid Build Coastguard Worker 
170*fb1b10abSAndroid Build Coastguard Worker   switch (tx_size) {
171*fb1b10abSAndroid Build Coastguard Worker     case TX_4X4:
172*fb1b10abSAndroid Build Coastguard Worker       above_ec = a[0] != 0;
173*fb1b10abSAndroid Build Coastguard Worker       left_ec = l[0] != 0;
174*fb1b10abSAndroid Build Coastguard Worker       break;
175*fb1b10abSAndroid Build Coastguard Worker     case TX_8X8:
176*fb1b10abSAndroid Build Coastguard Worker       above_ec = !!*(const uint16_t *)a;
177*fb1b10abSAndroid Build Coastguard Worker       left_ec = !!*(const uint16_t *)l;
178*fb1b10abSAndroid Build Coastguard Worker       break;
179*fb1b10abSAndroid Build Coastguard Worker     case TX_16X16:
180*fb1b10abSAndroid Build Coastguard Worker       above_ec = !!*(const uint32_t *)a;
181*fb1b10abSAndroid Build Coastguard Worker       left_ec = !!*(const uint32_t *)l;
182*fb1b10abSAndroid Build Coastguard Worker       break;
183*fb1b10abSAndroid Build Coastguard Worker     case TX_32X32:
184*fb1b10abSAndroid Build Coastguard Worker       above_ec = !!*(const uint64_t *)a;
185*fb1b10abSAndroid Build Coastguard Worker       left_ec = !!*(const uint64_t *)l;
186*fb1b10abSAndroid Build Coastguard Worker       break;
187*fb1b10abSAndroid Build Coastguard Worker     default: assert(0 && "Invalid transform size."); break;
188*fb1b10abSAndroid Build Coastguard Worker   }
189*fb1b10abSAndroid Build Coastguard Worker 
190*fb1b10abSAndroid Build Coastguard Worker   return combine_entropy_contexts(above_ec, left_ec);
191*fb1b10abSAndroid Build Coastguard Worker }
192*fb1b10abSAndroid Build Coastguard Worker 
193*fb1b10abSAndroid Build Coastguard Worker #ifdef __cplusplus
194*fb1b10abSAndroid Build Coastguard Worker }  // extern "C"
195*fb1b10abSAndroid Build Coastguard Worker #endif
196*fb1b10abSAndroid Build Coastguard Worker 
197*fb1b10abSAndroid Build Coastguard Worker #endif  // VPX_VP9_COMMON_VP9_ENTROPY_H_
198