A new version of our low poly terrain tool - Polaris - has been started for a while which aim to supercharge runtime & editor performance, enhance workflow & experience, strengthen assets integration and many more.
In this post, we will give you a first glance at what we've achieved so far!
*This post was written during the development of the asset. Things are subject to change.
Upgraded foliage renderers
In this version, tree and grass renderer are completely destroyed and rebuilt. Culling process now done quickly and precisely, which greatly reduce the workload put on your GPU, while efficiently use the spare power on the CPU. It also comes with better LOD-ing so you can build more complex outdoor scene.
Cell-based culling for tree
The terrain space is recursively subdivided into smaller "cells" using quadtree, where each cell contains 4 children cells. We test each cells agains the camera view frustum, if a cell is culled, we can quickly remove all children cells from the visible set.
Applying this method offer a huge gain in culling time.
To squeeze it even more, we shrink those cells so they only encapsulate their content:
Additional level of detail for tree & grass
Tree & grass now support an additional LOD1, where you can choose to use simpler models and materials that take less time to render on the GPU (fewer vertices, disable expensive visual effects such as wind, translucency, etc.)
There is also a "LOD Transition Distance" setting to nicely blend between LOD.
Ever wonder why we can reduce the grass vertex count without changing it look? Here's the trick:
For LOD0, we use a regular quad mesh:
For LOD1, we use a flipped triangle, where the tip goes deep below the "zero line"
Just 1 vertex? That doesn't sound impressive!
Hold on, the saving is far more with other grass shapes, especially when you have millions of instances.
LOD0 vertex count | LOD1 vertex count | Save % | Save per 1M instances | |
---|---|---|---|---|
Quad | 4 | 3 | 25% | 250K |
Cross | 8 | 5 | 37.5% | 375K |
TriCross | 12 | 7 | 41.7% | 417K |
Clump | 60 | 45 | 25% | 250K |
Benchmarking
We've setup 2 project in Unity 2022.3.9f1, one uses Polaris 2021 and one uses Polaris 3, with a grid of 3x3 terrains with the same settings and compare the result using Unity's analysis tools (Profiler, Frame Debugger, Stats).
System specs:
Intel Core i9 9900K, 3.6 GHz, 16 cores
NVIDIA GeForce RTX 2060
Note: result may differ depending on machine specs & scene setup. Data below is for reference only.
Time spent on the TreeRenderer.Render() function with 135K trees in the scene:
Frame time & stats with 135K trees in the scene:
Time spent on the GrassRenderer.Render() function with 1 million instances in the scene:
Frame time & stats with 1 million grass instances in the scene:
You can see that Polaris 3 has a reduction in batches & vertices count, which is valuable especially on mobile devices.
Frame time & stats in the Demo_00 scene:
It's clear that there is performance gain for existing scenes, just by upgrading the asset.
Improvement to low poly terrain mesh generation
Seams matching
Seams matching between terrain tiles will now write to the terrain datas.
Prior to this, adjacent tiles will calculate the median height value at a point "on the fly". This introduce a problem that seams won't match anymore if you dynamically load/unload tiles.
With this change, it's now easier to do terrain streaming without breaking the scene.
Mesh creation
It just got faster!
After a several optimizations, the Profiler showed an impressive result:
Processing time is about 334% faster.
Heap allocation is about 248% less.
Actual time may vary depending on your setup. We've a few screenshots of stats on the Discord channel.
Final words
And that's what we've got so far. Good things are coming!
Follow our devlog to learn more about exciting features ahead.
Low poly terrain creation is just a very small part of the making of your game, we hope our effort for Polaris can contribute something to your game's success.
If you're using or plan to use Polaris in your dream project, we're proud to be a part of it.
Comments