| Index: source/libvpx/vp9/common/vp9_entropy.h
|
| ===================================================================
|
| --- source/libvpx/vp9/common/vp9_entropy.h (revision 240950)
|
| +++ source/libvpx/vp9/common/vp9_entropy.h (working copy)
|
| @@ -17,56 +17,48 @@
|
| #include "vp9/common/vp9_common.h"
|
| #include "vp9/common/vp9_scan.h"
|
| #include "vp9/common/vp9_treecoder.h"
|
| +#include "vp9/common/vp9_entropymode.h"
|
|
|
| #define DIFF_UPDATE_PROB 252
|
|
|
| -/* Coefficient token alphabet */
|
| +// Coefficient token alphabet
|
| +#define ZERO_TOKEN 0 // 0 Extra Bits 0+0
|
| +#define ONE_TOKEN 1 // 1 Extra Bits 0+1
|
| +#define TWO_TOKEN 2 // 2 Extra Bits 0+1
|
| +#define THREE_TOKEN 3 // 3 Extra Bits 0+1
|
| +#define FOUR_TOKEN 4 // 4 Extra Bits 0+1
|
| +#define CATEGORY1_TOKEN 5 // 5-6 Extra Bits 1+1
|
| +#define CATEGORY2_TOKEN 6 // 7-10 Extra Bits 2+1
|
| +#define CATEGORY3_TOKEN 7 // 11-18 Extra Bits 3+1
|
| +#define CATEGORY4_TOKEN 8 // 19-34 Extra Bits 4+1
|
| +#define CATEGORY5_TOKEN 9 // 35-66 Extra Bits 5+1
|
| +#define CATEGORY6_TOKEN 10 // 67+ Extra Bits 14+1
|
| +#define EOB_TOKEN 11 // EOB Extra Bits 0+0
|
|
|
| -#define ZERO_TOKEN 0 /* 0 Extra Bits 0+0 */
|
| -#define ONE_TOKEN 1 /* 1 Extra Bits 0+1 */
|
| -#define TWO_TOKEN 2 /* 2 Extra Bits 0+1 */
|
| -#define THREE_TOKEN 3 /* 3 Extra Bits 0+1 */
|
| -#define FOUR_TOKEN 4 /* 4 Extra Bits 0+1 */
|
| -#define DCT_VAL_CATEGORY1 5 /* 5-6 Extra Bits 1+1 */
|
| -#define DCT_VAL_CATEGORY2 6 /* 7-10 Extra Bits 2+1 */
|
| -#define DCT_VAL_CATEGORY3 7 /* 11-18 Extra Bits 3+1 */
|
| -#define DCT_VAL_CATEGORY4 8 /* 19-34 Extra Bits 4+1 */
|
| -#define DCT_VAL_CATEGORY5 9 /* 35-66 Extra Bits 5+1 */
|
| -#define DCT_VAL_CATEGORY6 10 /* 67+ Extra Bits 14+1 */
|
| -#define DCT_EOB_TOKEN 11 /* EOB Extra Bits 0+0 */
|
| -#define MAX_ENTROPY_TOKENS 12
|
| -#define ENTROPY_NODES 11
|
| -#define EOSB_TOKEN 127 /* Not signalled, encoder only */
|
| +#define ENTROPY_TOKENS 12
|
|
|
| -#define INTER_MODE_CONTEXTS 7
|
| +#define ENTROPY_NODES 11
|
|
|
| -extern DECLARE_ALIGNED(16, const uint8_t,
|
| - vp9_pt_energy_class[MAX_ENTROPY_TOKENS]);
|
| +extern DECLARE_ALIGNED(16, const uint8_t, vp9_pt_energy_class[ENTROPY_TOKENS]);
|
|
|
| -extern const vp9_tree_index vp9_coef_tree[TREE_SIZE(MAX_ENTROPY_TOKENS)];
|
| -
|
| -#define DCT_EOB_MODEL_TOKEN 3 /* EOB Extra Bits 0+0 */
|
| +#define EOB_MODEL_TOKEN 3
|
| extern const vp9_tree_index vp9_coefmodel_tree[];
|
|
|
| -extern struct vp9_token vp9_coef_encodings[MAX_ENTROPY_TOKENS];
|
| -
|
| typedef struct {
|
| - vp9_tree_index *tree;
|
| + const vp9_tree_index *tree;
|
| const vp9_prob *prob;
|
| int len;
|
| int base_val;
|
| } vp9_extra_bit;
|
|
|
| // indexed by token value
|
| -extern const vp9_extra_bit vp9_extra_bits[MAX_ENTROPY_TOKENS];
|
| +extern const vp9_extra_bit vp9_extra_bits[ENTROPY_TOKENS];
|
|
|
| #define MAX_PROB 255
|
| #define DCT_MAX_VALUE 16384
|
|
|
| /* Coefficients are predicted via a 3-dimensional probability table. */
|
|
|
| -/* Outside dimension. 0 = Y with DC, 1 = UV */
|
| -#define BLOCK_TYPES 2
|
| #define REF_TYPES 2 // intra=0, inter=1
|
|
|
| /* Middle dimension reflects the coefficient position within the transform. */
|
| @@ -88,13 +80,14 @@
|
| coefficient band (and since zigzag positions 0, 1, and 2 are in
|
| distinct bands). */
|
|
|
| -#define PREV_COEF_CONTEXTS 6
|
| +#define COEFF_CONTEXTS 6
|
| +#define BAND_COEFF_CONTEXTS(band) ((band) == 0 ? 3 : COEFF_CONTEXTS)
|
|
|
| // #define ENTROPY_STATS
|
|
|
| -typedef unsigned int vp9_coeff_count[REF_TYPES][COEF_BANDS][PREV_COEF_CONTEXTS]
|
| - [MAX_ENTROPY_TOKENS];
|
| -typedef unsigned int vp9_coeff_stats[REF_TYPES][COEF_BANDS][PREV_COEF_CONTEXTS]
|
| +typedef unsigned int vp9_coeff_count[REF_TYPES][COEF_BANDS][COEFF_CONTEXTS]
|
| + [ENTROPY_TOKENS];
|
| +typedef unsigned int vp9_coeff_stats[REF_TYPES][COEF_BANDS][COEFF_CONTEXTS]
|
| [ENTROPY_NODES][2];
|
|
|
| #define SUBEXP_PARAM 4 /* Subexponential code parameter */
|
| @@ -102,8 +95,6 @@
|
|
|
| struct VP9Common;
|
| void vp9_default_coef_probs(struct VP9Common *cm);
|
| -
|
| -void vp9_coef_tree_initialize();
|
| void vp9_adapt_coef_probs(struct VP9Common *cm);
|
|
|
| static INLINE void reset_skip_context(MACROBLOCKD *xd, BLOCK_SIZE bsize) {
|
| @@ -120,41 +111,41 @@
|
|
|
| // This is the index in the scan order beyond which all coefficients for
|
| // 8x8 transform and above are in the top band.
|
| -// For 4x4 blocks the index is less but to keep things common the lookup
|
| -// table for 4x4 is padded out to this index.
|
| +// This macro is currently unused but may be used by certain implementations
|
| #define MAXBAND_INDEX 21
|
|
|
| -extern const uint8_t vp9_coefband_trans_8x8plus[MAXBAND_INDEX + 1];
|
| -extern const uint8_t vp9_coefband_trans_4x4[MAXBAND_INDEX + 1];
|
| +extern const uint8_t vp9_coefband_trans_8x8plus[1024];
|
| +extern const uint8_t vp9_coefband_trans_4x4[16];
|
|
|
| -
|
| -static int get_coef_band(const uint8_t * band_translate, int coef_index) {
|
| - return (coef_index > MAXBAND_INDEX)
|
| - ? (COEF_BANDS-1) : band_translate[coef_index];
|
| +static const uint8_t *get_band_translate(TX_SIZE tx_size) {
|
| + return tx_size == TX_4X4 ? vp9_coefband_trans_4x4
|
| + : vp9_coefband_trans_8x8plus;
|
| }
|
|
|
| // 128 lists of probabilities are stored for the following ONE node probs:
|
| // 1, 3, 5, 7, ..., 253, 255
|
| // In between probabilities are interpolated linearly
|
|
|
| -#define COEFPROB_MODELS 128
|
| +#define COEFF_PROB_MODELS 256
|
|
|
| #define UNCONSTRAINED_NODES 3
|
|
|
| #define PIVOT_NODE 2 // which node is pivot
|
|
|
| +#define MODEL_NODES (ENTROPY_NODES - UNCONSTRAINED_NODES)
|
| +extern const vp9_prob vp9_pareto8_full[COEFF_PROB_MODELS][MODEL_NODES];
|
| +
|
| typedef vp9_prob vp9_coeff_probs_model[REF_TYPES][COEF_BANDS]
|
| - [PREV_COEF_CONTEXTS]
|
| - [UNCONSTRAINED_NODES];
|
| + [COEFF_CONTEXTS][UNCONSTRAINED_NODES];
|
|
|
| typedef unsigned int vp9_coeff_count_model[REF_TYPES][COEF_BANDS]
|
| - [PREV_COEF_CONTEXTS]
|
| + [COEFF_CONTEXTS]
|
| [UNCONSTRAINED_NODES + 1];
|
|
|
| void vp9_model_to_full_probs(const vp9_prob *model, vp9_prob *full);
|
|
|
| -static int get_entropy_context(TX_SIZE tx_size,
|
| - ENTROPY_CONTEXT *a, ENTROPY_CONTEXT *l) {
|
| +static int get_entropy_context(TX_SIZE tx_size, const ENTROPY_CONTEXT *a,
|
| + const ENTROPY_CONTEXT *l) {
|
| ENTROPY_CONTEXT above_ec = 0, left_ec = 0;
|
|
|
| switch (tx_size) {
|
| @@ -163,48 +154,35 @@
|
| left_ec = l[0] != 0;
|
| break;
|
| case TX_8X8:
|
| - above_ec = !!*(uint16_t *)a;
|
| - left_ec = !!*(uint16_t *)l;
|
| + above_ec = !!*(const uint16_t *)a;
|
| + left_ec = !!*(const uint16_t *)l;
|
| break;
|
| case TX_16X16:
|
| - above_ec = !!*(uint32_t *)a;
|
| - left_ec = !!*(uint32_t *)l;
|
| + above_ec = !!*(const uint32_t *)a;
|
| + left_ec = !!*(const uint32_t *)l;
|
| break;
|
| case TX_32X32:
|
| - above_ec = !!*(uint64_t *)a;
|
| - left_ec = !!*(uint64_t *)l;
|
| + above_ec = !!*(const uint64_t *)a;
|
| + left_ec = !!*(const uint64_t *)l;
|
| break;
|
| default:
|
| - assert(!"Invalid transform size.");
|
| + assert(0 && "Invalid transform size.");
|
| }
|
|
|
| return combine_entropy_contexts(above_ec, left_ec);
|
| }
|
|
|
| -static const uint8_t *get_band_translate(TX_SIZE tx_size) {
|
| - return tx_size == TX_4X4 ? vp9_coefband_trans_4x4
|
| - : vp9_coefband_trans_8x8plus;
|
| -}
|
| +static const scan_order *get_scan(const MACROBLOCKD *xd, TX_SIZE tx_size,
|
| + PLANE_TYPE type, int block_idx) {
|
| + const MODE_INFO *const mi = xd->mi_8x8[0];
|
| + const MB_MODE_INFO *const mbmi = &mi->mbmi;
|
|
|
| -static void get_scan(const MACROBLOCKD *xd, TX_SIZE tx_size,
|
| - PLANE_TYPE type, int block_idx,
|
| - const int16_t **scan, const int16_t **scan_nb) {
|
| - switch (tx_size) {
|
| - case TX_4X4:
|
| - get_scan_nb_4x4(get_tx_type_4x4(type, xd, block_idx), scan, scan_nb);
|
| - break;
|
| - case TX_8X8:
|
| - get_scan_nb_8x8(get_tx_type_8x8(type, xd), scan, scan_nb);
|
| - break;
|
| - case TX_16X16:
|
| - get_scan_nb_16x16(get_tx_type_16x16(type, xd), scan, scan_nb);
|
| - break;
|
| - case TX_32X32:
|
| - *scan = vp9_default_scan_32x32;
|
| - *scan_nb = vp9_default_scan_32x32_neighbors;
|
| - break;
|
| - default:
|
| - assert(!"Invalid transform size.");
|
| + if (is_inter_block(mbmi) || type != PLANE_TYPE_Y || xd->lossless) {
|
| + return &vp9_default_scan_orders[tx_size];
|
| + } else {
|
| + const MB_PREDICTION_MODE mode =
|
| + mbmi->sb_type < BLOCK_8X8 ? mi->bmi[block_idx].as_mode : mbmi->mode;
|
| + return &vp9_scan_orders[tx_size][mode2txfm_map[mode]];
|
| }
|
| }
|
|
|
|
|