FFmpeg
|
AAC encoder psychoacoustic model. More...
#include "libavutil/attributes.h"
#include "libavutil/ffmath.h"
#include "avcodec.h"
#include "aactab.h"
#include "psymodel.h"
Go to the source code of this file.
Data Structures | |
struct | AacPsyBand |
information for single band used by 3GPP TS26.403-inspired psychoacoustic model More... | |
struct | AacPsyChannel |
single/pair channel context for psychoacoustic model More... | |
struct | AacPsyCoeffs |
psychoacoustic model frame type-dependent coefficients More... | |
struct | AacPsyContext |
3GPP TS26.403-inspired psychoacoustic model specific data More... | |
struct | PsyLamePreset |
LAME psy model preset struct. More... | |
Macros | |
#define | ATH_ADD 4 |
Functions | |
static float | lame_calc_attack_threshold (int bitrate) |
Calculate the ABR attack threshold from the above LAME psymodel table. More... | |
static av_cold void | lame_window_init (AacPsyContext *ctx, AVCodecContext *avctx) |
LAME psy model specific initialization. More... | |
static av_cold float | calc_bark (float f) |
Calculate Bark value for given line. More... | |
static av_cold float | ath (float f, float add) |
Calculate ATH value for given frequency. More... | |
static av_cold int | psy_3gpp_init (FFPsyContext *ctx) |
static float | iir_filter (int in, float state[2]) |
IIR filter used in block switching decision. More... | |
static av_unused FFPsyWindowInfo | psy_3gpp_window (FFPsyContext *ctx, const int16_t *audio, const int16_t *la, int channel, int prev_type) |
Tell encoder which window types to use. More... | |
static int | calc_bit_demand (AacPsyContext *ctx, float pe, int bits, int size, int short_window) |
static float | calc_pe_3gpp (AacPsyBand *band) |
static float | calc_reduction_3gpp (float a, float desired_pe, float pe, float active_lines) |
static float | calc_reduced_thr_3gpp (AacPsyBand *band, float min_snr, float reduction) |
static void | calc_thr_3gpp (const FFPsyWindowInfo *wi, const int num_bands, AacPsyChannel *pch, const uint8_t *band_sizes, const float *coefs, const int cutoff) |
static void | psy_hp_filter (const float *firbuf, float *hpfsmpl, const float *psy_fir_coeffs) |
static void | psy_3gpp_analyze_channel (FFPsyContext *ctx, int channel, const float *coefs, const FFPsyWindowInfo *wi) |
Calculate band thresholds as suggested in 3GPP TS26.403. More... | |
static void | psy_3gpp_analyze (FFPsyContext *ctx, int channel, const float **coeffs, const FFPsyWindowInfo *wi) |
static av_cold void | psy_3gpp_end (FFPsyContext *apc) |
static void | lame_apply_block_type (AacPsyChannel *ctx, FFPsyWindowInfo *wi, int uselongblock) |
static FFPsyWindowInfo | psy_lame_window (FFPsyContext *ctx, const float *audio, const float *la, int channel, int prev_type) |
Variables | |
static const PsyLamePreset | psy_abr_map [] |
LAME psy model preset table for ABR. More... | |
static const PsyLamePreset | psy_vbr_map [] |
LAME psy model preset table for constant quality. More... | |
static const float | psy_fir_coeffs [] |
LAME psy model FIR coefficient table. More... | |
static const uint8_t | window_grouping [9] |
window grouping information stored as bits (0 - new group, 1 - group continues) More... | |
const FFPsyModel | ff_aac_psy_model |
#define | PSY_3GPP_THR_SPREAD_HI 1.5f |
constants for 3GPP AAC psychoacoustic model More... | |
#define | PSY_3GPP_THR_SPREAD_LOW 3.0f |
#define | PSY_3GPP_EN_SPREAD_HI_L1 2.0f |
#define | PSY_3GPP_EN_SPREAD_HI_L2 1.5f |
#define | PSY_3GPP_EN_SPREAD_HI_S 1.5f |
#define | PSY_3GPP_EN_SPREAD_LOW_L 3.0f |
#define | PSY_3GPP_EN_SPREAD_LOW_S 2.0f |
#define | PSY_3GPP_RPEMIN 0.01f |
#define | PSY_3GPP_RPELEV 2.0f |
#define | PSY_3GPP_C1 3.0f /* log2(8) */ |
#define | PSY_3GPP_C2 1.3219281f /* log2(2.5) */ |
#define | PSY_3GPP_C3 0.55935729f /* 1 - C2 / C1 */ |
#define | PSY_SNR_1DB 7.9432821e-1f /* -1dB */ |
#define | PSY_SNR_25DB 3.1622776e-3f /* -25dB */ |
#define | PSY_3GPP_SAVE_SLOPE_L -0.46666667f |
#define | PSY_3GPP_SAVE_SLOPE_S -0.36363637f |
#define | PSY_3GPP_SAVE_ADD_L -0.84285712f |
#define | PSY_3GPP_SAVE_ADD_S -0.75f |
#define | PSY_3GPP_SPEND_SLOPE_L 0.66666669f |
#define | PSY_3GPP_SPEND_SLOPE_S 0.81818181f |
#define | PSY_3GPP_SPEND_ADD_L -0.35f |
#define | PSY_3GPP_SPEND_ADD_S -0.26111111f |
#define | PSY_3GPP_CLIP_LO_L 0.2f |
#define | PSY_3GPP_CLIP_LO_S 0.2f |
#define | PSY_3GPP_CLIP_HI_L 0.95f |
#define | PSY_3GPP_CLIP_HI_S 0.75f |
#define | PSY_3GPP_AH_THR_LONG 0.5f |
#define | PSY_3GPP_AH_THR_SHORT 0.63f |
#define | PSY_PE_FORGET_SLOPE 511 |
#define | PSY_3GPP_BITS_TO_PE(bits) ((bits) * 1.18f) |
#define | PSY_3GPP_PE_TO_BITS(bits) ((bits) / 1.18f) |
#define | PSY_LAME_FIR_LEN 21 |
LAME psy model FIR order. More... | |
#define | AAC_BLOCK_SIZE_LONG 1024 |
long block size More... | |
#define | AAC_BLOCK_SIZE_SHORT 128 |
short block size More... | |
#define | AAC_NUM_BLOCKS_SHORT 8 |
number of blocks in a short sequence More... | |
#define | PSY_LAME_NUM_SUBBLOCKS 3 |
Number of sub-blocks in each short block. More... | |
enum | { PSY_3GPP_AH_NONE, PSY_3GPP_AH_INACTIVE, PSY_3GPP_AH_ACTIVE } |
AAC encoder psychoacoustic model.
Definition in file aacpsy.c.
#define PSY_3GPP_THR_SPREAD_HI 1.5f |
constants for 3GPP AAC psychoacoustic model
Definition at line 44 of file aacpsy.c.
Referenced by psy_3gpp_init().
#define PSY_3GPP_THR_SPREAD_LOW 3.0f |
Definition at line 45 of file aacpsy.c.
Referenced by psy_3gpp_init().
#define PSY_3GPP_EN_SPREAD_HI_L1 2.0f |
Definition at line 47 of file aacpsy.c.
Referenced by psy_3gpp_init().
#define PSY_3GPP_EN_SPREAD_HI_S 1.5f |
Definition at line 51 of file aacpsy.c.
Referenced by psy_3gpp_init().
#define PSY_3GPP_EN_SPREAD_LOW_L 3.0f |
Definition at line 53 of file aacpsy.c.
Referenced by psy_3gpp_init().
#define PSY_3GPP_EN_SPREAD_LOW_S 2.0f |
Definition at line 55 of file aacpsy.c.
Referenced by psy_3gpp_init().
#define PSY_3GPP_C1 3.0f /* log2(8) */ |
Definition at line 60 of file aacpsy.c.
Referenced by calc_pe_3gpp().
#define PSY_3GPP_C2 1.3219281f /* log2(2.5) */ |
Definition at line 61 of file aacpsy.c.
Referenced by calc_pe_3gpp().
#define PSY_3GPP_C3 0.55935729f /* 1 - C2 / C1 */ |
Definition at line 62 of file aacpsy.c.
Referenced by calc_pe_3gpp().
#define PSY_SNR_1DB 7.9432821e-1f /* -1dB */ |
Definition at line 64 of file aacpsy.c.
Referenced by psy_3gpp_init().
#define PSY_SNR_25DB 3.1622776e-3f /* -25dB */ |
Definition at line 65 of file aacpsy.c.
Referenced by psy_3gpp_init().
#define PSY_3GPP_SAVE_SLOPE_L -0.46666667f |
Definition at line 67 of file aacpsy.c.
Referenced by calc_bit_demand().
#define PSY_3GPP_SAVE_SLOPE_S -0.36363637f |
Definition at line 68 of file aacpsy.c.
Referenced by calc_bit_demand().
#define PSY_3GPP_SAVE_ADD_L -0.84285712f |
Definition at line 69 of file aacpsy.c.
Referenced by calc_bit_demand().
#define PSY_3GPP_SAVE_ADD_S -0.75f |
Definition at line 70 of file aacpsy.c.
Referenced by calc_bit_demand().
#define PSY_3GPP_SPEND_SLOPE_L 0.66666669f |
Definition at line 71 of file aacpsy.c.
Referenced by calc_bit_demand().
#define PSY_3GPP_SPEND_SLOPE_S 0.81818181f |
Definition at line 72 of file aacpsy.c.
Referenced by calc_bit_demand().
#define PSY_3GPP_SPEND_ADD_L -0.35f |
Definition at line 73 of file aacpsy.c.
Referenced by calc_bit_demand().
#define PSY_3GPP_SPEND_ADD_S -0.26111111f |
Definition at line 74 of file aacpsy.c.
Referenced by calc_bit_demand().
#define PSY_3GPP_CLIP_LO_L 0.2f |
Definition at line 75 of file aacpsy.c.
Referenced by calc_bit_demand().
#define PSY_3GPP_CLIP_LO_S 0.2f |
Definition at line 76 of file aacpsy.c.
Referenced by calc_bit_demand().
#define PSY_3GPP_CLIP_HI_L 0.95f |
Definition at line 77 of file aacpsy.c.
Referenced by calc_bit_demand().
#define PSY_3GPP_CLIP_HI_S 0.75f |
Definition at line 78 of file aacpsy.c.
Referenced by calc_bit_demand().
#define PSY_PE_FORGET_SLOPE 511 |
Definition at line 83 of file aacpsy.c.
Referenced by calc_bit_demand().
#define PSY_3GPP_BITS_TO_PE | ( | bits | ) | ((bits) * 1.18f) |
Definition at line 91 of file aacpsy.c.
Referenced by psy_3gpp_init().
#define PSY_LAME_FIR_LEN 21 |
#define AAC_BLOCK_SIZE_LONG 1024 |
long block size
Definition at line 96 of file aacpsy.c.
Referenced by psy_3gpp_init(), and psy_hp_filter().
#define AAC_NUM_BLOCKS_SHORT 8 |
number of blocks in a short sequence
Definition at line 98 of file aacpsy.c.
Referenced by lame_window_init(), and psy_lame_window().
#define PSY_LAME_NUM_SUBBLOCKS 3 |
Number of sub-blocks in each short block.
Definition at line 99 of file aacpsy.c.
Referenced by lame_window_init().
#define ATH_ADD 4 |
Definition at line 287 of file aacpsy.c.
Referenced by psy_3gpp_init().
anonymous enum |
|
static |
Calculate the ABR attack threshold from the above LAME psymodel table.
Definition at line 232 of file aacpsy.c.
Referenced by lame_window_init().
|
static |
LAME psy model specific initialization.
Definition at line 262 of file aacpsy.c.
Referenced by psy_3gpp_init().
|
static |
Calculate Bark value for given line.
Definition at line 282 of file aacpsy.c.
Referenced by psy_3gpp_init().
|
static |
Calculate ATH value for given frequency.
Borrowed from Lame.
Definition at line 292 of file aacpsy.c.
Referenced by psy_3gpp_init().
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
Calculate band thresholds as suggested in 3GPP TS26.403.
Definition at line 649 of file aacpsy.c.
Referenced by psy_3gpp_analyze().
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
|
static |
const FFPsyModel ff_aac_psy_model |
Definition at line 1018 of file aacpsy.c.
Referenced by ff_psy_init().