mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2024-12-22 23:33:07 +00:00
remove permutation done to quant tables and then undone during idct
move permutation from idct to unpack_vlcs Originally committed as revision 4256 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
b178f758fa
commit
ea191e08d6
@ -886,7 +886,7 @@ static void init_dequantizer(Vp3DecodeContext *s)
|
||||
* the dequantization phase */
|
||||
for (i = 1; i < 64; i++) {
|
||||
|
||||
j = zigzag_index[i];
|
||||
j = i;
|
||||
|
||||
s->intra_y_dequant[j] = s->coded_intra_y_dequant[i] * ac_scale_factor / 100;
|
||||
if (s->intra_y_dequant[j] < MIN_DEQUANT_VAL)
|
||||
@ -1659,7 +1659,7 @@ static int unpack_vlcs(Vp3DecodeContext *s, GetBitContext *gb,
|
||||
if (!eob_run) {
|
||||
fragment->coeff_count += zero_run;
|
||||
if (fragment->coeff_count < 64)
|
||||
fragment->coeffs[fragment->coeff_count++] = coeff;
|
||||
fragment->coeffs[dezigzag_index[fragment->coeff_count++]] = coeff;
|
||||
debug_vlc(" fragment %d coeff = %d\n",
|
||||
s->coded_fragment_list[i], fragment->coeffs[coeff_index]);
|
||||
} else {
|
||||
|
@ -53,11 +53,10 @@ void vp3_idct_c(int16_t *input_data, int16_t *dequant_matrix,
|
||||
int32_t t1, t2;
|
||||
|
||||
int i, j;
|
||||
|
||||
|
||||
/* de-zigzag and dequantize */
|
||||
for (i = 0; i < coeff_count; i++) {
|
||||
j = dezigzag_index[i];
|
||||
dequantized_data[j] = dequant_matrix[i] * input_data[i];
|
||||
dequantized_data[i] = dequant_matrix[i] * input_data[i];
|
||||
}
|
||||
|
||||
/* Inverse DCT on the rows now */
|
||||
|
Loading…
Reference in New Issue
Block a user