-
Notifications
You must be signed in to change notification settings - Fork 3.1k
Encoder FFmpeg NVENC
With the new NVIDIA NVENC integration through FFmpeg you can achieve greater recording and stream quality, at no extra expense. Since it simply uses the FFmpeg integration and exposes it to OBS Studio, including all the necessary zero-copy logic, you can switch your stream over, set some parameters, and get started with a higher quality stream right now!
Version Information
Status | Version |
---|---|
Added | 0.8 |
Unstable | 0.9 |
Stable | N/A |
Deprecated | N/A |
Removed | N/A |
- High Quality Recording by Xaymar
- High Quality Streaming by Xaymar
This encoder shares some settings between all other FFmpeg based encoders. Please take a look at this document to learn more about them.
Changes the default values for all encoder settings except for a few FFmpeg settings like Bitrate. The default value for fields varies between -1
or an actual Default
entry. This can be used as a good baseline to create customized configurations on, as most of the time the High Quality
preset performs well enough for streaming, while the High Performance
preset is great for Constant Quantization Parameter (CQP) recording.
1920x1080 NV12 CBR on RTX 3090 | P1 HP |
P2 | P3 | P4 HQ |
P5 | P6 | P7 |
---|---|---|---|---|---|---|---|
High Quality No Multipass |
458 | 460 | 315 | 317 | 237 | 235 | 235 |
High Quality 1/4th Size Multipass |
384 | 386 | 384 | 371 | 318 | 313 | 315 |
High Quality Full Size Multipass |
241 | 241 | 241 | 236 | 212 | 212 | 211 |
The above numbers are for reference and are not guarantees, as even small differences can change a lot of numbers.
Settings exclusive to H.264/AVC encoding.
The profile determines which features in the codec are supposed to be enabled, with each higher option requiring additional encoder work. While the Baseline
profile has the widest support compared to Main
or High
, most devices released within the last 5-10 years should have no issues with High
.
Generally it is recommended to either pick Main
if you're targeting devices around the iPhone 3 timespan, and High
if you're targeting devices within the last 8 years. If the platform offers transcoding, you can freely choose the High
profile, with some exceptions (such as Mixer and WebRTC based platforms).
baseline | main | high | high444 | |
---|---|---|---|---|
FPS (p1, p2) | 108 | 106 | 106 | 74 |
% | 100 | 98.15 | 98.15 | 68.52 |
FPS (p3, p4) | 98 | 98 | 84 | 73 |
% | 100 | 100 | 85.71 | 74.49 |
FPS (p5) | 80 | 80 | 62 | 61 |
% | 100 | 100 | 77.50 | 76.25 |
FPS (p6) | 77 | 76 | 60 | 59 |
100 | 98.70 | 77.92 | 76.62 | |
FPS (p7) | 56 | 56 | 56 | 56 |
% | 100 | 100 | 100 | 100 |
Level determines the maximum macroblocks per second, which limits the resolution and framerate, while also affecting some other things like the maximum number of B-Frames. This setting is best left at Automatic
, as the encoder knows what the ideal setting is for the given resolution, framerate, profile, tier and bitrate.
Settings exclusive to H.265/HEVC encoding.
The profile determines which features of the codec are available and enabled, while also affecting other restrictions. The Main
profile is capable of 8-bit, Main 10-bit
is capable of 10-bit, and Range Extended
is capable of more than 10-bit. Any of these profiles are capable of 4:2:0, 4:2:2 and 4:4:4, however the support depends on the installed hardware.
Bitrate limitations are controlled with the Tier and Level setting. The Main
tier is usually meant for network streaming, while the High
tier is more aimed towards intermediate storage.
Just like in H264/AVC, the Level determines the maximum macroblocks and the maximum bitrate as well. This affects the maximum possible resolution and quality at any given level. Unlike H264/AVC however, the support for Levels, Tiers and Profiles depends on the power of the target device instead of the age. This setting is best left at Automatic
, as the encoder knows what the ideal setting is for the given resolution, framerate, profile, tier and bitrate.
Settings that control the final quality and size.
NVIDIAs NVENC offers several different options for bitrate control, such as CBR
, VBR
, CQP
and CQ
. Each mode has different targets, which have to be taken into account when selecting the mode to use:
- Constant Quantization Parameter (CQP) is used for indistinguishable or lossless recording. It produces constant compression output, based on the values set in the Quantization Parameters, with lower values being large while also being higher quality.
- Constant Bitrate (CBR) is used for streaming on older protocols where a relatively constant and controllable packet size matters a lot. CBR uses the Buffer Size and Bitrate Limits to achieve its goal. There is also a High Quality variant of this which enables additional options by default.
- Variable Bitrate (VBR) is used for local archiving as well as for modern streaming protocols. It can save space when there isn't much to encode, which pushing out high quality content when it matters. VBR uses the Buffer Size, Bitrate Limits and Quantization Parameters to achieve its goal. This also comes with a High Quality variant that enables additional options by default.
-
Constant Quality (CQ) is, like the name implies, a constant quality encoding method with the option of having an upper bitrate limit. This mode could be considered similar to x264s CRF, and achieves comparable quality. It is enabled by setting the
Mode
to any of the VBR options, settingBuffer Size
andTarget Bitrate
to 0, while setting theTarget Quality
to a value between 0 and 100.
Enables/Disables a second pass over the frames, which improves bitrate distribution and may increase or decrease quality slightly. This is an expensive feature and should be turned off first if performance is an issue. Requires additional CUDA GPU resources.
Disabled | Quarter Res | Full Res | |
---|---|---|---|
FPS | 106 | 82 | 57 |
% | 100 | 77.36 | 53.77 |
The number of frames to "look ahead", achieved by increasing the encoding delay by N frames. Setting this to 0 disables look ahead, which also disables both 'Adaptive I/B-Frames' options automatically. Increasing the number past a certain point results in diminishing returns, but the exact point is undefined and depends on Hardware used as well as content encoded. Requires additional CUDA GPU resources.
0 | >0 | |
---|---|---|
FPS | 106 | 99 |
% | 100 | 93.40 |
Adaptively insert I-Frames instead of P- or B-Frames when the use of such a frame would increase quality. Similar to x264s scenecut option, and seems to work fine for streaming services like Twitch and YouTube.
Adaptively insert B-Frames instead of P-Frames, or P-Frames instead of B-Frames, when the use of such a frame would increase quality.
All the possible limits for the Rate Control modes.
Ideal quality to achieve in CQ mode. Values closer to 0 are higher quality, while values closer to 100 are worse quality. A value of 0 disables CQ mode.
Ideal target bitrate to achieve, if possible.
Ideal maximum bitrate to achieve in VBR or CQ mode.
Defines the ideal upper boundary for the bitrate over twice the Keyframe Interval duration.
Lower and upper limits for the calculated quantization parameters, which affects how much something can be compressed. May break any intended bitrate limits if used wrong.
Quantization parameter values for I/P/B-Frames, which have different meaning depending on the rate control method:
- CQP: Fixed QP values for the entire encoding duration.
- VBR: Initial QP values for the start of the encoding session.
Adaptive Quantization helps improve bitrate distibrution over the frame (Spatial) or multiple frames (Temporal).
Spatial Adaptive Quantization improves the bitrate distribution and/or quality slightly by redistributing bitrate towards low-complexity (flat, smooth surfaces). In some high-motion games, enabling this actually results in a lower quality - more testing is required. The strength of this redistribution can be controlled in 16 steps using the slider. Requires additional CUDA GPU resources.
Temporal Adaptive Quantization improves the bitrate distribution and/or quality slightly by favoring I-Frames for low-motion or constant parts of a frame. This improves the quality for those parts, while freeing up some bitrate for the rest of the frame. Requires additional CUDA GPU resources.
Options that do not fit into any other category.
Sets the highest amount of B-Frames there might be at any given point it time. When "Adaptive B-Frames" and "Look Ahead" are disables, sets a fixed amount of B-Frames instead. Not all GPUs support B-Frames for H.264/AVC and H.265/HEVC, so ensure that yours does by checking with the NVIDIA customer support.
Controls if B-Frames can be used as reference or not, which has no performance impact and improves quality at the same time. The following options are available:
- Disabled (none): Disables using B-Frames as reference, which reduces quality and compression efficiency.
- (# of B-Frames)/2) (middle): Enables using half the number of B-Frames, favoring the "middle" of the IPB group.
- Each (each): Enables using all the B-Frames as reference, only available for H.265/HEVC.
Requires testing. Seems to remove reordering delay from certain types of encoding.
Enables weighted prediction which improves quality with luminance changes when no B-Frames are enabled. Enabling this reduces encoder performance, and it is automatically disabled if B-Frames are not set to 0. B-Frames give better quality in almost all cases. Requires additional CUDA GPU resources.
Requires testing. Seems to reduce references to some not-so-useful P-Frames. No solid data on this yet.
Requires testing.
Requires testing.
There is conflicting information from NVIDIA and NVIDIA on this. Their own documentation lists only 6 different generations, but their own website says that Turing and Ampere are 7th Generation.
- CUDA-based (any GPU)
- Kepler
- Maxwell
- Maxwell 2nd Generation
- Pascal
- Volta & GTX 1650
- GTX 1650 Super and up, Turing, Ampere
- Not yet released
You can measure impact of options this way:
- Generate a colored noise file which usually is problematic for every encoder:
ffmpeg -hide_banner -f lavfi -y -i color=#7e7e7e:size=1920x1080:rate=60:duration=60s,noise=alls=100:allf=t+u,format=yuv420p -pix_fmt yuv420p -f yuv4mpegpipe <FILE>.y4m
- Test each option for impact with the following command (adjust as necessary):
ffmpeg -hide_banner -s 1920x1080 -r 60/1 -pix_fmt yuv420p -color_range pc -colorspace bt709 -color_primaries bt709 -color_trc bt709 -i <FILE>.y4m -c:v h264_nvenc -preset p7 -tune hq -g 120 -b:v 20000k -maxrate 20000k -bufsize 40000k -rc cbr -rc-lookahead 32 -multipass 2 -no-scenecut 0 -b_adapt 1 -spatial-aq 1 -temporal-aq 1 -nonref_p 1 -aq-strength 7 -b_ref_mode middle -bf 4 -f null -
- Write down the fps=# part after encoding is done.
This work is licensed under a Creative Commons Attribution 4.0 International License.
The wiki has been under repeated automated attacks by bots, with attempts to phish or infect unsuspecting users with malware, trojans and similar software. As a response to these attacks and GitHubs complete ineptitude at handling this situation, we have decided to write-protect the wiki for the time being. If you wish to submit changes to the wiki, please do so over Discord. Thank you for understanding!
- 🟢 3D Transform
- 🔴 Auto-Framing
- 🟠 Blur
- 🟢 Color Grading
- 🔴 Denoising
- ❌ Displacement Mapping
- 🟢 Dynamic Mask
⚠️ SDF Effects- 🔴 Shaders
- 🔴 Spout
- 🔴 Upscaling
- 🔴 Virtual Greenscreen
- 🔴 Shaders
- 🔴 Sink
⚠️ Source Mirror
- 🔴 Shaders