mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-24 13:56:33 +02:00
Use coupling band sizes instead of coupling band structure when
calculating coupling transform coefficients. Originally committed as revision 19584 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
faccfeec0e
commit
603139022d
@ -412,14 +412,11 @@ static int decode_exponents(GetBitContext *gbc, int exp_strategy, int ngrps,
|
|||||||
*/
|
*/
|
||||||
static void calc_transform_coeffs_cpl(AC3DecodeContext *s)
|
static void calc_transform_coeffs_cpl(AC3DecodeContext *s)
|
||||||
{
|
{
|
||||||
int i, j, ch, bnd, subbnd;
|
int i, j, ch, bnd;
|
||||||
|
|
||||||
subbnd = -1;
|
|
||||||
i = s->start_freq[CPL_CH];
|
i = s->start_freq[CPL_CH];
|
||||||
for(bnd=0; bnd<s->num_cpl_bands; bnd++) {
|
for(bnd=0; bnd<s->num_cpl_bands; bnd++) {
|
||||||
do {
|
for (j = 0; j < s->cpl_band_sizes[bnd]; j++,i++) {
|
||||||
subbnd++;
|
|
||||||
for(j=0; j<12; j++) {
|
|
||||||
for(ch=1; ch<=s->fbw_channels; ch++) {
|
for(ch=1; ch<=s->fbw_channels; ch++) {
|
||||||
if(s->channel_in_cpl[ch]) {
|
if(s->channel_in_cpl[ch]) {
|
||||||
s->fixed_coeffs[ch][i] = ((int64_t)s->fixed_coeffs[CPL_CH][i] * (int64_t)s->cpl_coords[ch][bnd]) >> 23;
|
s->fixed_coeffs[ch][i] = ((int64_t)s->fixed_coeffs[CPL_CH][i] * (int64_t)s->cpl_coords[ch][bnd]) >> 23;
|
||||||
@ -427,9 +424,7 @@ static void calc_transform_coeffs_cpl(AC3DecodeContext *s)
|
|||||||
s->fixed_coeffs[ch][i] = -s->fixed_coeffs[ch][i];
|
s->fixed_coeffs[ch][i] = -s->fixed_coeffs[ch][i];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
i++;
|
}
|
||||||
}
|
|
||||||
} while(s->cpl_band_struct[subbnd]);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -884,7 +879,8 @@ static int decode_audio_block(AC3DecodeContext *s, int blk)
|
|||||||
decode_band_structure(gbc, blk, s->eac3, 0, cpl_start_subband,
|
decode_band_structure(gbc, blk, s->eac3, 0, cpl_start_subband,
|
||||||
cpl_end_subband,
|
cpl_end_subband,
|
||||||
ff_eac3_default_cpl_band_struct,
|
ff_eac3_default_cpl_band_struct,
|
||||||
s->cpl_band_struct, &s->num_cpl_bands, NULL);
|
s->cpl_band_struct, &s->num_cpl_bands,
|
||||||
|
s->cpl_band_sizes);
|
||||||
} else {
|
} else {
|
||||||
/* coupling not in use */
|
/* coupling not in use */
|
||||||
for (ch = 1; ch <= fbw_channels; ch++) {
|
for (ch = 1; ch <= fbw_channels; ch++) {
|
||||||
|
@ -83,6 +83,7 @@ typedef struct {
|
|||||||
int phase_flags[18]; ///< phase flags (phsflg)
|
int phase_flags[18]; ///< phase flags (phsflg)
|
||||||
int num_cpl_bands; ///< number of coupling bands (ncplbnd)
|
int num_cpl_bands; ///< number of coupling bands (ncplbnd)
|
||||||
uint8_t cpl_band_struct[18]; ///< coupling band structure (cplbndstrc)
|
uint8_t cpl_band_struct[18]; ///< coupling band structure (cplbndstrc)
|
||||||
|
uint8_t cpl_band_sizes[18]; ///< number of coeffs in each coupling band
|
||||||
int firstchincpl; ///< first channel in coupling
|
int firstchincpl; ///< first channel in coupling
|
||||||
int first_cpl_coords[AC3_MAX_CHANNELS]; ///< first coupling coordinates states (firstcplcos)
|
int first_cpl_coords[AC3_MAX_CHANNELS]; ///< first coupling coordinates states (firstcplcos)
|
||||||
int cpl_coords[AC3_MAX_CHANNELS][18]; ///< coupling coordinates (cplco)
|
int cpl_coords[AC3_MAX_CHANNELS][18]; ///< coupling coordinates (cplco)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user