84 #include <speex/speex.h>
85 #include <speex/speex_header.h>
86 #include <speex/speex_stereo.h>
114 const char *mode_str =
"unknown";
118 case SPEEX_MODEID_NB: mode_str =
"narrowband";
break;
119 case SPEEX_MODEID_WB: mode_str =
"wideband";
break;
120 case SPEEX_MODEID_UWB: mode_str =
"ultra-wideband";
break;
148 const SpeexMode *
mode;
156 "mono are supported\n", avctx->
channels);
162 case 8000: mode = &speex_nb_mode;
break;
163 case 16000: mode = &speex_wb_mode;
break;
164 case 32000: mode = &speex_uwb_mode;
break;
167 "Resample to 8, 16, or 32 kHz.\n", avctx->
sample_rate);
193 speex_encoder_ctl(s->
enc_state, SPEEX_SET_ABR,
195 speex_encoder_ctl(s->
enc_state, SPEEX_GET_ABR,
198 speex_encoder_ctl(s->
enc_state, SPEEX_SET_BITRATE,
200 speex_encoder_ctl(s->
enc_state, SPEEX_GET_BITRATE,
205 speex_encoder_ctl(s->
enc_state, SPEEX_SET_QUALITY,
207 speex_encoder_ctl(s->
enc_state, SPEEX_GET_BITRATE,
217 speex_encoder_ctl(s->
enc_state, SPEEX_SET_VAD, &s->
vad);
221 speex_encoder_ctl(s->
enc_state, SPEEX_SET_DTX, &s->
dtx);
229 speex_encoder_ctl(s->
enc_state, SPEEX_SET_COMPLEXITY, &complexity);
231 speex_encoder_ctl(s->
enc_state, SPEEX_GET_COMPLEXITY, &complexity);
245 header_data = speex_header_to_packet(&s->
header, &header_size);
250 speex_header_free(header_data);
257 memcpy(avctx->
extradata, header_data, header_size);
259 speex_header_free(header_data);
262 speex_bits_init(&s->
bits);
272 int16_t *samples = frame ? (int16_t *)frame->
data[0] :
NULL;
278 speex_encode_stereo_int(samples, s->
header.frame_size, &s->
bits);
289 speex_bits_pack(&s->
bits, 15, 5);
300 speex_bits_reset(&s->
bits);
317 speex_bits_destroy(&s->
bits);
326 #define OFFSET(x) offsetof(LibSpeexEncContext, x)
327 #define AE AV_OPT_FLAG_AUDIO_PARAM | AV_OPT_FLAG_ENCODING_PARAM
330 {
"cbr_quality",
"Set quality value (0 to 10) for CBR",
OFFSET(cbr_quality),
AV_OPT_TYPE_INT, { .i64 = 8 }, 0, 10,
AE },
331 {
"frames_per_packet",
"Number of frames to encode in each packet",
OFFSET(frames_per_packet),
AV_OPT_TYPE_INT, { .i64 = 1 }, 1, 8,
AE },
346 {
"compression_level",
"3" },
365 .supported_samplerates = (
const int[]){ 8000, 16000, 32000, 0 },
int pkt_frame_count
frame count for the current packet
int ff_alloc_packet2(AVCodecContext *avctx, AVPacket *avpkt, int64_t size)
Check AVPacket size and/or allocate data.
#define FF_COMPRESSION_DEFAULT
static av_cold int encode_init(AVCodecContext *avctx)
This structure describes decoded (raw) audio or video data.
static int encode_frame(AVCodecContext *avctx, AVPacket *avpkt, const AVFrame *frame, int *got_packet_ptr)
#define AV_LOG_WARNING
Something somehow does not look correct.
#define LIBAVUTIL_VERSION_INT
static av_cold int init(AVCodecContext *avctx)
int cbr_quality
CBR quality 0 to 10.
int vad
flag to enable VAD
SpeexBits bits
libspeex bitwriter context
static av_cold int encode_close(AVCodecContext *avctx)
#define AV_CH_LAYOUT_STEREO
int dtx
flag to enable DTX
const char * class_name
The name of the class; usually it is the same name as the context structure type to which the AVClass...
AudioFrameQueue afq
frame queue
av_cold void ff_af_queue_init(AVCodecContext *avctx, AudioFrameQueue *afq)
Initialize AudioFrameQueue.
uint8_t * extradata
some codecs need / can use extradata like Huffman tables.
AVCodec ff_libspeex_encoder
int duration
Duration of this packet in AVStream->time_base units, 0 if unknown.
int frames_per_packet
number of frames to encode in each packet
#define AV_LOG_ERROR
Something went wrong and cannot losslessly be recovered.
static const AVCodecDefault defaults[]
#define CODEC_CAP_DELAY
Encoder or decoder requires flushing with NULL input at the end in order to give the complete and cor...
#define NULL_IF_CONFIG_SMALL(x)
Return NULL if CONFIG_SMALL is true, otherwise the argument without modification. ...
int initial_padding
Audio only.
#define AV_LOG_DEBUG
Stuff which is only useful for libav* developers.
#define CODEC_FLAG_QSCALE
Use fixed qscale.
const char * name
Name of the codec implementation.
int ff_af_queue_add(AudioFrameQueue *afq, const AVFrame *f)
Add a frame to the queue.
Libavcodec external API header.
#define FF_INPUT_BUFFER_PADDING_SIZE
Required number of additionally allocated bytes at the end of the input bitstream for decoding...
int bit_rate
the average bitrate
audio channel layout utility functions
static const AVClass speex_class
int frame_size
Number of samples per channel in an audio frame.
void * enc_state
libspeex encoder state
AVSampleFormat
Audio sample formats.
int sample_rate
samples per second
main external API structure.
Describe the class of an AVClass context structure.
int global_quality
Global quality for codecs which cannot change it per frame.
uint8_t * data[AV_NUM_DATA_POINTERS]
pointer to the picture/channel planes.
common internal api header.
common internal and external API header
static av_cold void print_enc_params(AVCodecContext *avctx, LibSpeexEncContext *s)
SpeexHeader header
libspeex header struct
static const AVOption options[]
void ff_af_queue_remove(AudioFrameQueue *afq, int nb_samples, int64_t *pts, int *duration)
Remove frame(s) from the queue.
int channels
number of audio channels
int abr
flag to enable ABR
#define FF_QP2LAMBDA
factor to convert from H.263 QP to lambda
void ff_af_queue_close(AudioFrameQueue *afq)
Close AudioFrameQueue.
static enum AVSampleFormat sample_fmts[]
float vbr_quality
VBR quality 0.0 to 10.0.
#define AV_CH_LAYOUT_MONO
This structure stores compressed data.
int64_t pts
Presentation timestamp in AVStream->time_base units; the time at which the decompressed packet will b...