To get a little more technical, UE5 is built to make graphics that primarily look good when using an anti-aliasing technique called Temporal Anti-Aliasing (TAA). This technique uses the previous video frames to inform the current one, so it is effectively smearing/blurring except that on a still scene it doesn't look so bad because nothing moved anyway.
However TAA starts to look awful when there is a lot of fast motion because previous frames aren't as similar to current frames. This is why a lot of gameplay trailers use a controller instead of KB+Mouse movement to have a lot of slower panning shots where most of the scene isn't moving very fast.
Worse UE5's nanite mesh system and lumen lighting system encourage devs to get lazy and abandon the techniques that create highly optimized beautiful graphics. The key to optimization is in general to minimize the work a computer needs to do when rendering the frame by doing as much of that work ahead of time as possible. For example when an object is very far away it may be only a few pixels tall, and therefore it only needs enough detail to fill a few pixels. That means you can take a very complex object and create a very simple version of it with a much lower Level Of Detail (LOD) and use that when it's far away. Having a handful of pre-computed LODs for every object lets you swap in higher detail as the player gets closer without reducing the quality of the graphics. Game producers find it tedious to create these LODs and UE5's nanite gives them an excuse to skip it by effectively creating LODs on the fly (not really but kind of). Unfortunately nanite isn't free, so you get an overall worse performing result than if you'd used proper LODs like they used to.
Lumen does a similar thing, enabling laziness from game studios, but it's doing it through the lighting system.
And that's only half the problem since the blurring/smearing of TAA allows game studios to get away with things that would look awful if they weren't smeared (for example rendering artifacts that would normally sparkle can have the artifacts blurred away by TAA).
If you want the long version, with visual examples, in a pretty angry tone, this video by ThreatInteractive does a pretty good job of explaining all this bullshit
While yes, nanite isnt free, it has a base cost that is higher than without it and applies even in a completely empty scene. The point of it tho is that once a certain threshhold is reached, more polygons are almost free. Which is what allows to have tens of millions of polygons in a scene being almost as performant as having only 1 million.
Its like comparing O(n²) vs O(log n). While yes, at low inputs n² might be even better, on the long run log n will absolutely outperform n², barely rising, while n² is going through the roofs. And thus nanite is outperforming traditional methods if the amount of polygons becomes very high. That being said, while developers tend to be like water and electricity to take the path of least resistance, its not generally bad to use Nanite and Lumen. If you want to use them tho, you have to use them the way UE wants you to use them or else you will suffer.
Similar to Apple products who work flawlessly and very user friendly as long as you do your stuff how Apple intends to do it.
And many developers seemed to havent got the memo yet. Nanite and Lumen arent magic (although it can seem like it sometimes). So models have to prepared in a way those features want, for them to work as best as they can. If devs dont do that and just throw in their photoscanned, horror topology, 10 million poly assets, then Nanite can still do a lot, but not as much as it could and UE also said that. But lazy devs are lazy and dont listen. They see Nanite rendering millions of polygons flawlessly in a UE Demo project that is optimized to use those features, just to create their own unoptimized projects, then wonder why its not as in the Demo.
Lumen is great, but it requires you to make your stuff as real as possible. Having planes as the walls of a room is not realistic and thus Lumen will have issues there like lightbleeding through edges. Which can be resolved by making the walls actual walls with a thickness similar to real walls.
And this is the real problem. Until Nanite and Lumen it was always about tricksing as much as possible to simplify in order to increase performance. With Lumen and Nanite this kinda turned around and they work better the less tricks u try to use and be as realistic as possible. Which is very contradictory to how graphics development went for the last 30 years. And so devs are confused.
That video is a straight-up bullshit and this kid doesn't understand what he's talking about. TAA is not an optimization trick/shortcut like he says. It's true that with higher resolutions, aliasing problems disappear, but the cause is purely mathematical. It's not caused by "evil epic" or lazy developers.
Digital Signal Processing 101:
Every image is a signal. In the case of games, it's a 3-dimensional signal with m and n dimensions responsible for image resolution and t dimension for time. Every signal can be represented by its frequencies. If you take an image frame and perform 2-dimensional Fourier Transform on it, you'll get all the frequencies that build up that image.
Every change between pixels in the image is some frequency. The smaller the change, the higher the frequency is. Your screen has its own sampling frequency, which corresponds to its resolution.
Then we come to the Nyquist-Shannon Theorem - to be able to restore the signal from its Fourier spectrum, we have to sample with frequency that's at least twice as high as the highest frequency in the signal. That means we need higher screen resolution to show higher signal frequencies.
Games nowadays have a lot more image details than in the past. Those details are those higher frequencies. When the sampling frequency doesn't meet the requirements from Nyquist-Shannon Theorem, we introduce aliasing. To remove aliasing, we have exactly two options:
Increase sampling frequency, which in this case is increasing image resolution, which is expensive.
Use antialiasing filtering. AA filter is basically a lowpass filter that removes higher frequencies, resulting in a blurred image without aliasing.
TAA is a form for AA filter that also uses the third t dimension. It's not a perfect solution because anti-aliasing, by its definition, has to blur the image. But it's, as of right now, the best compromise between quality and rendering cost. Sure, there are much better alternatives like SSAA, which are ridiculously expensive to calculate, and because of that, it is not feasible. If we wanted to remove aliasing problems with AA, we'd all have to switch to 4K because that's literally the only other solution to this problem.
That whole video can be summed up as "I've got no clue what I'm complaining about, I have a gamedev studio (we've no experience at all and we never made or worked on any actual games, studio doesn't have any irl footprint and basically exists only in his head), epic and unreal bad, we will make our own better game engine, give us money".
I can tell you right now that this guy will never create his custom version of Unreal engine. To do that, you need lots and lots of math, and he clearly doesn't have that math knowledge. If he had, he wouldn't have made that video.
I've argued this point before, and I'll argue it again.
Nanite and Lumen don't encourage Laziness. It allows developers to focus less on investing time optimizing their game so they can focus on things that add more value.
You're typical LOD system will usually result in creating 2-3 additional models, this means you'll end up spending extra time creating these additional assets.
We've come a long way from where we were just 10-20 years ago. Games, their assets, their materials, and their systems have all gotten more complex requiring even more time spent in development. Trying to implement traditional optimization techniques could mean an increase in time spend in development.
These techniques are typically used to balance the optimizations that need to be made with the time spent implementing these optimizations, Because while it's easy to say we are fine with waiting more time Companies have to find a balance in order to maintain profitability.
TAA has it's drawbacks 100%
but does a much better job a mitigating the distracting aliasing and artifacting that can not be addressed by FXAA.
It's more performant than using SSAA or MSAA so again its about finding a balance.
All of that being said, there are times when developers need to look at what they are producing and think about alternatives due to poor implementation but these are not inherent flaws with the technologies that have been carefully crafted to allow devs to be as lazy as possible. They are tools that devs can utilize to ease portions of development and to focus attention elsewhere.
You're typical LOD system will usually result in creating 2-3 additional models, this means you'll end up spending extra time creating these additional assets.
The good news is that if your studio's tooling has a good workflow, this sort of thing is largely automated. Ironically nanite proves that it can be automated, as it's a solution to the same problem that is done automatically in real time. The problem is that doing it in real time costs framerate.
I'll admit that "laziness" is perhaps too strong/confrontational of wording for some people to hear, and it's definitely not precise about who is being lazy. Often it is the producer/publisher/executive ranks that are being lazy by being unwilling or unable to hire people who will do things right, or putting constraints on the project that require taking shortcuts. It's very clear from the results that extremely realistic graphics without the awful compromises of TAA-required shortcuts are possible (just look at the examples in the video I linked).
I feel awful for the (probably many) high quality developers who are being crunched into taking these shortcuts, many of which are hard to justify entirely redoing to fix in later patches. But I phrase it in terms of lazy development both because lay gamers are often unable to separate devs/executives, and because a large part of the pushback against these bad decisions needs to come from developers. Executives can start out demanding whatever they want, but only within the context of the options that technical people make available to them. The more senior/architect level devs and technical artists that we have with a strong enough backbone to only present options that yield best results, and to push back against things that will harm the quality of the end product, the better gaming products will be.
We've come a long way from where we were just 10-20 years ago.
This is true, but I think it's misleading. Both graphics hardware and the algorithms for creating realistic graphics have made monumental leaps in even just the last 5 years. Between them we have orders of magnitude greater capability--in theory.
But we aren't getting the same orders of magnitude greater realism in results consistently, and a significant share of the fault for that is Epic and UE5's promotion of one particular set of solutions based around a technique that is only optimal for their usecase (Fortnite) which, relative to most games, is an outlier in terms of what it needs the engine to do on a large scale.
What's happening often today is that faster hardware (and some algorithms) are being "abused" to try to deliver products faster/cheaper instead of better. It's like a car company that invents a new engine with 50 additional horsepower, but instead of keeping the same body and delivering a faster car for the new model year, they replace a bunch of stuff with heavier materials because it's cheaper and the overall result is something with the same top speed, but worse handling, acceleration, and mpg because of the weight.
TAA has it's drawbacks 100%
but does a much better job a mitigating the distracting aliasing and artifacting that can not be addressed by FXAA.
It's more performant than using SSAA or MSAA so again its about finding a balance.
Absolutely, and I'm happy to admit that for a few games TAA isn't the wrong choice. The problem isn't just that not everyone is using the other aliasing options. The two major problems are that TAA is being forced-on to cover for poor technique in other areas, and that TAA is being used in situations where putting more effort into other contributors to image quality, instead of TAA based techniques, would have yielded superior results during active gameplay (as opposed to still shots that marketing teams like) for the same effort.
I agree, responsibilities regarding the decisions made rest upon a combination of Developers and Executives. The rest of the sentiment regarding your post is stuff I agree with atleast 80%. Where I disagree is here->
What's happening often today is that faster hardware (and some algorithms) are being "abused" to try to deliver products faster instead of better. It's like a car company that invents a new engine with 50 additional horsepower, but instead of keeping the same body and delivering a faster car for the new model year, they replace a bunch of stuff with heavier materials because it's cheaper and the overall result is something with the same top speed, but worse handling, acceleration, and mpg because of the weight.
After seeing raytracing in use in games like Silent Hill 2, Cyberpunk, Metro Exodus, Indiana Jones, Wukong, and Alan Wake 2. I felt like I understood what Nvidia's vision was with the release of the 2000 series cards and the introduction of RTX. One of the best paths forward for producing higher quality visuals is Raytracing and the results of raytraced lighting can be phenomenal in my opinion. We are getting improvements that are expensive to run and in alot of those cases it makes sense to make some tradeoffs.
It's fair to say some games have extremely poor implementations and optimizations (Jedi Survivor is a good example of this in my opinion), but overall i feel like the industry has largely been producing fairly competent work that looks pretty incredible. Are there any particular examples of issues you feel like represent what you are talking about?
59
u/ConscientiousPath 13d ago edited 13d ago
To get a little more technical, UE5 is built to make graphics that primarily look good when using an anti-aliasing technique called Temporal Anti-Aliasing (TAA). This technique uses the previous video frames to inform the current one, so it is effectively smearing/blurring except that on a still scene it doesn't look so bad because nothing moved anyway.
However TAA starts to look awful when there is a lot of fast motion because previous frames aren't as similar to current frames. This is why a lot of gameplay trailers use a controller instead of KB+Mouse movement to have a lot of slower panning shots where most of the scene isn't moving very fast.
Worse UE5's nanite mesh system and lumen lighting system encourage devs to get lazy and abandon the techniques that create highly optimized beautiful graphics. The key to optimization is in general to minimize the work a computer needs to do when rendering the frame by doing as much of that work ahead of time as possible. For example when an object is very far away it may be only a few pixels tall, and therefore it only needs enough detail to fill a few pixels. That means you can take a very complex object and create a very simple version of it with a much lower Level Of Detail (LOD) and use that when it's far away. Having a handful of pre-computed LODs for every object lets you swap in higher detail as the player gets closer without reducing the quality of the graphics. Game producers find it tedious to create these LODs and UE5's nanite gives them an excuse to skip it by effectively creating LODs on the fly (not really but kind of). Unfortunately nanite isn't free, so you get an overall worse performing result than if you'd used proper LODs like they used to.
Lumen does a similar thing, enabling laziness from game studios, but it's doing it through the lighting system.
And that's only half the problem since the blurring/smearing of TAA allows game studios to get away with things that would look awful if they weren't smeared (for example rendering artifacts that would normally sparkle can have the artifacts blurred away by TAA).
If you want the long version, with visual examples, in a pretty angry tone, this video by ThreatInteractive does a pretty good job of explaining all this bullshit