Merge "Cleaning up vp9_rdopt.c."

This commit is contained in:
Dmitry Kovalev 2014-04-21 10:41:04 -07:00 committed by Gerrit Code Review
commit ece689650a

View File

@ -243,9 +243,7 @@ void vp9_initialize_me_consts(VP9_COMP *cpi, int qindex) {
cpi->mb.sadperbit4 = sad_per_bit4lut[qindex]; cpi->mb.sadperbit4 = sad_per_bit4lut[qindex];
} }
static void set_block_thresholds(VP9_COMP *cpi) { static void set_block_thresholds(const VP9_COMMON *cm, RD_OPT *rd) {
const VP9_COMMON *const cm = &cpi->common;
RD_OPT *const rd = &cpi->rd;
int i, bsize, segment_id; int i, bsize, segment_id;
for (segment_id = 0; segment_id < MAX_SEGMENTS; ++segment_id) { for (segment_id = 0; segment_id < MAX_SEGMENTS; ++segment_id) {
@ -280,20 +278,21 @@ static void set_block_thresholds(VP9_COMP *cpi) {
void vp9_initialize_rd_consts(VP9_COMP *cpi) { void vp9_initialize_rd_consts(VP9_COMP *cpi) {
VP9_COMMON *const cm = &cpi->common; VP9_COMMON *const cm = &cpi->common;
MACROBLOCK *const x = &cpi->mb; MACROBLOCK *const x = &cpi->mb;
RD_OPT *const rd = &cpi->rd;
int i; int i;
vp9_clear_system_state(); vp9_clear_system_state();
cpi->rd.RDDIV = RDDIV_BITS; // in bits (to multiply D by 128) rd->RDDIV = RDDIV_BITS; // in bits (to multiply D by 128)
cpi->rd.RDMULT = vp9_compute_rd_mult(cpi, cm->base_qindex + cm->y_dc_delta_q); rd->RDMULT = vp9_compute_rd_mult(cpi, cm->base_qindex + cm->y_dc_delta_q);
x->errorperbit = cpi->rd.RDMULT / RD_MULT_EPB_RATIO; x->errorperbit = rd->RDMULT / RD_MULT_EPB_RATIO;
x->errorperbit += (x->errorperbit == 0); x->errorperbit += (x->errorperbit == 0);
x->select_txfm_size = (cpi->sf.tx_size_search_method == USE_LARGESTALL && x->select_txfm_size = (cpi->sf.tx_size_search_method == USE_LARGESTALL &&
cm->frame_type != KEY_FRAME) ? 0 : 1; cm->frame_type != KEY_FRAME) ? 0 : 1;
set_block_thresholds(cpi); set_block_thresholds(cm, rd);
if (!cpi->sf.use_nonrd_pick_mode || cm->frame_type == KEY_FRAME) { if (!cpi->sf.use_nonrd_pick_mode || cm->frame_type == KEY_FRAME) {
fill_token_costs(x->token_costs, cm->fc.coef_probs); fill_token_costs(x->token_costs, cm->fc.coef_probs);
@ -2178,12 +2177,12 @@ static void mv_pred(VP9_COMP *cpi, MACROBLOCK *x,
x->pred_mv_sad[ref_frame] = best_sad; x->pred_mv_sad[ref_frame] = best_sad;
} }
static void estimate_ref_frame_costs(VP9_COMP *cpi, int segment_id, static void estimate_ref_frame_costs(const VP9_COMMON *cm,
const MACROBLOCKD *xd,
int segment_id,
unsigned int *ref_costs_single, unsigned int *ref_costs_single,
unsigned int *ref_costs_comp, unsigned int *ref_costs_comp,
vp9_prob *comp_mode_p) { vp9_prob *comp_mode_p) {
VP9_COMMON *const cm = &cpi->common;
MACROBLOCKD *const xd = &cpi->mb.e_mbd;
int seg_ref_active = vp9_segfeature_active(&cm->seg, segment_id, int seg_ref_active = vp9_segfeature_active(&cm->seg, segment_id,
SEG_LVL_REF_FRAME); SEG_LVL_REF_FRAME);
if (seg_ref_active) { if (seg_ref_active) {
@ -2348,7 +2347,7 @@ static void single_motion_search(VP9_COMP *cpi, MACROBLOCK *x,
int mi_row, int mi_col, int mi_row, int mi_col,
int_mv *tmp_mv, int *rate_mv) { int_mv *tmp_mv, int *rate_mv) {
MACROBLOCKD *xd = &x->e_mbd; MACROBLOCKD *xd = &x->e_mbd;
VP9_COMMON *cm = &cpi->common; const VP9_COMMON *cm = &cpi->common;
MB_MODE_INFO *mbmi = &xd->mi[0]->mbmi; MB_MODE_INFO *mbmi = &xd->mi[0]->mbmi;
struct buf_2d backup_yv12[MAX_MB_PLANE] = {{0}}; struct buf_2d backup_yv12[MAX_MB_PLANE] = {{0}};
int bestsme = INT_MAX; int bestsme = INT_MAX;
@ -2386,7 +2385,7 @@ static void single_motion_search(VP9_COMP *cpi, MACROBLOCK *x,
// Work out the size of the first step in the mv step search. // Work out the size of the first step in the mv step search.
// 0 here is maximum length first step. 1 is MAX >> 1 etc. // 0 here is maximum length first step. 1 is MAX >> 1 etc.
if (cpi->sf.auto_mv_step_size && cpi->common.show_frame) { if (cpi->sf.auto_mv_step_size && cm->show_frame) {
// Take wtd average of the step_params based on the last frame's // Take wtd average of the step_params based on the last frame's
// max mv magnitude and that based on the best ref mvs of the current // max mv magnitude and that based on the best ref mvs of the current
// block for the given reference. // block for the given reference.
@ -2397,7 +2396,7 @@ static void single_motion_search(VP9_COMP *cpi, MACROBLOCK *x,
} }
if (cpi->sf.adaptive_motion_search && bsize < BLOCK_64X64 && if (cpi->sf.adaptive_motion_search && bsize < BLOCK_64X64 &&
cpi->common.show_frame) { cm->show_frame) {
int boffset = 2 * (b_width_log2(BLOCK_64X64) - MIN(b_height_log2(bsize), int boffset = 2 * (b_width_log2(BLOCK_64X64) - MIN(b_height_log2(bsize),
b_width_log2(bsize))); b_width_log2(bsize)));
step_param = MAX(step_param, boffset); step_param = MAX(step_param, boffset);
@ -2412,7 +2411,7 @@ static void single_motion_search(VP9_COMP *cpi, MACROBLOCK *x,
if (tlevel < 5) if (tlevel < 5)
step_param += 2; step_param += 2;
for (i = LAST_FRAME; i <= ALTREF_FRAME && cpi->common.show_frame; ++i) { for (i = LAST_FRAME; i <= ALTREF_FRAME && cm->show_frame; ++i) {
if ((x->pred_mv_sad[ref] >> 3) > x->pred_mv_sad[i]) { if ((x->pred_mv_sad[ref] >> 3) > x->pred_mv_sad[i]) {
x->pred_mv[ref].as_int = 0; x->pred_mv[ref].as_int = 0;
tmp_mv->as_int = INVALID_MV; tmp_mv->as_int = INVALID_MV;
@ -2496,7 +2495,7 @@ static void single_motion_search(VP9_COMP *cpi, MACROBLOCK *x,
*rate_mv = vp9_mv_bit_cost(&tmp_mv->as_mv, &ref_mv, *rate_mv = vp9_mv_bit_cost(&tmp_mv->as_mv, &ref_mv,
x->nmvjointcost, x->mvcost, MV_COST_WEIGHT); x->nmvjointcost, x->mvcost, MV_COST_WEIGHT);
if (cpi->sf.adaptive_motion_search && cpi->common.show_frame) if (cpi->sf.adaptive_motion_search && cm->show_frame)
x->pred_mv[ref].as_int = tmp_mv->as_int; x->pred_mv[ref].as_int = tmp_mv->as_int;
if (scaled_ref_frame) { if (scaled_ref_frame) {
@ -3104,13 +3103,13 @@ static INLINE int rd_less_than_thresh(int64_t best_rd, int thresh,
// combination that wins out. // combination that wins out.
static void update_rd_thresh_fact(VP9_COMP *cpi, int bsize, static void update_rd_thresh_fact(VP9_COMP *cpi, int bsize,
int best_mode_index) { int best_mode_index) {
if (cpi->sf.adaptive_rd_thresh) { if (cpi->sf.adaptive_rd_thresh > 0) {
const int top_mode = bsize < BLOCK_8X8 ? MAX_REFS : MAX_MODES; const int top_mode = bsize < BLOCK_8X8 ? MAX_REFS : MAX_MODES;
int mode_index; int mode;
for (mode_index = 0; mode_index < top_mode; ++mode_index) { for (mode = 0; mode < top_mode; ++mode) {
int *const fact = &cpi->rd.thresh_freq_fact[bsize][mode_index]; int *const fact = &cpi->rd.thresh_freq_fact[bsize][mode];
if (mode_index == best_mode_index) { if (mode == best_mode_index) {
*fact -= (*fact >> 3); *fact -= (*fact >> 3);
} else { } else {
*fact = MIN(*fact + RD_THRESH_INC, *fact = MIN(*fact + RD_THRESH_INC,
@ -3178,7 +3177,7 @@ int64_t vp9_rd_pick_inter_mode_sb(VP9_COMP *cpi, MACROBLOCK *x,
x->skip_encode = cpi->sf.skip_encode_frame && x->q_index < QIDX_SKIP_THRESH; x->skip_encode = cpi->sf.skip_encode_frame && x->q_index < QIDX_SKIP_THRESH;
estimate_ref_frame_costs(cpi, segment_id, ref_costs_single, ref_costs_comp, estimate_ref_frame_costs(cm, xd, segment_id, ref_costs_single, ref_costs_comp,
&comp_mode_p); &comp_mode_p);
for (i = 0; i < REFERENCE_MODES; ++i) for (i = 0; i < REFERENCE_MODES; ++i)
@ -3792,7 +3791,7 @@ int64_t vp9_rd_pick_inter_mode_sub8x8(VP9_COMP *cpi, MACROBLOCK *x,
seg_mvs[i][j].as_int = INVALID_MV; seg_mvs[i][j].as_int = INVALID_MV;
} }
estimate_ref_frame_costs(cpi, segment_id, ref_costs_single, ref_costs_comp, estimate_ref_frame_costs(cm, xd, segment_id, ref_costs_single, ref_costs_comp,
&comp_mode_p); &comp_mode_p);
for (i = 0; i < REFERENCE_MODES; ++i) for (i = 0; i < REFERENCE_MODES; ++i)