Nice looking motion vector clamping functions.

Removing assign_and_clamp_mv function, making implementation of clamp_mv
and clamp_mv2 more clear and consistent.

Change-Id: Iecd08e1c1bf0379f8314ebe01811f8253f4ade58
This commit is contained in:
Dmitry Kovalev 2013-07-31 16:11:03 -07:00
parent 56df76bf1b
commit b621e2d72e
5 changed files with 33 additions and 60 deletions

View File

@ -32,7 +32,7 @@ void vp9_find_best_ref_mvs(MACROBLOCKD *xd,
// Make sure all the candidates are properly clamped etc // Make sure all the candidates are properly clamped etc
for (i = 0; i < MAX_MV_REF_CANDIDATES; ++i) { for (i = 0; i < MAX_MV_REF_CANDIDATES; ++i) {
lower_mv_precision(&mvlist[i], xd->allow_high_precision_mv); lower_mv_precision(&mvlist[i], xd->allow_high_precision_mv);
clamp_mv2(&mvlist[i], xd); clamp_mv2(&mvlist[i].as_mv, xd);
} }
*nearest = mvlist[0]; *nearest = mvlist[0];
*near = mvlist[1]; *near = mvlist[1];

View File

@ -29,24 +29,17 @@ void vp9_find_best_ref_mvs(MACROBLOCKD *xd,
int_mv *near); int_mv *near);
// TODO(jingning): this mv clamping function should be block size dependent. // TODO(jingning): this mv clamping function should be block size dependent.
static void clamp_mv(int_mv *mv, static void clamp_mv(MV *mv, int min_col, int max_col,
int mb_to_left_edge, int min_row, int max_row) {
int mb_to_right_edge, mv->col = clamp(mv->col, min_col, max_col);
int mb_to_top_edge, mv->row = clamp(mv->row, min_row, max_row);
int mb_to_bottom_edge) {
mv->as_mv.col = clamp(mv->as_mv.col, mb_to_left_edge, mb_to_right_edge);
mv->as_mv.row = clamp(mv->as_mv.row, mb_to_top_edge, mb_to_bottom_edge);
} }
static int clamp_mv2(int_mv *mv, const MACROBLOCKD *xd) { static void clamp_mv2(MV *mv, const MACROBLOCKD *xd) {
int_mv tmp_mv; clamp_mv(mv, xd->mb_to_left_edge - LEFT_TOP_MARGIN,
tmp_mv.as_int = mv->as_int;
clamp_mv(mv,
xd->mb_to_left_edge - LEFT_TOP_MARGIN,
xd->mb_to_right_edge + RIGHT_BOTTOM_MARGIN, xd->mb_to_right_edge + RIGHT_BOTTOM_MARGIN,
xd->mb_to_top_edge - LEFT_TOP_MARGIN, xd->mb_to_top_edge - LEFT_TOP_MARGIN,
xd->mb_to_bottom_edge + RIGHT_BOTTOM_MARGIN); xd->mb_to_bottom_edge + RIGHT_BOTTOM_MARGIN);
return tmp_mv.as_int != mv->as_int;
} }
void vp9_append_sub8x8_mvs_for_idx(VP9_COMMON *pc, void vp9_append_sub8x8_mvs_for_idx(VP9_COMMON *pc,

View File

@ -366,16 +366,6 @@ static INLINE COMPPREDMODE_TYPE read_comp_pred_mode(vp9_reader *r) {
return mode; return mode;
} }
static INLINE void assign_and_clamp_mv(int_mv *dst, const int_mv *src,
int mb_to_left_edge,
int mb_to_right_edge,
int mb_to_top_edge,
int mb_to_bottom_edge) {
dst->as_int = src->as_int;
clamp_mv(dst, mb_to_left_edge, mb_to_right_edge, mb_to_top_edge,
mb_to_bottom_edge);
}
static INLINE INTERPOLATIONFILTERTYPE read_switchable_filter_type( static INLINE INTERPOLATIONFILTERTYPE read_switchable_filter_type(
VP9D_COMP *pbi, vp9_reader *r) { VP9D_COMP *pbi, vp9_reader *r) {
VP9_COMMON *const cm = &pbi->common; VP9_COMMON *const cm = &pbi->common;
@ -558,36 +548,25 @@ static void read_inter_block_mode_info(VP9D_COMP *pbi, MODE_INFO *mi,
mv0->as_int = mi->bmi[3].as_mv[0].as_int; mv0->as_int = mi->bmi[3].as_mv[0].as_int;
mv1->as_int = mi->bmi[3].as_mv[1].as_int; mv1->as_int = mi->bmi[3].as_mv[1].as_int;
} else { } else {
const int mb_to_top_edge = xd->mb_to_top_edge - LEFT_TOP_MARGIN;
const int mb_to_bottom_edge = xd->mb_to_bottom_edge + RIGHT_BOTTOM_MARGIN;
const int mb_to_left_edge = xd->mb_to_left_edge - LEFT_TOP_MARGIN;
const int mb_to_right_edge = xd->mb_to_right_edge + RIGHT_BOTTOM_MARGIN;
switch (mbmi->mode) { switch (mbmi->mode) {
case NEARMV: case NEARMV:
// Clip "next_nearest" so that it does not extend to far out of image mv0->as_int = nearby.as_int;
assign_and_clamp_mv(mv0, &nearby, mb_to_left_edge, clamp_mv2(&mv0->as_mv, xd);
mb_to_right_edge,
mb_to_top_edge, if (ref1 > 0) {
mb_to_bottom_edge); mv1->as_int = nearby_second.as_int;
if (ref1 > 0) clamp_mv2(&mv1->as_mv, xd);
assign_and_clamp_mv(mv1, &nearby_second, mb_to_left_edge, }
mb_to_right_edge,
mb_to_top_edge,
mb_to_bottom_edge);
break; break;
case NEARESTMV: case NEARESTMV:
// Clip "next_nearest" so that it does not extend to far out of image mv0->as_int = nearest.as_int;
assign_and_clamp_mv(mv0, &nearest, mb_to_left_edge, clamp_mv2(&mv0->as_mv, xd);
mb_to_right_edge,
mb_to_top_edge, if (ref1 > 0) {
mb_to_bottom_edge); mv1->as_int = nearest_second.as_int;
if (ref1 > 0) clamp_mv2(&mv1->as_mv, xd);
assign_and_clamp_mv(mv1, &nearest_second, mb_to_left_edge, }
mb_to_right_edge,
mb_to_top_edge,
mb_to_bottom_edge);
break; break;
case ZEROMV: case ZEROMV:

View File

@ -1319,7 +1319,8 @@ int vp9_hex_search
fcenter_mv.as_mv.col = center_mv->as_mv.col >> 3; fcenter_mv.as_mv.col = center_mv->as_mv.col >> 3;
// 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->as_mv,
x->mv_col_min, x->mv_col_max, x->mv_row_min, x->mv_row_max);
br = ref_mv->as_mv.row; br = ref_mv->as_mv.row;
bc = ref_mv->as_mv.col; bc = ref_mv->as_mv.col;
@ -1475,7 +1476,8 @@ int vp9_diamond_search_sad_c(MACROBLOCK *x,
fcenter_mv.as_mv.row = center_mv->as_mv.row >> 3; fcenter_mv.as_mv.row = center_mv->as_mv.row >> 3;
fcenter_mv.as_mv.col = center_mv->as_mv.col >> 3; fcenter_mv.as_mv.col = center_mv->as_mv.col >> 3;
clamp_mv(ref_mv, x->mv_col_min, x->mv_col_max, x->mv_row_min, x->mv_row_max); clamp_mv(&ref_mv->as_mv,
x->mv_col_min, x->mv_col_max, x->mv_row_min, x->mv_row_max);
ref_row = ref_mv->as_mv.row; ref_row = ref_mv->as_mv.row;
ref_col = ref_mv->as_mv.col; ref_col = ref_mv->as_mv.col;
*num00 = 0; *num00 = 0;
@ -1615,7 +1617,8 @@ int vp9_diamond_search_sadx4(MACROBLOCK *x,
fcenter_mv.as_mv.row = center_mv->as_mv.row >> 3; fcenter_mv.as_mv.row = center_mv->as_mv.row >> 3;
fcenter_mv.as_mv.col = center_mv->as_mv.col >> 3; fcenter_mv.as_mv.col = center_mv->as_mv.col >> 3;
clamp_mv(ref_mv, x->mv_col_min, x->mv_col_max, x->mv_row_min, x->mv_row_max); clamp_mv(&ref_mv->as_mv,
x->mv_col_min, x->mv_col_max, x->mv_row_min, x->mv_row_max);
ref_row = ref_mv->as_mv.row; ref_row = ref_mv->as_mv.row;
ref_col = ref_mv->as_mv.col; ref_col = ref_mv->as_mv.col;
*num00 = 0; *num00 = 0;

View File

@ -1973,7 +1973,7 @@ static void rd_check_segment_txsize(VP9_COMP *cpi, MACROBLOCK *x,
// Should we do a full search (best quality only) // Should we do a full search (best quality only)
if (cpi->compressor_speed == 0) { if (cpi->compressor_speed == 0) {
/* Check if mvp_full is within the range. */ /* Check if mvp_full is within the range. */
clamp_mv(&mvp_full, x->mv_col_min, x->mv_col_max, clamp_mv(&mvp_full.as_mv, x->mv_col_min, x->mv_col_max,
x->mv_row_min, x->mv_row_max); x->mv_row_min, x->mv_row_max);
thissme = cpi->full_search_sad(x, &mvp_full, thissme = cpi->full_search_sad(x, &mvp_full,
@ -2833,10 +2833,8 @@ static int64_t handle_inter_mode(VP9_COMP *cpi, MACROBLOCK *x,
for (i = 0; i < num_refs; ++i) { for (i = 0; i < num_refs; ++i) {
cur_mv[i] = frame_mv[refs[i]]; cur_mv[i] = frame_mv[refs[i]];
// Clip "next_nearest" so that it does not extend to far out of image // Clip "next_nearest" so that it does not extend to far out of image
if (this_mode == NEWMV) if (this_mode != NEWMV)
assert(!clamp_mv2(&cur_mv[i], xd)); clamp_mv2(&cur_mv[i].as_mv, xd);
else
clamp_mv2(&cur_mv[i], xd);
if (mv_check_bounds(x, &cur_mv[i])) if (mv_check_bounds(x, &cur_mv[i]))
return INT64_MAX; return INT64_MAX;