-
Notifications
You must be signed in to change notification settings - Fork 92
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
Black frame insertion support for 180Hz / 240Hz / 300Hz / 360Hz #187
Comments
Long TermNot part of this item, but advanced discussion to a BFI sequel for high-Hz displays: I know @tonioni has incorporated several of my suggestions in the past... Being Blur Busters, I see many prototype displays. And I have seen a new concept algorithm to emulate a CRT tube. Did you know that playback of a 1000fps high-speed video of a CRT tube -- in real time onto a true 1000Hz display -- allows a 1000Hz display to perceptually emulate the original CRT? It's pretty fascinating. The world has have spatially-completed CRT filter emulation. But holy grail is the temporal emulation of CRT, like this. The refresh rate race to retina refresh rates (combined with HDR brightness to help brighten the beam emulation spot) -- will make CRT beam emulation algorithms practical for 240Hz+, 360Hz+ and future 1000Hz HDR monitors. ASUS has already masterplanned a 1000Hz display by year 2030. Long term, rolling-scan BFI (emulation of a CRT electron beam) is also a practical method as a Holy Grail, also mentioned in these items that are masterplanned for about year ~2025
Think about this -- assuming perfect blacks (OLED, MiniLED, or FALD LCD), it can pass the CRT turning test -- real tube versus a flat panel (behind thick glass) -- passing an A/B test is theoretically possible with a "retina resolution + retina refresh rate + retina This is likely possible between 2030-2040, but can already be tested (in less quality, but still superior to old BFI) on a 360Hz PG259QN since it can do 6 refresh cycles per emulated refresh cycle, allowing basic software-based rolling-scan CRT electron beam emulation! |
Problem is that I don't have >120Hz monitor. I prefer having single large ultra-wide screen monitors, currently 5120x1440, max 120Hz. It is fast enough with RTX3090. (3090 because 3080 is practically impossible to get), good for games, really good for any productivity task. I also don't do any shader stuff. It is someone else's problem. |
@tonioni -- That said, you can do simple BFI at 180Hz / 240Hz / 300Hz / 360Hz without a shader. Basically, ignore BFIv3 (which requires shader), and only worry about BFIv2 concept. I only mentioned too much beyond, only simply as a long-term thought exercise. I think you may have accidentally latched onto this. Since high refresh rates are slowly commoditizing (even 240Hz will become widespread in ten to twenty years, with 1000Hz in premium), you can ignore BFIv3 until year 2025-2030. 240Hz tablets/smartphones have 1/4th the browser scrolling motion blur of 60Hz, so that's the next big thing for mainstream once 240Hz no longer is an esports refresh rate in the 2030s -- as doubling Hz/fps halves motion blur -- until we reach retina refresh rates (low-persistence sample-and-hold -- CRT clarity without any black frames/strobing/flicker). . Anyway, near term -- the simple BFI (aka BFIv2) is now important. No shader, already implemented in JavaScriptI even programmed it in JavaScript in TestUFO to demonstrate you don't need a shader LINK: TestUFO Variable-Blur 4-Frame-Sequence Black Frame Insertion DemoSee -- JavaScript -- and no shader! View the TestUFO animation at 120Hz with strobing ON versus strobing OFF -- and you will see how you can adjust the motionblur amount as a ratio of visible frames versus black frames. A simple implementation of 180Hz/240Hz/300Hz/360Hz BFI should probably be only 100 lines of additional code. How To Test 240 Hz BFI at 120 HzUse a slowdown factor as follows: One you can test this by slowing down your emulator to 0.5x speed (30fps) and simulating 240Hz BFI at 120Hz in a kind of slo-mo BFI debugging. Use 0.6666x slowdown (Run 60Hz emulator at 40fps-40Hz at 40/60ths speed) for debugging 180Hz BFI at 120Hz. Once both 180Hz and 240Hz BFI works, then you don't need to debug any BFI ratios beyond 240Hz, since motion blur during non-strobed is very mathematically simple according to Blur Busters Law (1ms of pixel visibility time translates to 1 pixel of motion blur per 1000 pixels/sec), as seen in the motion animation demo. For 240Hz BFI, think about the number of visible emulator frame versus black frame in a 4-frames-per-emu-refresh sequence: 25%:75%: VISIBLE:BLACK = 75% motion blur reduction without needing strobing On certain models of 8-bit-panelled 240Hz monitors, some of these software-BFI settings look better than the hardware strobe backlight too, because there's no strobe crosstalk double-images. Mathematically it is simple. You can simply use some kind of -bfisequence 3:1 command line option or something, to dictate how many visible frames and how many black frames -- and let advanced users decide. Less than 100 lines of source codeYou already implemented 120Hz BFI in year 2013, and the feature is still there, correct? So this is just a simple sub-100-line modification to the existing BFI feature in WinUAE, correct? It was crappy on TN panels with LightBoost in year 2013, but software BFI looks vastly better now (and sometimes better than hardware strobing, on certain panels). Additional TestUFO Links Of Proposed WinUAE Modification
Note: If you don't have the refresh rate applicable, they will flicker like crazy. However, the 180Hz and 240Hz links above are still reasonably educational when viewed on a 120Hz panel. For 60 Hz users, only the first two links may be adequately educational. Now that you clicked on the TestUFO link above -- do you understand better of the no-shader easy BFI option? |
Somebody else other than Toni could do it but just want to definitively confirm no shader is needed. Not a rush, but it's something I'd like to see implemented in WinUAE eventually. GroovyMAME / RetroArch now supports it. (i.e. Basic 240 Hz BFI is a simply a very minor modification of existing 120 Hz BFI) |
Monitor update: Samsung Odyssey G49, 5120x1440@240Hz so 180Hz/240Hz (and obviously 150Hz/200Hz) might happen someday :) |
Black frame insertion looks massively better on 240Hz and 360Hz monitors (especially IPS) than 120Hz monitors. No burn in, better color, brighter, no chessboard-patterns, no color depth loss, etc.
RetroArch has already partially implemented it: libretro/RetroArch#10754
This is an easy change, IMHO. Crosspost:
New Methods of Emulating CRT Via Sheer Hz
I'm the founder of Blur Busters and creator of TestUFO. Today, we now have 240Hz 1ms IPS panels, and DELL is releasing a 360Hz IPS monitor this summer. This is an amazing opportunity for emulation.
Glossary
BFI = Black Frame Insertion, used to reduce motion blur on LCDs to mimic a CRT
BFIv1 = Classic 60fps at 120Hz BFI, already implemented
BFIv2 = Improvements to BFI for higher Hz
BFIv3 = Rolling-bar BFI, emulating CRT electron gun temporally
WinUAE already supports 60Hz BFI for 120Hz
60Hz Black Frame Insertion (BFI) improves massively at higher refresh rates for multiple reasons. Strobed and non-strobed. WinUAE already supports 60 Hz software BFI for 120Hz displays.
To understand black frame insertion, see animation demo: www.testufo.com/blackframes
This works great, and is already discussed in this libretro thread
Newer monitors already actually improved BFI in existing WinUAE. For example, 120Hz strobed on 240Hz panels look better than 120Hz strobed on 144Hz panels. And 240Hz IPS just came out too (better colors). 240Hz 1ms IPS strobed monitors look far better than old LightBoost panels, such as the Blur Busters Approved ViewSonic XG270 gaming monitor 240Hz 1ms IPS panel, which looks great with existing 120Hz PureXP+ on existing WinUAE BFI
Discovery That Higher Hz Improves Software BFI (240Hz, 360Hz)
We discovered that higher refresh rates improve software BFI even further for many reasons such as:
Animation Demonstration:
If you have a 60Hz monitor, animations will be very limited in explaining BFI, but you can view this Simple 60Hz Demo of Three Different BFI Motion Blurs. This will run at only 20 frames per second, but will adequately demonstrate the variable-blur BFI concept via custom blackframe sequences.
If you have a 240Hz monitor in sample-and-hold mode, view this upgraded TestUFO Variable-Blur Variable-Brightness BlackFrames Comparison. You'll immediately see the pros/cons. You can still view this on a 120Hz monitor to see this in a kind of a slow-motion, at least to gain a better understanding.
If you have a 120Hz monitor in LightBoost mode with a chessboard-pattern problem, view this upgraded TestUFO Inversion-Artifact-Proof BlackFrames Animation, you'll see the last UFO no longer have a chessboard pattern artifact. But it only runs at 40 frames per second. Chessboard patterning is often an issue on TN panels due to voltage inversion. Fixing this requires a 240Hz monitor configured to 180Hz with strobe enabled (e.g. BenQ XL2546 monitor, ViewSonic XG270 monitor). This, incidentially is also burnin-proof too.
Fun Education: There is now a TestUFO emulation of CRT 30fps at 60Hz side effect. This is just an educational exercise on how software BFI can still emulate the side effects of a CRT (half frame rate behavior). Mind you, this animation looks more correct on a 120Hz monitor, because it requires a 4-refresh sequence, but it's still passable education at any refresh rate.
Eliminates Image Retention
Odd-divisible refresh rates (180Hz and 300Hz) are completely image-retention-proof, since it doesn't interfere with LCD voltage inversion electronics. BFI is completely safe on all 180Hz-capable and 300Hz-capable monitors. Most 240Hz gaming monitors are capable of doing a 180Hz refresh rate.
FEATURE REQUEST:
Support Adjustable Software BFI for Higher Hz
WinUAE should support the following Black Frame Insertion (BFI) sequences:
BFI sequence on 120Hz for 60Hz emulation: ON, OFF
BFI sequence on 180Hz for 60Hz emulation: ON, OFF, OFF
BFI sequence on 240Hz for 60Hz emulation: ON, OFF, OFF, OFF
BFI sequence on 300Hz for 60Hz emulation: ON, OFF, OFF, OFF, OFF
BFI sequence on 360Hz for 60Hz emulation: ON, OFF, OFF, OFF, OFF, OFF
Best Case Display Motion Blur Reduction by BFI
The easiest way to do so is provide a comma-separated black-frame insertion sequence in a configuration file, to allow customizability. Default strings can be done for common scenarios, but would let advanced users customize BFI. Relative to the original blur of a 60Hz LCD, higher Hz produces more software-BFI-blur-reduction (non-strobed LCD use-case, though software BFI also helps hardware strobing too for these specific numbers, in lower strobe lag + better quality strobing).
120Hz BFI sequence (50% less motion blur): 1 , 0
180Hz BFI sequence (66% less motion blur): 1 , 0 , 0
240Hz BFI sequence (75% less motion blur): 1 , 0 , 0 , 0
300Hz BFI sequence (80% less motion blur): 1 , 0 , 0 , 0, 0
360Hz BFI sequence (83% less motion blur): 1 , 0 , 0 , 0 , 0 , 0
Adjustable Motion Blur (Tradeoff Between Flicker + Brightness + Clarity)
Custom sequences can allow you to adjust motion blur, brightness, and flicker tradeoff. Just like TestUFO Variable-Blur BFI Demo. Try this link on a high-Hz LCD with hardware strobing distabled! If you have 240Hz, try configuring 4 or 5 UFOs instead, to see more variable-blur flexibility. Adjustability is a continuum between hardware Hz to emulator Hz. Minimum persistence-based display motion blur is persistence of max Hz (1/360sec visibility = 2.8ms blur). Maximum display motion blur is emulator Hz (1/60sec visibility = 16.7ms blur). Thus higher Hz, the more BFI motion blur adjustability.
180Hz bright BFI sequence (33% less motion blur): 1 , 1 , 0
240Hz bright BFI sequence (25% less motion blur): 1 , 1 , 1 , 0
360Hz bright BFI sequence (66% less motion blur): 1 , 1 , 0 , 0 , 0 , 0
360Hz bright BFI sequence (33% less motion blur): 1 , 1 , 1 , 1, 0 , 0
Basic CRT Phosphor Decay Emulation
In fact, alpha-blended BFI is also desirable, so this could be a percentage setting or floating point setting, to approximate phosphor fade. This makes flickerfeel more approximate a CRT tube (as far as refresh granularity permits). And feels much less harsh than 60Hz squarewave for many.
240Hz alpha-blended BFI slow-rise slow-decay sequence: 0.5 , 1 , 0.5 , 0
360Hz alpha-blended BFI slow-rise slow-decay sequence: 0.5 , 1 , 0.5 , 0 , 0 , 0
360Hz alpha-blended BFI fast-rise, slow-decay sequence: 1 , 0.5 , 0.25 , 0 , 0 , 0
360Hz alpha-blended BFI fast-rise, superslow-decay sequence: 1 , 0.75 , 0.5 , 0.25 , 0.1 , 0
Alternative methods of configuration could be discussed instead.
Hopefully this is a very easy change for a WinUAE for the refresh rate race to retina refresh rates. For now, this can be just a simple configuration file string, to help users incubate this. It should be easy to write instruction guides, to help get more users playing with BFI.
BFI Percentage Terminology (in case it wasn't clear)
1 = Fully visible frame
0 = Fully black frame
0.5 = A darkened frame that is 50% brightness
Tips
Once this feature is implemented, I'd be happy to write an article about this to improve emulator BFI awareness among high-Hz monitor users
Hopefully this is a very easy change for WinUAE for the refresh rate race to retina refresh rates. For now, this can be just a simple configuration file string, to help users incubate this. It should be easy to write instruction guides, to help get more users playing with BFI.
The text was updated successfully, but these errors were encountered: