Mercurial > libavcodec.hg
diff ratecontrol.c @ 1806:2721e1859e19 libavcodec
normalize adaptive quantizatiuon fix (based upon a patch by (Jindrich Makovicka <makovick at kmlinux dot fjfi dot cvut dot cz>))
author | michael |
---|---|
date | Sat, 14 Feb 2004 13:37:58 +0000 |
parents | 07a484280a82 |
children | 18b8b2dcc037 |
line wrap: on
line diff
--- a/ratecontrol.c Sat Feb 14 03:49:43 2004 +0000 +++ b/ratecontrol.c Sat Feb 14 13:37:58 2004 +0000 @@ -545,9 +545,10 @@ /* handle qmin/qmax cliping */ if(s->flags&CODEC_FLAG_NORMALIZE_AQP){ + float factor= bits_sum/cplx_sum; for(i=0; i<s->mb_num; i++){ float newq= q*cplx_tab[i]/bits_tab[i]; - newq*= bits_sum/cplx_sum; + newq*= factor; if (newq > qmax){ bits_sum -= bits_tab[i]; @@ -558,6 +559,8 @@ cplx_sum -= cplx_tab[i]*q/qmin; } } + if(bits_sum < 0.001) bits_sum= 0.001; + if(cplx_sum < 0.001) cplx_sum= 0.001; } for(i=0; i<s->mb_num; i++){