psymodel.h File Reference
#include "avcodec.h"
Include dependency graph for psymodel.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Data Structures

struct  FFPsyBand
 single band psychoacoustic information More...
 
struct  FFPsyChannel
 single channel psychoacoustic information More...
 
struct  FFPsyChannelGroup
 psychoacoustic information for an arbitrary group of channels More...
 
struct  FFPsyWindowInfo
 windowing related information More...
 
struct  FFPsyContext
 context used by psychoacoustic model More...
 
struct  FFPsyModel
 codec-specific psychoacoustic model implementation More...
 

Macros

#define PSY_MAX_BANDS   128
 maximum possible number of bands More...
 
#define PSY_MAX_CHANS   20
 maximum number of channels More...
 
#define AAC_CUTOFF(s)   (s->bit_rate ? FFMIN3(4000 + s->bit_rate/8, 12000 + s->bit_rate/32, s->sample_rate / 2) : (s->sample_rate / 2))
 

Typedefs

typedef struct FFPsyBand FFPsyBand
 single band psychoacoustic information More...
 
typedef struct FFPsyChannel FFPsyChannel
 single channel psychoacoustic information More...
 
typedef struct FFPsyChannelGroup FFPsyChannelGroup
 psychoacoustic information for an arbitrary group of channels More...
 
typedef struct FFPsyWindowInfo FFPsyWindowInfo
 windowing related information More...
 
typedef struct FFPsyContext FFPsyContext
 context used by psychoacoustic model More...
 
typedef struct FFPsyModel FFPsyModel
 codec-specific psychoacoustic model implementation More...
 

Functions

int ff_psy_init (FFPsyContext *ctx, AVCodecContext *avctx, int num_lens, const uint8_t **bands, const int *num_bands, int num_groups, const uint8_t *group_map)
 Initialize psychoacoustic model. More...
 
FFPsyChannelGroupff_psy_find_group (FFPsyContext *ctx, int channel)
 Determine what group a channel belongs to. More...
 
void ff_psy_end (FFPsyContext *ctx)
 Cleanup model context at the end. More...
 
struct FFPsyPreprocessContextff_psy_preprocess_init (AVCodecContext *avctx)
 psychoacoustic model audio preprocessing initialization More...
 
void ff_psy_preprocess (struct FFPsyPreprocessContext *ctx, float **audio, int channels)
 Preprocess several channel in audio frame in order to compress it better. More...
 
void ff_psy_preprocess_end (struct FFPsyPreprocessContext *ctx)
 Cleanup audio preprocessing module. More...
 

Macro Definition Documentation

#define AAC_CUTOFF (   s)    (s->bit_rate ? FFMIN3(4000 + s->bit_rate/8, 12000 + s->bit_rate/32, s->sample_rate / 2) : (s->sample_rate / 2))

Definition at line 32 of file psymodel.h.

Referenced by ff_psy_preprocess_init(), and psy_3gpp_init().

#define PSY_MAX_BANDS   128

maximum possible number of bands

Definition at line 28 of file psymodel.h.

#define PSY_MAX_CHANS   20

maximum number of channels

Definition at line 30 of file psymodel.h.

Typedef Documentation

typedef struct FFPsyBand FFPsyBand

single band psychoacoustic information

typedef struct FFPsyChannel FFPsyChannel

single channel psychoacoustic information

psychoacoustic information for an arbitrary group of channels

typedef struct FFPsyContext FFPsyContext

context used by psychoacoustic model

typedef struct FFPsyModel FFPsyModel

codec-specific psychoacoustic model implementation

windowing related information

Function Documentation

void ff_psy_end ( FFPsyContext ctx)

Cleanup model context at the end.

Parameters
ctxmodel context

Definition at line 76 of file psymodel.c.

Referenced by aac_encode_end().

FFPsyChannelGroup* ff_psy_find_group ( FFPsyContext ctx,
int  channel 
)

Determine what group a channel belongs to.

Parameters
ctxpsymodel context
channelchannel to locate the group for
Returns
pointer to the FFPsyChannelGroup this channel belongs to

Definition at line 66 of file psymodel.c.

Referenced by psy_3gpp_analyze().

int ff_psy_init ( FFPsyContext ctx,
AVCodecContext avctx,
int  num_lens,
const uint8_t **  bands,
const int *  num_bands,
int  num_groups,
const uint8_t group_map 
)

Initialize psychoacoustic model.

Parameters
ctxmodel context
avctxcodec context
num_lensnumber of possible frame lengths
bandsscalefactor band lengths for all frame lengths
num_bandsnumber of scalefactor bands for all frame lengths
num_groupsnumber of channel groups
group_maparray with # of channels in group - 1, for each group
Returns
zero if successful, a negative value if not

Definition at line 31 of file psymodel.c.

Referenced by aac_encode_init().

void ff_psy_preprocess ( struct FFPsyPreprocessContext ctx,
float **  audio,
int  channels 
)

Preprocess several channel in audio frame in order to compress it better.

Parameters
ctxpreprocessing context
audiosamples to be filtered (in place)
channelsnumber of channel to preprocess

Definition at line 125 of file psymodel.c.

Referenced by aac_encode_frame().

void ff_psy_preprocess_end ( struct FFPsyPreprocessContext ctx)

Cleanup audio preprocessing module.

Definition at line 138 of file psymodel.c.

Referenced by aac_encode_end().

struct FFPsyPreprocessContext* ff_psy_preprocess_init ( AVCodecContext avctx)

psychoacoustic model audio preprocessing initialization

Definition at line 96 of file psymodel.c.

Referenced by aac_encode_init().