summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorsr55 <[email protected]>2018-12-01 13:45:31 +0000
committersr55 <[email protected]>2018-12-01 13:45:31 +0000
commit6c560316239a5e96754e315e0dba805020bf3e9d (patch)
treef88d787ec8571b021bd9ffdbd2e56fed5330b713
parent51377f3ce652a53f7d5e2e5120a60a17cece0f2c (diff)
Default Nvenc to use slower, higher quality settings. Fix some issues around the rate control, profile and level settings.
-rw-r--r--libhb/encavcodec.c68
-rw-r--r--win/CS/HandBrakeWPF/ViewModels/VideoViewModel.cs2
2 files changed, 57 insertions, 13 deletions
diff --git a/libhb/encavcodec.c b/libhb/encavcodec.c
index 3637be37e..49c6ea570 100644
--- a/libhb/encavcodec.c
+++ b/libhb/encavcodec.c
@@ -70,7 +70,7 @@ static const char * const vpx_preset_names[] =
static const char * const h26x_nvenc_preset_names[] =
{
- "llhp", "llhq", "ll", "bd", "hq", "hp", "fast", "medium", "slow", "default", NULL // No Lossless "losslesshp", "lossless",
+ "hq", "hp", "fast", "medium", "slow", "default", NULL // No Lossless "losslesshp", "lossless", "llhp", "llhq", "ll", "bd". We don't need them.
};
static const char * const h264_nvenc_profile_names[] =
@@ -316,6 +316,12 @@ int encavcodecInit( hb_work_object_t * w, hb_job_t * job )
// ffmpeg's mpeg2 encoder requires that the bit_rate_tolerance be >=
// bitrate * fps
context->bit_rate_tolerance = context->bit_rate * av_q2d(fps) + 1;
+
+ if ( job->vcodec == HB_VCODEC_FFMPEG_NVENC_H264 ||
+ job->vcodec == HB_VCODEC_FFMPEG_NVENC_H265 ) {
+ av_dict_set( &av_opts, "rc", "cbr_hq", 0 );
+ hb_log( "encavcodec: encoding at rc=cbr_hq Bitrate %d", job->vbitrate );
+ }
}
else
{
@@ -343,21 +349,30 @@ int encavcodecInit( hb_work_object_t * w, hb_job_t * job )
else if ( job->vcodec == HB_VCODEC_FFMPEG_NVENC_H264 ||
job->vcodec == HB_VCODEC_FFMPEG_NVENC_H265 )
{
+ char qualityI[7];
char quality[7];
+ char qualityB[7];
+ double adjustedQualityI = job->vquality - 2;
+ double adjustedQualityB = job->vquality + 2;
+ if (adjustedQualityB > 51) {
+ adjustedQualityB = 51;
+ }
+
+ if (adjustedQualityI < 0){
+ adjustedQualityI = 0;
+ }
+
snprintf(quality, 7, "%.2f", job->vquality);
- av_dict_set( &av_opts, "rc", "vbr", 0 );
+ snprintf(qualityI, 7, "%.2f", adjustedQualityI);
+ snprintf(qualityB, 7, "%.2f", adjustedQualityB);
+ av_dict_set( &av_opts, "rc", "constqp", 0 );
av_dict_set( &av_opts, "cq", quality, 0 );
// further Advanced Quality Settings in Constant Quality Mode
- av_dict_set( &av_opts, "init_qpP", "1", 0 );
- av_dict_set( &av_opts, "init_qpB", "1", 0 );
- av_dict_set( &av_opts, "init_qpI", "1", 0 );
- hb_log( "encavcodec: encoding at rc=vbr CQ %.2f", job->vquality );
-
- //This value was chosen to make the bitrate high enough
- //for nvenc to "turn off" the maximum bitrate feature
- //that is normally applied to constant quality.
- context->bit_rate = bit_rate_ceiling;
+ av_dict_set( &av_opts, "init_qpP", quality, 0 );
+ av_dict_set( &av_opts, "init_qpB", qualityB, 0 );
+ av_dict_set( &av_opts, "init_qpI", qualityI, 0 );
+ hb_log( "encavcodec: encoding at rc=constqp QP %.2f", job->vquality );
// Force IDR frames when we force a new keyframe for chapters
av_dict_set( &av_opts, "forced-idr", "1", 0 );
@@ -370,6 +385,10 @@ int encavcodecInit( hb_work_object_t * w, hb_job_t * job )
snprintf(quality, 7, "%.2f", job->vquality);
snprintf(qualityB, 7, "%.2f", adjustedQualityB);
+
+ if (adjustedQualityB > 51) {
+ adjustedQualityB = 51;
+ }
av_dict_set( &av_opts, "rc", "cqp", 0 );
@@ -380,7 +399,7 @@ int encavcodecInit( hb_work_object_t * w, hb_job_t * job )
{
av_dict_set( &av_opts, "qp_b", qualityB, 0 );
}
- hb_log( "encavcodec: encoding at CQ %.2f", job->vquality );
+ hb_log( "encavcodec: encoding at QP %.2f", job->vquality );
}
else
{
@@ -514,6 +533,31 @@ int encavcodecInit( hb_work_object_t * w, hb_job_t * job )
// FIXME
//context->tier = FF_TIER_UNKNOWN;
}
+
+ if ( job->vcodec == HB_VCODEC_FFMPEG_NVENC_H264 || job->vcodec == HB_VCODEC_FFMPEG_NVENC_H265 )
+ {
+ // Set profile and level
+ if (job->encoder_profile != NULL && *job->encoder_profile)
+ {
+ if (!strcasecmp(job->encoder_profile, "baseline"))
+ av_dict_set(&av_opts, "profile", "baseline", 0);
+ else if (!strcasecmp(job->encoder_profile, "main"))
+ av_dict_set(&av_opts, "profile", "main", 0);
+ else if (!strcasecmp(job->encoder_profile, "high"))
+ av_dict_set(&av_opts, "profile", "high", 0);
+ }
+
+ if (job->encoder_level != NULL && *job->encoder_level)
+ {
+ int i = 1;
+ while (hb_h264_level_names[i] != NULL)
+ {
+ if (!strcasecmp(job->encoder_level, hb_h264_level_names[i]))
+ av_dict_set(&av_opts, "level", job->encoder_level, 0);
+ ++i;
+ }
+ }
+ }
if( job->pass_id == HB_PASS_ENCODE_1ST ||
job->pass_id == HB_PASS_ENCODE_2ND )
diff --git a/win/CS/HandBrakeWPF/ViewModels/VideoViewModel.cs b/win/CS/HandBrakeWPF/ViewModels/VideoViewModel.cs
index b065755d7..8fb1018ec 100644
--- a/win/CS/HandBrakeWPF/ViewModels/VideoViewModel.cs
+++ b/win/CS/HandBrakeWPF/ViewModels/VideoViewModel.cs
@@ -1472,7 +1472,7 @@ namespace HandBrakeWPF.ViewModels
if (selectedEncoder == VideoEncoder.NvencH264 || selectedEncoder == VideoEncoder.NvencH265)
{
- middlePreset = this.VideoPresets.IndexOf(this.VideoPresets.FirstOrDefault(s => s.ShortName == "default"));
+ middlePreset = this.VideoPresets.IndexOf(this.VideoPresets.FirstOrDefault(s => s.ShortName == "slow"));
}
this.VideoPresetValue = middlePreset;