[FFmpeg-devel] [PATCH] update nvenc default parameters
Timo Rothenpieler
timo at rothenpieler.org
Mon Nov 9 13:17:06 CET 2015
> From: Agatha Hu <ahu at nvidia.com>
>
> ---
> libavcodec/nvenc.c | 22 +++++++++++++++-------
> 1 file changed, 15 insertions(+), 7 deletions(-)
>
> diff --git a/libavcodec/nvenc.c b/libavcodec/nvenc.c
> index 812b0b4..17d58fc 100644
> --- a/libavcodec/nvenc.c
> +++ b/libavcodec/nvenc.c
> @@ -769,8 +769,11 @@ static av_cold int nvenc_encode_init(AVCodecContext
> *avctx)
> if (avctx->bit_rate > 0)
> ctx->encode_config.rcParams.averageBitRate = avctx->bit_rate;
>
> - if (avctx->rc_max_rate > 0)
> + if (avctx->rc_max_rate > 0) {
> ctx->encode_config.rcParams.maxBitRate = avctx->rc_max_rate;
> + } else if (ctx->encode_config.rcParams.averageBitRate > 0) {
> + ctx->encode_config.rcParams.maxBitRate =
> ctx->encode_config.rcParams.averageBitRate;
> + }
>
> if (lossless) {
> if (avctx->codec->id == AV_CODEC_ID_H264)
> @@ -850,8 +853,11 @@ static av_cold int nvenc_encode_init(AVCodecContext
> *avctx)
> }
> }
>
> - if (avctx->rc_buffer_size > 0)
> + if (avctx->rc_buffer_size > 0) {
> ctx->encode_config.rcParams.vbvBufferSize = avctx->rc_buffer_size;
> + } else if (ctx->encode_config.rcParams.averageBitRate > 0) {
> + ctx->encode_config.rcParams.vbvBufferSize = 2 *
> ctx->encode_config.rcParams.averageBitRate;
> + }
>
> if (avctx->flags & AV_CODEC_FLAG_INTERLACED_DCT) {
> ctx->encode_config.frameFieldMode =
> NV_ENC_PARAMS_FRAME_FIELD_MODE_FIELD;
> @@ -1457,10 +1463,10 @@ static const enum AVPixelFormat pix_fmts_nvenc[]
> = {
> #define OFFSET(x) offsetof(NvencContext, x)
> #define VE AV_OPT_FLAG_VIDEO_PARAM | AV_OPT_FLAG_ENCODING_PARAM
> static const AVOption options[] = {
> - { "preset", "Set the encoding preset (one of slow = hq 2pass,
> medium = hq, fast = hp, hq, hp, bd, ll, llhq, llhp, default)",
> OFFSET(preset), AV_OPT_TYPE_STRING, { .str = "hq" }, 0, 0, VE },
> - { "profile", "Set the encoding profile (high, main, baseline or
> high444p)", OFFSET(profile), AV_OPT_TYPE_STRING, { 0 }, 0, 0, VE },
> - { "level", "Set the encoding level restriction (auto, 1.0, 1.0b,
> 1.1, 1.2, ..., 4.2, 5.0, 5.1)", OFFSET(level), AV_OPT_TYPE_STRING, { 0
> }, 0, 0, VE },
> - { "tier", "Set the encoding tier (main or high)", OFFSET(tier),
> AV_OPT_TYPE_STRING, { 0 }, 0, 0, VE },
> + { "preset", "Set the encoding preset (one of slow = hq 2pass,
> medium = hq, fast = hp, hq, hp, bd, ll, llhq, llhp, default)",
> OFFSET(preset), AV_OPT_TYPE_STRING, { .str = "medium" }, 0, 0, VE },
> + { "profile", "Set the encoding profile (high, main, baseline or
> high444p)", OFFSET(profile), AV_OPT_TYPE_STRING, { .str = "main" }, 0,
> 0, VE },
> + { "level", "Set the encoding level restriction (auto, 1.0, 1.0b,
> 1.1, 1.2, ..., 4.2, 5.0, 5.1)", OFFSET(level), AV_OPT_TYPE_STRING, {
> .str = "auto" }, 0, 0, VE },
> + { "tier", "Set the encoding tier (main or high)", OFFSET(tier),
> AV_OPT_TYPE_STRING, { .str = "main" }, 0, 0, VE },
> { "cbr", "Use cbr encoding mode", OFFSET(cbr), AV_OPT_TYPE_BOOL, {
> .i64 = 0 }, 0, 1, VE },
> { "2pass", "Use 2pass encoding mode", OFFSET(twopass),
> AV_OPT_TYPE_BOOL, { .i64 = -1 }, -1, 1, VE },
> { "gpu", "Selects which NVENC capable GPU to use. First GPU is 0,
> second is 1, and so on.", OFFSET(gpu), AV_OPT_TYPE_INT, { .i64 = 0 }, 0,
> INT_MAX, VE },
> @@ -1469,12 +1475,14 @@ static const AVOption options[] = {
> };
>
> static const AVCodecDefault nvenc_defaults[] = {
> - { "b", "0" },
> + { "b", "2M" },
> { "qmin", "-1" },
> { "qmax", "-1" },
> { "qdiff", "-1" },
> { "qblur", "-1" },
> { "qcomp", "-1" },
> + {"g", "250"},
> + {"bf", "0"},
> { NULL },
> };
>
applied, thanks.
More information about the ffmpeg-devel
mailing list