]> granicus.if.org Git - libvpx/commitdiff
Clamp rate correction factor after scaling it
authorAdrian Grange <agrange@google.com>
Tue, 10 Mar 2015 19:04:59 +0000 (12:04 -0700)
committerAdrian Grange <agrange@google.com>
Wed, 11 Mar 2015 16:08:15 +0000 (09:08 -0700)
Added clamp on the rate correction factor after
it has been scaled.

Change-Id: I5d4b46a101987b43c5bcfd7e0bd1b7b4d53640a4

vp9/encoder/vp9_ratectrl.c

index 79a89af90005ce6997475dc972f87045129e4531..8916e1107f7e70c99e5e52b722dc0a08ea823309 100644 (file)
@@ -377,7 +377,7 @@ static double get_rate_correction_factor(const VP9_COMP *cpi) {
       rcf = rc->rate_correction_factors[INTER_NORMAL];
   }
   rcf *= rcf_mult[rc->frame_size_selector];
-  return rcf > MAX_BPB_FACTOR ? MAX_BPB_FACTOR : rcf;
+  return fclamp(rcf, MIN_BPB_FACTOR, MAX_BPB_FACTOR);
 }
 
 static void set_rate_correction_factor(VP9_COMP *cpi, double factor) {
@@ -386,6 +386,8 @@ static void set_rate_correction_factor(VP9_COMP *cpi, double factor) {
   // Normalize RCF to account for the size-dependent scaling factor.
   factor /= rcf_mult[cpi->rc.frame_size_selector];
 
+  factor = fclamp(factor, MIN_BPB_FACTOR, MAX_BPB_FACTOR);
+
   if (cpi->common.frame_type == KEY_FRAME) {
     rc->rate_correction_factors[KF_STD] = factor;
   } else if (cpi->oxcf.pass == 2) {