-
-
Notifications
You must be signed in to change notification settings - Fork 97
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
Integrate sub-pixel morphological antialiasing (SMAA) in the Vulkan renderer #2779
Comments
For reference, the original SMAA code can be found here and it is MIT licenced. |
I found this: https://github.com/dmnsgn/glsl-smaa, i hope it helps. |
This porting work may also be useful as a reference: libretro/slang-shaders#189 |
Hey, if you want to take any reference from my work there, please check the aftermath: libretro/slang-shaders#192 I can't agree with the docs on luma by default. I tested it extensively and color based edge detection always gave me better results, with less aliasing but not blurrier. In the end, I exposed every config knob, so I could more easily tweak settings at runtime. Tweaking it for your content is worthwhile, this AA is powerful when properly setup.
My code is in the public domain, no restrictions apply. Feel free to copy anything. |
I've started work on integrating SMAA: https://github.com/Calinou/godot/tree/add-smaa-antialiasing It's far from functional yet, but feel free to take a look nonetheless. |
Is there any update on this? |
I haven't managed to get it working, as I have very little time to work on this. Note that Godot 4 now offers temporal antialiasing, which you could combine with sharpening to counteract the added blurriness. This would still result in some amount of visible ghosting depending on the scene, but TAA handles specular and shader-induced aliasing much better than SMAA (which barely has any positive effect on this kind of aliasing). TAA and FXAA sharpness can also be improved by adjusting mipmap LOD bias automatically. I still think supporting SMAA is valuable for at least 2 scenarios:
|
I don't have any stake in Godot at the moment, so my opinion might not be too relevant, but I think working on the multi-pass shaders proposal mentioned in the description is a more worthwhile use of time. With that, anyone could easily do SMAA or whatever other post-process effects they want, not limited by what the engine offers. Edit: Maybe these kinds of shaders should be on the Asset Library. |
CMAA2 may be a great alternative to consider, it's been used to great effect in the recently released Counter Strike 2 and seems to work well as an MSAAesque cheap post process fallback. The original repo published by Intel: https://github.com/GameTechDev/CMAA2 Intel's article on CMAA2 A ReShade implementation: https://github.com/LordOfLunacy/Insane-Shaders/blob/master/Shaders/CMAA_2.fx |
How is this coming along? I was going to open a proposal until I saw this one. SMAA is the perfect middle ground in terms of performance, quality, and artifacts. Q: Describe the project you are working on Q: Describe the problem or limitation you are having in your project Q: Describe the feature / enhancement and how it helps to overcome the problem or limitation Q: If this enhancement will not be used often, can it be worked around with a few lines of script? Q: Is there a reason why this should be core and not an add-on in the asset library? |
SMAA is generally considered to be a stale approach by 2023 standards, so I wouldn't hold my hopes for it being added as a core feature (in the age of ever-improving TAA solutions). However, the rendering engine will eventually be made more flexible so that SMAA can be implemented by an add-on. Modern games are often full of geometric and specular detail that SMAA can't do anything about. The only real use case I can see for SMAA nowadays is antialiasing an image when you have no access to motion vectors (such as running old games, antialiasing screenshots, etc). Similar concerns apply to other techniques like CMAA. Being able to use TAA + SMAA at the same time isn't so important anymore, now that we have access to FSR2 at native resolution. This provides high-quality antialiasing with a sharper result compared to native TAA. TAA is pending optimizations in the motion vector generation part, which will make it significantly less demanding. |
That's fine - the users wanting to use SMAA aren't expecting it to match or even come close to the antialiasing capability of TAA - the point is to get the best possible antialiasing possible today that isn't TAA (due to ghosting and artifacting that will never be solved no matter how improved TAA gets) or MSAA (due to prohibitive performance cost)
Irrelevant. Progress and development on non-temporal post process antialiasing methods has practically halted, so unless the Godot team is planning to create a bespoke new technique, SMAA is still the best there is. (again, if you don't want TAA or MSAA) If anything, FXAA is the stale, outdated, irrelevant technique - why is that still in core? |
I have tested the anti-aliasing algorithm with every kind of game art style, and I can say that it all depends on the art style or visual style. Godot will benefit by giving people choices in how they want to customize their game. FXAA: MSAA: TAA: SMAA: |
One thing I see forgotten in here is the fact that SMAA can optionally be temporal itself, also known as SMAAT2x |
I think temporal SMAA is actually stale, since updated TAA and TAAU (FSR 2) techniques have largely superseded any of the benefits temporal SMAA can offer today. But the single pass SMAA stays relevant and best in class due to the lack of development on non-temporal post process antialiasing methods. |
SMAAT2x still beats our TAA implementation in quality and likely even performance (though that is largely because of just how totally borked it is) and FSR2 is really expensive at native res, though I don't know the diff between SMAAT2x and FSR2 |
Absolutely, but as you say, that's a testament to how terrible Godot's TAA implementation is, rather than SMAA T2x being the way to go. And the current FSR 2 implementation has a disproportionately high performance cost - it's damn near 12% of GPU time on a relatively heavy and complex scene - so some optimization work is definitely due there. |
FSR2 performance matches what AMD states for it's Performance Costs, and it's really designed for Upscaling, where you're rendering at a lower internal resolution (reducing the FSR2 cost) and Upscaling, improving the performance due to significantly less shading per frame |
Hey all, just dropping in to add that it is actually possible to implement / port reshade AA to gdshader. here is my LXAA port: someone smarter than me could probably do a CMAA2 port if they wanted to. pretty tired of waiting for AA from godot, considering that FXAA is stale, TAA is broken (motion smear). |
I've never heard of HHAA, did you make it yourself? |
Yup, the idea was to be more aggressive than LXAA (which tends to be extremely conservative for the sake of anti-blur), but less blurry than the blur-fest that is FXAA. HHAA is a weird hybrid/combined antialiasing shader, but imo it works pretty well (I do believe it could still be more aggressive - though I don't think I'm smart enough to make something better than this). Because of its completely custom nature though, it may have a sizeable performance impact, though I roughly tested it and it seems to be fine. Also may have bugs in implementation. |
It produces pretty SMAAesque results to my eyes when I tested it on Bistro-Demo-Tweaked. Any chance you could port CeeJayDK's SMAA? 👉👈🥺 I tried it myself but I have zero shader knowledge and only got as far as porting the UI variables 😅 |
Inexperienced with setting up shaders for Godot here, how would one implement either of these in a 3D template? |
Tested the two out, HHAA is good but you were right about it being very aggressive as it does not seem to like particle effects whatsoever. This is using the default values for the hhaa-d shader. |
yeah, after making HHAA-D, I did a whole bunch more testing and ironed out the bugs. The edge detection in HHAA originally had a ton of false positives that were being dropped later on by the blending technique. I made an improved version called AHAA (actually being used in a shipgame now), maybe that would be better? also, another thing is that it is VERY important to set the render_priority of the ShaderMaterial to -128 (also causes the noise issue). |
The render_priority was the only thing that was messing me up, thank you so very much for this |
The recent fantastic progress on implementing motion blur as a Compositor effect has got me thinking - how hard would it be to implement SMAA as a compositor effect? ᵃⁿᵈ ʷᵒᵘˡᵈ ᵃⁿʸᵒⁿᵉ ᵇᵉ ʷⁱˡˡⁱⁿᵍ ᵗᵒ ⁱᵐᵖˡᵉᵐᵉⁿᵗ ⁱᵗ ᵖˡᵉᵃˢᵉ 😁 |
I think it's within the realm of possibility, as multipass effects can be implemented this way. In fact, it's probably easier than motion blur since SMAA only depends on the color buffer (at least in its higher quality modes, which are most relevant in 2024). |
Just made an SMAA compositor effect here. It's only SMAA 1x, but I plan on working on T2x soon. |
Raymond there's nothing else to say, you're based, you're a chad, you are him, and all the other Gen Z superlatives I can muster 💖💖💖 I've tested the compositor effect and it's perfect. Looks exactly as you'd expect, works at differing render scales, costs pretty much nothing in terms of performance. For anyone else looking to use RGDTAB's compositor effect, I heavilly recommend setting the edge detection method to color and the quality to at least high. (medium and below disables diagonal and corner detection, which has a disproportionate cost to quality compared to the meager performance benefits) |
Color isn't the best, it'll introduce Moire artifacts (similar to FXAA) on some objects with High frequency textures: SMAA Color Ultra (same happens on all other settings) SMAA Luma Ultra (same on all other settings) As the person who made a PR (godotengine/godot#89582) to update Godot's FXAA to Nvidia's FXAA version 3.11 I'm glad you've made that essentially obsolete for Godot IMHO, and I'm looking forward to seeing what other modes of SMAA will be like in Godot Probably Best Settings to use are the Luma mode on High |
Moire on patterns is an expected (and acceptable) side effect of full morphological AA - the alternative would be not touching certain parts of the image, which would allow aliasing. IIRC both Jorge Jimenez (the creator of SMAA) and Christian Jensen (implemented SMAA for SweetFX) have confirmed that Luma was always meant to be a less accurate but faster mode, and is pretty much just a legacy leftover from the old days. Using Luma in actual game scenarios, you'll miss out on anti-aliasing texture detail, foliage, and even edges within shadowed areas. In SweetFX, which would pretty much be the reference implementation nowadays since games stopped using SMAA, the default is Color and Ultra - but with threshold set to 0.1 rather than 0.05. |
well seems something is wrong with SMAA implementation if so, as there's virtually no difference in any of the scenarios mentioned, in fact upon further testing it isn't really providing AA for Shadows at all (past the dithering a little) |
Not the shadows: objects and surfaces in shadow. Basically scenarios where there's low luminance contrast and only high color contrast. This was more relevant back in the old days where lots of open world games only had IBL as ambient light as opposed to the fancier bounce lighting we tend to have nowadays, but is fundamentally relevant to the difference of the two approaches. Luma: Color: Open the images in fullscreen, note the boundary between tree bark and tree leaves, and the grass. |
as far as SMAAT2x is concerned, jittering the camera could be a problem, as Camera3D doesn't allow you to modify the Projection, although it Does allow you to get it using |
Yeah, you're right. It looks like there's an open PR to allow custom Camera3D projection matrices, so once that gets merged I'll start work on it. |
This is actually amazing dude THANK YOU |
I come here based on one single Youtube comment - so beware. 😄 It said, that SMAA is the only viable option for VR. After reading that threat, I somehow question it, although I have to say, TAA seems not a good option for this use case for sure. What do we use - and recommend for VR? Alternatives, that we haven't implemented yet? |
TAA is 100% bad for VR, you are going to make your players sick, guaranteed, doesn't matter if it's really sharp or fancy like DLSS. SMAA will be better for VR, but still fundementally flawed, since you'll still get subpixel "dancing" and general inconsistency between the two renders. This'll be true for any post process antialiasing solution. The only viable options for VR are MSAA... and SSAA I guess, but I don't think it's practical to require a supercomputer from your players 😅 |
FXAA and SMAA are the only viable options for VR. Now FXAA and SMAA also give slightly different results from eye to eye, but they're on the level of "so does no antialiasing, you just have to live with it" type of deal, and is somewhat mitigated by the ultra high resolutions made possible by eye tracking and VRS |
On mobile hardware based VR platforms like the Quest, MSAA is not as deleteriously expensive as it is on PC/console, and is more practical. (Although still expensive) On PC VR, you'll either follow in the footsteps of Half Life Alyx and make MSAA work at all costs and have players enjoy your game, or you'll go the Bethesda route and deploy with TAA or FXAA and turn players off VR forever. There's no easy path - the harsh reality with VR right now is if you can't afford MSAA with your project, then you can't afford your project, period. Even in Unreal, the proper way to do VR is to switch to the Forward renderer to get MSAA, and live with the much more limited feature set. Of course, you get a lot of amateurs ignoring that advice and releasing blurry ass TAA VR games anyway... |
It seems like Unreal, Unity, and a bunch of others add a specially adjusted TAA for VR. But I dont have any experience with it. To me, this reads like a custom AA for VR is suitable. Khornos is the only entity, I see capable doing that. |
The person writing to you probably meant MSAA instead of SMAA. These are easily confused for each other but are very different. MSAA is multisample antialiasing (not post-process AA) while SMAA is subpixel morphological antialiasing (post-process AA). Post-process AA is not suited for VR in general, since most of the aliasing that's distracting in VR is of a subpixel nature (and post-process AA can't do anything about it). |
I see. Adjusting the AA for VR, like to accomodate for edge detection, specifically tuned for VR lens distortion and implementing per-eye processing, is something done in any of the AA in Godot? |
Not that I know of, but I wouldn't use FXAA in VR in any engine due to its blurriness. |
But that should apply to TAA as well, right? |
Yes, TAA has similar problems with VR (on top of ghosting issues). |
Just to be sure, pancake optics can provide clearer edge definition, so they are less susepticle to that? And considering that higher resolution displays spread the effect across more pixels, I assume that makes individual subpixel patterns less noticeable? It would also be more noticable on OLEDs, considering their uneven subpixel distribution? |
While pancakes look sharper to the human eye, the underlying issues with post-processing based AA blur being noticeable are still there. Besides, it's not like modern VR displays are too sharp right now. They've made big strides since 2014 for sure, but the screen door effect is still a problem in 2024. Even my Quest 3 with 1.5x supersampling on each axis still looks a bit blurry, and that's without any lens inserts (I wear glasses with slight correction normally, so I'm comparing it to real vision without glasses). To get a truly sharp image in VR for a majority of users (where pixels are impossible to distinguish from each other), you'd need 8K resolution. |
Related to #3401.
Describe the project you are working on
The Godot editor 🙂
Describe the problem or limitation you are having in your project
Right now, we have MSAA and FXAA available in both
3.x
andmaster
. These algorithms serve their intended purposes, but each of them has their own limitations:master
due to the added complexity of shaders. This is especially noticeable when using GIProbe or SDFGI. It also doesn't smooth out aliasing that originates from fragment shaders such as specular aliasing. (Alpha-tested surfaces are now well-handled thanks to alpha antialiasing and alpha-to-coverage support.)It's possible to use both MSAA and FXAA at the same time, but this has a significant cost and it won't improve the image's sharpness after it has been reduced by FXAA.
It's great that MSAA is still supported in
master
(thanks to the clustered forward renderer), but we have to admit that it's difficult to use in production with today's shader complexity. Therefore, this makes MSAA mostly suited to games that use few visual effects, which generally implies a stylized art direction.Describe the feature / enhancement and how it helps to overcome the problem or limitation
Sub-pixel morphological antialiasing (SMAA) has been around since 2011 and is now a proven post-processing-based antialiasing algorithm. It's still used in a lot of AAA games.
Performance-wise, SMAA is more expensive than FXAA, but it does a good job at antialiasing despite introducing less blurriness. Either way, SMAA is likely to be less expensive than even 2× MSAA on the Vulkan renderer (despite providing better edge smoothing overall).
Describe how your proposal will work, with code, pseudo-code, mock-ups, and/or diagrams
One downside of SMAA is that it's notoriously difficult to implement. Not only it's a multi-pass algorithm (unlike FXAA which is single-pass), there are also many quality settings to tinker with.
We can probably go with the recommended SMAA settings (luma-based edge detection), and only see if there are real benefits to exposing quality knobs in the project settings (such as changing the edge detection algorithm).
SMAA also offers an optional temporal component, but that comes with added complexity and motion trails commonly associated with temporal antialiasing algorithms. Therefore, I suggest we leave out the temporal antialiasing part of SMAA and focus on spatial-only SMAA (also called SMAA 1×). SMAA won't look as smooth without this temporal component, but SMAA still looks better than FXAA without it.
I've looked around a bit and couldn't figure out how to add a multi-pass post processing shader in Godot's GLSL core, so feel free to give it a try.
Question: Can this be implemented in
3.x
?I haven't seen any implementation of SMAA on OpenGL ES 3.0 (and even less OpenGL ES 2.0), so probably not.Edit: It's possible to implement SMAA in WebGL 2.0 (and therefore OpenGL ES 3.0): https://github.com/dmnsgn/glsl-smaa
If this enhancement will not be used often, can it be worked around with a few lines of script?
Since real-time multi-pass shaders aren't possible in "userland" Godot yet, no.
Is there a reason why this should be core and not an add-on in the asset library?
See above.
The text was updated successfully, but these errors were encountered: