Index: source/libvpx/vp9/common/vp9_entropy.h |
=================================================================== |
--- source/libvpx/vp9/common/vp9_entropy.h (revision 177019) |
+++ source/libvpx/vp9/common/vp9_entropy.h (working copy) |
@@ -8,10 +8,10 @@ |
* be found in the AUTHORS file in the root of the source tree. |
*/ |
- |
#ifndef VP9_COMMON_VP9_ENTROPY_H_ |
#define VP9_COMMON_VP9_ENTROPY_H_ |
+#include "vpx/vpx_integer.h" |
#include "vp9/common/vp9_treecoder.h" |
#include "vp9/common/vp9_blockd.h" |
#include "vp9/common/vp9_common.h" |
@@ -55,24 +55,27 @@ |
#define PROB_UPDATE_BASELINE_COST 7 |
#define MAX_PROB 255 |
-#define DCT_MAX_VALUE 8192 |
+#define DCT_MAX_VALUE 16384 |
/* Coefficients are predicted via a 3-dimensional probability table. */ |
/* Outside dimension. 0 = Y no DC, 1 = Y2, 2 = UV, 3 = Y with DC */ |
-#define BLOCK_TYPES 4 |
+#define BLOCK_TYPES_4X4 4 |
#define BLOCK_TYPES_8X8 4 |
#define BLOCK_TYPES_16X16 4 |
+#define BLOCK_TYPES_32X32 4 |
+ |
/* Middle dimension is a coarsening of the coefficient's |
position within the 4x4 DCT. */ |
#define COEF_BANDS 8 |
-extern DECLARE_ALIGNED(16, const int, vp9_coef_bands[16]); |
+extern DECLARE_ALIGNED(16, const int, vp9_coef_bands_4x4[16]); |
extern DECLARE_ALIGNED(64, const int, vp9_coef_bands_8x8[64]); |
extern DECLARE_ALIGNED(16, const int, vp9_coef_bands_16x16[256]); |
+extern DECLARE_ALIGNED(16, const int, vp9_coef_bands_32x32[1024]); |
/* Inside dimension is 3-valued measure of nearby complexity, that is, |
the extent to which nearby coefficients are nonzero. For the first |
@@ -91,24 +94,61 @@ |
distinct bands). */ |
/*# define DC_TOKEN_CONTEXTS 3*/ /* 00, 0!0, !0!0 */ |
-#define PREV_COEF_CONTEXTS 4 |
+#define PREV_COEF_CONTEXTS 4 |
+typedef unsigned int vp9_coeff_count[COEF_BANDS][PREV_COEF_CONTEXTS] |
+ [MAX_ENTROPY_TOKENS]; |
+typedef unsigned int vp9_coeff_stats[COEF_BANDS][PREV_COEF_CONTEXTS] |
+ [ENTROPY_NODES][2]; |
+typedef vp9_prob vp9_coeff_probs[COEF_BANDS][PREV_COEF_CONTEXTS] |
+ [ENTROPY_NODES]; |
+ |
#define SUBEXP_PARAM 4 /* Subexponential code parameter */ |
#define MODULUS_PARAM 13 /* Modulus parameter */ |
-extern DECLARE_ALIGNED(16, const unsigned char, vp9_prev_token_class[MAX_ENTROPY_TOKENS]); |
+extern DECLARE_ALIGNED(16, const uint8_t, |
+ vp9_prev_token_class[MAX_ENTROPY_TOKENS]); |
struct VP9Common; |
void vp9_default_coef_probs(struct VP9Common *); |
-extern DECLARE_ALIGNED(16, const int, vp9_default_zig_zag1d[16]); |
+extern DECLARE_ALIGNED(16, const int, vp9_default_zig_zag1d_4x4[16]); |
-extern DECLARE_ALIGNED(16, const int, vp9_col_scan[16]); |
-extern DECLARE_ALIGNED(16, const int, vp9_row_scan[16]); |
+extern DECLARE_ALIGNED(16, const int, vp9_col_scan_4x4[16]); |
+extern DECLARE_ALIGNED(16, const int, vp9_row_scan_4x4[16]); |
extern DECLARE_ALIGNED(64, const int, vp9_default_zig_zag1d_8x8[64]); |
+extern DECLARE_ALIGNED(16, const int, vp9_default_zig_zag1d_16x16[256]); |
+extern DECLARE_ALIGNED(16, const int, vp9_default_zig_zag1d_32x32[1024]); |
+ |
void vp9_coef_tree_initialize(void); |
- |
-extern DECLARE_ALIGNED(16, const int, vp9_default_zig_zag1d_16x16[256]); |
void vp9_adapt_coef_probs(struct VP9Common *); |
-#endif |
+static void vp9_reset_mb_tokens_context(MACROBLOCKD* const xd) { |
+ /* Clear entropy contexts */ |
+ vpx_memset(xd->above_context, 0, sizeof(ENTROPY_CONTEXT_PLANES)); |
+ vpx_memset(xd->left_context, 0, sizeof(ENTROPY_CONTEXT_PLANES)); |
+} |
+ |
+#if CONFIG_NEWCOEFCONTEXT |
+ |
+#define MAX_NEIGHBORS 5 |
+#define NEWCOEFCONTEXT_BAND_COND(b) ((b) >= 1) |
+void vp9_init_neighbors(void); |
+ |
+const int *vp9_get_coef_neighbors_handle(const int *scan); |
+int vp9_get_coef_neighbor_context(const short int *qcoeff_ptr, int nodc, |
+ const int *neigbor_handle, int rc); |
+extern DECLARE_ALIGNED(16, int, vp9_default_zig_zag1d_4x4_neighbors[ |
+ 16 * MAX_NEIGHBORS]); |
+extern DECLARE_ALIGNED(16, int, vp9_row_scan_4x4_neighbors[ |
+ 16 * MAX_NEIGHBORS]); |
+extern DECLARE_ALIGNED(16, int, vp9_col_scan_4x4_neighbors[ |
+ 16 * MAX_NEIGHBORS]); |
+extern DECLARE_ALIGNED(16, int, vp9_default_zig_zag1d_8x8_neighbors[ |
+ 64 * MAX_NEIGHBORS]); |
+extern DECLARE_ALIGNED(16, int, vp9_default_zig_zag1d_16x16_neighbors[ |
+ 256 * MAX_NEIGHBORS]); |
+extern DECLARE_ALIGNED(16, int, vp9_default_zig_zag1d_32x32_neighbors[ |
+ 1024 * MAX_NEIGHBORS]); |
+#endif // CONFIG_NEWCOEFCONTEXT |
+#endif // VP9_COMMON_VP9_ENTROPY_H_ |