#include "avcodec.h"
#include "dsputil.h"
#include "get_bits.h"
#include "bytestream.h"
#include "libavutil/audioconvert.h"
#include "libavutil/avassert.h"
Go to the source code of this file.
Data Structures | |
struct | APEFilter |
Filters applied to the decoded data. More... | |
struct | APERice |
struct | APERangecoder |
struct | APEPredictor |
Filter histories. More... | |
struct | APEContext |
Decoder context. More... | |
Defines | |
#define | ALT_BITSTREAM_READER_LE |
#define | BLOCKS_PER_LOOP 4608 |
#define | MAX_CHANNELS 2 |
#define | MAX_BYTESPERSAMPLE 3 |
#define | APE_FRAMECODE_MONO_SILENCE 1 |
#define | APE_FRAMECODE_STEREO_SILENCE 3 |
#define | APE_FRAMECODE_PSEUDO_STEREO 4 |
#define | HISTORY_SIZE 512 |
#define | PREDICTOR_ORDER 8 |
#define | PREDICTOR_SIZE 50 |
Total size of all predictor histories. | |
#define | YDELAYA (18 + PREDICTOR_ORDER*4) |
#define | YDELAYB (18 + PREDICTOR_ORDER*3) |
#define | XDELAYA (18 + PREDICTOR_ORDER*2) |
#define | XDELAYB (18 + PREDICTOR_ORDER) |
#define | YADAPTCOEFFSA 18 |
#define | XADAPTCOEFFSA 14 |
#define | YADAPTCOEFFSB 10 |
#define | XADAPTCOEFFSB 5 |
#define | APE_FILTER_LEVELS 3 |
Enumerations | |
enum | APECompressionLevel { COMPRESSION_LEVEL_FAST = 1000, COMPRESSION_LEVEL_NORMAL = 2000, COMPRESSION_LEVEL_HIGH = 3000, COMPRESSION_LEVEL_EXTRA_HIGH = 4000, COMPRESSION_LEVEL_INSANE = 5000 } |
Possible compression levels. More... | |
Functions | |
static av_cold int | ape_decode_close (AVCodecContext *avctx) |
static av_cold int | ape_decode_init (AVCodecContext *avctx) |
static void | update_rice (APERice *rice, int x) |
static int | ape_decode_value (APEContext *ctx, APERice *rice) |
static void | entropy_decode (APEContext *ctx, int blockstodecode, int stereo) |
static int | init_entropy_decoder (APEContext *ctx) |
static void | init_predictor_decoder (APEContext *ctx) |
static int | APESIGN (int32_t x) |
Get inverse sign of integer (-1 for positive, 1 for negative and 0 for zero). | |
static av_always_inline int | predictor_update_filter (APEPredictor *p, const int decoded, const int filter, const int delayA, const int delayB, const int adaptA, const int adaptB) |
static void | predictor_decode_stereo (APEContext *ctx, int count) |
static void | predictor_decode_mono (APEContext *ctx, int count) |
static void | do_init_filter (APEFilter *f, int16_t *buf, int order) |
static void | init_filter (APEContext *ctx, APEFilter *f, int16_t *buf, int order) |
static void | do_apply_filter (APEContext *ctx, int version, APEFilter *f, int32_t *data, int count, int order, int fracbits) |
static void | apply_filter (APEContext *ctx, APEFilter *f, int32_t *data0, int32_t *data1, int count, int order, int fracbits) |
static void | ape_apply_filters (APEContext *ctx, int32_t *decoded0, int32_t *decoded1, int count) |
static int | init_frame_decoder (APEContext *ctx) |
static void | ape_unpack_mono (APEContext *ctx, int count) |
static void | ape_unpack_stereo (APEContext *ctx, int count) |
static int | ape_decode_frame (AVCodecContext *avctx, void *data, int *got_frame_ptr, AVPacket *avpkt) |
static void | ape_flush (AVCodecContext *avctx) |
Variables | |
static const uint16_t | ape_filter_orders [5][APE_FILTER_LEVELS] |
Filter orders depending on compression level. | |
static const uint8_t | ape_filter_fracbits [5][APE_FILTER_LEVELS] |
Filter fraction bits depending on compression level. | |
static const int32_t | initial_coeffs [4] |
AVCodec | ff_ape_decoder |
APE range decoding functions | |
#define | CODE_BITS 32 |
#define | TOP_VALUE ((unsigned int)1 << (CODE_BITS-1)) |
#define | SHIFT_BITS (CODE_BITS - 9) |
#define | EXTRA_BITS ((CODE_BITS-2) % 8 + 1) |
#define | BOTTOM_VALUE (TOP_VALUE >> 8) |
#define | MODEL_ELEMENTS 64 |
static const uint16_t | counts_3970 [22] |
Fixed probabilities for symbols in Monkey Audio version 3.97. | |
static const uint16_t | counts_diff_3970 [21] |
Probability ranges for symbols in Monkey Audio version 3.97. | |
static const uint16_t | counts_3980 [22] |
Fixed probabilities for symbols in Monkey Audio version 3.98. | |
static const uint16_t | counts_diff_3980 [21] |
Probability ranges for symbols in Monkey Audio version 3.98. | |
static void | range_start_decoding (APEContext *ctx) |
Start the decoder. | |
static void | range_dec_normalize (APEContext *ctx) |
Perform normalization. | |
static int | range_decode_culfreq (APEContext *ctx, int tot_f) |
Calculate culmulative frequency for next symbol. | |
static int | range_decode_culshift (APEContext *ctx, int shift) |
Decode value with given size in bits. | |
static void | range_decode_update (APEContext *ctx, int sy_f, int lt_f) |
Update decoding state. | |
static int | range_decode_bits (APEContext *ctx, int n) |
Decode n bits (n <= 16) without modelling. | |
static int | range_get_symbol (APEContext *ctx, const uint16_t counts[], const uint16_t counts_diff[]) |
Decode symbol. |
Definition in file apedec.c.
#define APE_FILTER_LEVELS 3 |
Definition at line 72 of file apedec.c.
Referenced by ape_apply_filters(), ape_decode_close(), ape_decode_init(), and init_frame_decoder().
#define APE_FRAMECODE_PSEUDO_STEREO 4 |
#define APE_FRAMECODE_STEREO_SILENCE 3 |
Definition at line 41 of file apedec.c.
Referenced by ape_unpack_mono(), ape_unpack_stereo(), and entropy_decode().
#define BLOCKS_PER_LOOP 4608 |
#define BOTTOM_VALUE (TOP_VALUE >> 8) |
#define EXTRA_BITS ((CODE_BITS-2) % 8 + 1) |
#define HISTORY_SIZE 512 |
Definition at line 44 of file apedec.c.
Referenced by ape_decode_init(), do_apply_filter(), init_filter(), predictor_decode_mono(), and predictor_decode_stereo().
#define MODEL_ELEMENTS 64 |
#define PREDICTOR_SIZE 50 |
Total size of all predictor histories.
Definition at line 47 of file apedec.c.
Referenced by init_predictor_decoder(), predictor_decode_mono(), and predictor_decode_stereo().
#define TOP_VALUE ((unsigned int)1 << (CODE_BITS-1)) |
#define XADAPTCOEFFSA 14 |
#define XADAPTCOEFFSB 5 |
#define XDELAYA (18 + PREDICTOR_ORDER*2) |
#define XDELAYB (18 + PREDICTOR_ORDER) |
#define YADAPTCOEFFSA 18 |
Definition at line 54 of file apedec.c.
Referenced by predictor_decode_mono(), and predictor_decode_stereo().
#define YADAPTCOEFFSB 10 |
#define YDELAYA (18 + PREDICTOR_ORDER*4) |
Definition at line 49 of file apedec.c.
Referenced by predictor_decode_mono(), and predictor_decode_stereo().
#define YDELAYB (18 + PREDICTOR_ORDER*3) |
enum APECompressionLevel |
static void ape_apply_filters | ( | APEContext * | ctx, | |
int32_t * | decoded0, | |||
int32_t * | decoded1, | |||
int | count | |||
) | [static] |
static av_cold int ape_decode_close | ( | AVCodecContext * | avctx | ) | [static] |
static int ape_decode_frame | ( | AVCodecContext * | avctx, | |
void * | data, | |||
int * | got_frame_ptr, | |||
AVPacket * | avpkt | |||
) | [static] |
static av_cold int ape_decode_init | ( | AVCodecContext * | avctx | ) | [static] |
static int ape_decode_value | ( | APEContext * | ctx, | |
APERice * | rice | |||
) | [inline, static] |
static void ape_flush | ( | AVCodecContext * | avctx | ) | [static] |
static void ape_unpack_mono | ( | APEContext * | ctx, | |
int | count | |||
) | [static] |
static void ape_unpack_stereo | ( | APEContext * | ctx, | |
int | count | |||
) | [static] |
static int APESIGN | ( | int32_t | x | ) | [inline, static] |
Get inverse sign of integer (-1 for positive, 1 for negative and 0 for zero).
Definition at line 529 of file apedec.c.
Referenced by do_apply_filter(), predictor_decode_mono(), and predictor_update_filter().
static void apply_filter | ( | APEContext * | ctx, | |
APEFilter * | f, | |||
int32_t * | data0, | |||
int32_t * | data1, | |||
int | count, | |||
int | order, | |||
int | fracbits | |||
) | [static] |
static void do_apply_filter | ( | APEContext * | ctx, | |
int | version, | |||
APEFilter * | f, | |||
int32_t * | data, | |||
int | count, | |||
int | order, | |||
int | fracbits | |||
) | [static] |
static void entropy_decode | ( | APEContext * | ctx, | |
int | blockstodecode, | |||
int | stereo | |||
) | [static] |
static int init_entropy_decoder | ( | APEContext * | ctx | ) | [static] |
static void init_filter | ( | APEContext * | ctx, | |
APEFilter * | f, | |||
int16_t * | buf, | |||
int | order | |||
) | [static] |
static int init_frame_decoder | ( | APEContext * | ctx | ) | [static] |
static void init_predictor_decoder | ( | APEContext * | ctx | ) | [static] |
static void predictor_decode_mono | ( | APEContext * | ctx, | |
int | count | |||
) | [static] |
static void predictor_decode_stereo | ( | APEContext * | ctx, | |
int | count | |||
) | [static] |
static av_always_inline int predictor_update_filter | ( | APEPredictor * | p, | |
const int | decoded, | |||
const int | filter, | |||
const int | delayA, | |||
const int | delayB, | |||
const int | adaptA, | |||
const int | adaptB | |||
) | [static] |
static void range_dec_normalize | ( | APEContext * | ctx | ) | [inline, static] |
Perform normalization.
Definition at line 249 of file apedec.c.
Referenced by range_decode_culfreq(), and range_decode_culshift().
static int range_decode_bits | ( | APEContext * | ctx, | |
int | n | |||
) | [inline, static] |
Decode n bits (n <= 16) without modelling.
Definition at line 303 of file apedec.c.
Referenced by ape_decode_value().
static int range_decode_culfreq | ( | APEContext * | ctx, | |
int | tot_f | |||
) | [inline, static] |
Calculate culmulative frequency for next symbol.
Does NO update!
ctx | decoder context | |
tot_f | is the total frequency or (code_value)1<<shift |
Definition at line 270 of file apedec.c.
Referenced by ape_decode_value().
static int range_decode_culshift | ( | APEContext * | ctx, | |
int | shift | |||
) | [inline, static] |
Decode value with given size in bits.
ctx | decoder context | |
shift | number of bits to decode |
Definition at line 282 of file apedec.c.
Referenced by range_decode_bits(), and range_get_symbol().
static void range_decode_update | ( | APEContext * | ctx, | |
int | sy_f, | |||
int | lt_f | |||
) | [inline, static] |
Update decoding state.
ctx | decoder context | |
sy_f | the interval length (frequency of the symbol) | |
lt_f | the lower end (frequency sum of < symbols) |
Definition at line 296 of file apedec.c.
Referenced by ape_decode_value(), range_decode_bits(), and range_get_symbol().
static int range_get_symbol | ( | APEContext * | ctx, | |
const uint16_t | counts[], | |||
const uint16_t | counts_diff[] | |||
) | [inline, static] |
Decode symbol.
ctx | decoder context | |
counts | probability range start position | |
counts_diff | probability range widths |
Definition at line 355 of file apedec.c.
Referenced by ape_decode_value().
static void range_start_decoding | ( | APEContext * | ctx | ) | [inline, static] |
static void update_rice | ( | APERice * | rice, | |
int | x | |||
) | [inline, static] |
const uint8_t ape_filter_fracbits[5][APE_FILTER_LEVELS] [static] |
Initial value:
{ { 0, 0, 0 }, { 11, 0, 0 }, { 11, 0, 0 }, { 10, 13, 0 }, { 11, 13, 15 } }
Definition at line 84 of file apedec.c.
Referenced by ape_apply_filters().
const uint16_t ape_filter_orders[5][APE_FILTER_LEVELS] [static] |
Initial value:
{ { 0, 0, 0 }, { 16, 0, 0 }, { 64, 0, 0 }, { 32, 256, 0 }, { 16, 256, 1280 } }
Definition at line 75 of file apedec.c.
Referenced by ape_apply_filters(), ape_decode_init(), and init_frame_decoder().
const uint16_t counts_3970[22] [static] |
Initial value:
{ 0, 14824, 28224, 39348, 47855, 53994, 58171, 60926, 62682, 63786, 64463, 64878, 65126, 65276, 65365, 65419, 65450, 65469, 65480, 65487, 65491, 65493, }
Definition at line 316 of file apedec.c.
Referenced by ape_decode_value().
const uint16_t counts_3980[22] [static] |
Initial value:
{ 0, 19578, 36160, 48417, 56323, 60899, 63265, 64435, 64971, 65232, 65351, 65416, 65447, 65466, 65476, 65482, 65485, 65488, 65490, 65491, 65492, 65493, }
Definition at line 334 of file apedec.c.
Referenced by ape_decode_value().
const uint16_t counts_diff_3970[21] [static] |
Initial value:
{ 14824, 13400, 11124, 8507, 6139, 4177, 2755, 1756, 1104, 677, 415, 248, 150, 89, 54, 31, 19, 11, 7, 4, 2, }
Definition at line 325 of file apedec.c.
Referenced by ape_decode_value().
const uint16_t counts_diff_3980[21] [static] |
Initial value:
{ 19578, 16582, 12257, 7906, 4576, 2366, 1170, 536, 261, 119, 65, 31, 19, 10, 6, 3, 3, 2, 1, 1, 1, }
Definition at line 343 of file apedec.c.
Referenced by ape_decode_value().
Initial value:
{ .name = "ape", .type = AVMEDIA_TYPE_AUDIO, .id = CODEC_ID_APE, .priv_data_size = sizeof(APEContext), .init = ape_decode_init, .close = ape_decode_close, .decode = ape_decode_frame, .capabilities = CODEC_CAP_SUBFRAMES | CODEC_CAP_DELAY | CODEC_CAP_DR1, .flush = ape_flush, .long_name = NULL_IF_CONFIG_SMALL("Monkey's Audio"), }
const int32_t initial_coeffs[4] [static] |
Initial value:
{ 360, 317, -109, 98 }
Definition at line 506 of file apedec.c.
Referenced by init_predictor_decoder().