# HG changeset patch # User kostya # Date 1153540440 0 # Node ID da6095607f260b208997eaa4138c2d5450f97fc5 # Parent 3d6e4ef3170d788650b934e3b477bb6603fd32dc Don't do non-uniform quantization on zero coeffs. diff -r 3d6e4ef3170d -r da6095607f26 vc1.c --- a/vc1.c Fri Jul 21 04:06:06 2006 +0000 +++ b/vc1.c Sat Jul 22 03:54:00 2006 +0000 @@ -2061,13 +2061,13 @@ if(dc_pred_dir) { //left for(k = 1; k < 8; k++) { 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; } } else { //top for(k = 1; k < 8; k++) { block[k] = ac_val[k + 8] * scale; - if(!v->pquantizer) + if(!v->pquantizer && block[k]) block[k] += (block[k] < 0) ? -v->pq : v->pq; } } @@ -2260,13 +2260,13 @@ if(dc_pred_dir) { //left for(k = 1; k < 8; k++) { 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; } } else { //top for(k = 1; k < 8; k++) { block[k] = ac_val2[k + 8] * scale; - if(!v->pquantizer) + if(!v->pquantizer && block[k]) block[k] += (block[k] < 0) ? -mquant : mquant; } }