From: Ravi Chaudhary Date: Mon, 11 Mar 2019 09:39:08 +0000 (+0530) Subject: Refine active best quality of layered ARF frames X-Git-Tag: v1.8.1~84^2 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=4bb51416e183381cd1df474662a8224a47476c2d;p=libvpx Refine active best quality of layered ARF frames Change-Id: If630af68fc3793d579a947d5955c2001c0cf0a8d --- diff --git a/vp9/encoder/vp9_ratectrl.c b/vp9/encoder/vp9_ratectrl.c index 793171547..b51f6797b 100644 --- a/vp9/encoder/vp9_ratectrl.c +++ b/vp9/encoder/vp9_ratectrl.c @@ -1446,20 +1446,19 @@ static int rc_pick_q_and_bounds_two_pass(const VP9_COMP *cpi, int *bottom_index, // Constrained quality use slightly lower active best. active_best_quality = active_best_quality * 15 / 16; - - // Modify best quality for second level arfs. For mode VPX_Q this - // becomes the baseline frame q. - if (gf_group->rf_level[gf_group_index] == GF_ARF_LOW) { - const int layer_depth = gf_group->layer_depth[gf_group_index]; - // linearly fit the frame q depending on the layer depth index from - // the base layer ARF. - active_best_quality = - ((layer_depth - 1) * q + active_best_quality + layer_depth / 2) / - layer_depth; - } } else { active_best_quality = get_gf_active_quality(cpi, q, cm->bit_depth); } + // Modify best quality for second level arfs. For mode VPX_Q this + // becomes the baseline frame q. + if (gf_group->rf_level[gf_group_index] == GF_ARF_LOW) { + const int layer_depth = gf_group->layer_depth[gf_group_index]; + // linearly fit the frame q depending on the layer depth index from + // the base layer ARF. + active_best_quality = + ((layer_depth - 1) * q + active_best_quality + layer_depth / 2) / + layer_depth; + } } else { active_best_quality = inter_minq[active_worst_quality];