diff options
author | Corey Hickey <bugfood-ml@fatooh.org> | 2006-06-03 06:26:04 +0000 |
---|---|---|
committer | Corey Hickey <bugfood-ml@fatooh.org> | 2006-06-03 06:26:04 +0000 |
commit | f9243d34f19da816e05ad9e314e52b609e928bb1 (patch) | |
tree | 2dfd9ef977aad109bb8a8b516d1bbe318490230b /libavcodec | |
parent | 7e5370516b96b92f2c37b943695b8933e92f40c7 (diff) | |
download | ffmpeg-f9243d34f19da816e05ad9e314e52b609e928bb1.tar.gz |
Make B-frame reduction sensitivity by b_strategy/vb_strategy = 1
user-tunable.
Originally committed as revision 5450 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec')
-rw-r--r-- | libavcodec/avcodec.h | 7 | ||||
-rw-r--r-- | libavcodec/mpegvideo.c | 2 | ||||
-rw-r--r-- | libavcodec/utils.c | 2 |
3 files changed, 10 insertions, 1 deletions
diff --git a/libavcodec/avcodec.h b/libavcodec/avcodec.h index d352edc97b..eb0fe81856 100644 --- a/libavcodec/avcodec.h +++ b/libavcodec/avcodec.h @@ -1977,6 +1977,13 @@ typedef struct AVCodecContext { * - decoding: unused */ int mv0_threshold; + + /** + * adjusts sensitivity of b_frame_strategy 1 + * - encoding: set by user. + * - decoding: unused + */ + int b_sensitivity; } AVCodecContext; /** diff --git a/libavcodec/mpegvideo.c b/libavcodec/mpegvideo.c index dac57c6cd0..6393cc91fe 100644 --- a/libavcodec/mpegvideo.c +++ b/libavcodec/mpegvideo.c @@ -2375,7 +2375,7 @@ static void select_input_picture(MpegEncContext *s){ } } for(i=0; i<s->max_b_frames+1; i++){ - if(s->input_picture[i]==NULL || s->input_picture[i]->b_frame_score - 1 > s->mb_num/40) break; + if(s->input_picture[i]==NULL || s->input_picture[i]->b_frame_score - 1 > s->mb_num/s->avctx->b_sensitivity) break; } b_frames= FFMAX(0, i-1); diff --git a/libavcodec/utils.c b/libavcodec/utils.c index 84860e270b..ce66439117 100644 --- a/libavcodec/utils.c +++ b/libavcodec/utils.c @@ -741,6 +741,7 @@ static AVOption options[]={ {"sc_factor", NULL, OFFSET(scenechange_factor), FF_OPT_TYPE_INT, 6, 0, INT_MAX, V|E}, {"mv0_threshold", NULL, OFFSET(mv0_threshold), FF_OPT_TYPE_INT, 256, 0, INT_MAX, V|E}, {"ivlc", "intra vlc table", 0, FF_OPT_TYPE_CONST, CODEC_FLAG2_INTRA_VLC, INT_MIN, INT_MAX, V|E, "flags2"}, +{"b_sensitivity", NULL, OFFSET(b_sensitivity), FF_OPT_TYPE_INT, 40, 1, INT_MAX, V|E}, {NULL}, }; @@ -796,6 +797,7 @@ void avcodec_get_context_defaults(AVCodecContext *s){ s->nsse_weight= 8; s->sample_fmt= SAMPLE_FMT_S16; // FIXME: set to NONE s->mv0_threshold= 256; + s->b_sensitivity= 40; s->intra_quant_bias= FF_DEFAULT_QUANT_BIAS; s->inter_quant_bias= FF_DEFAULT_QUANT_BIAS; |