-
Notifications
You must be signed in to change notification settings - Fork 14
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
No H264/AVC B-frame options in latest 0.2.0 release #16
Comments
It is helpful to know that people actively want to use these options. I'm curious, could you tell me why they are important? For context, the comment you are referring to is probably obs-amf/source/encoder_avc.cpp Line 152 in 4df6493
|
That is the line I was referring to, yes! I would like use of B-Frames as they use less bitrate pr-frame than P-frames, which gives each GOP more overall bitrate use on P frames, as well as use on reference P and B frames. Likewise, B-frames, in combination with other encoder features that help distribute bitrate over a GOP, benefit from needing to use less of the GOP's bitrate on B-frames. TL;DR: B-frames are important when streaming and/or recording at low bitrates; streaming to Twitch, for example. |
I think b frames already enabled even without manually setting those settings. |
When using the Transcoding preset, as your plugin does, B-frames should be enabled by default, but no combination of settings over about 2 hours of testing could provoke the GPU into using B-frames, using OBS Studio 27.2.3 and the latest build of your plugin, with new AMD Radeon drivers. I read through the AMF AVC encoder documentation several times trying what appeared to be proper combinations of... sigh I think I am an idiot sandwich. In being distracted during the making of the post above, I went back and re-read the release notes from AMF Release 1.4.24. The comment about B-frames reads "Support for consecutive B-frames and adaptive miniGOP for AVC Encoder". I think I read what I wanted to, and did not read what was actually stated. I do not believe Navi 1x/2x have B-frame support with AVC yet. My apologies. |
Like I wrote in my previous post I still think that b frames are already being used. The commented out part merely allows extra configuration of b frames. It does not disable b frames. A definitive test could be done by analyzing a recording with a tool that can output frame information like ffmpeg. We can keep this issue open because it would still be nice to enable the configuration. |
I did spend a few hours before I submitted this ticket, using your 0.2.0 plugin version with the latest OBS Studio, trying to provoke H264 to use B-frames. I used the following command on each recording (the same I used to monitor B-Frames with Nvidia) to no avail:
The only thing I could think of, was an old rumor that previous generation AMD GPU's only used B-frames with CQP, but I could not find any documentation on that comment specifically, nor could I provoke my RX 6900 XT into using B-frames with any combination of rate control, based on settings from AMD's documentation that should allow the encoder to use B-frames. I can give it another try today and see what results I come up with. |
If you have already tested it then you don't need to again. I can try the same command. |
I think, as a test, if you added the following into your plugin, hopefully this may nudge the encoder to use B-frames, since it does not do so by default. (I did run more tests last night, to no avail) Line 157: AMF_VIDEO_ENCODER_MAX_CONSECUTIVE_BPICTURES L"MaxConsecutiveBPictures" // amf_int64; Maximum number of consecutive B Pictures |
@e00E @cs9kc I tested self compiled FFMPEG without AMF_VIDEO_ENCODER_MAX_CONSECUTIVE_BPICTURES option only with latest AMF on 6700XT, but no b-frame. So we can not encode with b-frame as long as we can set AMF_VIDEO_ENCODER_MAX_CONSECUTIVE_BPICTURES. |
You can certainly build ffmpeg with the latest AMF package, but the rest of the code in ffmpeg itself is not set up to interface with the new options in the latest AMF version. With RDNA/2 GPU's, b-frames almost certainly do not and will not work with ffmpeg-based encoding until AMD's AMF team work with ffmpeg to get the program itself updated to interface properly with the latest AMF version. |
Hello! Thank you so much for updating your plugin to the latest version of AMF!
I see in your code that you do have some information about B-frames already inserted, but the code is currently commented out. If you have the time, could I request that you enable control of B-Frames and their associated parameters, please?
Thank you so much for your hard work!
The text was updated successfully, but these errors were encountered: