<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Entertaining Code &#187; Career</title>
	<atom:link href="http://www.entertainingcode.com/tags/career/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.entertainingcode.com</link>
	<description>Coding and the games industry</description>
	<lastBuildDate>Mon, 28 Jun 2010 16:56:33 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
			<item>
		<title>What&#8217;s a Good Final Year Project?</title>
		<link>http://www.entertainingcode.com/archives/whats-a-good-final-year-project/</link>
		<comments>http://www.entertainingcode.com/archives/whats-a-good-final-year-project/#comments</comments>
		<pubDate>Tue, 11 Aug 2009 20:20:43 +0000</pubDate>
		<dc:creator>slicedlime</dc:creator>
				<category><![CDATA[The Games Industry]]></category>
		<category><![CDATA[Career]]></category>
		<category><![CDATA[Code]]></category>
		<category><![CDATA[Games]]></category>
		<category><![CDATA[Learning]]></category>

		<guid isPermaLink="false">http://www.entertainingcode.com/?p=861</guid>
		<description><![CDATA[Here's a question from the mailbag, coming from a stude [...]]]></description>
			<content:encoded><![CDATA[<p>Here&#8217;s a question from the mailbag, coming from a student doing games programming at a university, gearing up for his final-year project:</p>
<blockquote><p>The degree I&#8217;m doing currently has been very much centered around graphical programming, aswell as using various programming languages to bolster our CV&#8217;s I would imagine. We&#8217;ve not really touched on networking, or AI at all. Our main language in graphical programming has been OpenGL too, we&#8217;ve dabbled with DirectX a little, mostly managed directX with XNA.</p>
<p>As a programmer already in the industry, could you give me any advice on the type, and level of project I should aim for, for it to be a suitable demo project to show to prospective employers? It&#8217;s difficult enough as students to find our way into the games industry; if we don&#8217;t know what employers <em>want,</em> or what is considered worthy in the eyes of the employer, it lowers our odds tenfold.</p></blockquote>
<p>In a way, the answer to the question depends on what kind of position you&#8217;re trying for. I&#8217;ll try to answer with regards to as many positions as I know.</p>
<p>For starters, is graphics programming what you want to be doing? If it is, things like what graphics APIs you know become a lot more important. From what I know, most games studios that do windows game development have gravitated towards DirectX. With that in mind, having done a large(ish) project on DirectX could definitely be a plus. If all other things are equal, I&#8217;d definitely go for learning DirectX.</p>
<p>Not having experience with networking or AI isn&#8217;t all that much of an issue, unless you imagine going specifically for a networking or AI programming position (and even then, it&#8217;s more of a bonus than a requirement). One thing is clear however&#8230; if you&#8217;re looking to get into professional development at a large studio, you should be going for C++.</p>
<p>Now if we look past the technical requirements, there are a few things that can be said about such a project in itself. What you get from a good project is a nice entry into your demo reel &#8212; something to show off. This has a few implications, but most importantly something I&#8217;ve touched on before, in <a href="http://www.entertainingcode.com/archives/a-spectacular-failure/">A Spectacular Failure</a>: your project is going to be judged on emotional first impressions, not how technologically advanced it is or how nicely coded it is.</p>
<p>Your number one enemy is over-scoping the project, ending up with something that does lots of things, but does none of them in a great way. Come up with a good core gameplay for the game, and then polish it to a great shine. Fix all those annoying glitches and bugs, make sure everything looks as impressive as possible. It doesn&#8217;t need to be rocket science, as long as it&#8217;s well executed. In the end, what a games studio is looking for is a programmer who knows how to finish projects in a good way.</p>
<p>That doesn&#8217;t mean your project should be Space Invaders, but in general trying for something too big is more of a problem than overdoing something too small.</p>
<p>Finally, as an entry on your demo reel, make sure you make the game available in an easy manner. Have a page with plenty of screen shots, videos and preferably the game itself easily downloadable. Your coding ability will definitely be tested with some form of work sample as you apply to studios, so the code itself being available is less important. Reading code is hard, so <a href="http://www.entertainingcode.com/archives/trying-the-open-source-shortcut/">it&#8217;s unlikely that someone will have time to read yours</a>. However, having a finished game to show off is worth a lot, as is the experience of going through all the phases in finishing a game.</p>
<p>Other posts you may find interesting, relating to getting into the games industry and getting started with games:</p>
<ul>
<li><a href="http://www.entertainingcode.com/archives/getting-into-games-a-follow-up/">Getting Into Games</a></li>
<li><a href="http://www.entertainingcode.com/archives/an-exceptionally-stupid-idea/">An Exceptionally Stupid Idea</a></li>
<li><a href="http://www.entertainingcode.com/archives/lets-make-a-game-engine/">Let&#8217;s Make a Game Engine</a></li>
</ul>
<p><script type="text/javascript"><!--
google_ad_client = "pub-2919823884810618";
/* Links */
google_ad_slot = "5892302561";
google_ad_width = 468;
google_ad_height = 15;
//-->
</script>
<script type="text/javascript"
src="http://pagead2.googlesyndication.com/pagead/show_ads.js">
</script></p>
]]></content:encoded>
			<wfw:commentRss>http://www.entertainingcode.com/archives/whats-a-good-final-year-project/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Getting Into Games &#8212; A Follow-up</title>
		<link>http://www.entertainingcode.com/archives/getting-into-games-a-follow-up/</link>
		<comments>http://www.entertainingcode.com/archives/getting-into-games-a-follow-up/#comments</comments>
		<pubDate>Sat, 11 Jul 2009 16:14:12 +0000</pubDate>
		<dc:creator>slicedlime</dc:creator>
				<category><![CDATA[The Games Industry]]></category>
		<category><![CDATA[Career]]></category>
		<category><![CDATA[Code]]></category>
		<category><![CDATA[Games]]></category>

		<guid isPermaLink="false">http://www.entertainingcode.com/?p=753</guid>
		<description><![CDATA[My post from a week or so ago about the differences bet [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.entertainingcode.com/archives/making-games/">My post from a week or so ago</a> about the differences between working as a software engineer in a games studio and in other places generated a fair number of interesting comments and questions, both here and at various syndication sites. In this post I will try to answer and comment on the most common and interesting ones.</p>
<h3>Working at a Games Studio</h3>
<p>Getting started with something I intentionally left out:</p>
<blockquote><p><em>Low pay. Good luck trying to buy a house.</em></p></blockquote>
<p>There&#8217;s a well known discrepancy between salary in your average programming gig and your average games programming gig. I left it out of the original post because of two factors:</p>
<ol>
<li>The difference is highly overstated. Salary varies much more within each class of work than between the two. While it is true I could probably get more money by switching to another job, the same is true for many others, and the difference wouldn&#8217;t be worth it to me.</li>
<li>It&#8217;s your choice. I expect you to make a well-informed choice on taking <em>any </em>job when it comes to what you get paid. Don&#8217;t just take any job because someone told you you get paid a lot in a certain business &#8212; make sure you get what you&#8217;re worth.</li>
</ol>
<p>A second issue from the same commenter (and several others):</p>
<blockquote><p><em>Yes, you have to come to work on Saturday and Sunday.</em></p></blockquote>
<p>This is an issue in the industry, and I&#8217;ve seen pretty bad cases of it. Since I started coding games, the working conditions have improved by far though &#8212; and this doesn&#8217;t only seem to be my situation but applies to many others I&#8217;ve spoken to at other studios (mainly within EA though &#8212; would be happy to hear the perspective of other people). At the moment, from where I&#8217;m sitting, things are looking pretty good.</p>
<p>I&#8217;m not saying crunches don&#8217;t happen, I&#8217;m just saying they&#8217;re reasonably few, have a good purpose and focused time span, and include a time off compensation after the deadline has been passed.</p>
<p>The most problematic part of this is that it&#8217;s extremely hard to figure out if this applies to any given studio without actually working there or knowing someone who does.</p>
<blockquote><p><em>I wouldn&#8217;t want to be the guy working on the next Madden game</em></p></blockquote>
<p>Well, I actually know <a href="http://twitter.com/ian_cummings">the guy working on the next Madden game</a> and he is incredibly dedicated and seemed to love what he was working with last time I saw him. About the comment, he told me &#8220;Well we don&#8217;t want that guy anyway,&#8221; which is very true &#8212; the reason there is a Madden game every year is because there are lots of people interested in a new Madden game every year, and among that crowd there will certainly be people who are interested enough to want to work on the game.</p>
<p>It&#8217;s funny, because I sometimes hear the exact opposite of this comment at work. &#8220;It&#8217;d be so awesome to work on an iterative title where you just got to improve things and do all those cool changes that we have to cut&#8221;. Working on Madden is a pretty sweet place to be if you love sports games.</p>
<p>People sometimes seem to think that innovation only means new game franchise. There are lots of interesting developments and innovations within franchises, even within a &#8220;plain old sequel&#8221;, and working on one of those titles avoids one of the great drawbacks of the games industry: half the time you&#8217;re semi-panicking because your game engine isn&#8217;t in a shippable state and there&#8217;s a whole game team trying to use it to create a game.</p>
<p>That way, working on Battlefield: Bad Company 2 is nicer than working with the first game: the same chance for innovation, but less problems with others not being able to innovate due to the state of the code.</p>
<h3>Getting started</h3>
<p>A question that keeps popping up is any version on this:</p>
<blockquote><p><em>I’m a frustrated web developer who’s always wanted to make the move into game development, but have yet to find the time to train myself and start shifting my skills over. </em></p>
<p><em>Any tips for someone looking to start out in that direction?</em></p></blockquote>
<p>I&#8217;ve touched on this subject before, in <a href="http://www.entertainingcode.com/archives/an-exceptionally-stupid-idea/">An Exceptionally Stupid Idea</a>, which tells the story of what I did. That post may be best applicable if you&#8217;re still in college, but there is a certain truth to it regardless of where you are. Time is money however, and with anything in life  you&#8217;ll need to do investments&#8230; so seeing where you could free up time is a first step.</p>
<p>What do do with the time once you have it? Well, the games industry is looking for a few things:</p>
<ul>
<li>Skilled programmers</li>
<li>&#8230; who know the language</li>
<li>&#8230; and with some experience of games</li>
</ul>
<p>The third is actually somewhat optional, though most recruiters would never admit that. Becoming a good programmer is a hard topic to cover &#8212; more than half the stuff on this blog is already devoted to that, so I&#8217;m not going to comment further on that one.</p>
<p>Chances are slim you&#8217;ll be coding anything but C++ if you code games, so if you&#8217;re not already very familiar with the language, you should get familiar with it. It&#8217;s often said that good programmers learn new languages quickly, and to a certain extent I agree with this&#8230; but if the problem is complicated enough, you need to be a language expert.</p>
<p>Finally, getting some form of portfolio is good, even if it&#8217;s &#8220;just a side project&#8221;. That could also be a good project to use as practice if you&#8217;re not too familiar with the language. Further, it helps if you&#8217;re a gamer and stay on top of what&#8217;s going on in the industry.</p>
<p>This actually ties into another comment, which was the most compact piece of information:</p>
<blockquote><p><em>C++</em></p></blockquote>
<p>If you dislike C++, turn elsewhere. I personally think it&#8217;s an extremely capable language once you learn to harness it properly. It is dangerous without the safety equipment though, and sadly some of that equipment doesn&#8217;t work with games.</p>
<p>Other languages are starting to appear when it comes to games coding. I&#8217;ve heard examples of LUA, java and C# being used as scripting languages, and of course there&#8217;s <a href="http://en.wikipedia.org/wiki/UnrealScript">UnrealScript</a>. These can be extremely beneficial for iteration times and such, but the grunt of the software is still going to be C++.</p>
<p><strong>Update</strong>: I should also mention another old post of mine about this: <a href="http://www.entertainingcode.com/archives/lets-make-a-game-engine/">Let&#8217;s Make a Game Engine!</a></p>
<h3>Games Programming</h3>
<p>I tried to avoid getting into the details of hardware and the coding that goes with it in the previous post, since I love talking about these sort of things and I didn&#8217;t want it to become a rant but hey, you asked!</p>
<blockquote><p><em>Console hardware (I&#8217;m looking at you, PS3) is made for pretty graphics demos, not simulation. If you work on the AI or physics, be prepared to focus your energy on low level optimisation and cache misses, because your AI code is never going to be any more sophisticated than a state machine.</em></p></blockquote>
<p>Well&#8230; I&#8217;m the lead AI coder on Frostbite, and while there are lots of things to be said about the Frostbite AI, &#8220;no more sophisticated than a state machine&#8221; is not one of them. I agree, some things (especially physics queries) are expensive on the hardware, but that simply means you need to re-think how you do stuff.</p>
<p>SPU code is a vastly different beast from your average code. There are some bad programming habits that can completely destroy your code for SPUs&#8230; and among those bad habits are the ones that would lead you to get stuck on low-level optimizations. Once you learn how it works, there is an incredible amount of power in the PS3. I&#8217;d dare to say it&#8217;s still relatively untapped, and that as time passes we&#8217;ll see more sophisticated uses of it.</p>
<p>The limitations of console hardware is <em>different</em>. That doesn&#8217;t mean you can&#8217;t implement physics or AI, it just means maybe you&#8217;ve got to challenge your assumptions about <em>how</em> you implement physics and AI.</p>
<blockquote><p><em>I guess the Parallelism approaches are a little different in both worlds. I bet you gamedev guys have been working with Data Parallelism for a while (i.e: programming the Playstation2 Vector units. I don’t think life is getting any easier on you guys with all those Cell SPEs to squeeze!).</em></p>
<p><em> In the enterprisey side, task parallelism is an emerging topic with languages like Erlang, Clojure and Haskell offering different abstractions for spreading computations over different hardware threads/cores.</em></p></blockquote>
<p>The vectorization units of the PS2 are a quite limited way to do data-parallel work, so I disagree with you here &#8212; with the SPUs on the PS3, it actually is easier, because it&#8217;s less limited in what you can do with them. Vectorization units and other primitive forms of data-parallelism often work in lockstep, whereas the PS3 actually has a bunch of individual, highly capable although slightly quirky processors.</p>
<p>Games are full of data-parallelisable problems as well. Rendering is the classic example &#8212; the reason GPUs have been such a hot development the last few years is that rendering lends itself so well to parallelism. But there are many other things as well &#8212; the aforementioned AI is ideal in some ways, as it tends to be made up of lots of separate processes for different actors or entities.</p>
<p>Task parallelism is also something that can be utilized to a great degree in games since there are simply so many orthogonal tasks to complete. Update the UI, do physics simulations, calculate character skinning, play audio&#8230; I can&#8217;t go into details on that, but we do a whole lot of it in Frostbite. Sadly, you do end up needing to care about many of the details that using an abstracted language would let you ignore though.</p>
<p>Still, it&#8217;s one of the most exciting aspects of coding for me, since games are one of those applications that can actually use all the power of parallel computers.</p>
<p><script type="text/javascript"><!--
google_ad_client = "pub-2919823884810618";
/* Links */
google_ad_slot = "5892302561";
google_ad_width = 468;
google_ad_height = 15;
//-->
</script>
<script type="text/javascript"
src="http://pagead2.googlesyndication.com/pagead/show_ads.js">
</script></p>
<script type="text/javascript">
var flattr_wp_ver = '0.9.11';
var flattr_uid = '409';
var flattr_url = 'http://www.entertainingcode.com';
var flattr_lng = 'en_GB';
var flattr_cat = 'text';
var flattr_tag = 'blog,wordpress,rss,feed';
var flattr_btn = 'large';
var flattr_tle = 'Entertaining Code';
var flattr_dsc = 'Coding and the games industry';
</script>
<script src="http://api.flattr.com/button/load.js?v=0.2" type="text/javascript"></script>]]></content:encoded>
			<wfw:commentRss>http://www.entertainingcode.com/archives/getting-into-games-a-follow-up/feed/</wfw:commentRss>
		<slash:comments>8</slash:comments>
		</item>
		<item>
		<title>Making Games</title>
		<link>http://www.entertainingcode.com/archives/making-games/</link>
		<comments>http://www.entertainingcode.com/archives/making-games/#comments</comments>
		<pubDate>Wed, 01 Jul 2009 23:55:45 +0000</pubDate>
		<dc:creator>slicedlime</dc:creator>
				<category><![CDATA[The Games Industry]]></category>
		<category><![CDATA[Career]]></category>
		<category><![CDATA[Code]]></category>
		<category><![CDATA[Games]]></category>

		<guid isPermaLink="false">http://www.entertainingcode.com/?p=722</guid>
		<description><![CDATA[I hear from programmers every now and then who are cons [...]]]></description>
			<content:encoded><![CDATA[<p>I hear from programmers every now and then who are considering trying to get into the games industry. Our projects are strange beasts that are similar to other software projects in some ways, yet vastly different in other ways. Still, if you look at it from outside, most of these differences will be hard to spot.</p>
<p>With this post, I will try to list what I see as the biggest differences between working on a game and working on a different kind of software project. If you have any questions related to it, please post them as comments and I&#8217;ll do a follow-up round.</p>
<h3>The Passion and Dedication</h3>
<p>It sounds like a cliché, but games are made by mostly gamers. In all the teams I&#8217;ve worked with spanning maybe a hundred, there&#8217;s only a few people that aren&#8217;t absolutely passionate about games, and completely dedicated to making kick-ass entertainment.</p>
<p>The enterprise coders I&#8217;ve worked with pretty much fall into two categories: the day job coders who don&#8217;t care much and the hackers that appreciate technical challenges. As you move into games, not only does just about everyone fall into the second category, but nearly everyone is also excited about the games themselves, regardless of the technical challenges involved.</p>
<p>If you&#8217;re looking for a place to work where your colleagues will be really cool, skilled people with a passion, then the games industry is where to look.</p>
<p>On a cynical note related to that, the abuse of this passion and dedication is what has given the games industry something of a bad reputation (and a well deserved one too). My impression is that working conditions have improved quite a lot across the board, even if there are still the occasional horror stories. If I were to give one piece of actual advice, it&#8217;d be to be rather thorough in your background checks on companies.</p>
<h3>Creativity</h3>
<p>Game developers live off creativity. Even the most simple churn-out-sequels factory will attract highly creative people, and studios will tend to cater to creativity to a much higher degree than most other software development companies.</p>
<p>If you&#8217;re highly creative, you will probably find it easy to fit in. My experience is that creative suggestions are almost universally appreciated regardless of source.</p>
<h3>Cross-discipline, Bleeding Edge Development</h3>
<p>Games teams are made up of a number of disciplines that vary depending on what type of game you&#8217;re making, but generally speaking you&#8217;ll at least have Designers, Graphical Artists, Animators, Sound Designers and Programmers. Our projects have Mission Designers, Environment Artists, Effects Designers and other disciplines as well.</p>
<p>In a way, this is no different than many other types projects where some end-users create some of the data for the system, but there is a major difference in the fact that the hardware platforms are either consoles or PCs with specs so high that they don&#8217;t even exist yet. The coders on the team will be creating a game framework, which is then populated with different kinds of content to produce the game.</p>
<p>The problem with this is that they&#8217;re using the software tools you&#8217;re building (like the editor and data processing pipeline) to create the game while you&#8217;re still trying to build the tools, only to run it in a game engine that is also not done yet.</p>
<p>It&#8217;s a bit like trying to produce a business application while part of your team is working on creating the source code editor you must use, and a different part of the team is building your compiler. In some magical way, the components must all mesh together so that not only are the tools done when it&#8217;s time to ship the product, but that content creators have time to do something useful with them as well.</p>
<p>This creates an extra layer of complexity to the projects that I haven&#8217;t seen anywhere else. Inter-discipline dependencies between disciplines that work in very different manners can cause common project management techniques for software development to break down, because most of the team isn&#8217;t developing software.</p>
<h3>Performance Focus and Hardware Platforms</h3>
<p>From a technical point of view, there is a heavy focus on code performance. This creates a different kind of environment, where some modern programming techniques are simply too expensive to use. It also means you tend to get good at optimizations after a while.</p>
<p>The hardware we run on is increasingly becoming paralell. Using all of the power in the PS3, for instance, requires a fairly well developed parallelism, forcing the shift from single-threaded to multi-threaded coding onto game programming long before most applications need to care all that much.</p>
<p>(Note that my view on the state of the industry is rather limited here. DICE is ahead with the Frostbite engine on current console tech, some other engines are hopelessly behind, but it&#8217;s always hard to tell what others have in development.)</p>
<p>The hardware platforms themselves can sometimes be immature and cause problems when you have to jump through hoops to get things working (simple example: graphics driver bugs).</p>
<p>The platforms themselves also impose other restrictions on your code, like the low memory cap of current generation consoles and extreme penalties for cache misses and branching.</p>
<h3>Playing Games at Work (!)</h3>
<p>I couldn&#8217;t leave that out, could I? Yes, we playtest our games at work. They&#8217;re a lot of fun, most of the time, so getting to play awesome games before anyone else is quite a perk. To be completely honest I must admit that there are times when it&#8217;s not much fun at all&#8230; but they are quite uncommon. And hey&#8230; you get to shoot your boss.</p>
<p><script type="text/javascript"><!--
google_ad_client = "pub-2919823884810618";
/* Links */
google_ad_slot = "5892302561";
google_ad_width = 468;
google_ad_height = 15;
//-->
</script>
<script type="text/javascript"
src="http://pagead2.googlesyndication.com/pagead/show_ads.js">
</script></p>
]]></content:encoded>
			<wfw:commentRss>http://www.entertainingcode.com/archives/making-games/feed/</wfw:commentRss>
		<slash:comments>7</slash:comments>
		</item>
		<item>
		<title>A Tour of the Games Studio</title>
		<link>http://www.entertainingcode.com/archives/a-tour-of-the-games-studio/</link>
		<comments>http://www.entertainingcode.com/archives/a-tour-of-the-games-studio/#comments</comments>
		<pubDate>Tue, 09 Jun 2009 17:31:33 +0000</pubDate>
		<dc:creator>slicedlime</dc:creator>
				<category><![CDATA[The Games Industry]]></category>
		<category><![CDATA[Career]]></category>
		<category><![CDATA[DICE]]></category>
		<category><![CDATA[EA]]></category>
		<category><![CDATA[Games]]></category>

		<guid isPermaLink="false">http://www.entertainingcode.com/?p=698</guid>
		<description><![CDATA[There's a hole slew of misconceptions and weird comment [...]]]></description>
			<content:encoded><![CDATA[<p>There&#8217;s a hole slew of misconceptions and weird comments that inevitably go around as soon as any large game studio announces a game, or releases a game, or&#8230; well, just about anything else. So with this post, I&#8217;d like to welcome you to a small sightseeing tour of how a games studio works, on the inside.</p>
<p>I hope to give you a chance to see how a games studio works &#8212; maybe it&#8217;ll create better understanding of what it is you&#8217;re saying when you chatter around forums about the latest greatest game from some studio, or maybe it even gives you valuable insight if you&#8217;re looking to get into the games industry.</p>
<h3>The Myth of the A-Team and the B-Team</h3>
<div id="attachment_701" class="wp-caption alignright" style="width: 310px"><a href="http://www.entertainingcode.com/wp-content/uploads/2009/06/dice-entrance.jpg"><img class="size-medium wp-image-701" title="dice-entrance" src="http://www.entertainingcode.com/wp-content/uploads/2009/06/dice-entrance-300x218.jpg" alt="Somewhere in the DICE Office" width="300" height="218" /></a><p class="wp-caption-text">Somewhere in the DICE Office</p></div>
<p>As soon as a game announcement turns up, knowing fanboys will appear on all forums around, claiming grand things like <em>&#8220;Wow, this sure is great. Now we know DICE has the A-team is working on this while the B-team was doing (other title here).&#8221; </em>Substitute with &#8220;good team&#8221; and &#8220;bad team&#8221; or whatever you will.</p>
<p>The reality is not only that there isn&#8217;t any first or second-rate teams, but that the teams themselves don&#8217;t really exist as a concept. People move between teams constantly &#8212; some project doesn&#8217;t need any more audio work now, so the sound designers move over to the next one. Meanwhile, the programmers are fixing the remaining bugs and getting set to ship the game. Most of the artists left the project before that.</p>
<p>That means that there&#8217;s rarely a situation where a team in a large studio makes one title and then immediately goes on to make another one &#8212; more likely the team will split up and head to other projects. Some may jump on to help another project get the final bugs squashed, others may jump on to prototype a new game.</p>
<h3>The Life of a Game Project</h3>
<p>That leads us to the life cycle of a games project, because another misconception is that the team making a game will remain the same group of people all the way through.</p>
<p>A project generally starts out small. A few designers basically start up by spending some time trying to answer the simple question of &#8220;What game do we want to make?&#8221; Sometimes this is more straightforward than other times &#8212; but more often than not it is somewhat complicated and difficult. Even sequels usually start out in a state of &#8220;don&#8217;t really know what this is about&#8221;.</p>
<p>There&#8217;s this nice thought many people have about games as having this brilliant idea first, and then just making the game. This never happens. The project will probably get to some kind of rough concept of what they want to do, what kind of technology platform to use, what setting, and so on&#8230; and then go into pre-production.</p>
<p>The pre-production phase of a project is when the project starts taking on more people. Coders join, artists join, and most probably more designers join. The mission now becomes trying to prototype, test and prove all the different aspects of the game &#8212; figure out the core game mechanics, make art target concept environments, make sure all the tools needed work properly. The goal is usually to build a small section of the game as a proof of concept.</p>
<p>The project has probably been running for at least six months by the time it finishes pre-production and heads into production. It staffs up even more, and sets about building all the levels, missions, features and content needed for the complete game. The amount of time it takes to do this varies wildly depending on the game.</p>
<p>Still, through production concepts are refined. As playtests are done, the developers think of new ways to improve the game, and the new ideas are worked into the concept.</p>
<h3>What You See Is All There Is?</h3>
<p>By the time you hear of a project, it&#8217;ll generally be in production. Conceptual prototyping is relatively cheap, so studios can afford doing concepts for games as a test, and if they don&#8217;t turn out well then cancel the project. This means that at any time, your favourite games studios out there are probably doing cool stuff you have no clue about.</p>
<p>This way of doing things also means most views on the state of a game are somewhat flawed. By the time a game hits beta and you get to see it, it&#8217;s virtually completed and only bug fixing remains. Comments like &#8220;well this is an early beta, they&#8217;ll change lots of stuff&#8221; are quite common and somewhat funny to see &#8212; very few game changes will be done once a game is in beta.</p>
<p>That doesn&#8217;t mean quality doesn&#8217;t increase though &#8212; much of the quality you see in a game comes from the actual fixing of bugs, not the adding of features.</p>
<h3>&#8220;Not that the devs are ever gonna care&#8221;</h3>
<p>Gamers tend to show a pretty large dose of resentment towards game developers. In general, what you see is an announcement met with awe and comments like &#8220;this&#8217;ll be the most awesome ever&#8221;. This attitude then changes over time, until at release, the comments tend to sound more like &#8220;they messed it up&#8221;.</p>
<p>A strange aspect of this is that many gamers seem to be deep into the belief that game devs don&#8217;t care about them, about the games they make, or about anything at all other than earning a quick buck. This is strange because the games industry is not the place to go to make the good money while slacking &#8212; it&#8217;s generally a grind of long hours of dedicated work and not as well paid as other comparable areas (making business apps is definitely much more lucrative for a programmer).</p>
<p>Yet people still do it? Why? Because these people are gamers and love what they do. Maybe somewhere there are big-name execs that don&#8217;t care, but I haven&#8217;t met them yet. I&#8217;ve only met the EA execs who beat half the dev team on Battlefield: Bad Company (though dogtagging your boss is sweet indeed).</p>
<p>That&#8217;s all part of what makes the games industry such a great place to be if you love games &#8212; not only do you get to work with games, you get to work with gamers.</p>
<p>Yet most people seem to think that game developers isolate themselves in a small glass jar somewhere, and start ignoring the internet as soon as their project becomes public. Nearly every forum or blog post about a game has a bitter comment about &#8220;no chance the devs will bother to read this&#8221;.</p>
<p>Guess what &#8212; we do read stuff on the &#8216;net. Not only because we&#8217;re gamers but because we care deeply about making the best game possible. So why don&#8217;t we answer? Well, I think you could imagine what&#8217;d happen. Half the people would call you a liar, and the rest would bombard you with even more. There&#8217;s no way for a game developer to answer questions or opinions on a forum without immediately being subjected to at least twice the amount of new questions or opinions. We&#8217;d simply run out of time.</p>
<p>And well&#8230; at the end of the day, we have games to make.</p>
<p>For my own part, I&#8217;m more connected than most. Toss me a line on <a href="http://twitter.com/slicedlime">twitter</a> if you have a question.</p>
<script type="text/javascript">
var flattr_wp_ver = '0.9.11';
var flattr_uid = '409';
var flattr_url = 'http://www.entertainingcode.com';
var flattr_lng = 'en_GB';
var flattr_cat = 'text';
var flattr_tag = 'blog,wordpress,rss,feed';
var flattr_btn = 'large';
var flattr_tle = 'Entertaining Code';
var flattr_dsc = 'Coding and the games industry';
</script>
<script src="http://api.flattr.com/button/load.js?v=0.2" type="text/javascript"></script>]]></content:encoded>
			<wfw:commentRss>http://www.entertainingcode.com/archives/a-tour-of-the-games-studio/feed/</wfw:commentRss>
		<slash:comments>8</slash:comments>
		</item>
		<item>
		<title>A Spectacular Failure</title>
		<link>http://www.entertainingcode.com/archives/a-spectacular-failure/</link>
		<comments>http://www.entertainingcode.com/archives/a-spectacular-failure/#comments</comments>
		<pubDate>Sun, 26 Apr 2009 19:45:12 +0000</pubDate>
		<dc:creator>slicedlime</dc:creator>
				<category><![CDATA[The Games Industry]]></category>
		<category><![CDATA[Career]]></category>
		<category><![CDATA[Code]]></category>
		<category><![CDATA[Games]]></category>

		<guid isPermaLink="false">http://www.entertainingcode.com/?p=244</guid>
		<description><![CDATA[Back in the day I worked with the startup independent d [...]]]></description>
			<content:encoded><![CDATA[<p>Back in the day I worked with the startup independent developer Limebird Entertainment, we entered into a few game development competitions. You know the kind &#8212; make a game, show it off together with lots of others and then a group of people select the best ones for some prize.</p>
<p>Usually, the competitions themselves were not that exciting, but you know you take what you can get in terms of exposure and if you&#8217;re making a game anyway, then why not enter it into the competition? So we did.</p>
<p>The immediate result of this is that <strong>we now had a deadline</strong>. Deadlines can be incredibly healthy things because they force you to pull together and produce something solid. It doesn&#8217;t matter how many subsystems you have in place or how brilliant they are unless you&#8217;ve got something you can actually <a href="http://www.entertainingcode.com/archives/trying-the-open-source-shortcut/">show off to impress people</a>.</p>
<p>Another thing about deadlines is that you&#8217;re always behind for them. We were no exception here&#8230; I&#8217;ve done some crazy crunching at my current job, but for a single crunch, the one we did on Velox for that competition must be the absolute worst kind of crazy. The setup of the competition that year was that you bring your machine in (unless you liked the ones they had), and you show off the game on a big projector screen.</p>
<p><img class="alignright size-full wp-image-500" title="velox-racer" src="http://www.entertainingcode.com/wp-content/uploads/2009/04/velox-racer.jpg" alt="velox-racer" width="200" height="100" />We worked incredibly long hours the week leading up to that deadline. The game was coming together really well, but we were working ourselves dead. We didn&#8217;t really have all the stuff in that we wanted, however, and the deadline loomed. We worked all through the night to the presentation day, and then finally packed up our demo machine and left for the presentation.</p>
<p>At this time, I&#8217;d been awake and at work on this thing for about 30 hours. I was dead tired, and I&#8217;m sure my colleague wasn&#8217;t much better off. I was running on fumes and Coca-Cola.</p>
<p>Anyway, we set up the game, show off our menu system, host and join a network game and fly around for a bit in the hovercraft. Really high-tech stuff for the kind of level the competition was at, but it was also pretty rough around the edges. A minimap bug led to us having a hard time finding each others, for instance. Also, not having prepared any <em>presentation</em> as such, we sort of played around for a bit and showed off most of what we had in a rather unordered manner.</p>
<p>Then I went home, slept for 4 hours or so, got up, fixed most of our major bugs, and slept for another 10 hours.</p>
<p>The competition? We lost it to a team who&#8217;s game was an un-innovative re-make of an old game and whos engine was basically a Maya file viewer that needed really top-end hardware to even run properly, despite the really simple stuff they were doing.</p>
<p><strong>So just what happened there?</strong></p>
<p><img class="alignright size-full wp-image-505" title="box_e" src="http://www.entertainingcode.com/wp-content/uploads/2009/04/box_e.jpg" alt="box_e" width="200" height="200" />The first thing to take away from this story is hidden in what happened after the demo. I slept for just a few hours, and was so conditioned to working with the game that I went back to it, even though we didn&#8217;t have a deadline anymore. But something had changed &#8212; I wasn&#8217;t dead tired anymore, so my mental clarity was much much better, which meant I could do much more good.</p>
<p>If you ever think about doing an all-nighter to hit a deadline, think again. If you&#8217;re crunching hard for long periods of time, <a href="http://www.igda.org/articles/erobinson_crunch.php">stop to think</a>, because chances are you&#8217;ve crunched so long that you now produce less in 12 hours than you normally would in 8.</p>
<p>The second question is the key to why we lost the competition: Polish and show. We failed to analyse the situation of what our target was, so instead of locking down early and polishing what we had, we forged on adding stuff to our game. If we&#8217;d come to our demo in a better shape with a presentation we&#8217;d practiced for beforehand and a polished game, we might have done a lot better. Now our high-tech stuff just looked bland next to the shiny effects of the winner-to-be (as did many other teams&#8217; high-tech stuff, by the way).</p>
<p>Whenever you&#8217;re up against a deadline and need to show off what you&#8217;re working on, take a few minutes to identify what could give you the maximum impact with the people who&#8217;ll be watching and judging your stuff. <strong>Focus on the right things</strong>.</p>
<p>And have a good night&#8217;s sleep before you go there.</p>
<p></p>
]]></content:encoded>
			<wfw:commentRss>http://www.entertainingcode.com/archives/a-spectacular-failure/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Trying the Open Source Shortcut</title>
		<link>http://www.entertainingcode.com/archives/trying-the-open-source-shortcut/</link>
		<comments>http://www.entertainingcode.com/archives/trying-the-open-source-shortcut/#comments</comments>
		<pubDate>Thu, 16 Apr 2009 18:40:47 +0000</pubDate>
		<dc:creator>slicedlime</dc:creator>
				<category><![CDATA[Code]]></category>
		<category><![CDATA[Career]]></category>

		<guid isPermaLink="false">http://www.entertainingcode.com/?p=463</guid>
		<description><![CDATA[Jeff Atwood relates the story of an anonymous open sour [...]]]></description>
			<content:encoded><![CDATA[<p>Jeff Atwood relates <a href="http://www.codinghorror.com/blog/archives/001255.html">the story of an anonymous open source developer</a>, who has done code and design on several open source projects and wanted to use this as a good reference for job interviews.</p>
<blockquote><p>One company seemed impressed with my enthusiasm for the job but it was part of their policy to provide coding tests. This seemed perfectly reasonable and I did it by using the first solution I thought about. When I got to the phone interview, the guy spent about five minutes telling me how inefficient my coding solution was and that they were not very impressed. Then I asked whether he had looked at the open source projects I mentioned. He said no &#8211; but it seems his impression was already set based on my performance in the coding test.</p></blockquote>
<p>The anonymous programmer then goes on to ask if Open Source experience is overrated? I&#8217;m sure it isn&#8217;t, but just like Jeff writes, you&#8217;ve got to <strong>pick a good project </strong>&#8211; one that will impress me by its result. The thought that having done Open Source software development will somehow get you out of having to perform well on a coding test and on interviews is kind of peculiar.</p>
<p>In a recruitment situation, what you&#8217;re looking for is not only someone who&#8217;s skilled enough, but also passionate enough about getting that job to prove it. Joel Spolsky calls it <a href="http://www.joelonsoftware.com/articles/SortingResumes.html">pickiness</a>. Now going back to what our anonymous coder wrote:</p>
<blockquote><p>I did it by using the first solution I thought about</p></blockquote>
<p>I&#8217;m not surprised about the result. Caring about the code you&#8217;re doing and the job you&#8217;re applying for <strong>shows</strong>, both on coding test results and on your cover letter.</p>
<p>Open Source development does look good on a resume to me, but I&#8217;ve also seem some people with impressive resumes completely fail at implementing a very simple coding test. I absolutely understand the recruiter in the quote above &#8212; if your coding test result is bad, I&#8217;m not going to take the time to give more than a cursory glance to your previous projects, especially if you can&#8217;t answer well about why you wrote it the way you did.</p>
<p>It&#8217;s also a somewhat weird expectation from his side. <a href="http://www.codinghorror.com/blog/archives/000684.html">Reading code you don&#8217;t know is hard</a> and takes lots of time so the chance I&#8217;m going to download your open source code and actually read through it is virtually zero. If you haven&#8217;t done anything that <strong>actually achieved something</strong>, why should I care?  Even if you have, why would that matter if you just proved to me that you&#8217;re not what I&#8217;m looking for? Trust me, reading the results of a coding test is hard enough work, and if you have a fair few candidates, you&#8217;re not going to want to do much more than that.</p>
<p>He continues:</p>
<blockquote><p><strong>One of the reasons I worked so hard on open source projects was to make job interviews easier.</strong> By providing prospective employers with large samples of publically available working code, I thought I would give them something more useful to think about than my performance on a particular coding test or whether the acronyms in the job skills matched my &#8220;years spent&#8221;.</p></blockquote>
<p>I agree with Jeff that working on an open source development project is a good way to boost your resume &#8212; but it&#8217;s not a shortcut through having to perform well in all other areas. My tip is if you care about getting that job, put as much effort into the application and coding test as you would on any project code &#8212; open source or closed.</p>
<p></p>
<script type="text/javascript">
var flattr_wp_ver = '0.9.11';
var flattr_uid = '409';
var flattr_url = 'http://www.entertainingcode.com';
var flattr_lng = 'en_GB';
var flattr_cat = 'text';
var flattr_tag = 'blog,wordpress,rss,feed';
var flattr_btn = 'large';
var flattr_tle = 'Entertaining Code';
var flattr_dsc = 'Coding and the games industry';
</script>
<script src="http://api.flattr.com/button/load.js?v=0.2" type="text/javascript"></script>]]></content:encoded>
			<wfw:commentRss>http://www.entertainingcode.com/archives/trying-the-open-source-shortcut/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>An Exceptionally Stupid Idea</title>
		<link>http://www.entertainingcode.com/archives/an-exceptionally-stupid-idea/</link>
		<comments>http://www.entertainingcode.com/archives/an-exceptionally-stupid-idea/#comments</comments>
		<pubDate>Sat, 07 Mar 2009 00:04:37 +0000</pubDate>
		<dc:creator>slicedlime</dc:creator>
				<category><![CDATA[The Games Industry]]></category>
		<category><![CDATA[Career]]></category>
		<category><![CDATA[Code]]></category>
		<category><![CDATA[Games]]></category>

		<guid isPermaLink="false">http://www.entertainingcode.com/?p=242</guid>
		<description><![CDATA[I've been asked a fair few times how to get into the ga [...]]]></description>
			<content:encoded><![CDATA[<p>I&#8217;ve been asked a fair few times how to get into the games industry. It&#8217;s one of those job sectors where there&#8217;s tons of people who want to work, but still a shortage of people due to the lack of actually qualified people. Some of this is because there&#8217;s been a lack of education, some because it&#8217;s a somewhat harsh business to be in with a high turnover. Either way, it means there should be openings, if you&#8217;re interested.</p>
<p><strong>So how do you get in?</strong></p>
<p>The answer is very dependent on what you like, and what you do. The lack of education for designers has been solved lately with game design schools popping up like mushrooms all over the place. That creates a new problem though, as some of these schools aren&#8217;t exactly viewed as top notch by game studios. If you choose to go that route, be very careful about what school you pick.</p>
<p>If you&#8217;re a programmer, however, do not go anywhere near specialized &#8220;games&#8221; schools. What you need is a regular Software Engineering / Computer Science college. Don&#8217;t make <strong>the mistake of thinking that game coding is some special form of coding</strong>, that doesn&#8217;t abide by the normal rules of code. When choosing classes, go for anything in connection to games &#8212; graphics courses are common. Take anything they have with low-level programming and hardware. And take at least one programming project course.</p>
<p>Regardless of what education you end up in and what field you&#8217;re in, I have two generic pieces of advice that should apply to just about everyone:</p>
<ol>
<li>Have a side project.</li>
<li>Put your heart into it.</li>
</ol>
<p>I&#8217;m not going to claim this is the only way you can do it &#8212; but <strong>I&#8217;ll offer you a way that&#8217;s very effective</strong> if you&#8217;ve got the energy to stick to it.</p>
<h3>Side Projects</h3>
<p>And by side project, I don&#8217;t mean &#8220;implement space invaders&#8221;, I mean make something about two levels above your own experience and ability, and a lot larger than anything you&#8217;ve ever made before. Get at least one other person on board in the project, and work hard on it, reworking it and <strong>trying to perfect it</strong>.</p>
<p>The point of doing this is not the project itself, though it certainly helps to have a major project to show as a demo when talking about getting that job, <strong>the point is the experience you get while doing it</strong>. There&#8217;s a range of vital skills that nothing in any formal education will teach you, so you better get those skills for yourself.</p>
<p>I teamed up with a classmate and started writing a game engine while I was in college. It turned out to be a project that lasted four years, and that with a bit more luck could have led to something more than just a side project. The experience was invaluable.</p>
<p>Trying to tie your courses and your side project together is also a worthwhile enterprise. We ended up doing a number of home works in several 3d graphics courses in our game engine, and even made a game prototype as a software project course.</p>
<h3>Put Your Heart Into It</h3>
<p>Lots of students seem to go to college more for the college parties than for the college studies. That&#8217;s fine, in a general sense, but if you want to get yourself set to get any highly sought-after job, really, you&#8217;ll want to <strong>do everything you do with a sense of perfection</strong>.</p>
<p>Make it a goal to do well even on the difficult and boring things, and to excel on the interesting things. Take one step further than you really need to, and if things are interesting, keep walking even if it seems silly. Far too many people stop when they&#8217;ve completed an interesting task because that&#8217;s as far as they needed to take it, even though they were interested in the subject and could learn more by just keeping at it.</p>
<p>If I were to describe my method of doing things in college in one word, it&#8217;d be &#8220;Overkill&#8221;.</p>
<h3>An Exceptionally Stupid Idea</h3>
<p>Let me illustrate the above with a story.</p>
<p>In a course on mechanics we were making differential equation solver calculations on a housefly walking across a surface &#8212; calculating how the limbs and body moved while keeping the feet steady. The calculation application we were using was fancy enough to include a 3d visualization of the process. Cool idea, but to someone used to working with 3d graphics engines it was brutally ugly.</p>
<p>So the afternoon on the day before we were due to present it, we got an exceptionally stupid idea: &#8220;Let&#8217;s render this thing to a movie instead &#8212; it&#8217;ll look sweet&#8221;. The presentation was the morning after, we had the Solaris environment on the Sun boxes in the computer rooms to toy with, and my incredibly underpowered PC laptop&#8230; not much to cheer for, when looking for 3d graphics tools on a tight notice &#8212; but we did have <a href="http://www.povray.org/">POVRay</a> on the Solaris boxes.</p>
<p>We looked at the file format of our calculation tool, looked at the povray file format, and set off writing a converter. A number of hours, a break for pizza and lots of fiddling later, we had a converter and something that key-framed each frame into a separate povray source file. By now it was evening and the place was near-empty.</p>
<p>We ray traced the first frame. It took a disheartening amount of time. We had a couple of minutes of video to render, which turns out to be several thousand frames. I don&#8217;t remember the exact numbers now, but at the speed we were going, we&#8217;d be done a few weeks later. Give up, go home time?</p>
<p>Not for us. We had a near-empty room full of Sun workstations, and a way to run remote commands. So we tried to build frames remotely, but had no way to make a direct copy to the computers. Home directories were on a tight quota, which meant we couldn&#8217;t work online.</p>
<p>So we set to work creating a script that set up packages of work, copied them onto the home directory, started a remote job which copied the package to a local temp drive on the remote computer and rendered the frames.</p>
<p>We shipped packages to every free computer in the room, which was basically all of them by that point. Midnight came and went with a frightening speed. Still not good enough. A scan of the computer net confirmed that the rest of the rooms were as empty as the one we were in &#8212; so a list of computers with no-one logged in later we&#8217;d shipped off packages to every available computer on 3 floors, and 100+ computers were happily chugging out frames for our video.</p>
<p>By sunrise the next day we&#8217;ve got thousands of frames of video data spread out across every computer on site. An epic struggle of sending off remote jobs to copy these onto the network home drive started, moving them down onto my laptop as soon as they were online. We managed to get them all copied in time, and set the laptop on encoding them all into a video file.</p>
<p>Encoding videos isn&#8217;t the quickest thing you could do, and on a laptop at the time it was painfully slow. It was still building by the time the class started. Clock&#8217;s ticking, and the progress bar&#8217;s hardly moving&#8230; but our presentation was scheduled for the second of two hours of class, so we let the laptop encode as the first presentations were held.</p>
<p>In total, working all through that night, we managed to get the video together with 15 minutes to spare. And it did indeed look sweet. People went &#8220;ooh&#8221; when they saw it.</p>
<h3>The Point?</h3>
<p>So what was the point of the entire thing? We had been done with the actual assignment before this story even started. We had the idea at about the same time anyone else would have stopped because the assignment was done. It didn&#8217;t give us any academic benefits. <strong>But we learned a lot</strong>. We took on a challenge and grew with beating it.</p>
<p>By the time we were forced to give up the development of our game engine, and I went to work on <a href="http://www.amazon.com/gp/product/B000WS97QI?ie=UTF8&amp;tag=entercode-20&amp;linkCode=as2&amp;camp=1789&amp;creative=9325&amp;creativeASIN=B000WS97QI">Battlefield: Bad Company</a><img style="border:none !important; margin:0px !important;" src="http://www.assoc-amazon.com/e/ir?t=entercode-20&amp;l=as2&amp;o=1&amp;a=B000WS97QI" border="0" alt="" width="1" height="1" /> for DICE, we&#8217;d already created a fully networked multi-player hovercraft racing game with fully scriptable game modes that had error-correcting network transfer, could automatically send you any maps or game modes you were missing when you joined a server and worked on Windows, Linux, Mac OS X and Solaris.</p>
<p>With that kind of experience and track record, getting a games industry job won&#8217;t be hard, and performing far above everyone&#8217;s expectations will be something that comes naturally.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.entertainingcode.com/archives/an-exceptionally-stupid-idea/feed/</wfw:commentRss>
		<slash:comments>6</slash:comments>
		</item>
	</channel>
</rss>
