Hi,
I'm currently developing a game in UE5, as the number of assets grows, new and unique textures also grows.
I'm wondering if Virtual texture streaming will improve (decrease) VRAM use.
Reading the documentation, and googling my question, I found little to no information at all about the benefits (real world examples) of using VTS.
In my game, I have some 4k textures and lots of 2k and smaller textures.
Does anyone have experience in projects where all textures (or some) were converted to VTS and if it bring any improvements in VRAM use ? The documentation mention that it will have more instructions per texture sample, that can affect GPU time and shader compilation times...
Does anyone have information about it ?
Replies
it has nominal effect on gpu performance, its main downside is cpu overhead - which is relatively minimal and extremely scalable.
virtual textures are specifically designed to enable large numbers of unique textures, and can reduce shader complexity if used correctly (by baking "shader features" back into the unique texture set)
The increased time in GPU and CPU is almost non existent.
Thanks a lot for pointing me to the right direction.
The static memory footprint of the assets that render into the RVT doesn't change - not a huge problem, but worth knowing that stuff doesn't completely evaporate.
You need to load all the high mips / models etc. at the time the RVT is generated (on level load / when forced) - this means the machine doing it actually needs to be able to load all the things it needs.
There is one other huge benefit to be had outside of the VRAM
Anything rendered into the RVT isn't visible at runtime so you can (for example) cover your landscape in little mesh decals (not projected decals) tell them to render into RVT (and be hidden as a result) and not pay the occlusion query or mesh rendering cost per frame.
This works extremely well - particularly on shit hardware like xbone and even switch (you still have to store the meshes in memory )
and a note
The more stuff you shove into the RVT (and the more complicated the stuff), the more time needs to be spent on updates. This can manifest as spikes in your frame times and is generally only really a problem if you are moving/turning/teleporting the camera quickly but it's worth knowing that it's a thing in case you start to see stutters.
the simple first solution is to reduce the number of actors getting rendered into the RVT - eg. by merging meshes
SVT / VT are static so there are no updates at runtime
1: using SVTs (you can bake them from the RVT volume) is a very effective way of reducing the amount of resources required at runtime- they are static so will not include any runtime edits to the RVT and are used in place of the lower mips of the RVT (try 5 levels as a starting point)
2: rendering things that animate into the RVT is expensive - those fancy demos where RVT is used to do trails in snow are probably not realistic use cases for large scale environments (not saying you couldn't, but expect some pretty significant overheads)
Beyond that, they're textures. You can use the channels for anything you want and you can render basically anything into them - the compression schemes limit you somewhat but 5.3 'should' allow you to manage a lot more RVT assets than previous releases (haven't tested it yet)
Looking forward to your reply, thank you!
without trying it my guess would be no cos it's a dynamic effect and the svt bake isn't done from a 'distance'.
the low tech solution would be to manually force the distant textures to be visible when you build the svt - I expect a bit of poking round in the engine code could get you a tickybox though
one thing it might be worth investigating is whether you can sample the built SVT in a material (I'm not sure whether it's exposed/exposable or not). you could potentially blend between a couple of them if it is.