|
|
@ -594,13 +594,13 @@ static int vorbis_parse_setup_hdr_floors(vorbis_context *vc) |
|
|
|
|
|
|
|
|
|
|
|
create_map(vc, i); |
|
|
|
create_map(vc, i); |
|
|
|
|
|
|
|
|
|
|
|
/* codebook dim is for padding if codebook dim doesn't *
|
|
|
|
/* codebook dim is for padding if codebook dim doesn't *
|
|
|
|
* divide order+1 then we need to read more data */ |
|
|
|
* divide order+1 then we need to read more data */ |
|
|
|
floor_setup->data.t0.lsp = |
|
|
|
floor_setup->data.t0.lsp = |
|
|
|
av_malloc((floor_setup->data.t0.order+1 + max_codebook_dim) |
|
|
|
av_malloc((floor_setup->data.t0.order+1 + max_codebook_dim) |
|
|
|
* sizeof(float)); |
|
|
|
* sizeof(float)); |
|
|
|
if (!floor_setup->data.t0.lsp) |
|
|
|
if (!floor_setup->data.t0.lsp) |
|
|
|
return -1; |
|
|
|
return -1; |
|
|
|
|
|
|
|
|
|
|
|
#ifdef V_DEBUG /* debug output parsed headers */ |
|
|
|
#ifdef V_DEBUG /* debug output parsed headers */ |
|
|
|
AV_DEBUG("floor0 order: %u\n", floor_setup->data.t0.order); |
|
|
|
AV_DEBUG("floor0 order: %u\n", floor_setup->data.t0.order); |
|
|
@ -1107,9 +1107,9 @@ static int vorbis_floor0_decode(vorbis_context *vc, |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/* calculate linear floor value */ |
|
|
|
/* calculate linear floor value */ |
|
|
|
q = exp((((amplitude*vf->amplitude_offset) / |
|
|
|
q = exp((((amplitude*vf->amplitude_offset) / |
|
|
|
(((1 << vf->amplitude_bits) - 1) * sqrt(p + q))) |
|
|
|
(((1 << vf->amplitude_bits) - 1) * sqrt(p + q))) |
|
|
|
- vf->amplitude_offset) * .11512925f); |
|
|
|
- vf->amplitude_offset) * .11512925f); |
|
|
|
|
|
|
|
|
|
|
|
/* fill vector */ |
|
|
|
/* fill vector */ |
|
|
|
do { |
|
|
|
do { |
|
|
|