xref: /aosp_15_r20/external/libvpx/vp8/common/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_VP8_COMMON_ENTROPY_H_
12*fb1b10abSAndroid Build Coastguard Worker #define VPX_VP8_COMMON_ENTROPY_H_
13*fb1b10abSAndroid Build Coastguard Worker 
14*fb1b10abSAndroid Build Coastguard Worker #include "treecoder.h"
15*fb1b10abSAndroid Build Coastguard Worker #include "blockd.h"
16*fb1b10abSAndroid Build Coastguard Worker 
17*fb1b10abSAndroid Build Coastguard Worker #ifdef __cplusplus
18*fb1b10abSAndroid Build Coastguard Worker extern "C" {
19*fb1b10abSAndroid Build Coastguard Worker #endif
20*fb1b10abSAndroid Build Coastguard Worker 
21*fb1b10abSAndroid Build Coastguard Worker /* Coefficient token alphabet */
22*fb1b10abSAndroid Build Coastguard Worker 
23*fb1b10abSAndroid Build Coastguard Worker #define ZERO_TOKEN 0         /* 0         Extra Bits 0+0 */
24*fb1b10abSAndroid Build Coastguard Worker #define ONE_TOKEN 1          /* 1         Extra Bits 0+1 */
25*fb1b10abSAndroid Build Coastguard Worker #define TWO_TOKEN 2          /* 2         Extra Bits 0+1 */
26*fb1b10abSAndroid Build Coastguard Worker #define THREE_TOKEN 3        /* 3         Extra Bits 0+1 */
27*fb1b10abSAndroid Build Coastguard Worker #define FOUR_TOKEN 4         /* 4         Extra Bits 0+1 */
28*fb1b10abSAndroid Build Coastguard Worker #define DCT_VAL_CATEGORY1 5  /* 5-6       Extra Bits 1+1 */
29*fb1b10abSAndroid Build Coastguard Worker #define DCT_VAL_CATEGORY2 6  /* 7-10      Extra Bits 2+1 */
30*fb1b10abSAndroid Build Coastguard Worker #define DCT_VAL_CATEGORY3 7  /* 11-18     Extra Bits 3+1 */
31*fb1b10abSAndroid Build Coastguard Worker #define DCT_VAL_CATEGORY4 8  /* 19-34     Extra Bits 4+1 */
32*fb1b10abSAndroid Build Coastguard Worker #define DCT_VAL_CATEGORY5 9  /* 35-66     Extra Bits 5+1 */
33*fb1b10abSAndroid Build Coastguard Worker #define DCT_VAL_CATEGORY6 10 /* 67+       Extra Bits 11+1 */
34*fb1b10abSAndroid Build Coastguard Worker #define DCT_EOB_TOKEN 11     /* EOB       Extra Bits 0+0 */
35*fb1b10abSAndroid Build Coastguard Worker 
36*fb1b10abSAndroid Build Coastguard Worker #define MAX_ENTROPY_TOKENS 12
37*fb1b10abSAndroid Build Coastguard Worker #define ENTROPY_NODES 11
38*fb1b10abSAndroid Build Coastguard Worker 
39*fb1b10abSAndroid Build Coastguard Worker extern const vp8_tree_index vp8_coef_tree[];
40*fb1b10abSAndroid Build Coastguard Worker 
41*fb1b10abSAndroid Build Coastguard Worker extern const struct vp8_token_struct vp8_coef_encodings[MAX_ENTROPY_TOKENS];
42*fb1b10abSAndroid Build Coastguard Worker 
43*fb1b10abSAndroid Build Coastguard Worker typedef struct {
44*fb1b10abSAndroid Build Coastguard Worker   vp8_tree_p tree;
45*fb1b10abSAndroid Build Coastguard Worker   const vp8_prob *prob;
46*fb1b10abSAndroid Build Coastguard Worker   int Len;
47*fb1b10abSAndroid Build Coastguard Worker   int base_val;
48*fb1b10abSAndroid Build Coastguard Worker } vp8_extra_bit_struct;
49*fb1b10abSAndroid Build Coastguard Worker 
50*fb1b10abSAndroid Build Coastguard Worker extern const vp8_extra_bit_struct
51*fb1b10abSAndroid Build Coastguard Worker     vp8_extra_bits[12]; /* indexed by token value */
52*fb1b10abSAndroid Build Coastguard Worker 
53*fb1b10abSAndroid Build Coastguard Worker #define PROB_UPDATE_BASELINE_COST 7
54*fb1b10abSAndroid Build Coastguard Worker 
55*fb1b10abSAndroid Build Coastguard Worker #define MAX_PROB 255
56*fb1b10abSAndroid Build Coastguard Worker #define DCT_MAX_VALUE 2048
57*fb1b10abSAndroid Build Coastguard Worker 
58*fb1b10abSAndroid Build Coastguard Worker /* Coefficients are predicted via a 3-dimensional probability table. */
59*fb1b10abSAndroid Build Coastguard Worker 
60*fb1b10abSAndroid Build Coastguard Worker /* Outside dimension.  0 = Y no DC, 1 = Y2, 2 = UV, 3 = Y with DC */
61*fb1b10abSAndroid Build Coastguard Worker 
62*fb1b10abSAndroid Build Coastguard Worker #define BLOCK_TYPES 4
63*fb1b10abSAndroid Build Coastguard Worker 
64*fb1b10abSAndroid Build Coastguard Worker /* Middle dimension is a coarsening of the coefficient's
65*fb1b10abSAndroid Build Coastguard Worker    position within the 4x4 DCT. */
66*fb1b10abSAndroid Build Coastguard Worker 
67*fb1b10abSAndroid Build Coastguard Worker #define COEF_BANDS 8
68*fb1b10abSAndroid Build Coastguard Worker extern DECLARE_ALIGNED(16, const unsigned char, vp8_coef_bands[16]);
69*fb1b10abSAndroid Build Coastguard Worker 
70*fb1b10abSAndroid Build Coastguard Worker /* Inside dimension is 3-valued measure of nearby complexity, that is,
71*fb1b10abSAndroid Build Coastguard Worker    the extent to which nearby coefficients are nonzero.  For the first
72*fb1b10abSAndroid Build Coastguard Worker    coefficient (DC, unless block type is 0), we look at the (already encoded)
73*fb1b10abSAndroid Build Coastguard Worker    blocks above and to the left of the current block.  The context index is
74*fb1b10abSAndroid Build Coastguard Worker    then the number (0,1,or 2) of these blocks having nonzero coefficients.
75*fb1b10abSAndroid Build Coastguard Worker    After decoding a coefficient, the measure is roughly the size of the
76*fb1b10abSAndroid Build Coastguard Worker    most recently decoded coefficient (0 for 0, 1 for 1, 2 for >1).
77*fb1b10abSAndroid Build Coastguard Worker    Note that the intuitive meaning of this measure changes as coefficients
78*fb1b10abSAndroid Build Coastguard Worker    are decoded, e.g., prior to the first token, a zero means that my neighbors
79*fb1b10abSAndroid Build Coastguard Worker    are empty while, after the first token, because of the use of end-of-block,
80*fb1b10abSAndroid Build Coastguard Worker    a zero means we just decoded a zero and hence guarantees that a non-zero
81*fb1b10abSAndroid Build Coastguard Worker    coefficient will appear later in this block.  However, this shift
82*fb1b10abSAndroid Build Coastguard Worker    in meaning is perfectly OK because our context depends also on the
83*fb1b10abSAndroid Build Coastguard Worker    coefficient band (and since zigzag positions 0, 1, and 2 are in
84*fb1b10abSAndroid Build Coastguard Worker    distinct bands). */
85*fb1b10abSAndroid Build Coastguard Worker 
86*fb1b10abSAndroid Build Coastguard Worker /*# define DC_TOKEN_CONTEXTS        3*/ /* 00, 0!0, !0!0 */
87*fb1b10abSAndroid Build Coastguard Worker #define PREV_COEF_CONTEXTS 3
88*fb1b10abSAndroid Build Coastguard Worker 
89*fb1b10abSAndroid Build Coastguard Worker extern DECLARE_ALIGNED(16, const unsigned char,
90*fb1b10abSAndroid Build Coastguard Worker                        vp8_prev_token_class[MAX_ENTROPY_TOKENS]);
91*fb1b10abSAndroid Build Coastguard Worker 
92*fb1b10abSAndroid Build Coastguard Worker extern const vp8_prob vp8_coef_update_probs[BLOCK_TYPES][COEF_BANDS]
93*fb1b10abSAndroid Build Coastguard Worker                                            [PREV_COEF_CONTEXTS][ENTROPY_NODES];
94*fb1b10abSAndroid Build Coastguard Worker 
95*fb1b10abSAndroid Build Coastguard Worker struct VP8Common;
96*fb1b10abSAndroid Build Coastguard Worker void vp8_default_coef_probs(struct VP8Common *);
97*fb1b10abSAndroid Build Coastguard Worker 
98*fb1b10abSAndroid Build Coastguard Worker extern DECLARE_ALIGNED(16, const int, vp8_default_zig_zag1d[16]);
99*fb1b10abSAndroid Build Coastguard Worker extern DECLARE_ALIGNED(16, const short, vp8_default_inv_zig_zag[16]);
100*fb1b10abSAndroid Build Coastguard Worker extern DECLARE_ALIGNED(16, const short, vp8_default_zig_zag_mask[16]);
101*fb1b10abSAndroid Build Coastguard Worker extern const int vp8_mb_feature_data_bits[MB_LVL_MAX];
102*fb1b10abSAndroid Build Coastguard Worker 
103*fb1b10abSAndroid Build Coastguard Worker void vp8_coef_tree_initialize(void);
104*fb1b10abSAndroid Build Coastguard Worker #ifdef __cplusplus
105*fb1b10abSAndroid Build Coastguard Worker }  // extern "C"
106*fb1b10abSAndroid Build Coastguard Worker #endif
107*fb1b10abSAndroid Build Coastguard Worker 
108*fb1b10abSAndroid Build Coastguard Worker #endif  // VPX_VP8_COMMON_ENTROPY_H_
109