Hi,
How triangles are counted in DebugHud? I see that I have counted about 8 times more than it is in models. What could be the reason for this surplus?
Triangles calculation in DebugHud
data:image/s3,"s3://crabby-images/d4887/d488753d86ff0b8e668b5953ee479473df639683" alt=""
data:image/s3,"s3://crabby-images/e0b18/e0b1844b622603647b09d480acb4e5684a8ba5c6" alt=""
More info, plz. Shadows, viewports, text, anything.
E.g. screenshot of Uhro window.
data:image/s3,"s3://crabby-images/aa30a/aa30a80677a3293677c1029ff9709c67f6c582c4" alt=""
I found same problem some time ago. DebugHud always add its text triangles to summary triangles count. It adds about 10000 triangles if DebugHud is in DEBUGHUD_SHOW_ALL mode.
data:image/s3,"s3://crabby-images/c0311/c0311e8e58fc49e4891324db443d239704df852c" alt=""
Sorry to reply this old post.
I am having the same question.
I have two terrains, each is constructed by a 65*65 heightmap.
So for each terrain, I expect 64 * 64 * 2 = 8192 triangles. Total would be
~16,000 triangles.
But I am seeing
61,559 triangles instead,
about
4 times more
!
Attached two screenshots.
Overview
Zoom In (you can count the size manually)
data:image/s3,"s3://crabby-images/701bd/701bd92880b7ea239da6b0aa3b0a5a6183bd6a65" alt=""
It looks to me that you have 64 x 64 quads per height map, so 128 x 128 triangles x 2. That puts you at ~33k. The rest is apparently taken up by the HUD text and logo.
data:image/s3,"s3://crabby-images/c0311/c0311e8e58fc49e4891324db443d239704df852c" alt=""
Correct me if I am wrong, but
1 quad = 2 triangles
, so 64 x 64
quads
= 64 * 64 * 2 = 8192 triangles. Two terrains make it into
~16k
. I think you double counted it.
Even by your calculation, the logo and HUD is making up the rest ~30k triangles which does not make any sense to me?
data:image/s3,"s3://crabby-images/c0311/c0311e8e58fc49e4891324db443d239704df852c" alt=""
I did a simple test, just rotate the camera to the background and no terrain showing.
The base count of triangles
~11k
.
This agrees with @
KonstantTom
’s result
data:image/s3,"s3://crabby-images/701bd/701bd92880b7ea239da6b0aa3b0a5a6183bd6a65" alt=""
My bad. I misread your post and didn’t see that you multiplied by 2 before doubling (and yeah, if counting the triangles across, my formula should have been 128 x 64 x 2 = ~16K).
So, I did a test with an empty scene and got ~12k tris. Then I threw a model in and got 97k tris. However, that model in Blender is only 28k Tris… So, it looks like something
is
wrong. I never questioned it before
data:image/s3,"s3://crabby-images/c0311/c0311e8e58fc49e4891324db443d239704df852c" alt=""
That’s interesting.
So basically for my case,
the display triangles / real triagnels = (62k - 12k) / 16k ~ 3 times;
For your case,
the display triangles / real triagnels = (97k - 12k) / 28k ~ 3 times;
A quick guess would be the calculation counted vertices instead of triangles .
But I took a quick look at the source code, could not find anything suspicious. For example, in
D3D11Graphics.cpp
or
OGLGraphics.cpp
, we can get the
primitiveCount
number.
static void GetD3DPrimitiveType(unsigned elementCount, PrimitiveType type, unsigned& primitiveCount,
D3D_PRIMITIVE_TOPOLOGY& d3dPrimitiveType)
{
switch (type)
{
case TRIANGLE_LIST:
primitiveCount = elementCount / 3;
d3dPrimitiveType = D3D_PRIMITIVE_TOPOLOGY_TRIANGLELIST;
break;
...
}
}
Anyway, I believe it should be just a mis-count somewhere, not mistakenly rendering more triangles than we need. So it should not impact the performance.
data:image/s3,"s3://crabby-images/cfa6e/cfa6edf196155245acfc9df43dc6f733027b2dc8" alt=""
Note that in forward rendering, each per-pixel light will re-render the affected geometry. If you have an unlit scene there should be just a single pass.
For shadowed lights, there will be also shadow map pass, which renders even more triangles.
data:image/s3,"s3://crabby-images/c0311/c0311e8e58fc49e4891324db443d239704df852c" alt=""
Ah! That explains it!
I do have 3 lights in the scene.
When I leave only one light there, the total triangle count is ~28k, exactly 16k + base 12k.
Thanks so much for pointing this out ! Lasse!
I am still learning all those computer graphics rendering techniques. I am writing a custom terrain class to dynamically create/destroy patches for a super large world.