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