diff --git a/vp8/common/entropymode.c b/vp8/common/entropymode.c index 493728d5d5d8c5e422df3726de8811bab64e39ee..41922834fd7f322c5370d5c9213efa0b6c48749c 100644 --- a/vp8/common/entropymode.c +++ b/vp8/common/entropymode.c @@ -264,8 +264,10 @@ void vp8_entropy_mode_init() vp8_tokens_from_tree(vp8_uv_mode_encodings, vp8_uv_mode_tree); vp8_tokens_from_tree(vp8_mbsplit_encodings, vp8_mbsplit_tree); - vp8_tokens_from_tree(VP8_MVREFENCODINGS, vp8_mv_ref_tree); - vp8_tokens_from_tree(VP8_SUBMVREFENCODINGS, vp8_sub_mv_ref_tree); + vp8_tokens_from_tree_offset(vp8_mv_ref_encoding_array, + vp8_mv_ref_tree, NEARESTMV); + vp8_tokens_from_tree_offset(vp8_sub_mv_ref_encoding_array, + vp8_sub_mv_ref_tree, LEFT4X4); vp8_tokens_from_tree(vp8_small_mvencodings, vp8_small_mvtree); } diff --git a/vp8/common/entropymode.h b/vp8/common/entropymode.h index afa513d3c73cb54c16e7bc317e324a60e80e5056..3d5af7cf7d8cbc4c7b2f476514c6d350bd0f6658 100644 --- a/vp8/common/entropymode.h +++ b/vp8/common/entropymode.h @@ -54,10 +54,6 @@ extern struct vp8_token_struct vp8_mbsplit_encodings [VP8_NUMMBSPLITS]; extern struct vp8_token_struct vp8_mv_ref_encoding_array [VP8_MVREFS]; extern struct vp8_token_struct vp8_sub_mv_ref_encoding_array [VP8_SUBMVREFS]; -#define VP8_MVREFENCODINGS (vp8_mv_ref_encoding_array - NEARESTMV) -#define VP8_SUBMVREFENCODINGS (vp8_sub_mv_ref_encoding_array - LEFT4X4) - - extern const vp8_tree_index vp8_small_mvtree[]; extern struct vp8_token_struct vp8_small_mvencodings [8]; diff --git a/vp8/common/treecoder.c b/vp8/common/treecoder.c index 5829cb70161ce79d6bb660f915220271f05653ff..495abd7162baaeaacdf2aca3023792df6e53d3e3 100644 --- a/vp8/common/treecoder.c +++ b/vp8/common/treecoder.c @@ -47,6 +47,12 @@ void vp8_tokens_from_tree(struct vp8_token_struct *p, vp8_tree t) tree2tok(p, t, 0, 0, 0); } +void vp8_tokens_from_tree_offset(struct vp8_token_struct *p, vp8_tree t, + int offset) +{ + tree2tok(p - offset, t, 0, 0, 0); +} + static void branch_counts( int n, /* n = size of alphabet */ vp8_token tok [ /* n */ ], diff --git a/vp8/common/treecoder.h b/vp8/common/treecoder.h index c8f5af96d95eb1338ce9ffd548e80c2b00d47584..9903275362d5b0aff3b081bf65398d40351098cf 100644 --- a/vp8/common/treecoder.h +++ b/vp8/common/treecoder.h @@ -54,6 +54,8 @@ typedef const struct vp8_token_struct /* Construct encoding array from tree. */ void vp8_tokens_from_tree(struct vp8_token_struct *, vp8_tree); +void vp8_tokens_from_tree_offset(struct vp8_token_struct *, vp8_tree, + int offset); /* Convert array of token occurrence counts into a table of probabilities diff --git a/vp8/encoder/bitstream.c b/vp8/encoder/bitstream.c index 3d7c7612deeb5cc4a6dbc6d3a5ddacbead6a1dc3..21629841b03fc880348bf4bcce453201058dde7b 100644 --- a/vp8/encoder/bitstream.c +++ b/vp8/encoder/bitstream.c @@ -792,7 +792,8 @@ static void write_mv_ref assert(NEARESTMV <= m && m <= SPLITMV); - vp8_write_token(w, vp8_mv_ref_tree, p, VP8_MVREFENCODINGS + m); + vp8_write_token(w, vp8_mv_ref_tree, p, + vp8_mv_ref_encoding_array - NEARESTMV + m); } static void write_sub_mv_ref @@ -802,7 +803,8 @@ static void write_sub_mv_ref { assert(LEFT4X4 <= m && m <= NEW4X4); - vp8_write_token(w, vp8_sub_mv_ref_tree, p, VP8_SUBMVREFENCODINGS + m); + vp8_write_token(w, vp8_sub_mv_ref_tree, p, + vp8_sub_mv_ref_encoding_array - LEFT4X4 + m); } static void write_mv diff --git a/vp8/encoder/rdopt.c b/vp8/encoder/rdopt.c index 8fe2d206a62ddb035f553b56f5292b6c313e2993..3c6f0b32458ddef266adf85637505c362854b337 100644 --- a/vp8/encoder/rdopt.c +++ b/vp8/encoder/rdopt.c @@ -880,7 +880,8 @@ int vp8_cost_mv_ref(MB_PREDICTION_MODE m, const int near_mv_ref_ct[4]) vp8_prob p [VP8_MVREFS-1]; assert(NEARESTMV <= m && m <= SPLITMV); vp8_mv_ref_probs(p, near_mv_ref_ct); - return vp8_cost_token(vp8_mv_ref_tree, p, VP8_MVREFENCODINGS + m); + return vp8_cost_token(vp8_mv_ref_tree, p, + vp8_mv_ref_encoding_array - NEARESTMV + m); } void vp8_set_mbmode_and_mvs(MACROBLOCK *x, MB_PREDICTION_MODE mb, MV *mv)