mirror of
https://gitee.com/openharmony/third_party_ffmpeg
synced 2024-11-23 19:30:05 +00:00
Last hunk of the AAC decoder code to be OKed and build system and documentation
alterations as appropriate Originally committed as revision 14873 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
7fb262b568
commit
7d8f3de4a8
@ -130,6 +130,7 @@ version <next>
|
|||||||
- D-Cinema audio muxer
|
- D-Cinema audio muxer
|
||||||
- Electronic Arts TGV decoder
|
- Electronic Arts TGV decoder
|
||||||
- Apple Lossless Audio Codec (ALAC) encoder
|
- Apple Lossless Audio Codec (ALAC) encoder
|
||||||
|
- AAC decoder
|
||||||
|
|
||||||
version 0.4.9-pre1:
|
version 0.4.9-pre1:
|
||||||
|
|
||||||
|
@ -337,7 +337,7 @@ following image formats are supported:
|
|||||||
@item 4X IMA ADPCM @tab @tab X
|
@item 4X IMA ADPCM @tab @tab X
|
||||||
@item 8SVX audio @tab @tab X
|
@item 8SVX audio @tab @tab X
|
||||||
@item AAC @tab X @tab X
|
@item AAC @tab X @tab X
|
||||||
@tab Supported through the external library libfaac/libfaad.
|
@tab Encoding is supported through the external library libfaac.
|
||||||
@item AC-3 @tab IX @tab IX
|
@item AC-3 @tab IX @tab IX
|
||||||
@tab liba52 can be used alternatively for decoding.
|
@tab liba52 can be used alternatively for decoding.
|
||||||
@item AMR-NB @tab X @tab X
|
@item AMR-NB @tab X @tab X
|
||||||
|
@ -25,6 +25,7 @@ HEADERS = avcodec.h opt.h
|
|||||||
|
|
||||||
OBJS-$(CONFIG_ENCODERS) += faandct.o jfdctfst.o jfdctint.o
|
OBJS-$(CONFIG_ENCODERS) += faandct.o jfdctfst.o jfdctint.o
|
||||||
|
|
||||||
|
OBJS-$(CONFIG_AAC_DECODER) += aac.o aactab.o mdct.o fft.o
|
||||||
OBJS-$(CONFIG_AASC_DECODER) += aasc.o
|
OBJS-$(CONFIG_AASC_DECODER) += aasc.o
|
||||||
OBJS-$(CONFIG_AC3_DECODER) += ac3dec.o ac3tab.o ac3dec_data.o ac3.o mdct.o fft.o
|
OBJS-$(CONFIG_AC3_DECODER) += ac3dec.o ac3tab.o ac3dec_data.o ac3.o mdct.o fft.o
|
||||||
OBJS-$(CONFIG_AC3_ENCODER) += ac3enc.o ac3tab.o ac3.o
|
OBJS-$(CONFIG_AC3_ENCODER) += ac3enc.o ac3tab.o ac3.o
|
||||||
|
@ -1104,6 +1104,42 @@ static int decode_extension_payload(AACContext * ac, GetBitContext * gb, int cnt
|
|||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Decode Temporal Noise Shaping filter coefficients and apply all-pole filters; reference: 4.6.9.3.
|
||||||
|
*
|
||||||
|
* @param decode 1 if tool is used normally, 0 if tool is used in LTP.
|
||||||
|
* @param coef spectral coefficients
|
||||||
|
*/
|
||||||
|
static void apply_tns(float coef[1024], TemporalNoiseShaping * tns, IndividualChannelStream * ics, int decode) {
|
||||||
|
const int mmm = FFMIN(ics->tns_max_bands, ics->max_sfb);
|
||||||
|
int w, filt, m, i, ib;
|
||||||
|
int bottom, top, order, start, end, size, inc;
|
||||||
|
float lpc[TNS_MAX_ORDER];
|
||||||
|
|
||||||
|
for (w = 0; w < ics->num_windows; w++) {
|
||||||
|
bottom = ics->num_swb;
|
||||||
|
for (filt = 0; filt < tns->n_filt[w]; filt++) {
|
||||||
|
top = bottom;
|
||||||
|
bottom = FFMAX(0, top - tns->length[w][filt]);
|
||||||
|
order = tns->order[w][filt];
|
||||||
|
if (order == 0)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
/* tns_decode_coef
|
||||||
|
* FIXME: This duplicates the functionality of some double code in lpc.c.
|
||||||
|
*/
|
||||||
|
for (m = 0; m < order; m++) {
|
||||||
|
float tmp;
|
||||||
|
lpc[m] = tns->coef[w][filt][m];
|
||||||
|
for (i = 0; i < m/2; i++) {
|
||||||
|
tmp = lpc[i];
|
||||||
|
lpc[i] += lpc[m] * lpc[m-1-i];
|
||||||
|
lpc[m-1-i] += lpc[m] * tmp;
|
||||||
|
}
|
||||||
|
if(m & 1)
|
||||||
|
lpc[i] += lpc[m] * lpc[i];
|
||||||
|
}
|
||||||
|
|
||||||
start = ics->swb_offset[FFMIN(bottom, mmm)];
|
start = ics->swb_offset[FFMIN(bottom, mmm)];
|
||||||
end = ics->swb_offset[FFMIN( top, mmm)];
|
end = ics->swb_offset[FFMIN( top, mmm)];
|
||||||
if ((size = end - start) <= 0)
|
if ((size = end - start) <= 0)
|
||||||
@ -1118,7 +1154,7 @@ static int decode_extension_payload(AACContext * ac, GetBitContext * gb, int cnt
|
|||||||
// ar filter
|
// ar filter
|
||||||
for (m = 0; m < size; m++, start += inc)
|
for (m = 0; m < size; m++, start += inc)
|
||||||
for (i = 1; i <= FFMIN(m, order); i++)
|
for (i = 1; i <= FFMIN(m, order); i++)
|
||||||
coef[start] -= coef[start - i*inc] * lpc[i];
|
coef[start] -= coef[start - i*inc] * lpc[i-1];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -181,6 +181,7 @@ void avcodec_register_all(void)
|
|||||||
REGISTER_ENCDEC (ZMBV, zmbv);
|
REGISTER_ENCDEC (ZMBV, zmbv);
|
||||||
|
|
||||||
/* audio codecs */
|
/* audio codecs */
|
||||||
|
REGISTER_DECODER (AAC, aac);
|
||||||
REGISTER_ENCDEC (AC3, ac3);
|
REGISTER_ENCDEC (AC3, ac3);
|
||||||
REGISTER_ENCDEC (ALAC, alac);
|
REGISTER_ENCDEC (ALAC, alac);
|
||||||
REGISTER_DECODER (APE, ape);
|
REGISTER_DECODER (APE, ape);
|
||||||
|
@ -30,7 +30,7 @@
|
|||||||
#include "libavutil/avutil.h"
|
#include "libavutil/avutil.h"
|
||||||
|
|
||||||
#define LIBAVCODEC_VERSION_MAJOR 51
|
#define LIBAVCODEC_VERSION_MAJOR 51
|
||||||
#define LIBAVCODEC_VERSION_MINOR 68
|
#define LIBAVCODEC_VERSION_MINOR 69
|
||||||
#define LIBAVCODEC_VERSION_MICRO 0
|
#define LIBAVCODEC_VERSION_MICRO 0
|
||||||
|
|
||||||
#define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \
|
#define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \
|
||||||
|
Loading…
Reference in New Issue
Block a user