Add AVCodecContext.lpc_type and Add AVCodecContext.lpc_passes fields.
Add AVLPCType enum. Deprecate AVCodecContext.use_lpc. Originally committed as revision 24199 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
31769dad7d
commit
23940f1405
@ -12,6 +12,11 @@ libavutil: 2009-03-08
|
|||||||
|
|
||||||
API changes, most recent first:
|
API changes, most recent first:
|
||||||
|
|
||||||
|
2010-07-11 - r????? - lavc 52.83.0
|
||||||
|
Add AVCodecContext.lpc_type and Add AVCodecContext.lpc_passes fields.
|
||||||
|
Add AVLPCType enum.
|
||||||
|
Deprecate AVCodecContext.use_lpc.
|
||||||
|
|
||||||
2010-07-11 - r24185 - lavc 52.82.0 - avsubtitle_free()
|
2010-07-11 - r24185 - lavc 52.82.0 - avsubtitle_free()
|
||||||
Add a function for free the contents of a AVSubtitle generated by
|
Add a function for free the contents of a AVSubtitle generated by
|
||||||
avcodec_decode_subtitle.
|
avcodec_decode_subtitle.
|
||||||
|
@ -145,7 +145,8 @@ static void calc_predictor_params(AlacEncodeContext *s, int ch)
|
|||||||
s->avctx->frame_size,
|
s->avctx->frame_size,
|
||||||
s->min_prediction_order,
|
s->min_prediction_order,
|
||||||
s->max_prediction_order,
|
s->max_prediction_order,
|
||||||
ALAC_MAX_LPC_PRECISION, coefs, shift, 1,
|
ALAC_MAX_LPC_PRECISION, coefs, shift,
|
||||||
|
AV_LPC_TYPE_LEVINSON, 0,
|
||||||
ORDER_METHOD_EST, ALAC_MAX_LPC_SHIFT, 1);
|
ORDER_METHOD_EST, ALAC_MAX_LPC_SHIFT, 1);
|
||||||
|
|
||||||
s->lpc[ch].lpc_order = opt_order;
|
s->lpc[ch].lpc_order = opt_order;
|
||||||
|
@ -30,7 +30,7 @@
|
|||||||
#include "libavutil/avutil.h"
|
#include "libavutil/avutil.h"
|
||||||
|
|
||||||
#define LIBAVCODEC_VERSION_MAJOR 52
|
#define LIBAVCODEC_VERSION_MAJOR 52
|
||||||
#define LIBAVCODEC_VERSION_MINOR 82
|
#define LIBAVCODEC_VERSION_MINOR 83
|
||||||
#define LIBAVCODEC_VERSION_MICRO 0
|
#define LIBAVCODEC_VERSION_MICRO 0
|
||||||
|
|
||||||
#define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \
|
#define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \
|
||||||
@ -526,6 +526,18 @@ enum AVChromaLocation{
|
|||||||
AVCHROMA_LOC_NB , ///< Not part of ABI
|
AVCHROMA_LOC_NB , ///< Not part of ABI
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* LPC analysis type
|
||||||
|
*/
|
||||||
|
enum AVLPCType {
|
||||||
|
AV_LPC_TYPE_DEFAULT = -1, ///< use the codec default LPC type
|
||||||
|
AV_LPC_TYPE_NONE = 0, ///< do not use LPC prediction or use all zero coefficients
|
||||||
|
AV_LPC_TYPE_FIXED = 1, ///< fixed LPC coefficients
|
||||||
|
AV_LPC_TYPE_LEVINSON = 2, ///< Levinson-Durbin recursion
|
||||||
|
AV_LPC_TYPE_CHOLESKY = 3, ///< Cholesky factorization
|
||||||
|
AV_LPC_TYPE_NB , ///< Not part of ABI
|
||||||
|
};
|
||||||
|
|
||||||
typedef struct RcOverride{
|
typedef struct RcOverride{
|
||||||
int start_frame;
|
int start_frame;
|
||||||
int end_frame;
|
int end_frame;
|
||||||
@ -2413,12 +2425,15 @@ typedef struct AVCodecContext {
|
|||||||
int compression_level;
|
int compression_level;
|
||||||
#define FF_COMPRESSION_DEFAULT -1
|
#define FF_COMPRESSION_DEFAULT -1
|
||||||
|
|
||||||
|
#if LIBAVCODEC_VERSION_MAJOR < 53
|
||||||
/**
|
/**
|
||||||
* Sets whether to use LPC mode - used by FLAC encoder.
|
* Sets whether to use LPC mode - used by FLAC encoder.
|
||||||
* - encoding: Set by user.
|
* - encoding: Set by user.
|
||||||
* - decoding: unused
|
* - decoding: unused
|
||||||
|
* @deprecated Deprecated in favor of lpc_type and lpc_passes.
|
||||||
*/
|
*/
|
||||||
int use_lpc;
|
int use_lpc;
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* LPC coefficient precision - used by FLAC encoder
|
* LPC coefficient precision - used by FLAC encoder
|
||||||
@ -2672,6 +2687,20 @@ typedef struct AVCodecContext {
|
|||||||
float crf_max;
|
float crf_max;
|
||||||
|
|
||||||
int log_level_offset;
|
int log_level_offset;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Determines which LPC analysis algorithm to use.
|
||||||
|
* - encoding: Set by user
|
||||||
|
* - decoding: unused
|
||||||
|
*/
|
||||||
|
enum AVLPCType lpc_type;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Number of passes to use for Cholesky factorization during LPC analysis
|
||||||
|
* - encoding: Set by user
|
||||||
|
* - decoding: unused
|
||||||
|
*/
|
||||||
|
int lpc_passes;
|
||||||
} AVCodecContext;
|
} AVCodecContext;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -44,7 +44,8 @@
|
|||||||
typedef struct CompressionOptions {
|
typedef struct CompressionOptions {
|
||||||
int compression_level;
|
int compression_level;
|
||||||
int block_time_ms;
|
int block_time_ms;
|
||||||
int use_lpc;
|
enum AVLPCType lpc_type;
|
||||||
|
int lpc_passes;
|
||||||
int lpc_coeff_precision;
|
int lpc_coeff_precision;
|
||||||
int min_prediction_order;
|
int min_prediction_order;
|
||||||
int max_prediction_order;
|
int max_prediction_order;
|
||||||
@ -208,7 +209,11 @@ static av_cold int flac_encode_init(AVCodecContext *avctx)
|
|||||||
}
|
}
|
||||||
|
|
||||||
s->options.block_time_ms = ((int[]){ 27, 27, 27,105,105,105,105,105,105,105,105,105,105})[level];
|
s->options.block_time_ms = ((int[]){ 27, 27, 27,105,105,105,105,105,105,105,105,105,105})[level];
|
||||||
s->options.use_lpc = ((int[]){ 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1})[level];
|
s->options.lpc_type = ((int[]){ AV_LPC_TYPE_FIXED, AV_LPC_TYPE_FIXED, AV_LPC_TYPE_FIXED,
|
||||||
|
AV_LPC_TYPE_LEVINSON, AV_LPC_TYPE_LEVINSON, AV_LPC_TYPE_LEVINSON,
|
||||||
|
AV_LPC_TYPE_LEVINSON, AV_LPC_TYPE_LEVINSON, AV_LPC_TYPE_LEVINSON,
|
||||||
|
AV_LPC_TYPE_LEVINSON, AV_LPC_TYPE_LEVINSON, AV_LPC_TYPE_LEVINSON,
|
||||||
|
AV_LPC_TYPE_LEVINSON})[level];
|
||||||
s->options.min_prediction_order= ((int[]){ 2, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1})[level];
|
s->options.min_prediction_order= ((int[]){ 2, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1})[level];
|
||||||
s->options.max_prediction_order= ((int[]){ 3, 4, 4, 6, 8, 8, 8, 8, 12, 12, 12, 32, 32})[level];
|
s->options.max_prediction_order= ((int[]){ 3, 4, 4, 6, 8, 8, 8, 8, 12, 12, 12, 32, 32})[level];
|
||||||
s->options.prediction_order_method = ((int[]){ ORDER_METHOD_EST, ORDER_METHOD_EST, ORDER_METHOD_EST,
|
s->options.prediction_order_method = ((int[]){ ORDER_METHOD_EST, ORDER_METHOD_EST, ORDER_METHOD_EST,
|
||||||
@ -220,45 +225,83 @@ static av_cold int flac_encode_init(AVCodecContext *avctx)
|
|||||||
s->options.max_partition_order = ((int[]){ 2, 2, 3, 3, 3, 8, 8, 8, 8, 8, 8, 8, 8})[level];
|
s->options.max_partition_order = ((int[]){ 2, 2, 3, 3, 3, 8, 8, 8, 8, 8, 8, 8, 8})[level];
|
||||||
|
|
||||||
/* set compression option overrides from AVCodecContext */
|
/* set compression option overrides from AVCodecContext */
|
||||||
if(avctx->use_lpc >= 0) {
|
#if LIBAVCODEC_VERSION_MAJOR < 53
|
||||||
s->options.use_lpc = av_clip(avctx->use_lpc, 0, 11);
|
/* for compatibility with deprecated AVCodecContext.use_lpc */
|
||||||
|
if (avctx->use_lpc == 0) {
|
||||||
|
s->options.lpc_type = AV_LPC_TYPE_FIXED;
|
||||||
|
} else if (avctx->use_lpc == 1) {
|
||||||
|
s->options.lpc_type = AV_LPC_TYPE_LEVINSON;
|
||||||
|
} else if (avctx->use_lpc > 1) {
|
||||||
|
s->options.lpc_type = AV_LPC_TYPE_CHOLESKY;
|
||||||
|
s->options.lpc_passes = avctx->use_lpc - 1;
|
||||||
}
|
}
|
||||||
if(s->options.use_lpc == 1)
|
#endif
|
||||||
av_log(avctx, AV_LOG_DEBUG, " use lpc: Levinson-Durbin recursion with Welch window\n");
|
if (avctx->lpc_type > AV_LPC_TYPE_DEFAULT) {
|
||||||
else if(s->options.use_lpc > 1)
|
if (avctx->lpc_type > AV_LPC_TYPE_CHOLESKY) {
|
||||||
av_log(avctx, AV_LOG_DEBUG, " use lpc: Cholesky factorization\n");
|
av_log(avctx, AV_LOG_ERROR, "unknown lpc type: %d\n", avctx->lpc_type);
|
||||||
|
return -1;
|
||||||
if(avctx->min_prediction_order >= 0) {
|
}
|
||||||
if(s->options.use_lpc) {
|
s->options.lpc_type = avctx->lpc_type;
|
||||||
if(avctx->min_prediction_order < MIN_LPC_ORDER ||
|
if (s->options.lpc_type == AV_LPC_TYPE_CHOLESKY) {
|
||||||
avctx->min_prediction_order > MAX_LPC_ORDER) {
|
if (avctx->lpc_passes < 0) {
|
||||||
av_log(avctx, AV_LOG_ERROR, "invalid min prediction order: %d\n",
|
// default number of passes for Cholesky
|
||||||
avctx->min_prediction_order);
|
s->options.lpc_passes = 2;
|
||||||
|
} else if (avctx->lpc_passes == 0) {
|
||||||
|
av_log(avctx, AV_LOG_ERROR, "invalid number of lpc passes: %d\n",
|
||||||
|
avctx->lpc_passes);
|
||||||
return -1;
|
return -1;
|
||||||
|
} else {
|
||||||
|
s->options.lpc_passes = avctx->lpc_passes;
|
||||||
}
|
}
|
||||||
} else {
|
}
|
||||||
|
}
|
||||||
|
switch (s->options.lpc_type) {
|
||||||
|
case AV_LPC_TYPE_NONE:
|
||||||
|
av_log(avctx, AV_LOG_DEBUG, " lpc type: None\n");
|
||||||
|
break;
|
||||||
|
case AV_LPC_TYPE_FIXED:
|
||||||
|
av_log(avctx, AV_LOG_DEBUG, " lpc type: Fixed pre-defined coefficients\n");
|
||||||
|
break;
|
||||||
|
case AV_LPC_TYPE_LEVINSON:
|
||||||
|
av_log(avctx, AV_LOG_DEBUG, " lpc type: Levinson-Durbin recursion with Welch window\n");
|
||||||
|
break;
|
||||||
|
case AV_LPC_TYPE_CHOLESKY:
|
||||||
|
av_log(avctx, AV_LOG_DEBUG, " lpc type: Cholesky factorization, %d pass%s\n",
|
||||||
|
s->options.lpc_passes, s->options.lpc_passes==1?"":"es");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (s->options.lpc_type == AV_LPC_TYPE_NONE) {
|
||||||
|
s->options.min_prediction_order = 0;
|
||||||
|
} else if (avctx->min_prediction_order >= 0) {
|
||||||
|
if (s->options.lpc_type == AV_LPC_TYPE_FIXED) {
|
||||||
if(avctx->min_prediction_order > MAX_FIXED_ORDER) {
|
if(avctx->min_prediction_order > MAX_FIXED_ORDER) {
|
||||||
av_log(avctx, AV_LOG_ERROR, "invalid min prediction order: %d\n",
|
av_log(avctx, AV_LOG_ERROR, "invalid min prediction order: %d\n",
|
||||||
avctx->min_prediction_order);
|
avctx->min_prediction_order);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
} else if(avctx->min_prediction_order < MIN_LPC_ORDER ||
|
||||||
|
avctx->min_prediction_order > MAX_LPC_ORDER) {
|
||||||
|
av_log(avctx, AV_LOG_ERROR, "invalid min prediction order: %d\n",
|
||||||
|
avctx->min_prediction_order);
|
||||||
|
return -1;
|
||||||
}
|
}
|
||||||
s->options.min_prediction_order = avctx->min_prediction_order;
|
s->options.min_prediction_order = avctx->min_prediction_order;
|
||||||
}
|
}
|
||||||
if(avctx->max_prediction_order >= 0) {
|
if (s->options.lpc_type == AV_LPC_TYPE_NONE) {
|
||||||
if(s->options.use_lpc) {
|
s->options.max_prediction_order = 0;
|
||||||
if(avctx->max_prediction_order < MIN_LPC_ORDER ||
|
} else if (avctx->max_prediction_order >= 0) {
|
||||||
avctx->max_prediction_order > MAX_LPC_ORDER) {
|
if (s->options.lpc_type == AV_LPC_TYPE_FIXED) {
|
||||||
av_log(avctx, AV_LOG_ERROR, "invalid max prediction order: %d\n",
|
|
||||||
avctx->max_prediction_order);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if(avctx->max_prediction_order > MAX_FIXED_ORDER) {
|
if(avctx->max_prediction_order > MAX_FIXED_ORDER) {
|
||||||
av_log(avctx, AV_LOG_ERROR, "invalid max prediction order: %d\n",
|
av_log(avctx, AV_LOG_ERROR, "invalid max prediction order: %d\n",
|
||||||
avctx->max_prediction_order);
|
avctx->max_prediction_order);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
} else if (avctx->max_prediction_order < MIN_LPC_ORDER ||
|
||||||
|
avctx->max_prediction_order > MAX_LPC_ORDER) {
|
||||||
|
av_log(avctx, AV_LOG_ERROR, "invalid max prediction order: %d\n",
|
||||||
|
avctx->max_prediction_order);
|
||||||
|
return -1;
|
||||||
}
|
}
|
||||||
s->options.max_prediction_order = avctx->max_prediction_order;
|
s->options.max_prediction_order = avctx->max_prediction_order;
|
||||||
}
|
}
|
||||||
@ -754,7 +797,8 @@ static int encode_residual(FlacEncodeContext *ctx, int ch)
|
|||||||
omethod = ctx->options.prediction_order_method;
|
omethod = ctx->options.prediction_order_method;
|
||||||
|
|
||||||
/* FIXED */
|
/* FIXED */
|
||||||
if(!ctx->options.use_lpc || max_order == 0 || (n <= max_order)) {
|
if (ctx->options.lpc_type == AV_LPC_TYPE_NONE ||
|
||||||
|
ctx->options.lpc_type == AV_LPC_TYPE_FIXED || n <= max_order) {
|
||||||
uint32_t bits[MAX_FIXED_ORDER+1];
|
uint32_t bits[MAX_FIXED_ORDER+1];
|
||||||
if(max_order > MAX_FIXED_ORDER) max_order = MAX_FIXED_ORDER;
|
if(max_order > MAX_FIXED_ORDER) max_order = MAX_FIXED_ORDER;
|
||||||
opt_order = 0;
|
opt_order = 0;
|
||||||
@ -780,8 +824,9 @@ static int encode_residual(FlacEncodeContext *ctx, int ch)
|
|||||||
|
|
||||||
/* LPC */
|
/* LPC */
|
||||||
opt_order = ff_lpc_calc_coefs(&ctx->dsp, smp, n, min_order, max_order,
|
opt_order = ff_lpc_calc_coefs(&ctx->dsp, smp, n, min_order, max_order,
|
||||||
precision, coefs, shift, ctx->options.use_lpc,
|
precision, coefs, shift, ctx->options.lpc_type,
|
||||||
omethod, MAX_LPC_SHIFT, 0);
|
ctx->options.lpc_passes, omethod,
|
||||||
|
MAX_LPC_SHIFT, 0);
|
||||||
|
|
||||||
if(omethod == ORDER_METHOD_2LEVEL ||
|
if(omethod == ORDER_METHOD_2LEVEL ||
|
||||||
omethod == ORDER_METHOD_4LEVEL ||
|
omethod == ORDER_METHOD_4LEVEL ||
|
||||||
|
@ -165,7 +165,8 @@ static int estimate_best_order(double *ref, int min_order, int max_order)
|
|||||||
int ff_lpc_calc_coefs(DSPContext *s,
|
int ff_lpc_calc_coefs(DSPContext *s,
|
||||||
const int32_t *samples, int blocksize, int min_order,
|
const int32_t *samples, int blocksize, int min_order,
|
||||||
int max_order, int precision,
|
int max_order, int precision,
|
||||||
int32_t coefs[][MAX_LPC_ORDER], int *shift, int use_lpc,
|
int32_t coefs[][MAX_LPC_ORDER], int *shift,
|
||||||
|
enum AVLPCType lpc_type, int lpc_passes,
|
||||||
int omethod, int max_shift, int zero_shift)
|
int omethod, int max_shift, int zero_shift)
|
||||||
{
|
{
|
||||||
double autoc[MAX_LPC_ORDER+1];
|
double autoc[MAX_LPC_ORDER+1];
|
||||||
@ -174,20 +175,21 @@ int ff_lpc_calc_coefs(DSPContext *s,
|
|||||||
int i, j, pass;
|
int i, j, pass;
|
||||||
int opt_order;
|
int opt_order;
|
||||||
|
|
||||||
assert(max_order >= MIN_LPC_ORDER && max_order <= MAX_LPC_ORDER && use_lpc > 0);
|
assert(max_order >= MIN_LPC_ORDER && max_order <= MAX_LPC_ORDER &&
|
||||||
|
lpc_type > AV_LPC_TYPE_FIXED);
|
||||||
|
|
||||||
if(use_lpc == 1){
|
if (lpc_type == AV_LPC_TYPE_LEVINSON) {
|
||||||
s->lpc_compute_autocorr(samples, blocksize, max_order, autoc);
|
s->lpc_compute_autocorr(samples, blocksize, max_order, autoc);
|
||||||
|
|
||||||
compute_lpc_coefs(autoc, max_order, &lpc[0][0], MAX_LPC_ORDER, 0, 1);
|
compute_lpc_coefs(autoc, max_order, &lpc[0][0], MAX_LPC_ORDER, 0, 1);
|
||||||
|
|
||||||
for(i=0; i<max_order; i++)
|
for(i=0; i<max_order; i++)
|
||||||
ref[i] = fabs(lpc[i][i]);
|
ref[i] = fabs(lpc[i][i]);
|
||||||
}else{
|
} else if (lpc_type == AV_LPC_TYPE_CHOLESKY) {
|
||||||
LLSModel m[2];
|
LLSModel m[2];
|
||||||
double var[MAX_LPC_ORDER+1], av_uninit(weight);
|
double var[MAX_LPC_ORDER+1], av_uninit(weight);
|
||||||
|
|
||||||
for(pass=0; pass<use_lpc-1; pass++){
|
for(pass=0; pass<lpc_passes; pass++){
|
||||||
av_init_lls(&m[pass&1], max_order);
|
av_init_lls(&m[pass&1], max_order);
|
||||||
|
|
||||||
weight=0;
|
weight=0;
|
||||||
|
@ -42,7 +42,8 @@
|
|||||||
int ff_lpc_calc_coefs(DSPContext *s,
|
int ff_lpc_calc_coefs(DSPContext *s,
|
||||||
const int32_t *samples, int blocksize, int min_order,
|
const int32_t *samples, int blocksize, int min_order,
|
||||||
int max_order, int precision,
|
int max_order, int precision,
|
||||||
int32_t coefs[][MAX_LPC_ORDER], int *shift, int use_lpc,
|
int32_t coefs[][MAX_LPC_ORDER], int *shift,
|
||||||
|
enum AVLPCType lpc_type, int lpc_passes,
|
||||||
int omethod, int max_shift, int zero_shift);
|
int omethod, int max_shift, int zero_shift);
|
||||||
|
|
||||||
void ff_lpc_compute_autocorr(const int32_t *data, int len, int lag,
|
void ff_lpc_compute_autocorr(const int32_t *data, int len, int lag,
|
||||||
|
@ -382,7 +382,9 @@ static const AVOption options[]={
|
|||||||
{"ivlc", "intra vlc table", 0, FF_OPT_TYPE_CONST, CODEC_FLAG2_INTRA_VLC, INT_MIN, INT_MAX, V|E, "flags2"},
|
{"ivlc", "intra vlc table", 0, FF_OPT_TYPE_CONST, CODEC_FLAG2_INTRA_VLC, INT_MIN, INT_MAX, V|E, "flags2"},
|
||||||
{"b_sensitivity", "adjusts sensitivity of b_frame_strategy 1", OFFSET(b_sensitivity), FF_OPT_TYPE_INT, 40, 1, INT_MAX, V|E},
|
{"b_sensitivity", "adjusts sensitivity of b_frame_strategy 1", OFFSET(b_sensitivity), FF_OPT_TYPE_INT, 40, 1, INT_MAX, V|E},
|
||||||
{"compression_level", NULL, OFFSET(compression_level), FF_OPT_TYPE_INT, FF_COMPRESSION_DEFAULT, INT_MIN, INT_MAX, V|A|E},
|
{"compression_level", NULL, OFFSET(compression_level), FF_OPT_TYPE_INT, FF_COMPRESSION_DEFAULT, INT_MIN, INT_MAX, V|A|E},
|
||||||
|
#if LIBAVCODEC_VERSION_MAJOR < 53
|
||||||
{"use_lpc", "sets whether to use LPC mode (FLAC)", OFFSET(use_lpc), FF_OPT_TYPE_INT, -1, INT_MIN, INT_MAX, A|E},
|
{"use_lpc", "sets whether to use LPC mode (FLAC)", OFFSET(use_lpc), FF_OPT_TYPE_INT, -1, INT_MIN, INT_MAX, A|E},
|
||||||
|
#endif
|
||||||
{"lpc_coeff_precision", "LPC coefficient precision (FLAC)", OFFSET(lpc_coeff_precision), FF_OPT_TYPE_INT, DEFAULT, 0, INT_MAX, A|E},
|
{"lpc_coeff_precision", "LPC coefficient precision (FLAC)", OFFSET(lpc_coeff_precision), FF_OPT_TYPE_INT, DEFAULT, 0, INT_MAX, A|E},
|
||||||
{"min_prediction_order", NULL, OFFSET(min_prediction_order), FF_OPT_TYPE_INT, -1, INT_MIN, INT_MAX, A|E},
|
{"min_prediction_order", NULL, OFFSET(min_prediction_order), FF_OPT_TYPE_INT, -1, INT_MIN, INT_MAX, A|E},
|
||||||
{"max_prediction_order", NULL, OFFSET(max_prediction_order), FF_OPT_TYPE_INT, -1, INT_MIN, INT_MAX, A|E},
|
{"max_prediction_order", NULL, OFFSET(max_prediction_order), FF_OPT_TYPE_INT, -1, INT_MIN, INT_MAX, A|E},
|
||||||
@ -417,6 +419,12 @@ static const AVOption options[]={
|
|||||||
{"intra_refresh", "use periodic insertion of intra blocks instead of keyframes", 0, FF_OPT_TYPE_CONST, CODEC_FLAG2_INTRA_REFRESH, INT_MIN, INT_MAX, V|E, "flags2"},
|
{"intra_refresh", "use periodic insertion of intra blocks instead of keyframes", 0, FF_OPT_TYPE_CONST, CODEC_FLAG2_INTRA_REFRESH, INT_MIN, INT_MAX, V|E, "flags2"},
|
||||||
{"crf_max", "in crf mode, prevents vbv from lowering quality beyond this point", OFFSET(crf_max), FF_OPT_TYPE_FLOAT, DEFAULT, 0, 51, V|E},
|
{"crf_max", "in crf mode, prevents vbv from lowering quality beyond this point", OFFSET(crf_max), FF_OPT_TYPE_FLOAT, DEFAULT, 0, 51, V|E},
|
||||||
{"log_level_offset", "set the log level offset", OFFSET(log_level_offset), FF_OPT_TYPE_INT, 0, INT_MIN, INT_MAX },
|
{"log_level_offset", "set the log level offset", OFFSET(log_level_offset), FF_OPT_TYPE_INT, 0, INT_MIN, INT_MAX },
|
||||||
|
{"lpc_type", "specify LPC algorithm", OFFSET(lpc_type), FF_OPT_TYPE_INT, AV_LPC_TYPE_DEFAULT, AV_LPC_TYPE_DEFAULT, AV_LPC_TYPE_NB-1, A|E},
|
||||||
|
{"none", NULL, 0, FF_OPT_TYPE_CONST, AV_LPC_TYPE_NONE, INT_MIN, INT_MAX, A|E, "lpc_type"},
|
||||||
|
{"fixed", NULL, 0, FF_OPT_TYPE_CONST, AV_LPC_TYPE_FIXED, INT_MIN, INT_MAX, A|E, "lpc_type"},
|
||||||
|
{"levinson", NULL, 0, FF_OPT_TYPE_CONST, AV_LPC_TYPE_LEVINSON, INT_MIN, INT_MAX, A|E, "lpc_type"},
|
||||||
|
{"cholesky", NULL, 0, FF_OPT_TYPE_CONST, AV_LPC_TYPE_CHOLESKY, INT_MIN, INT_MAX, A|E, "lpc_type"},
|
||||||
|
{"lpc_passes", "number of passes to use for Cholesky factorization during LPC analysis", OFFSET(lpc_passes), FF_OPT_TYPE_INT, -1, INT_MIN, INT_MAX, A|E},
|
||||||
{NULL},
|
{NULL},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -452,8 +452,8 @@ static int ra144_encode_frame(AVCodecContext *avctx, uint8_t *frame,
|
|||||||
32)];
|
32)];
|
||||||
|
|
||||||
ff_lpc_calc_coefs(&ractx->dsp, lpc_data, NBLOCKS * BLOCKSIZE, LPC_ORDER,
|
ff_lpc_calc_coefs(&ractx->dsp, lpc_data, NBLOCKS * BLOCKSIZE, LPC_ORDER,
|
||||||
LPC_ORDER, 16, lpc_coefs, shift, 1, ORDER_METHOD_EST, 12,
|
LPC_ORDER, 16, lpc_coefs, shift, AV_LPC_TYPE_LEVINSON,
|
||||||
0);
|
0, ORDER_METHOD_EST, 12, 0);
|
||||||
for (i = 0; i < LPC_ORDER; i++)
|
for (i = 0; i < LPC_ORDER; i++)
|
||||||
block_coefs[NBLOCKS - 1][i] = -(lpc_coefs[LPC_ORDER - 1][i] <<
|
block_coefs[NBLOCKS - 1][i] = -(lpc_coefs[LPC_ORDER - 1][i] <<
|
||||||
(12 - shift[LPC_ORDER - 1]));
|
(12 - shift[LPC_ORDER - 1]));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user