Merge "Removing redundant mvsadcost local variables."

This commit is contained in:
Dmitry Kovalev 2014-04-14 10:30:38 -07:00 committed by Gerrit Code Review
commit 908e1218cd

View File

@ -66,7 +66,7 @@ int vp9_init_search_range(VP9_COMP *cpi, int size) {
} }
static INLINE int mv_cost(const MV *mv, static INLINE int mv_cost(const MV *mv,
const int *joint_cost, int *comp_cost[2]) { const int *joint_cost, int *const comp_cost[2]) {
return joint_cost[vp9_get_mv_joint(mv)] + return joint_cost[vp9_get_mv_joint(mv)] +
comp_cost[0][mv->row] + comp_cost[1][mv->col]; comp_cost[0][mv->row] + comp_cost[1][mv->col];
} }
@ -90,14 +90,13 @@ static int mv_err_cost(const MV *mv, const MV *ref,
return 0; return 0;
} }
static int mvsad_err_cost(const MV *mv, const MV *ref, static int mvsad_err_cost(const MACROBLOCK *x, const MV *mv, const MV *ref,
const int *mvjsadcost, int *mvsadcost[2],
int error_per_bit) { int error_per_bit) {
if (mvsadcost) { if (x->nmvsadcost) {
const MV diff = { mv->row - ref->row, const MV diff = { mv->row - ref->row,
mv->col - ref->col }; mv->col - ref->col };
return ROUND_POWER_OF_TWO(mv_cost(&diff, mvjsadcost, mvsadcost) * return ROUND_POWER_OF_TWO(mv_cost(&diff, x->nmvjointsadcost,
error_per_bit, 8); x->nmvsadcost) * error_per_bit, 8);
} }
return 0; return 0;
} }
@ -478,8 +477,7 @@ static INLINE int is_mv_in(const MACROBLOCK *x, const MV *mv) {
{\ {\
if (thissad < bestsad) {\ if (thissad < bestsad) {\
if (use_mvcost) \ if (use_mvcost) \
thissad += mvsad_err_cost(&this_mv, &fcenter_mv, \ thissad += mvsad_err_cost(x, &this_mv, &fcenter_mv, sad_per_bit);\
mvjsadcost, mvsadcost, sad_per_bit);\
if (thissad < bestsad) {\ if (thissad < bestsad) {\
bestsad = thissad;\ bestsad = thissad;\
best_site = i;\ best_site = i;\
@ -519,9 +517,6 @@ static int vp9_pattern_search(const MACROBLOCK *x,
int k = -1; int k = -1;
const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3}; const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3};
int best_init_s = search_param_to_steps[search_param]; int best_init_s = search_param_to_steps[search_param];
const int *const mvjsadcost = x->nmvjointsadcost;
int *mvsadcost[2] = {x->nmvsadcost[0], x->nmvsadcost[1]};
// adjust ref_mv to make sure it is within MV range // adjust ref_mv to make sure it is within MV range
clamp_mv(ref_mv, x->mv_col_min, x->mv_col_max, x->mv_row_min, x->mv_row_max); clamp_mv(ref_mv, x->mv_col_min, x->mv_col_max, x->mv_row_min, x->mv_row_max);
br = ref_mv->row; br = ref_mv->row;
@ -530,8 +525,8 @@ static int vp9_pattern_search(const MACROBLOCK *x,
// Work out the start point for the search // Work out the start point for the search
bestsad = vfp->sdf(what->buf, what->stride, bestsad = vfp->sdf(what->buf, what->stride,
get_buf_from_mv(in_what, ref_mv), in_what->stride, get_buf_from_mv(in_what, ref_mv), in_what->stride,
0x7fffffff) + mvsad_err_cost(ref_mv, &fcenter_mv, 0x7fffffff) + mvsad_err_cost(x, ref_mv, &fcenter_mv,
mvjsadcost, mvsadcost, sad_per_bit); sad_per_bit);
// Search all possible scales upto the search param around the center point // Search all possible scales upto the search param around the center point
// pick the scale of the point that is best as the starting scale of // pick the scale of the point that is best as the starting scale of
@ -891,10 +886,6 @@ int vp9_full_range_search_c(const MACROBLOCK *x, MV *ref_mv, MV *best_mv,
unsigned int thissad; unsigned int thissad;
const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3}; const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3};
const int *mvjsadcost = x->nmvjointsadcost;
int *mvsadcost[2] = {x->nmvsadcost[0], x->nmvsadcost[1]};
int tr, tc; int tr, tc;
int best_tr = 0; int best_tr = 0;
int best_tc = 0; int best_tc = 0;
@ -916,8 +907,7 @@ int vp9_full_range_search_c(const MACROBLOCK *x, MV *ref_mv, MV *best_mv,
// Check the starting position // Check the starting position
bestsad = fn_ptr->sdf(what, what_stride, in_what, in_what_stride, 0x7fffffff) bestsad = fn_ptr->sdf(what, what_stride, in_what, in_what_stride, 0x7fffffff)
+ mvsad_err_cost(best_mv, &fcenter_mv, + mvsad_err_cost(x, best_mv, &fcenter_mv, sad_per_bit);
mvjsadcost, mvsadcost, sad_per_bit);
start_row = MAX(-range, x->mv_row_min - ref_row); start_row = MAX(-range, x->mv_row_min - ref_row);
start_col = MAX(-range, x->mv_col_min - ref_col); start_col = MAX(-range, x->mv_col_min - ref_col);
@ -938,8 +928,7 @@ int vp9_full_range_search_c(const MACROBLOCK *x, MV *ref_mv, MV *best_mv,
if (sad_array[i] < bestsad) { if (sad_array[i] < bestsad) {
const MV this_mv = {ref_row + tr, ref_col + tc + i}; const MV this_mv = {ref_row + tr, ref_col + tc + i};
thissad = sad_array[i] + thissad = sad_array[i] +
mvsad_err_cost(&this_mv, &fcenter_mv, mvsad_err_cost(x, &this_mv, &fcenter_mv, sad_per_bit);
mvjsadcost, mvsadcost, sad_per_bit);
if (thissad < bestsad) { if (thissad < bestsad) {
bestsad = thissad; bestsad = thissad;
best_tr = tr; best_tr = tr;
@ -955,8 +944,7 @@ int vp9_full_range_search_c(const MACROBLOCK *x, MV *ref_mv, MV *best_mv,
if (thissad < bestsad) { if (thissad < bestsad) {
const MV this_mv = {ref_row + tr, ref_col + tc + i}; const MV this_mv = {ref_row + tr, ref_col + tc + i};
thissad += mvsad_err_cost(&this_mv, &fcenter_mv, thissad += mvsad_err_cost(x, &this_mv, &fcenter_mv, sad_per_bit);
mvjsadcost, mvsadcost, sad_per_bit);
if (thissad < bestsad) { if (thissad < bestsad) {
bestsad = thissad; bestsad = thissad;
@ -988,8 +976,6 @@ int vp9_diamond_search_sad_c(const MACROBLOCK *x,
const search_site *const ss = &x->ss[search_param * x->searches_per_step]; const search_site *const ss = &x->ss[search_param * x->searches_per_step];
const int tot_steps = (x->ss_count / x->searches_per_step) - search_param; const int tot_steps = (x->ss_count / x->searches_per_step) - search_param;
const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3}; const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3};
const int *mvjsadcost = x->nmvjointsadcost;
int *mvsadcost[2] = {x->nmvsadcost[0], x->nmvsadcost[1]};
const uint8_t *best_address, *in_what_ref; const uint8_t *best_address, *in_what_ref;
int best_sad = INT_MAX; int best_sad = INT_MAX;
int best_site = 0; int best_site = 0;
@ -1005,7 +991,7 @@ int vp9_diamond_search_sad_c(const MACROBLOCK *x,
// Check the starting position // Check the starting position
best_sad = fn_ptr->sdf(what->buf, what->stride, best_sad = fn_ptr->sdf(what->buf, what->stride,
best_address, in_what->stride, 0x7fffffff) + best_address, in_what->stride, 0x7fffffff) +
mvsad_err_cost(best_mv, &fcenter_mv, mvjsadcost, mvsadcost, sad_per_bit); mvsad_err_cost(x, best_mv, &fcenter_mv, sad_per_bit);
i = 1; i = 1;
@ -1018,8 +1004,7 @@ int vp9_diamond_search_sad_c(const MACROBLOCK *x,
best_address + ss[i].offset, in_what->stride, best_address + ss[i].offset, in_what->stride,
best_sad); best_sad);
if (sad < best_sad) { if (sad < best_sad) {
sad += mvsad_err_cost(&mv, &fcenter_mv, mvjsadcost, mvsadcost, sad += mvsad_err_cost(x, &mv, &fcenter_mv, sad_per_bit);
sad_per_bit);
if (sad < best_sad) { if (sad < best_sad) {
best_sad = sad; best_sad = sad;
best_site = i; best_site = i;
@ -1044,8 +1029,7 @@ int vp9_diamond_search_sad_c(const MACROBLOCK *x,
best_address + ss[best_site].offset, best_address + ss[best_site].offset,
in_what->stride, best_sad); in_what->stride, best_sad);
if (sad < best_sad) { if (sad < best_sad) {
sad += mvsad_err_cost(&this_mv, &fcenter_mv, sad += mvsad_err_cost(x, &this_mv, &fcenter_mv, sad_per_bit);
mvjsadcost, mvsadcost, sad_per_bit);
if (sad < best_sad) { if (sad < best_sad) {
best_sad = sad; best_sad = sad;
best_mv->row += ss[best_site].mv.row; best_mv->row += ss[best_site].mv.row;
@ -1095,10 +1079,6 @@ int vp9_diamond_search_sadx4(const MACROBLOCK *x,
const int tot_steps = (x->ss_count / x->searches_per_step) - search_param; const int tot_steps = (x->ss_count / x->searches_per_step) - search_param;
const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3}; const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3};
const int *mvjsadcost = x->nmvjointsadcost;
int *mvsadcost[2] = {x->nmvsadcost[0], x->nmvsadcost[1]};
clamp_mv(ref_mv, x->mv_col_min, x->mv_col_max, x->mv_row_min, x->mv_row_max); clamp_mv(ref_mv, x->mv_col_min, x->mv_col_max, x->mv_row_min, x->mv_row_max);
ref_row = ref_mv->row; ref_row = ref_mv->row;
ref_col = ref_mv->col; ref_col = ref_mv->col;
@ -1112,8 +1092,7 @@ int vp9_diamond_search_sadx4(const MACROBLOCK *x,
// Check the starting position // Check the starting position
bestsad = fn_ptr->sdf(what, what_stride, in_what, in_what_stride, 0x7fffffff) bestsad = fn_ptr->sdf(what, what_stride, in_what, in_what_stride, 0x7fffffff)
+ mvsad_err_cost(best_mv, &fcenter_mv, + mvsad_err_cost(x, best_mv, &fcenter_mv, sad_per_bit);
mvjsadcost, mvsadcost, sad_per_bit);
i = 1; i = 1;
@ -1146,9 +1125,8 @@ int vp9_diamond_search_sadx4(const MACROBLOCK *x,
if (sad_array[t] < bestsad) { if (sad_array[t] < bestsad) {
const MV this_mv = {best_mv->row + ss[i].mv.row, const MV this_mv = {best_mv->row + ss[i].mv.row,
best_mv->col + ss[i].mv.col}; best_mv->col + ss[i].mv.col};
sad_array[t] += mvsad_err_cost(&this_mv, &fcenter_mv, sad_array[t] += mvsad_err_cost(x, &this_mv, &fcenter_mv,
mvjsadcost, mvsadcost, sad_per_bit); sad_per_bit);
if (sad_array[t] < bestsad) { if (sad_array[t] < bestsad) {
bestsad = sad_array[t]; bestsad = sad_array[t];
best_site = i; best_site = i;
@ -1168,9 +1146,7 @@ int vp9_diamond_search_sadx4(const MACROBLOCK *x,
in_what_stride, bestsad); in_what_stride, bestsad);
if (thissad < bestsad) { if (thissad < bestsad) {
thissad += mvsad_err_cost(&this_mv, &fcenter_mv, thissad += mvsad_err_cost(x, &this_mv, &fcenter_mv, sad_per_bit);
mvjsadcost, mvsadcost, sad_per_bit);
if (thissad < bestsad) { if (thissad < bestsad) {
bestsad = thissad; bestsad = thissad;
best_site = i; best_site = i;
@ -1289,12 +1265,10 @@ int vp9_full_search_sad_c(const MACROBLOCK *x, const MV *ref_mv,
const int row_max = MIN(ref_mv->row + distance, x->mv_row_max); const int row_max = MIN(ref_mv->row + distance, x->mv_row_max);
const int col_min = MAX(ref_mv->col - distance, x->mv_col_min); const int col_min = MAX(ref_mv->col - distance, x->mv_col_min);
const int col_max = MIN(ref_mv->col + distance, x->mv_col_max); const int col_max = MIN(ref_mv->col + distance, x->mv_col_max);
const int *mvjsadcost = x->nmvjointsadcost;
int *mvsadcost[2] = {x->nmvsadcost[0], x->nmvsadcost[1]};
const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3}; const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3};
int best_sad = fn_ptr->sdf(what->buf, what->stride, int best_sad = fn_ptr->sdf(what->buf, what->stride,
get_buf_from_mv(in_what, ref_mv), in_what->stride, 0x7fffffff) + get_buf_from_mv(in_what, ref_mv), in_what->stride, 0x7fffffff) +
mvsad_err_cost(ref_mv, &fcenter_mv, mvjsadcost, mvsadcost, sad_per_bit); mvsad_err_cost(x, ref_mv, &fcenter_mv, sad_per_bit);
*best_mv = *ref_mv; *best_mv = *ref_mv;
for (r = row_min; r < row_max; ++r) { for (r = row_min; r < row_max; ++r) {
@ -1302,9 +1276,7 @@ int vp9_full_search_sad_c(const MACROBLOCK *x, const MV *ref_mv,
const MV mv = {r, c}; const MV mv = {r, c};
const int sad = fn_ptr->sdf(what->buf, what->stride, const int sad = fn_ptr->sdf(what->buf, what->stride,
get_buf_from_mv(in_what, &mv), in_what->stride, best_sad) + get_buf_from_mv(in_what, &mv), in_what->stride, best_sad) +
mvsad_err_cost(&mv, &fcenter_mv, mvjsadcost, mvsadcost, mvsad_err_cost(x, &mv, &fcenter_mv, sad_per_bit);
sad_per_bit);
if (sad < best_sad) { if (sad < best_sad) {
best_sad = sad; best_sad = sad;
*best_mv = mv; *best_mv = mv;
@ -1338,8 +1310,6 @@ int vp9_full_search_sadx3(const MACROBLOCK *x, const MV *ref_mv,
const int col_max = MIN(ref_col + distance, x->mv_col_max); const int col_max = MIN(ref_col + distance, x->mv_col_max);
unsigned int sad_array[3]; unsigned int sad_array[3];
const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3}; const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3};
const int *mvjsadcost = x->nmvjointsadcost;
int *mvsadcost[2] = {x->nmvsadcost[0], x->nmvsadcost[1]};
// Work out the mid point for the search // Work out the mid point for the search
const uint8_t *bestaddress = &in_what[ref_row * in_what_stride + ref_col]; const uint8_t *bestaddress = &in_what[ref_row * in_what_stride + ref_col];
@ -1350,8 +1320,7 @@ int vp9_full_search_sadx3(const MACROBLOCK *x, const MV *ref_mv,
// Baseline value at the centre // Baseline value at the centre
bestsad = fn_ptr->sdf(what, what_stride, bestsad = fn_ptr->sdf(what, what_stride,
bestaddress, in_what_stride, 0x7fffffff) bestaddress, in_what_stride, 0x7fffffff)
+ mvsad_err_cost(best_mv, &fcenter_mv, + mvsad_err_cost(x, best_mv, &fcenter_mv, sad_per_bit);
mvjsadcost, mvsadcost, sad_per_bit);
for (r = row_min; r < row_max; r++) { for (r = row_min; r < row_max; r++) {
const uint8_t *check_here = &in_what[r * in_what_stride + col_min]; const uint8_t *check_here = &in_what[r * in_what_stride + col_min];
@ -1368,9 +1337,7 @@ int vp9_full_search_sadx3(const MACROBLOCK *x, const MV *ref_mv,
if (thissad < bestsad) { if (thissad < bestsad) {
this_mv.col = c; this_mv.col = c;
thissad += mvsad_err_cost(&this_mv, &fcenter_mv, thissad += mvsad_err_cost(x, &this_mv, &fcenter_mv, sad_per_bit);
mvjsadcost, mvsadcost, sad_per_bit);
if (thissad < bestsad) { if (thissad < bestsad) {
bestsad = thissad; bestsad = thissad;
best_mv->row = r; best_mv->row = r;
@ -1388,9 +1355,7 @@ int vp9_full_search_sadx3(const MACROBLOCK *x, const MV *ref_mv,
if (thissad < bestsad) { if (thissad < bestsad) {
this_mv.col = c; this_mv.col = c;
thissad += mvsad_err_cost(&this_mv, &fcenter_mv, thissad += mvsad_err_cost(x, &this_mv, &fcenter_mv, sad_per_bit);
mvjsadcost, mvsadcost, sad_per_bit);
if (thissad < bestsad) { if (thissad < bestsad) {
bestsad = thissad; bestsad = thissad;
best_mv->row = r; best_mv->row = r;
@ -1430,9 +1395,6 @@ int vp9_full_search_sadx8(const MACROBLOCK *x, const MV *ref_mv,
unsigned int sad_array[3]; unsigned int sad_array[3];
const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3}; const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3};
const int *mvjsadcost = x->nmvjointsadcost;
int *mvsadcost[2] = {x->nmvsadcost[0], x->nmvsadcost[1]};
// Work out the mid point for the search // Work out the mid point for the search
const uint8_t *bestaddress = &in_what[ref_row * in_what_stride + ref_col]; const uint8_t *bestaddress = &in_what[ref_row * in_what_stride + ref_col];
@ -1442,8 +1404,7 @@ int vp9_full_search_sadx8(const MACROBLOCK *x, const MV *ref_mv,
// Baseline value at the center // Baseline value at the center
bestsad = fn_ptr->sdf(what, what_stride, bestsad = fn_ptr->sdf(what, what_stride,
bestaddress, in_what_stride, 0x7fffffff) bestaddress, in_what_stride, 0x7fffffff)
+ mvsad_err_cost(best_mv, &fcenter_mv, + mvsad_err_cost(x, best_mv, &fcenter_mv, sad_per_bit);
mvjsadcost, mvsadcost, sad_per_bit);
for (r = row_min; r < row_max; r++) { for (r = row_min; r < row_max; r++) {
const uint8_t *check_here = &in_what[r * in_what_stride + col_min]; const uint8_t *check_here = &in_what[r * in_what_stride + col_min];
@ -1460,9 +1421,7 @@ int vp9_full_search_sadx8(const MACROBLOCK *x, const MV *ref_mv,
if (thissad < bestsad) { if (thissad < bestsad) {
this_mv.col = c; this_mv.col = c;
thissad += mvsad_err_cost(&this_mv, &fcenter_mv, thissad += mvsad_err_cost(x, &this_mv, &fcenter_mv, sad_per_bit);
mvjsadcost, mvsadcost, sad_per_bit);
if (thissad < bestsad) { if (thissad < bestsad) {
bestsad = thissad; bestsad = thissad;
best_mv->row = r; best_mv->row = r;
@ -1485,9 +1444,7 @@ int vp9_full_search_sadx8(const MACROBLOCK *x, const MV *ref_mv,
if (thissad < bestsad) { if (thissad < bestsad) {
this_mv.col = c; this_mv.col = c;
thissad += mvsad_err_cost(&this_mv, &fcenter_mv, thissad += mvsad_err_cost(x, &this_mv, &fcenter_mv, sad_per_bit);
mvjsadcost, mvsadcost, sad_per_bit);
if (thissad < bestsad) { if (thissad < bestsad) {
bestsad = thissad; bestsad = thissad;
best_mv->row = r; best_mv->row = r;
@ -1506,9 +1463,7 @@ int vp9_full_search_sadx8(const MACROBLOCK *x, const MV *ref_mv,
if (thissad < bestsad) { if (thissad < bestsad) {
this_mv.col = c; this_mv.col = c;
thissad += mvsad_err_cost(&this_mv, &fcenter_mv, thissad += mvsad_err_cost(x, &this_mv, &fcenter_mv, sad_per_bit);
mvjsadcost, mvsadcost, sad_per_bit);
if (thissad < bestsad) { if (thissad < bestsad) {
bestsad = thissad; bestsad = thissad;
best_mv->row = r; best_mv->row = r;
@ -1533,13 +1488,10 @@ int vp9_refining_search_sad_c(const MACROBLOCK *x,
const struct buf_2d *const what = &x->plane[0].src; const struct buf_2d *const what = &x->plane[0].src;
const struct buf_2d *const in_what = &xd->plane[0].pre[0]; const struct buf_2d *const in_what = &xd->plane[0].pre[0];
const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3}; const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3};
const int *mvjsadcost = x->nmvjointsadcost;
int *mvsadcost[2] = {x->nmvsadcost[0], x->nmvsadcost[1]};
unsigned int best_sad = fn_ptr->sdf(what->buf, what->stride, unsigned int best_sad = fn_ptr->sdf(what->buf, what->stride,
get_buf_from_mv(in_what, ref_mv), get_buf_from_mv(in_what, ref_mv),
in_what->stride, 0x7fffffff) + in_what->stride, 0x7fffffff) +
mvsad_err_cost(ref_mv, &fcenter_mv, mvjsadcost, mvsadcost, error_per_bit); mvsad_err_cost(x, ref_mv, &fcenter_mv, error_per_bit);
int i, j; int i, j;
for (i = 0; i < search_range; i++) { for (i = 0; i < search_range; i++) {
@ -1552,8 +1504,7 @@ int vp9_refining_search_sad_c(const MACROBLOCK *x,
unsigned int sad = fn_ptr->sdf(what->buf, what->stride, unsigned int sad = fn_ptr->sdf(what->buf, what->stride,
get_buf_from_mv(in_what, &mv), in_what->stride, best_sad); get_buf_from_mv(in_what, &mv), in_what->stride, best_sad);
if (sad < best_sad) { if (sad < best_sad) {
sad += mvsad_err_cost(&mv, &fcenter_mv, mvjsadcost, mvsadcost, sad += mvsad_err_cost(x, &mv, &fcenter_mv, error_per_bit);
error_per_bit);
if (sad < best_sad) { if (sad < best_sad) {
best_sad = sad; best_sad = sad;
best_site = j; best_site = j;
@ -1582,12 +1533,10 @@ int vp9_refining_search_sadx4(const MACROBLOCK *x,
const struct buf_2d *const what = &x->plane[0].src; const struct buf_2d *const what = &x->plane[0].src;
const struct buf_2d *const in_what = &xd->plane[0].pre[0]; const struct buf_2d *const in_what = &xd->plane[0].pre[0];
const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3}; const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3};
const int *mvjsadcost = x->nmvjointsadcost;
int *mvsadcost[2] = {x->nmvsadcost[0], x->nmvsadcost[1]};
const uint8_t *best_address = get_buf_from_mv(in_what, ref_mv); const uint8_t *best_address = get_buf_from_mv(in_what, ref_mv);
unsigned int best_sad = fn_ptr->sdf(what->buf, what->stride, best_address, unsigned int best_sad = fn_ptr->sdf(what->buf, what->stride, best_address,
in_what->stride, 0x7fffffff) + in_what->stride, 0x7fffffff) +
mvsad_err_cost(ref_mv, &fcenter_mv, mvjsadcost, mvsadcost, error_per_bit); mvsad_err_cost(x, ref_mv, &fcenter_mv, error_per_bit);
int i, j; int i, j;
for (i = 0; i < search_range; i++) { for (i = 0; i < search_range; i++) {
@ -1612,9 +1561,7 @@ int vp9_refining_search_sadx4(const MACROBLOCK *x,
if (sads[j] < best_sad) { if (sads[j] < best_sad) {
const MV mv = {ref_mv->row + neighbors[j].row, const MV mv = {ref_mv->row + neighbors[j].row,
ref_mv->col + neighbors[j].col}; ref_mv->col + neighbors[j].col};
sads[j] += mvsad_err_cost(&mv, &fcenter_mv, sads[j] += mvsad_err_cost(x, &mv, &fcenter_mv, error_per_bit);
mvjsadcost, mvsadcost, error_per_bit);
if (sads[j] < best_sad) { if (sads[j] < best_sad) {
best_sad = sads[j]; best_sad = sads[j];
best_site = j; best_site = j;
@ -1631,9 +1578,7 @@ int vp9_refining_search_sadx4(const MACROBLOCK *x,
get_buf_from_mv(in_what, &mv), get_buf_from_mv(in_what, &mv),
in_what->stride, best_sad); in_what->stride, best_sad);
if (sad < best_sad) { if (sad < best_sad) {
sad += mvsad_err_cost(&mv, &fcenter_mv, sad += mvsad_err_cost(x, &mv, &fcenter_mv, error_per_bit);
mvjsadcost, mvsadcost, error_per_bit);
if (sad < best_sad) { if (sad < best_sad) {
best_sad = sad; best_sad = sad;
best_site = j; best_site = j;
@ -1669,12 +1614,10 @@ int vp9_refining_search_8p_c(const MACROBLOCK *x,
const struct buf_2d *const what = &x->plane[0].src; const struct buf_2d *const what = &x->plane[0].src;
const struct buf_2d *const in_what = &xd->plane[0].pre[0]; const struct buf_2d *const in_what = &xd->plane[0].pre[0];
const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3}; const MV fcenter_mv = {center_mv->row >> 3, center_mv->col >> 3};
const int *mvjsadcost = x->nmvjointsadcost;
int *mvsadcost[2] = {x->nmvsadcost[0], x->nmvsadcost[1]};
unsigned int best_sad = fn_ptr->sdaf(what->buf, what->stride, unsigned int best_sad = fn_ptr->sdaf(what->buf, what->stride,
get_buf_from_mv(in_what, ref_mv), in_what->stride, get_buf_from_mv(in_what, ref_mv), in_what->stride,
second_pred, 0x7fffffff) + second_pred, 0x7fffffff) +
mvsad_err_cost(ref_mv, &fcenter_mv, mvjsadcost, mvsadcost, error_per_bit); mvsad_err_cost(x, ref_mv, &fcenter_mv, error_per_bit);
int i, j; int i, j;
for (i = 0; i < search_range; ++i) { for (i = 0; i < search_range; ++i) {
@ -1689,8 +1632,7 @@ int vp9_refining_search_8p_c(const MACROBLOCK *x,
get_buf_from_mv(in_what, &mv), in_what->stride, get_buf_from_mv(in_what, &mv), in_what->stride,
second_pred, best_sad); second_pred, best_sad);
if (sad < best_sad) { if (sad < best_sad) {
sad += mvsad_err_cost(&mv, &fcenter_mv, sad += mvsad_err_cost(x, &mv, &fcenter_mv, error_per_bit);
mvjsadcost, mvsadcost, error_per_bit);
if (sad < best_sad) { if (sad < best_sad) {
best_sad = sad; best_sad = sad;
best_site = j; best_site = j;