1
0
mirror of https://github.com/FFmpeg/FFmpeg.git synced 2025-01-13 21:28:01 +02:00

Don't do non-uniform quantization on zero coeffs.

Originally committed as revision 5810 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
Kostya Shishkov 2006-07-22 03:54:00 +00:00
parent aab7715910
commit 4b94465927

View File

@ -2061,13 +2061,13 @@ not_coded:
if(dc_pred_dir) { //left if(dc_pred_dir) { //left
for(k = 1; k < 8; k++) { for(k = 1; k < 8; k++) {
block[k << 3] = ac_val[k] * scale; block[k << 3] = ac_val[k] * scale;
if(!v->pquantizer) if(!v->pquantizer && block[k << 3])
block[k << 3] += (block[k << 3] < 0) ? -v->pq : v->pq; block[k << 3] += (block[k << 3] < 0) ? -v->pq : v->pq;
} }
} else { //top } else { //top
for(k = 1; k < 8; k++) { for(k = 1; k < 8; k++) {
block[k] = ac_val[k + 8] * scale; block[k] = ac_val[k + 8] * scale;
if(!v->pquantizer) if(!v->pquantizer && block[k])
block[k] += (block[k] < 0) ? -v->pq : v->pq; block[k] += (block[k] < 0) ? -v->pq : v->pq;
} }
} }
@ -2260,13 +2260,13 @@ static int vc1_decode_intra_block(VC1Context *v, DCTELEM block[64], int n, int c
if(dc_pred_dir) { //left if(dc_pred_dir) { //left
for(k = 1; k < 8; k++) { for(k = 1; k < 8; k++) {
block[k << 3] = ac_val2[k] * scale; block[k << 3] = ac_val2[k] * scale;
if(!v->pquantizer) if(!v->pquantizer && block[k << 3])
block[k << 3] += (block[k << 3] < 0) ? -mquant : mquant; block[k << 3] += (block[k << 3] < 0) ? -mquant : mquant;
} }
} else { //top } else { //top
for(k = 1; k < 8; k++) { for(k = 1; k < 8; k++) {
block[k] = ac_val2[k + 8] * scale; block[k] = ac_val2[k + 8] * scale;
if(!v->pquantizer) if(!v->pquantizer && block[k])
block[k] += (block[k] < 0) ? -mquant : mquant; block[k] += (block[k] < 0) ? -mquant : mquant;
} }
} }