Nanite making my meshes super low poly and causing shading issues

Hello everyone, I’ve been fighting with this problem for a few days now and cant seem to figure out the issue.

I am working with a high-poly detailed model of a vehicle with over 45mio polygons. I have imported the model using the datasmith format (exported from blender using the datasmith exporter add-on) via a dataprep asset.
In the Dataprep asset itself I am simply applying a Material Substitution table to assign all of my UE materials and then merging the objects.

I am doing this separately for the wheels, interior, exterior, glass objects, the centre console flap (so I can animate it) and the seats. This means I end up with 6 objects.

Due to the High polygon count I need to enable nanite so that my fps jumps from 25/30 to around 70/80.

Unfortunately when enabling nanite I encounter a few problems:


First Problem - Low Poly Results

For some reason, my models seem to get optimized when enabling nanite and result in chunky, low-poly looking meshes, even from up close where 100% of the triangle count should be used.

In this image you can see the ambient light ring, the circular air vents and the Centre Console flap being very low poly. The reflections on the black bar (top left) are also very bad.
image

I’ve tried various settings:

  • Reducing the “Fallback Target Relativ Error” to 0
  • checked the object scale (its imported correctly)
  • checked screen percentage (yes its set to 100%)
  • decreased “r.Nanite.MaxPixelsPerEdge” to 0.2 and still no change

As you can see here, the normals themselves are fine on the nanite version

and here the non-nanite version:

I find it odd that the triangles on e.g. the centre console flap are optimized very much compared to the centre consoel around it. One could argue that the object is flat and therefore can be optimized more, but as you can see from the image above, the corners are completely broken.

What am I missing here?


Second Problem: Shading Issues

I need raytrace shadows enabled. When enabling nanite my geometry receives very weird shading issues as can be seen below:

Yes I have tried applying all fixes noted in william fauchers video.

The only thing that remotely worked was reducing the “Fallback Target Relativ Error” to 0, however, even then I had some artefacts which are not acceptable in my scene.

To fix the issue, I currently have “r.RayTracing.NormalBias” set to 3, however this brings its own shading problems with it, so I’d like to see if there are alternatives you guys might be able to suggest.


I would very much appreciate any help I can get on this matter as I cant find anything about this online.

Hey!

Were you able to fix this problem?

Yes, although I’m not entirely sure how. Regarding the nanite polygon scaling issue I have done some additional data-prep to the file and the issue seems to be resolved, I assume it might have been an issue with transforms not have been frozen/applied before importing into UE5.

Regarding the shading I believe the following Console Var solved the issue:
r.Raytracing.Shadows.EnableTwoSidedGeometry 0

When you enable Nanite on a mesh, it also creates a fallback mesh. This means that it uses traditional LODs for the fallback mesh and made it too low poly. To adjust the resolution of your fallback mesh; under your Nanite settings for the mesh, switch the Fallback Target from Auto (default) to “Relative Error” and then set the Relative Error value to a low number (0.1 for example).

A lower number will create a higher-resolution fallback mesh. You can see the triangles of your fallback mesh under the mesh details shown in the top left corner of Persona.

I need to point out that THIS IS NOT THE ACTUAL FIX - If your mesh looks low poly with Nanite enabled, it means that it’s not using nanite for the mesh, but instead rendering your fallback mesh. So although switching to Relative Error and setting the value to 0.1 will seemingly fix the problem, it’s just an illusion because all you did was increase the polycount of the mesh that is being displayed (which you may want to do anyway mind you).

The actual solution is to figure out why your mesh isn’t using Nanite even if Nanite is enabled. The most likely reason is that your mesh is probably using a translucent material which is not yet supported on Nanite meshes. The solution here is to either separate the translucent parts of the mesh and make them non-nanite meshes, or to disable translucency on any materials that are applied to the nanite mesh. The fastest way is to disable translucency on your material (to make sure this is the problem) by opening your material instance, scrolling to the Material Override section, and switching Blend Mode from Translucent to Opaque.

Or if you’re not using a material instance, make this change in the master material.

If removing the translucent material doesn’t fix the issue, here’s a link to the currently supported features of nanite:

1 Like

check with preserve data enabled in nanite