{"id":28420,"date":"2015-09-03T19:52:40","date_gmt":"2015-09-04T00:52:40","guid":{"rendered":"http:\/\/www.shamusyoung.com\/twentysidedtale\/?p=28420"},"modified":"2015-09-04T21:21:54","modified_gmt":"2015-09-05T02:21:54","slug":"knights-of-the-old-republic-ep5-canderous-the-manderous","status":"publish","type":"post","link":"https:\/\/www.shamusyoung.com\/twentysidedtale\/?p=28420","title":{"rendered":"Knights of the Old Republic EP5: Canderous the Manderous"},"content":{"rendered":"<p><table class='nomargin' cellspacing='0' width='100%' cellpadding='0' align='center' border='0'><tr><td><iframe loading=\"lazy\" width=\"1024\" height=\"576\" src=\"https:\/\/www.youtube.com\/embed\/_LOBVjOvfWY\" frameborder=\"0\" allowfullscreen class=\"embed\"><\/iframe><br\/><small><a href='http:\/\/www.youtube.com\/watch?v=_LOBVjOvfWY'>Link (YouTube)<\/a><\/small><\/td><\/tr><\/table><\/p>\n<p>New games have spoiled us. There&#8217;s this unspoken assumption: <em>If you change zones, have a cutscene, or pass through a loading screen, you get an auto-save.<\/em> But in 2003, this was not a rule. We had all three of those things happen here without getting a save. Spoiler: This comes back to bite us in this episode.<\/p>\n<p>If you want to know about this Invisible War game we were talking about, there&#8217;s an <a href=\"https:\/\/www.youtube.com\/watch?v=59PzmOLSf00\">Errant Signal episode<\/a> for that. <\/p>\n<p>I find the comparison interesting because both of these games came out the same year and both were multiplatform releases, coming out on both Xbox and Windows. The original Xbox had just 64MB of ram. For comparison, Good Robot &#8211; <a href=\"https:\/\/www.youtube.com\/watch?v=sj3Rx-rmFFI\">the 2D side-scrolling indie game I&#8217;m helping to develop<\/a> &#8211; currently eats about 200MB. To be fair, a lot of that bloat comes from the third-party libraries we&#8217;re using. Over the last 12 years, a lot of software has come along to relieve coders from the drudgery of making their own code for interfaces, audio code, rendering pipeline, controller input, and a dozen other things. That&#8217;s wonderful, inasmuch as it&#8217;s made the current surge in indie development possible for a whole generation of developers who would rather focus on gameplay than building complex technical frameworks. Sure, there&#8217;s a steep performance cost to doing things this way, but like <a href=\"?p=28376\">I said in the column this week<\/a>, Moore&#8217;s Law was pretty sweet while it lasted, and gave us so much extra power to spend on stuff like this.<\/p>\n<p>Still, it&#8217;s amazing to think that my little game uses more than three times as much memory as KOTOR. Actually quite a bit more, since certainly the Xbox operating system would have eaten into that 64MB.<\/p>\n<p><em>EDIT: Actually Good Robot only uses 132MB. I was looking at the numbers for the debug build when I wrote this post. So Good Robot is only twice the size of KOTOR, not three times the size. <\/em><\/p>\n<p>I think one of the big technical blunders for Invisible War was moving to bump-mapping and bloom lighting. Those technologies were pretty new at the time. KOTOR doesn&#8217;t do any of those fancy tricks, and has a super-primitive lighting model. Going strictly by technology, KOTOR came out in 2003 but was using technology from 1999 or so. It&#8217;s also third-person, so the camera is further away from the scenery. Which means they can get away with low-resolution texture maps. <\/p>\n<p>Not only were the texture maps in Invisible War larger, but they needed double the texture maps, because bump mapping \/ normal mapping requires another texture. The bloom lighting would have required an extra framebuffer, which would have eaten 3 precious megabytes all by itself.<\/p>\n<p><em>EDIT: 3MB was based on the assumption that this game ran at 720p, but it was only 480p. So the bloom framebuffer would have been just under a megabyte. I still say that&#8217;s not the best use of resources in such a memory-starved situation, but not <strong>nearly<\/strong> as bad as 3MB.<\/em><\/p>\n<p>By not blowing memory on fancy rendering tricks, BioWare was able to spend more of their meager memory budget on game space: Rooms and corridors and such. Yes, KOTOR looks pretty barren and could clearly use some furnishings here and there, but it&#8217;s still better than Invisible War and their closet-sized cities. <\/p>\n","protected":false},"excerpt":{"rendered":"<p>Link (YouTube) New games have spoiled us. There&#8217;s this unspoken assumption: If you change zones, have a cutscene, or pass through a loading screen, you get an auto-save. But in 2003, this was not a rule. We had all three of those things happen here without getting a save. Spoiler: This comes back to bite [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[188],"tags":[84,513,128],"class_list":["post-28420","post","type-post","status-publish","format-standard","hentry","category-spoilerwarning","tag-bioware","tag-kotor","tag-star-wars"],"_links":{"self":[{"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=\/wp\/v2\/posts\/28420","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=28420"}],"version-history":[{"count":0,"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=\/wp\/v2\/posts\/28420\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=28420"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=28420"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.shamusyoung.com\/twentysidedtale\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=28420"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}