| FFmpeg
    | 
Go to the source code of this file.
| Data Structures | |
| struct | AC3BitAllocParameters | 
| Macros | |
| #define | USE_FIXED 0 | 
| #define | FIXR(x) ((float)(x)) | 
| #define | FIXR12(x) ((float)(x)) | 
| #define | FIXR15(x) ((float)(x)) | 
| #define | ROUND15(x) (x) | 
| #define | AC3_RENAME(x) x | 
| #define | AC3_NORM(norm) (1.0f/(norm)) | 
| #define | AC3_MUL(a, b) ((a) * (b)) | 
| #define | AC3_RANGE(x) (dynamic_range_tab[(x)]) | 
| #define | AC3_HEAVY_RANGE(x) (ff_ac3_heavy_dynamic_range_tab[(x)]) | 
| #define | AC3_DYNAMIC_RANGE(x) (powf(x, s->drc_scale)) | 
| #define | AC3_SPX_BLEND(x) (x)* (1.0f/32) | 
| #define | AC3_DYNAMIC_RANGE1 1.0f | 
| #define | AC3_LEVEL(x) ROUND15((x) * FIXR15(M_SQRT1_2)) | 
| Typedefs | |
| typedef float | INTFLOAT | 
| typedef float | UINTFLOAT | 
| typedef float | SHORTFLOAT | 
| Functions | |
| void | ff_ac3_bit_alloc_calc_psd (int8_t *exp, int start, int end, int16_t *psd, int16_t *band_psd) | 
| Calculate the log power-spectral density of the input signal.  More... | |
| int | ff_ac3_bit_alloc_calc_mask (AC3BitAllocParameters *s, int16_t *band_psd, int start, int end, int fast_gain, int is_lfe, int dba_mode, int dba_nsegs, uint8_t *dba_offsets, uint8_t *dba_lengths, uint8_t *dba_values, int16_t *mask) | 
| Calculate the masking curve.  More... | |
Common code between the AC-3 encoder and decoder.
Definition in file ac3.h.
| #define AC3_RANGE | ( | x | ) | (dynamic_range_tab[(x)]) | 
| #define AC3_HEAVY_RANGE | ( | x | ) | (ff_ac3_heavy_dynamic_range_tab[(x)]) | 
| typedef float SHORTFLOAT | 
| void ff_ac3_bit_alloc_calc_psd | ( | int8_t * | exp, | 
| int | start, | ||
| int | end, | ||
| int16_t * | psd, | ||
| int16_t * | band_psd | ||
| ) | 
Calculate the log power-spectral density of the input signal.
This gives a rough estimate of signal power in the frequency domain by using the spectral envelope (exponents). The psd is also separately grouped into critical bands for use in the calculating the masking curve. 128 units in psd = -6 dB. The dbknee parameter in AC3BitAllocParameters determines the reference level.
| [in] | exp | frequency coefficient exponents | 
| [in] | start | starting bin location | 
| [in] | end | ending bin location | 
| [out] | psd | signal power for each frequency bin | 
| [out] | band_psd | signal power for each critical band | 
Definition at line 175 of file ac3.c.
Referenced by bit_alloc_masking(), and decode_audio_block().
| int ff_ac3_bit_alloc_calc_mask | ( | AC3BitAllocParameters * | s, | 
| int16_t * | band_psd, | ||
| int | start, | ||
| int | end, | ||
| int | fast_gain, | ||
| int | is_lfe, | ||
| int | dba_mode, | ||
| int | dba_nsegs, | ||
| uint8_t * | dba_offsets, | ||
| uint8_t * | dba_lengths, | ||
| uint8_t * | dba_values, | ||
| int16_t * | mask | ||
| ) | 
Calculate the masking curve.
First, the excitation is calculated using parameters in s and the signal power in each critical band. The excitation is compared with a predefined hearing threshold table to produce the masking curve. If delta bit allocation information is provided, it is used for adjusting the masking curve, usually to give a closer match to a better psychoacoustic model.
| [in] | s | adjustable bit allocation parameters | 
| [in] | band_psd | signal power for each critical band | 
| [in] | start | starting bin location | 
| [in] | end | ending bin location | 
| [in] | fast_gain | fast gain (estimated signal-to-mask ratio) | 
| [in] | is_lfe | whether or not the channel being processed is the LFE | 
| [in] | dba_mode | delta bit allocation mode (none, reuse, or new) | 
| [in] | dba_nsegs | number of delta segments | 
| [in] | dba_offsets | location offsets for each segment | 
| [in] | dba_lengths | length of each segment | 
| [in] | dba_values | delta bit allocation for each segment | 
| [out] | mask | calculated masking curve | 
Definition at line 201 of file ac3.c.
Referenced by bit_alloc_masking(), and decode_audio_block().
 1.8.17
 1.8.17