h261 dequant fix
Originally committed as revision 3180 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
b658ecfeb8
commit
bb8140f29d
@ -5800,7 +5800,7 @@ static void dct_unquantize_h263_inter_c(MpegEncContext *s,
|
|||||||
static void dct_unquantize_h261_intra_c(MpegEncContext *s,
|
static void dct_unquantize_h261_intra_c(MpegEncContext *s,
|
||||||
DCTELEM *block, int n, int qscale)
|
DCTELEM *block, int n, int qscale)
|
||||||
{
|
{
|
||||||
int i, level, odd;
|
int i, level, even;
|
||||||
int nCoeffs;
|
int nCoeffs;
|
||||||
|
|
||||||
assert(s->block_last_index[n]>=0);
|
assert(s->block_last_index[n]>=0);
|
||||||
@ -5809,16 +5809,16 @@ static void dct_unquantize_h261_intra_c(MpegEncContext *s,
|
|||||||
block[0] = block[0] * s->y_dc_scale;
|
block[0] = block[0] * s->y_dc_scale;
|
||||||
else
|
else
|
||||||
block[0] = block[0] * s->c_dc_scale;
|
block[0] = block[0] * s->c_dc_scale;
|
||||||
odd = qscale & 0x1;
|
even = (qscale & 1)^1;
|
||||||
nCoeffs= s->inter_scantable.raster_end[ s->block_last_index[n] ];
|
nCoeffs= s->inter_scantable.raster_end[ s->block_last_index[n] ];
|
||||||
|
|
||||||
for(i=1; i<=nCoeffs; i++){
|
for(i=1; i<=nCoeffs; i++){
|
||||||
level = block[i];
|
level = block[i];
|
||||||
if (level){
|
if (level){
|
||||||
if (level < 0){
|
if (level < 0){
|
||||||
level = qscale * ((level << 1) - 1) + (~odd);
|
level = qscale * ((level << 1) - 1) + even;
|
||||||
}else{
|
}else{
|
||||||
level = qscale * ((level << 1) + 1) - (~odd);
|
level = qscale * ((level << 1) + 1) - even;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
block[i] = level;
|
block[i] = level;
|
||||||
@ -5828,12 +5828,12 @@ static void dct_unquantize_h261_intra_c(MpegEncContext *s,
|
|||||||
static void dct_unquantize_h261_inter_c(MpegEncContext *s,
|
static void dct_unquantize_h261_inter_c(MpegEncContext *s,
|
||||||
DCTELEM *block, int n, int qscale)
|
DCTELEM *block, int n, int qscale)
|
||||||
{
|
{
|
||||||
int i, level, odd;
|
int i, level, even;
|
||||||
int nCoeffs;
|
int nCoeffs;
|
||||||
|
|
||||||
assert(s->block_last_index[n]>=0);
|
assert(s->block_last_index[n]>=0);
|
||||||
|
|
||||||
odd = qscale & 0x1;
|
even = (qscale & 1)^1;
|
||||||
|
|
||||||
nCoeffs= s->inter_scantable.raster_end[ s->block_last_index[n] ];
|
nCoeffs= s->inter_scantable.raster_end[ s->block_last_index[n] ];
|
||||||
|
|
||||||
@ -5841,9 +5841,9 @@ static void dct_unquantize_h261_inter_c(MpegEncContext *s,
|
|||||||
level = block[i];
|
level = block[i];
|
||||||
if (level){
|
if (level){
|
||||||
if (level < 0){
|
if (level < 0){
|
||||||
level = qscale * ((level << 1) - 1) + (~odd);
|
level = qscale * ((level << 1) - 1) + even;
|
||||||
}else{
|
}else{
|
||||||
level = qscale * ((level << 1) + 1) - (~odd);
|
level = qscale * ((level << 1) + 1) - even;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
block[i] = level;
|
block[i] = level;
|
||||||
|
Loading…
Reference in New Issue
Block a user