11-25-2019, 08:40 AM
Blog: Handling Unity scene hierarchy and performance
<div style="margin: 5px 5% 10px 5%;"><img src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance.jpg" width="469" height="250" title="" alt="" /></div><div><p><strong><i><small> The following blog post, unless otherwise noted, was written by a member of Gamasutras community.<br />The thoughts and opinions expressed are those of the writer and not Gamasutra or its parent company. </small></i></strong> </p>
<hr>
<p data-css="tve-u-16e85c2bf35"><em>Last week, I wrote a </em><a href="https://thegamedev.guru/unity-performance/scene-hierarchy-optimization/" target="_blank" rel="noopener noreferrer"><em>post </em></a><em>to show you </em><em>how your unity scene hierarchy is reducing the performance of your game</em><em>. That post arose awareness across many of you developers. And so, many of you asked great questions that I’ll answer in today’s entry.</em></p>
<p data-css="tve-u-16e85c2bf35"><em>[The original post can be found <a href="https://thegamedev.guru/unity-performance/scene-hierarchy-catch-that-performance-thief-part-2/" target="_blank" rel="noopener noreferrer">here</a>]</em></p>
<p><img alt data-css="tve-u-16e85c27d93" data-id="3974" height="250" src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance.jpg" title="Unity-Scene-Hierarchy-Part2-Thumbnail" width="469"></p>
<p>Yes… I confess.</p>
<p>The examples I often show you in my blog posts are not real-life projects. This is one of the points you have been commenting on.</p>
<p><em>Ruben, this is an artificial scenario.</em></p>
<p><em>Ruben, this doesn’t happen in games.</em></p>
<p>You see, I understand. It’s easy to doubt the information I provide you when the only cases you see are extreme.<s> I’d even rub some salt in the wound on the Reddit threads if the author wasn’t me (see <a href="https://www.reddit.com/r/gamedev/comments/dv71y1/unity_your_scene_hierarchy_is_robbing_you/" target="_blank" rel="noopener noreferrer">how I got owned</a>).</s></p>
<p>But here’s the thing: all the information I give you is based on the <strong>pain and gains of real-life projects</strong> I worked on. I do my research before I write here too.</p>
<p>Doing research is great. But that takes time. A lot.</p>
<p>So I won’t set up a new game for every weekly post that I publish. What I do instead is to create a small project to make a point…</p>
<p>…A very real point that I experienced in production games.</p>
<p>You’re never going to come across the exact dummy project in your games. <strong>But you’re likely to suffer from the issues these points reveal</strong>.</p>
<p>And that’s what matters.</p>
<p>So I took some of the feedback you provided for today’s post. I’ll elaborate on some of the problematic hierarchy patterns you’ll commonly see in production games. We will address unity scene hierarchy bottlenecks based on the <a href="https://thegamedev.guru/unity-performance/scene-hierarchy-optimization/#tab-con-3" target="_blank" rel="noopener noreferrer">tools</a> I gave you in the last article:</p>
<ul>
<li data-css="tve-u-16e850d7209">The <em>FAP Hierarchy Tool</em></li>
<li data-css="tve-u-16e850d7209">The <em>DetachGameObject</em> simple performance boostingg component</li>
</ul>
<p><strong>Quick Navigation (opens in a new tab)</strong></p>
<p><a href="https://thegamedev.guru/unity-performance/scene-hierarchy-catch-that-performance-thief-part-2/#tab-con-3" rel="nofollow noopener noreferrer" target="_blank">The golden rules for an efficient scene hierarchy</a></p>
<p> <a href="https://thegamedev.guru/unity-performance/scene-hierarchy-catch-that-performance-thief-part-2/#tab-con-4" rel="nofollow noopener noreferrer" target="_blank">The Gamedev Guru’s Golden Rules of a Clean Unity Scene Hierarchy</a></p>
<p><a href="https://thegamedev.guru/unity-performance/scene-hierarchy-catch-that-performance-thief-part-2/#tab-con-5" rel="nofollow noopener noreferrer" target="_blank">Flattening a unity scene hierarchy: an artificial case-study</a></p>
<p> <a href="https://thegamedev.guru/unity-performance/scene-hierarchy-catch-that-performance-thief-part-2/#tab-con-6" rel="nofollow noopener noreferrer" target="_blank">The hierarchy structure</a></p>
<p> <a href="https://thegamedev.guru/unity-performance/scene-hierarchy-catch-that-performance-thief-part-2/#tab-con-7" rel="nofollow noopener noreferrer" target="_blank">Profiling the unoptimized scene</a></p>
<p> <a href="https://thegamedev.guru/unity-performance/scene-hierarchy-catch-that-performance-thief-part-2/#tab-con-2" rel="nofollow noopener noreferrer" target="_blank">Flattening our scene hierarchy</a></p>
<p><a href="https://thegamedev.guru/unity-performance/scene-hierarchy-catch-that-performance-thief-part-2/#tab-con-0" rel="nofollow noopener noreferrer" target="_blank">So what?</a></p>
<h2 id="tab-con-3">The golden rules for an efficient scene hierarchy</h2>
<p>In the previous post we established a guideline for diagnosing and optimizing unity scene hierarchies.</p>
<p data-css="tve-u-16e851023f5">Let’s quickly recap <strong>The Gamedev Guru’s golden rules for an efficient hierarchy</strong>:</p>
<p><a href="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance.png" target="_blank" rel="noopener noreferrer"><img alt height="270" src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance.png" width="600"></a></p>
<p>These apply especially to hierarchy trees that have <strong>dynamic objects</strong>. And by dynamic I mean, game objects whose transforms are altered. It can be a position, a rotation, a scale or any of the attributes you find in a <em>RectTransform</em>.</p>
<p>If an entire tree is static, i.e. no periodical transform changes, then don’t worry about that tree.</p>
<p>You see, <strong>propagating </strong>these transform changes takes time. And it takes more time when you have more game objects in the same tree.</p>
<p>But it’s not the total CPU time that concerns me the most. The issue that I see is that it is pretty hard for Unity to do these transform operations in <strong>parallel </strong>when they happen to be in the same hierarchy tree.</p>
<p>So changes in complex trees take a higher CPU time for two main reasons:</p>
<ul>
<li>The absolute CPU time required to do the math increases</li>
<li>These calculations cannot be spread across different threads</li>
</ul>
<h2 id="tab-con-5">Flattening a unity scene hierarchy: an artificial case-study</h2>
<p>I’m a pragmatic and practical professional developer. So let’s see all this theory in action.</p>
<h3 id="tab-con-6">The hierarchy structure</h3>
<p>What I have here for you is a scene full of props, particle systems and characters. This is how the unity scene hierarchy looks like:</p>
<p><a href="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-1.png" target="_blank" rel="noopener noreferrer"><img alt="Unity Scene Hierarchy: Original Structure" data-css="tve-u-16e858bbad7" data-id="3967" data-tcb-events="__TCB_EVENT_[{"t":"click","a":"thrive_zoom","c":{"id":"3967","size":"full"}}]_TNEVE_BCT__" height="500" src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-1.png" title="Unity-Scene-Hierarchy-Kinda-Deep" width="211"></a></p>
<p><em>Unity Scene Hierarchy: Original Structure</em></p>
<p data-css="tve-u-16e858db459">That’s it. No magic. <strong>4-5 levels of depth</strong>, plus all the bones required for the characters. Nothing too crazy apart from the 300 simple characters, which probably accounts for all the missing pieces that a real game has.</p>
<p>Have a look at <em>World</em>. It’s a single root game object containing <strong>way too many children</strong>. This fact violates the first golden rule of an efficient unity scene hierarchy.</p>
<p>Is that bad? I don’t know. The way to find out is by <strong>measuring its relative cost.</strong></p>
<p>I’m using free assets I found in the asset store. That means, I can’t upload this project to GitHub or I’ll risk ending up in jail. Yeah, thanks for that restrictive license, Unity.</p>
<h3 id="tab-con-7">Profiling the unoptimized scene</h3>
<p data-css="tve-u-16e85cd0244">And so I start the scene. Not much happening, just a slight amount of movement. I cannot say this is the funniest game I ever played.</p>
<p><img alt="Sample project "gameplay"" data-css="tve-u-16e85ccc124" data-id="3975" data-tcb-events="__TCB_EVENT_[{"t":"click","a":"thrive_zoom","c":{"id":"3975","size":"full"}}]_TNEVE_BCT__" height="269" src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance.gif" title="Unity-Scene-Hierarchy-Gameplay" width="534"></p>
<p><em>Sample project “gameplay”</em></p>
<p data-css="tve-u-16e85cd8a98">Well, I’m not an artist or designer. I’m excused for the looks but not for the performance. Point which brings me to using the profiler now.</p>
<p data-css="tve-u-16e85249ba9">I captured a 300-frame profile and here’s what I got:</p>
<p><a href="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-1.jpg" target="_blank" rel="noopener noreferrer"><img alt="Unity Scene Hierarchy: Pre-Optimization" data-css="tve-u-16e8523d53b" data-id="3965" data-tcb-events="__TCB_EVENT_[{"t":"click","a":"thrive_zoom","c":{"id":"3965","size":"full"}}]_TNEVE_BCT__" height="239" src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-1.jpg" title="Unity-Scene-Hierarchy-Pre-Optimization" width="600"></a></p>
<p><em>Unity Scene Hierarchy: Pre-Optimization</em></p>
<p>Was that useful?</p>
<p>Nah, don’t even bother to look at the image.</p>
<p>We don’t know whether that’s good or bad, because we don’t have a reference point.</p>
<p>But we can compare… We can compare against an equivalent, flattened hierarchy.</p>
<p>Let’s try that out.</p>
<h3 id="tab-con-2">Flattening our scene hierarchy</h3>
<p>Analyzing the previous hierarchy, we can notice something of interest.</p>
<p data-css="tve-u-16e85b72326">Most of the introduced game objects are there for organization purposes in this setup. That means, some <strong>added hierarchy levels are useful for developers to </strong><strong>structure content</strong> around them. We incorporate these objects to make development easier.</p>
<p>Game objects such as <em>World</em>, <em>City</em>, <em>Props </em>don’t serve any other purpose than organizing. Our characters, particles, UI and props do not really depend on those to accomplish their goals.</p>
<p>I see a potential gain here.</p>
<p>But on the other side, we don’t want to break the only organizational tool we have. I don’t want to deal with a flat hierarchy during development. That sucks.</p>
<p data-css="tve-u-16e85ce78d6"><strong>We want to keep things structured on the editor and yet we want our game to be performant on run-time</strong>.</p>
<p data-css="tve-u-16e85cedc82">Ehmm… Is this possible?</p>
<p>You bet it is. That we can do by making use of the script you downloaded in the <a href="https://thegamedev.guru/unity-performance/scene-hierarchy-optimization/#tab-con-3" target="_blank" rel="noopener noreferrer">first part of the blog series</a>: <em>DetachGameObject</em>. This script will let you maintain the original hierarchy when you develop your game but will unparent the gameobject of your choice to squeeze all its <em>performance juice</em> on run-time.</p>
<p data-css="tve-u-16e85a081de">So I’ll add right now our <em>DetachGameObject </em>component to the Character prefab, to all particle systems and to the dynamic canvas we have in place. I’ll ask our component to unparent the game object after a delay of 15 seconds so I can take two profiles: one before detaching and another after it.</p>
<p data-css="tve-u-16e859f706f">Below you find the <em>DetachGameObject </em>asset applied to an example particle effect.</p>
<p><a href="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-2.png"><img alt="DetachGameObject Performance Booster" data-css="tve-u-16e859ee904" data-id="3968" data-tcb-events="__TCB_EVENT_[{"t":"click","a":"thrive_zoom","c":{"id":"3968","size":"full"}}]_TNEVE_BCT__" height="265" src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-2.png" title="Unity-Scene-Hierarchy-DetachGameObject" width="600"></a></p>
<p><em>DetachGameObject Performance Booster</em></p>
<p>Now that I have set up all <em>DetachGameObject </em>components, there’s only one thing remaining. That’s right, press the play button!</p>
<p>So I run the game and after 15 seconds…</p>
<p><a href="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-3.png" target="_blank" rel="noopener noreferrer"><img alt="Scene Hierarchy: Flatter Optimized Version" data-css="tve-u-16e85a63e36" data-id="3969" data-tcb-events="__TCB_EVENT_[{"t":"click","a":"thrive_zoom","c":{"id":"3969","size":"full"}}]_TNEVE_BCT__" height="480" src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-3.png" title="Unity-Scene-Hierarchy-Flat" width="200"></a></p>
<p><em>Scene Hierarchy: Flatter Optimized Version</em></p>
<p><strong>Boom</strong>.</p>
<p>All my characters, particles and UI have been <strong>detached</strong>. Now the hierarchy is much <strong>flatter</strong>.</p>
<p><em>So I wonder…</em></p>
<p>How do both profiles compare? Let’s use the neat <a href="https://blogs.unity3d.com/2019/05/13/introducing-the-profile-analyzer/" target="_blank" rel="noopener noreferrer">profile analyzer</a> to get some fresh numbers.</p>
<p><em>*drums*</em></p>
<p><a href="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-4.png" target="_blank" rel="noopener noreferrer"><img alt="Profile Comparison: Deeper vs. Boosted Flatter CPU Performance" data-css="tve-u-16e85b3559e" data-id="3970" height="312" src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-4.png" title="Unity-Scene-Hierarchy-Profile-Analyzer" width="600"></a></p>
<p><em>Profile Comparison: Deeper vs. Boosted Flatter CPU Performance</em></p>
<p>I’ll translate for you what this chart means…</p>
<p>This comparison says that there’re <strong>significant differences</strong> between the deeper and flatter hierarchies.</p>
<p><strong>The flatter hierarchy improves performance significantly over the deeper one</strong>.</p>
<p>Yes, you might not have 300 characters, but you will surely have many over 100 times more complexity in real gameplay elements, scripts, networking and such.</p>
<h2 id="tab-con-0">So what?</h2>
<p>The conclusion is simple: <strong>there’s a performance penalty you’re paying if you don’t have a flat hierarchy</strong>. Can you afford it? That’s a question only you can answer. And you better answer that with data and metrics. My metrics in my previous games always reach the same conclusion: I don’t want to pay that expensive bill. I let instead <em>DetachGameObject</em> pay it for me.</p>
<p>That’s my advice to you. Measure your game through the profiler and <a href="https://thegamedev.guru/unity-performance/scene-hierarchy-optimization/" target="_blank" rel="noopener noreferrer"><em>FAP Hierarchy Tool</em></a>. Both tools will immensely help you finding scene hierarchy bottlenecks in your Unity game.</p>
<p>Always remember…</p>
<p data-css="tve-u-16e85b5a072"><strong>Flattening your hierarchy will improve your Unity CPU performance</strong>.</p>
<p>What were your scores before and after flattening your hierarchy? Share below.</p>
</div>
https://www.sickgaming.net/blog/2019/11/...rformance/
<div style="margin: 5px 5% 10px 5%;"><img src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance.jpg" width="469" height="250" title="" alt="" /></div><div><p><strong><i><small> The following blog post, unless otherwise noted, was written by a member of Gamasutras community.<br />The thoughts and opinions expressed are those of the writer and not Gamasutra or its parent company. </small></i></strong> </p>
<hr>
<p data-css="tve-u-16e85c2bf35"><em>Last week, I wrote a </em><a href="https://thegamedev.guru/unity-performance/scene-hierarchy-optimization/" target="_blank" rel="noopener noreferrer"><em>post </em></a><em>to show you </em><em>how your unity scene hierarchy is reducing the performance of your game</em><em>. That post arose awareness across many of you developers. And so, many of you asked great questions that I’ll answer in today’s entry.</em></p>
<p data-css="tve-u-16e85c2bf35"><em>[The original post can be found <a href="https://thegamedev.guru/unity-performance/scene-hierarchy-catch-that-performance-thief-part-2/" target="_blank" rel="noopener noreferrer">here</a>]</em></p>
<p><img alt data-css="tve-u-16e85c27d93" data-id="3974" height="250" src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance.jpg" title="Unity-Scene-Hierarchy-Part2-Thumbnail" width="469"></p>
<p>Yes… I confess.</p>
<p>The examples I often show you in my blog posts are not real-life projects. This is one of the points you have been commenting on.</p>
<p><em>Ruben, this is an artificial scenario.</em></p>
<p><em>Ruben, this doesn’t happen in games.</em></p>
<p>You see, I understand. It’s easy to doubt the information I provide you when the only cases you see are extreme.<s> I’d even rub some salt in the wound on the Reddit threads if the author wasn’t me (see <a href="https://www.reddit.com/r/gamedev/comments/dv71y1/unity_your_scene_hierarchy_is_robbing_you/" target="_blank" rel="noopener noreferrer">how I got owned</a>).</s></p>
<p>But here’s the thing: all the information I give you is based on the <strong>pain and gains of real-life projects</strong> I worked on. I do my research before I write here too.</p>
<p>Doing research is great. But that takes time. A lot.</p>
<p>So I won’t set up a new game for every weekly post that I publish. What I do instead is to create a small project to make a point…</p>
<p>…A very real point that I experienced in production games.</p>
<p>You’re never going to come across the exact dummy project in your games. <strong>But you’re likely to suffer from the issues these points reveal</strong>.</p>
<p>And that’s what matters.</p>
<p>So I took some of the feedback you provided for today’s post. I’ll elaborate on some of the problematic hierarchy patterns you’ll commonly see in production games. We will address unity scene hierarchy bottlenecks based on the <a href="https://thegamedev.guru/unity-performance/scene-hierarchy-optimization/#tab-con-3" target="_blank" rel="noopener noreferrer">tools</a> I gave you in the last article:</p>
<ul>
<li data-css="tve-u-16e850d7209">The <em>FAP Hierarchy Tool</em></li>
<li data-css="tve-u-16e850d7209">The <em>DetachGameObject</em> simple performance boostingg component</li>
</ul>
<p><strong>Quick Navigation (opens in a new tab)</strong></p>
<p><a href="https://thegamedev.guru/unity-performance/scene-hierarchy-catch-that-performance-thief-part-2/#tab-con-3" rel="nofollow noopener noreferrer" target="_blank">The golden rules for an efficient scene hierarchy</a></p>
<p> <a href="https://thegamedev.guru/unity-performance/scene-hierarchy-catch-that-performance-thief-part-2/#tab-con-4" rel="nofollow noopener noreferrer" target="_blank">The Gamedev Guru’s Golden Rules of a Clean Unity Scene Hierarchy</a></p>
<p><a href="https://thegamedev.guru/unity-performance/scene-hierarchy-catch-that-performance-thief-part-2/#tab-con-5" rel="nofollow noopener noreferrer" target="_blank">Flattening a unity scene hierarchy: an artificial case-study</a></p>
<p> <a href="https://thegamedev.guru/unity-performance/scene-hierarchy-catch-that-performance-thief-part-2/#tab-con-6" rel="nofollow noopener noreferrer" target="_blank">The hierarchy structure</a></p>
<p> <a href="https://thegamedev.guru/unity-performance/scene-hierarchy-catch-that-performance-thief-part-2/#tab-con-7" rel="nofollow noopener noreferrer" target="_blank">Profiling the unoptimized scene</a></p>
<p> <a href="https://thegamedev.guru/unity-performance/scene-hierarchy-catch-that-performance-thief-part-2/#tab-con-2" rel="nofollow noopener noreferrer" target="_blank">Flattening our scene hierarchy</a></p>
<p><a href="https://thegamedev.guru/unity-performance/scene-hierarchy-catch-that-performance-thief-part-2/#tab-con-0" rel="nofollow noopener noreferrer" target="_blank">So what?</a></p>
<h2 id="tab-con-3">The golden rules for an efficient scene hierarchy</h2>
<p>In the previous post we established a guideline for diagnosing and optimizing unity scene hierarchies.</p>
<p data-css="tve-u-16e851023f5">Let’s quickly recap <strong>The Gamedev Guru’s golden rules for an efficient hierarchy</strong>:</p>
<p><a href="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance.png" target="_blank" rel="noopener noreferrer"><img alt height="270" src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance.png" width="600"></a></p>
<p>These apply especially to hierarchy trees that have <strong>dynamic objects</strong>. And by dynamic I mean, game objects whose transforms are altered. It can be a position, a rotation, a scale or any of the attributes you find in a <em>RectTransform</em>.</p>
<p>If an entire tree is static, i.e. no periodical transform changes, then don’t worry about that tree.</p>
<p>You see, <strong>propagating </strong>these transform changes takes time. And it takes more time when you have more game objects in the same tree.</p>
<p>But it’s not the total CPU time that concerns me the most. The issue that I see is that it is pretty hard for Unity to do these transform operations in <strong>parallel </strong>when they happen to be in the same hierarchy tree.</p>
<p>So changes in complex trees take a higher CPU time for two main reasons:</p>
<ul>
<li>The absolute CPU time required to do the math increases</li>
<li>These calculations cannot be spread across different threads</li>
</ul>
<h2 id="tab-con-5">Flattening a unity scene hierarchy: an artificial case-study</h2>
<p>I’m a pragmatic and practical professional developer. So let’s see all this theory in action.</p>
<h3 id="tab-con-6">The hierarchy structure</h3>
<p>What I have here for you is a scene full of props, particle systems and characters. This is how the unity scene hierarchy looks like:</p>
<p><a href="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-1.png" target="_blank" rel="noopener noreferrer"><img alt="Unity Scene Hierarchy: Original Structure" data-css="tve-u-16e858bbad7" data-id="3967" data-tcb-events="__TCB_EVENT_[{"t":"click","a":"thrive_zoom","c":{"id":"3967","size":"full"}}]_TNEVE_BCT__" height="500" src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-1.png" title="Unity-Scene-Hierarchy-Kinda-Deep" width="211"></a></p>
<p><em>Unity Scene Hierarchy: Original Structure</em></p>
<p data-css="tve-u-16e858db459">That’s it. No magic. <strong>4-5 levels of depth</strong>, plus all the bones required for the characters. Nothing too crazy apart from the 300 simple characters, which probably accounts for all the missing pieces that a real game has.</p>
<p>Have a look at <em>World</em>. It’s a single root game object containing <strong>way too many children</strong>. This fact violates the first golden rule of an efficient unity scene hierarchy.</p>
<p>Is that bad? I don’t know. The way to find out is by <strong>measuring its relative cost.</strong></p>
<p>I’m using free assets I found in the asset store. That means, I can’t upload this project to GitHub or I’ll risk ending up in jail. Yeah, thanks for that restrictive license, Unity.</p>
<h3 id="tab-con-7">Profiling the unoptimized scene</h3>
<p data-css="tve-u-16e85cd0244">And so I start the scene. Not much happening, just a slight amount of movement. I cannot say this is the funniest game I ever played.</p>
<p><img alt="Sample project "gameplay"" data-css="tve-u-16e85ccc124" data-id="3975" data-tcb-events="__TCB_EVENT_[{"t":"click","a":"thrive_zoom","c":{"id":"3975","size":"full"}}]_TNEVE_BCT__" height="269" src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance.gif" title="Unity-Scene-Hierarchy-Gameplay" width="534"></p>
<p><em>Sample project “gameplay”</em></p>
<p data-css="tve-u-16e85cd8a98">Well, I’m not an artist or designer. I’m excused for the looks but not for the performance. Point which brings me to using the profiler now.</p>
<p data-css="tve-u-16e85249ba9">I captured a 300-frame profile and here’s what I got:</p>
<p><a href="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-1.jpg" target="_blank" rel="noopener noreferrer"><img alt="Unity Scene Hierarchy: Pre-Optimization" data-css="tve-u-16e8523d53b" data-id="3965" data-tcb-events="__TCB_EVENT_[{"t":"click","a":"thrive_zoom","c":{"id":"3965","size":"full"}}]_TNEVE_BCT__" height="239" src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-1.jpg" title="Unity-Scene-Hierarchy-Pre-Optimization" width="600"></a></p>
<p><em>Unity Scene Hierarchy: Pre-Optimization</em></p>
<p>Was that useful?</p>
<p>Nah, don’t even bother to look at the image.</p>
<p>We don’t know whether that’s good or bad, because we don’t have a reference point.</p>
<p>But we can compare… We can compare against an equivalent, flattened hierarchy.</p>
<p>Let’s try that out.</p>
<h3 id="tab-con-2">Flattening our scene hierarchy</h3>
<p>Analyzing the previous hierarchy, we can notice something of interest.</p>
<p data-css="tve-u-16e85b72326">Most of the introduced game objects are there for organization purposes in this setup. That means, some <strong>added hierarchy levels are useful for developers to </strong><strong>structure content</strong> around them. We incorporate these objects to make development easier.</p>
<p>Game objects such as <em>World</em>, <em>City</em>, <em>Props </em>don’t serve any other purpose than organizing. Our characters, particles, UI and props do not really depend on those to accomplish their goals.</p>
<p>I see a potential gain here.</p>
<p>But on the other side, we don’t want to break the only organizational tool we have. I don’t want to deal with a flat hierarchy during development. That sucks.</p>
<p data-css="tve-u-16e85ce78d6"><strong>We want to keep things structured on the editor and yet we want our game to be performant on run-time</strong>.</p>
<p data-css="tve-u-16e85cedc82">Ehmm… Is this possible?</p>
<p>You bet it is. That we can do by making use of the script you downloaded in the <a href="https://thegamedev.guru/unity-performance/scene-hierarchy-optimization/#tab-con-3" target="_blank" rel="noopener noreferrer">first part of the blog series</a>: <em>DetachGameObject</em>. This script will let you maintain the original hierarchy when you develop your game but will unparent the gameobject of your choice to squeeze all its <em>performance juice</em> on run-time.</p>
<p data-css="tve-u-16e85a081de">So I’ll add right now our <em>DetachGameObject </em>component to the Character prefab, to all particle systems and to the dynamic canvas we have in place. I’ll ask our component to unparent the game object after a delay of 15 seconds so I can take two profiles: one before detaching and another after it.</p>
<p data-css="tve-u-16e859f706f">Below you find the <em>DetachGameObject </em>asset applied to an example particle effect.</p>
<p><a href="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-2.png"><img alt="DetachGameObject Performance Booster" data-css="tve-u-16e859ee904" data-id="3968" data-tcb-events="__TCB_EVENT_[{"t":"click","a":"thrive_zoom","c":{"id":"3968","size":"full"}}]_TNEVE_BCT__" height="265" src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-2.png" title="Unity-Scene-Hierarchy-DetachGameObject" width="600"></a></p>
<p><em>DetachGameObject Performance Booster</em></p>
<p>Now that I have set up all <em>DetachGameObject </em>components, there’s only one thing remaining. That’s right, press the play button!</p>
<p>So I run the game and after 15 seconds…</p>
<p><a href="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-3.png" target="_blank" rel="noopener noreferrer"><img alt="Scene Hierarchy: Flatter Optimized Version" data-css="tve-u-16e85a63e36" data-id="3969" data-tcb-events="__TCB_EVENT_[{"t":"click","a":"thrive_zoom","c":{"id":"3969","size":"full"}}]_TNEVE_BCT__" height="480" src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-3.png" title="Unity-Scene-Hierarchy-Flat" width="200"></a></p>
<p><em>Scene Hierarchy: Flatter Optimized Version</em></p>
<p><strong>Boom</strong>.</p>
<p>All my characters, particles and UI have been <strong>detached</strong>. Now the hierarchy is much <strong>flatter</strong>.</p>
<p><em>So I wonder…</em></p>
<p>How do both profiles compare? Let’s use the neat <a href="https://blogs.unity3d.com/2019/05/13/introducing-the-profile-analyzer/" target="_blank" rel="noopener noreferrer">profile analyzer</a> to get some fresh numbers.</p>
<p><em>*drums*</em></p>
<p><a href="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-4.png" target="_blank" rel="noopener noreferrer"><img alt="Profile Comparison: Deeper vs. Boosted Flatter CPU Performance" data-css="tve-u-16e85b3559e" data-id="3970" height="312" src="https://www.sickgaming.net/blog/wp-content/uploads/2019/11/blog-handling-unity-scene-hierarchy-and-performance-4.png" title="Unity-Scene-Hierarchy-Profile-Analyzer" width="600"></a></p>
<p><em>Profile Comparison: Deeper vs. Boosted Flatter CPU Performance</em></p>
<p>I’ll translate for you what this chart means…</p>
<p>This comparison says that there’re <strong>significant differences</strong> between the deeper and flatter hierarchies.</p>
<p><strong>The flatter hierarchy improves performance significantly over the deeper one</strong>.</p>
<p>Yes, you might not have 300 characters, but you will surely have many over 100 times more complexity in real gameplay elements, scripts, networking and such.</p>
<h2 id="tab-con-0">So what?</h2>
<p>The conclusion is simple: <strong>there’s a performance penalty you’re paying if you don’t have a flat hierarchy</strong>. Can you afford it? That’s a question only you can answer. And you better answer that with data and metrics. My metrics in my previous games always reach the same conclusion: I don’t want to pay that expensive bill. I let instead <em>DetachGameObject</em> pay it for me.</p>
<p>That’s my advice to you. Measure your game through the profiler and <a href="https://thegamedev.guru/unity-performance/scene-hierarchy-optimization/" target="_blank" rel="noopener noreferrer"><em>FAP Hierarchy Tool</em></a>. Both tools will immensely help you finding scene hierarchy bottlenecks in your Unity game.</p>
<p>Always remember…</p>
<p data-css="tve-u-16e85b5a072"><strong>Flattening your hierarchy will improve your Unity CPU performance</strong>.</p>
<p>What were your scores before and after flattening your hierarchy? Share below.</p>
</div>
https://www.sickgaming.net/blog/2019/11/...rformance/