FFmpeg
opusenc_psy.h
Go to the documentation of this file.
1 /*
2  * Opus encoder
3  * Copyright (c) 2017 Rostislav Pehlivanov <atomnuker@gmail.com>
4  *
5  * This file is part of FFmpeg.
6  *
7  * FFmpeg is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Lesser General Public
9  * License as published by the Free Software Foundation; either
10  * version 2.1 of the License, or (at your option) any later version.
11  *
12  * FFmpeg is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15  * Lesser General Public License for more details.
16  *
17  * You should have received a copy of the GNU Lesser General Public
18  * License along with FFmpeg; if not, write to the Free Software
19  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20  */
21 
22 #ifndef AVCODEC_OPUSENC_PSY_H
23 #define AVCODEC_OPUSENC_PSY_H
24 
25 #include "opusenc.h"
26 #include "opusenc_utils.h"
28 
29 /* Each step is 2.5ms */
30 typedef struct OpusPsyStep {
31  int index; /* Current index */
32  int silence;
33  float energy[OPUS_MAX_CHANNELS][CELT_MAX_BANDS]; /* Masking effects included */
34  float tone[OPUS_MAX_CHANNELS][CELT_MAX_BANDS]; /* Tonality */
35  float stereo[CELT_MAX_BANDS]; /* IS/MS compatibility */
36  float change_amp[OPUS_MAX_CHANNELS][CELT_MAX_BANDS]; /* Jump over last frame */
37  float total_change; /* Total change */
38 
41 } OpusPsyStep;
42 
43 typedef struct OpusBandExcitation {
44  float excitation;
48 
49 typedef struct PsyChain {
50  int start;
51  int end;
52 } PsyChain;
53 
54 typedef struct OpusPsyContext {
59 
60  PsyChain cs[128];
61  int cs_num;
62 
66 
68  int max_steps;
69 
73 
74  DECLARE_ALIGNED(32, float, scratch)[2048];
75 
76  /* Stats */
77  float rc_waste;
78  float avg_is_band;
81 
82  /* State */
88  int eof;
89  float lambda;
93 
98 
100  struct FFBufQueue *bufqueue, OpusEncOptions *options);
103 
104 #endif /* AVCODEC_OPUSENC_PSY_H */
OpusPsyStep::stereo
float stereo[CELT_MAX_BANDS]
Definition: opusenc_psy.h:35
OpusPsyContext::buffered_steps
int buffered_steps
Definition: opusenc_psy.h:86
OpusBandExcitation::excitation
float excitation
Definition: opusenc_psy.h:44
OpusPsyContext::bsize_analysis
int bsize_analysis
Definition: opusenc_psy.h:72
PsyChain
Definition: opusenc_psy.h:49
OpusBandExcitation::excitation_init
float excitation_init
Definition: opusenc_psy.h:46
FF_BUFQUEUE_SIZE
#define FF_BUFQUEUE_SIZE
Definition: audiotoolboxenc.c:25
ff_opus_psy_init
int ff_opus_psy_init(OpusPsyContext *s, AVCodecContext *avctx, struct FFBufQueue *bufqueue, OpusEncOptions *options)
Definition: opusenc_psy.c:516
ff_opus_psy_end
int ff_opus_psy_end(OpusPsyContext *s)
Definition: opusenc_psy.c:593
OpusPsyStep::silence
int silence
Definition: opusenc_psy.h:32
CELT_BLOCK_960
@ CELT_BLOCK_960
Definition: opus_celt.h:60
OpusPsyStep::coeffs
float coeffs[OPUS_MAX_CHANNELS][OPUS_BLOCK_SIZE(CELT_BLOCK_960)]
Definition: opusenc_psy.h:40
OpusPsyContext::steps
OpusPsyStep * steps[FF_BUFQUEUE_SIZE+1]
Definition: opusenc_psy.h:67
OpusPsyContext::lambda
float lambda
Definition: opusenc_psy.h:89
OpusPsyContext::bfilter_lo
FFBesselFilter bfilter_lo[OPUS_MAX_CHANNELS][CELT_MAX_BANDS]
Definition: opusenc_psy.h:64
PsyChain::end
int end
Definition: opusenc_psy.h:51
ff_opus_psy_signal_eof
void ff_opus_psy_signal_eof(OpusPsyContext *s)
Definition: opusenc_psy.c:588
OpusPsyContext::avctx
AVCodecContext * avctx
Definition: opusenc_psy.h:55
OpusPsyStep::change_amp
float change_amp[OPUS_MAX_CHANNELS][CELT_MAX_BANDS]
Definition: opusenc_psy.h:36
OpusPsyContext::lambda_lp
FFBesselFilter lambda_lp
Definition: opusenc_psy.h:83
OpusPsyContext::ex
OpusBandExcitation ex[OPUS_MAX_CHANNELS][CELT_MAX_BANDS]
Definition: opusenc_psy.h:63
ff_opus_psy_celt_frame_process
int ff_opus_psy_celt_frame_process(OpusPsyContext *s, CeltFrame *f, int index)
Definition: opusenc_psy.c:455
OPUS_BLOCK_SIZE
#define OPUS_BLOCK_SIZE(x)
Definition: opusenc.h:39
OpusPsyContext::steps_to_process
int steps_to_process
Definition: opusenc_psy.h:87
ff_opus_psy_postencode_update
void ff_opus_psy_postencode_update(OpusPsyContext *s, CeltFrame *f, OpusRangeCoder *rc)
Definition: opusenc_psy.c:479
OpusPsyStep
Definition: opusenc_psy.h:30
s
#define s(width, name)
Definition: cbs_vp9.c:257
MDCT15Context
Definition: mdct15.h:28
f
#define f(width, name)
Definition: cbs_vp9.c:255
OpusPsyContext
Definition: opusenc_psy.h:54
OpusBandExcitation::excitation_dist
float excitation_dist
Definition: opusenc_psy.h:45
OpusPacketInfo
Definition: opusenc.h:48
opusenc.h
OpusPsyStep::total_change
float total_change
Definition: opusenc_psy.h:37
OpusPsyContext::dual_stereo_used
int64_t dual_stereo_used
Definition: opusenc_psy.h:79
CELT_MAX_BANDS
#define CELT_MAX_BANDS
Definition: opus.h:45
OpusPsyContext::inflection_points
int * inflection_points
Definition: opusenc_psy.h:90
index
int index
Definition: gxfenc.c:89
options
const OptionDef options[]
OpusPsyContext::max_steps
int max_steps
Definition: opusenc_psy.h:68
OpusPsyStep::bands
float * bands[OPUS_MAX_CHANNELS][CELT_MAX_BANDS]
Definition: opusenc_psy.h:39
OpusPsyStep::index
int index
Definition: opusenc_psy.h:31
OpusPsyContext::redo_analysis
int redo_analysis
Definition: opusenc_psy.h:85
OpusPsyContext::dsp
AVFloatDSPContext * dsp
Definition: opusenc_psy.h:56
OpusPsyStep::tone
float tone[OPUS_MAX_CHANNELS][CELT_MAX_BANDS]
Definition: opusenc_psy.h:34
OpusRangeCoder
Definition: opus_rc.h:40
AVFloatDSPContext
Definition: float_dsp.h:24
OpusPsyContext::eof
int eof
Definition: opusenc_psy.h:88
OpusPsyContext::avg_is_band
float avg_is_band
Definition: opusenc_psy.h:78
DECLARE_ALIGNED
#define DECLARE_ALIGNED(n, t, v)
Definition: mem.h:112
FFBufQueue
Structure holding the queue.
Definition: bufferqueue.h:49
OpusPsyContext::cs_num
int cs_num
Definition: opusenc_psy.h:61
ff_opus_psy_process
int ff_opus_psy_process(OpusPsyContext *s, OpusPacketInfo *p)
Definition: opusenc_psy.c:223
OPUS_MAX_CHANNELS
#define OPUS_MAX_CHANNELS
Definition: opusenc.h:34
OpusPsyStep::energy
float energy[OPUS_MAX_CHANNELS][CELT_MAX_BANDS]
Definition: opusenc_psy.h:33
FFBesselFilter
Definition: opusenc_utils.h:27
OpusPsyContext::inflection_points_count
int inflection_points_count
Definition: opusenc_psy.h:91
OpusPsyContext::bfilter_hi
FFBesselFilter bfilter_hi[OPUS_MAX_CHANNELS][CELT_MAX_BANDS]
Definition: opusenc_psy.h:65
OpusPsyContext::mdct
MDCT15Context * mdct[CELT_BLOCK_NB]
Definition: opusenc_psy.h:71
OpusPsyContext::total_packets_out
int64_t total_packets_out
Definition: opusenc_psy.h:80
OpusPsyContext::rc_waste
float rc_waste
Definition: opusenc_psy.h:77
window_func.h
OpusPsyContext::cs
PsyChain cs[128]
Definition: opusenc_psy.h:60
AVCodecContext
main external API structure.
Definition: avcodec.h:526
OpusPsyContext::p
OpusPacketInfo p
Definition: opusenc_psy.h:84
OpusBandExcitation
Definition: opusenc_psy.h:43
opusenc_utils.h
PsyChain::start
int start
Definition: opusenc_psy.h:50
OpusPsyContext::options
OpusEncOptions * options
Definition: opusenc_psy.h:58
OpusEncOptions
Definition: opusenc.h:43
CELT_BLOCK_NB
@ CELT_BLOCK_NB
Definition: opus_celt.h:62
OpusPsyContext::bufqueue
struct FFBufQueue * bufqueue
Definition: opusenc_psy.h:57
OpusPsyContext::scratch
float scratch[2048]
Definition: opusenc_psy.h:74
ff_opus_psy_celt_frame_init
void ff_opus_psy_celt_frame_init(OpusPsyContext *s, CeltFrame *f, int index)
Definition: opusenc_psy.c:254
OpusPsyContext::window
float * window[CELT_BLOCK_NB]
Definition: opusenc_psy.h:70
CeltFrame
Definition: opus_celt.h:92