Texture Streaming in Echoes of the Atlas


There has been a bit of confusion about this recently, so I felt it was best to explain what Texture Streaming is for, how it helps, and further improvements we will make based on recent feedback.

Historically, Path of Exile's engine would drop a lot of frames (causing a bad stutter) whenever a new asset needed to be rendered but hadn't been loaded yet. So for example, you used a skill for the first time, it'd stutter for a bit while loading the relevant shaders and textures from the hard drive. We mitigated this somewhat with various preloading systems where the game starts to load assets in advance once it knows you're about to encounter them, but it wasn't really a perfect solution.

Improvements to the engine over the last year have had a focus on trying as hard as possible to maintain a stable frame rate, regardless of what is happening. This involves being able to draw a frame even if certain assets aren't loaded yet. The simplest example of this is that if the shader for something isn't loaded yet, then the game doesn't know how to draw it at all, so nothing is drawn. Shaders are given very high priority and so it's quite rare to see something flash into existence, but it can happen occasionally. We feel that this compromise is better than having the whole game client stall until that asset is loaded.

While shaders are fast to load, textures can be a lot slower, as they are often hundreds of kilobytes in size. If no texture was loaded, then the game client would just render the object entirely in black. This didn't look great, but we also didn't want to have the entire client stall while loading the texture. So our compromise was to generate a pack of blurry low-resolution versions of all the textures in the game, make sure it's preloaded right when you launch the client, and then use these stand-in textures while the full ones are loaded.

This "Texture Streaming" tech was added in Echoes of the Atlas, and its goal is to maintain a stable frame rate (never stuttering while assets are loaded) and still drawing something relatively close to the full-detail version of the asset so that you can play while loading is finishing. Further improvements to this system were made in today's 3.13.1 patch with the goal of not consuming too many CPU cores on slower systems.

While it's acceptable for assets to briefly be drawn with blurry-textures during gameplay when they first appear (and is far better than a stall, drawing nothing, or drawing pure blackness), it's not great at all when you load into an area and everything looks terrible for a period of time. We are trying to re-engineer stuff so that the initial loading screen covers the initial asset loading, as it should do. This should ideally mean the new system is only upside - a stable frame rate and no sustained period of terrible texture load-in for some users. We don't have a timeline for this currently but it's hopefully like a week or two. Rest assured that we're going to keep working on this until it's a good experience.

In addition to the above explanation, it's also important to understand that Texture Streaming is the backbone of an ongoing memory usage improvement project that will help make Path of Exile 2 perform well with its higher-detail assets.

There are various other reports of bad performance that are being attributed to Texture Streaming but we believe are not related. Those performance problems are real, and we are investigating them on a case-by-case basis, but they are being conflated with texture streaming when they are actually just unrelated engine issues that we need to identify and fix.
Posted by 
on
Grinding Gear Games
Is it possible to show the wireframes of stuff that's being loaded instead of a blurry texture, or am I talking out of my ass?
IRON MAN
Thx
Last edited by SneakySkiler on Jan 27, 2021, 10:17:56 PM
This is all the majority of us wants. Transparency, thank you for saying something.
3rd
Thanks for the communique! Keep up the great work!
IGN: Steeldraconis
G3 Patreon: https://www.patreon.com/goodguygaming
Youtube: http://tinyurl.com/y5nvpcpo
Check out the CHAD Zerker build: https://www.pathofexile.com/forum/view-thread/2478633
S𓆣C𓆣A𓆣R𓆣A𓆣B𓆣G𓆣O𓆣D𓆣L𓆣I𓆣V𓆣E𓆣S𓆣
Last year GGG rolled out a resolution slider for Mac. How come they didn't implement this for PC and Console Users too?
Just another Forum Signature in a Sea of Signatures.
XD?
first keppo
Is there any news of the performance issues potentially related to these texture streaming modifcations?

My game completely freezes for 2-3 seconds whenever I open a harvest or start a delirium or a legion pops, and so far I have not been able to find a solution.

Honestly, I'm more okay with the low res textures; but the game freezing for a few seconds is a pretty big issue because oftentimes my character is dead by the time the game unfreezes
Last edited by distort3d on Jan 27, 2021, 10:20:34 PM

Report Forum Post

Report Account:

Report Type

Additional Info