ref: 840dc6966de11aaa21f292aa3eff36f66ccfc3a5
parent: 1492ccbe6e9bd8f8b46fa103166889fc22dac48e
author: Marco Paniconi <marpan@google.com>
date: Wed Mar 20 09:39:48 EDT 2019
vp9-rtc: Fixes for low-resoln The force smooth_filter should only be used for noisy content, so for now keep it off and add TODO. Also fix/adjust low-resoln condition and threshold in cyclic refresh. Change-Id: I6c456dc9f23daabba20badd65a2f7ee6c5e259c4
--- a/vp9/encoder/vp9_aq_cyclicrefresh.c
+++ b/vp9/encoder/vp9_aq_cyclicrefresh.c
@@ -530,9 +530,9 @@
cr->rate_boost_fac = 10;
}
// Adjust some parameters for low resolutions.
- if (cm->width <= 352 && cm->height <= 288) {
+ if (cm->width * cm->height <= 352 * 288) {
if (rc->avg_frame_bandwidth < 3000) {
- cr->motion_thresh = 16;
+ cr->motion_thresh = 64;
cr->rate_boost_fac = 13;
} else {
cr->max_qdelta_perc = 70;
--- a/vp9/encoder/vp9_pickmode.c
+++ b/vp9/encoder/vp9_pickmode.c
@@ -1700,11 +1700,10 @@
int no_scaling = 0;
unsigned int thresh_svc_skip_golden = 500;
unsigned int thresh_skip_golden = 500;
- int force_smooth_filter =
- (cpi->oxcf.speed >= 8 && cm->width * cm->height <= 320 * 240 &&
- cm->base_qindex >= 200)
- ? 1
- : 0;
+ // TODO(marpan/jianj): forcing smooth_interpol is visually better for noisy
+ // content, at low resolns. Look into adding this conditon. For now keep
+ // it off.
+ int force_smooth_filter = 0;
int scene_change_detected =
cpi->rc.high_source_sad ||
(cpi->use_svc && cpi->svc.high_source_sad_superframe);