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]]; |
} |
} |