SOURCE 2006 Presentation by Luke Arntson Game Programming Optimization.

Slides:



Advertisements
Similar presentations
Traditional practice separates seismic data processing and further interpretation. However the most efficient processing methods utilize a-priori information.
Advertisements

Introduction Games have always been a fundamental part of human life. Space storm “ عاصفة الفضاء” is a 3D SCI-FI game that consists of two stages presented.
Team Offense: The 21 Set.
Electrical Energy and Electric Potential AP Physics C.
Chapter 4 Game Analysis: Centipede. Arcade Games Get a player to easily understand a game A player’s game, even the game of an expert, could not last.
Representing Motion Chapter 2 (pg 30-55). Do Now Why is it important to describe and analyze motion? How fast? How far? Slowing/Speeding? Rest/Constant.
INNER WORKINGS OF UNITY 3D. WHAT WE ARE GOING TO COVER Intro to Unity Physics & Game Objects Cameras & Lighting Textures & Materials Quaternions and Rotation.
Physics 218, Lecture XVII1 Physics 218 Lecture 17 Dr. David Toback.
1 Geometry A line in 3D space is represented by  S is a point on the line, and V is the direction along which the line runs  Any point P on the line.
Introduction What is this ? What is this ? This project is a part of a scientific research in machine learning, whose objective is to develop a system,
Physics 218, Lecture XVII1 Physics 218 Lecture 17 Dr. David Toback.
Mr Barton’s Maths Notes
JAWS Space-Shooter Game Design Language Justin Lu Guoxin Andy Lin Winston Chao Shoaib Anwar.
Electrical Energy and Electric Potential
Module 6 Lesson 16.
SuperCorners. Problem The Corners sample robot has a simple strategy: first, move into a corner of the arena, and second sweep the gun back and forth.
Backgrounds, Inheritance in GameMaker (BrickMania 1 of 2) Foundations of Interactive Game Design Professor Jim Whitehead January 28, 2008 Creative Commons.
CSS Sprites. What are sprites? In the early days of video games, memory for graphics was very low. So to make things load quickly and make graphics look.
Motion Chapter 12.
The force on a current-carrying wire A magnetic field exerts a force on a single moving charge, so it's not surprising that it exerts a force on a current-carrying.
TIPM3 Kindergarten and First Grade
Some Cool Tricks.  We can consider the screen as high school graph paper.  Each sprite or object is located somewhere in the coordinate system.
1 CO Games Development 1 Week 6 Introduction To Pathfinding + Crash and Turn + Breadth-first Search Gareth Bellaby.
Ikaruga Charlie Cross CIS Overview Released in 2001 in Japanese Arcades. Released for Dreamcast in 2002 Finally released for Gamecube in.
Description, Classes, Interfaces, Hierarchy, Specifics George Georgiev Telerik Software Academy academy.telerik.com Technical Trainer itgeorge.net.
Addison Wesley is an imprint of © 2010 Pearson Addison-Wesley. All rights reserved. Chapter 7 The Game Loop and Animation Starting Out with Games & Graphics.
SOLIDWORKS: Lesson II – Revolutions, Fillets, & Chamfers UCF Engineering.
Kinematics in 2-D Concept Map
Moving Around in Scratch The Basics… -You do want to have Scratch open as you will be creating a program. -Follow the instructions and if you have questions.
Two-Dimensional Motion and VectorsSection 1 Preview Section 1 Introduction to VectorsIntroduction to Vectors Section 2 Vector OperationsVector Operations.
CO1301: Games Concepts Dr Nick Mitchell (Room CM 226) Material originally prepared by Gareth Bellaby.
Multitouch and Collision Detection MOBILE SOFTWARE DEVELOPMENT.
11 Adding Tomato Targets Session Session Overview  We now have a game which lets a player bounce a piece of cheese on a bread bat  Now we have.
GAME:IT Helicopter Objectives: Review skills in making directional sprites Create objects that shoot and destroy for points Create random enemies on the.
240-Current Research Easily Extensible Systems, Octave, Input Formats, SOA.
Game Maker Terminology
1 Object-Oriented Programming (Java), Unit 24 Stand In Final Project Description Kirk Scott.
Shooters in GameMaker J Parker.
1 Project Management Example Solving Sudoku 2 What is Sudoku?  Sudoku is a game with 9 columns and 9 rows and 9 “boxes” composed of a 3 x 3 Grid  Numbers.
Dakota Humphries (Project Lead) Thomas Impellitteri (Tech Lead) Daryl McGhee II (Design Lead) Keith Rosier (Asset Lead)
Strategy Using Strategy1. Scan Path / Strategy It is important to visualize the scan path you want for a feature before you begin taking points on your.
Module 6Aberration and Doppler Shift of Light1 Module 6 Aberration and Doppler Shift of Light The term aberration used here means deviation. If a light.
Game Maker Galactic Mail Advanced Group: Complete Galactic Mail, then start developing an independent project.
Bridges To Computing General Information: This document was created for use in the "Bridges to Computing" project of Brooklyn College. You are invited.
 In this packet we will look at:  The meaning of acceleration  How acceleration is related to velocity and time  2 distinct types acceleration  A.
1 Project designed and created by M. Shajith Kumar.
by Richard J. Terwilliger Arrrgh Mate! That Pirate Ship won’t get my booty.
Chess Strategies Component Skills Strategies Prototype Josh Waters, Ty Fenn, Tianyu Chen.
RIHP community Umpiring sessions
SixIdeas for a capstone to GCS Spring Hellavation 3 rd person survival horror game Player is equipped with two weapons generic gun and slicer WSAD.
Intellectual Development from One to Three Chapter 12.
Welcome VIPs! Please help yourself to refreshments and find a seat. If you could sum up - in 5 words or less - your feelings about math homework this past.
Adding two numbers together which have the same absolute value but are opposite in sign results in a value of zero. This same principle can be applied.
Introduction to Game Programming & Design III Lecture III.
MS Access. Most A2 projects use MS Access Has sufficient depth to support a significant project. Relational Databases. Fairly easy to develop a good user.
The Stingray Example Program CMT3311. Stingray - an example 2D game May be useful as a simple case study Most 2D games need to solve generic problems.
Maths in Biosciences – Strategic sampling. Find the infected ash tree Column vector Coordinate Ash dieback DiseaseFungus epidemic.
Game Maker Tutorials Introduction Clickball IntroductionClickball Where is it? Shooting Where is it?Shooting.
Part 1 Projectiles launched horizontally
Chapter 3 Kinematics in two dimensions
Electrical Energy and Electric Potential
Background Shapes & Collision Resolution (Top-down and Side-scrolling)
Intro & Point-to-Box, Circle-to-Circle, Point-to-Circle
AP Physics Chapter 6 Momentum and Collisions
Fundamentals of Programming
AP Physics Chapter 6 Momentum and Collisions
CO Games Concepts Week 12 Collision Detection
Electrical Energy and Electric Potential
Electrical Energy and Electric Potential
Presentation transcript:

SOURCE 2006 Presentation by Luke Arntson Game Programming Optimization

Optimization Research How important is optimization in games? Optimization is the most essential part of coding when it comes to game development. Coders must always take into consideration the optimization of their solutions to ensure full-speed games. What types of optimization will we cover? There are many ways to properly optimize programs, including games. In this presentation, we will cover many ways of solving the same problems using optimization as key. The beauty of programming is the ability to be creative with the solutions, and finding new ways to approach old problems.

What Games Are We Going To Cover? Tetris – the classic puzzle block game Bullet Dodger – a vertical space shooter space shooter Death Bomberman – a clone of the original Bomberman the original Bomberman

Creating and Optimizing Tetris First, start with the layout The most prevalent type of layout for the Tetris piece is a 4x4 array. This array is used to tell the game where the Tetris blocks will be. By simplifying the Tetris piece itself, we can simplify the problem. I have implemented a system using the Tetris block coordinates in the 4x4 array, rather than the array itself. Next, let us look at rotations So now that we have determined the Tetris pieces can be created with coordinates, let us observe how we can apply rotations to these pieces.

Layout of Tetris Pieces With permission of Phil Hassey, code from FTetris philhassey – philhassey – 1. Box shape 2. Z shape 3. T shape my Tetris example my Tetris example Note: Numbers represent distance from top left corner Numbers are also in order: Left, Top, Right, and Bottom 1. Box shape 1. [(0,1), (0,0), (1,0), (1,1)] 2. Z shape 2. [(0,0), (1,0), (2,1), (1,1)] 3. T shape 3. [(0,0), (1,0), (2,0), (1,1)] See how much code was saved? Not only has this decreased the code amount significantly, but has also lead a path of optimization. 2. [(0,0,0,0), 2. [(0,0,0,0), (1,1,0,0), (1,1,0,0), (0,1,1,0), (0,1,1,0), (0,0,0,0),] (0,0,0,0),] 1. [(0,0,0,0), 1. [(0,0,0,0), (0,1,1,0), (0,1,1,0), (0,0,0,0),] (0,0,0,0),] 3.[(0,0,0,0), 3.[(0,0,0,0), (1,1,1,0), (1,1,1,0), (0,1,0,0), (0,1,0,0), (0,0,0,0),] (0,0,0,0),]

X Y0123Y0123 [(0,0,0,0), [(0,0,0,0), (1,1,1,0), (1,1,1,0), (0,1,0,0), (0,1,0,0), (0,0,0,0),] (0,0,0,0),] Visual Example Of Phil Hassey’s Code Here is a visual representation of how the 4x4 array is being drawn in Fractal Tetris by Phil Hassey.  Let us pretend we are building a Tetris piece, and the piece is made of four blocks  Each block is represented as a 1 or a 0 in the 4x4 array  We can now observe the array and watch how the 1s and 0s fill the grid

Visual Example Of Coordinates in Tetris Let use now examine the code given for coordinates of the piece, rather than a 4x4 array.  Let us pretend we are building a Tetris piece, and the piece is made of four blocks  Each block has (x,y) coordinates on a 4x4 grid X Y0123Y0123 [(0,0), (1,0), (2,0), (1,1)]  We can now match the coordinates given with the code: [(0,0), (1,0), (2,0), (1,1)] (0,0) (1,0) (2,0)(1,1)

How Do We Represent Rotations? First, what is a set of rotations? A set of rotations can be defined as a list of pieces. So using (X,Y) coordinates, we can define the following: Z Piece 1 st.(0,0), (1,0), (2,1), (1,1) 2 nd.(0,1), (1,0), (1,1), (0,2) T Shape Piece 1 st.(0,0), (1,0), (2,0), (1,1) 2 nd.(0,1), (1,0), (1,1), (1,2) 3 rd.(0,1), (1,0), (2,1), (1,1) 4 th.(0,1), (0,0), (1,1), (0,2) 7 Shape Piece 1 st.(0,0), (1,0), (1,1), (1,2) 2 nd.(0,1), (2,0), (2,1), (1,1) 3 rd.(0,1), (0,0), (1,2), (0,2) 4 th.(0,0), (1,0), (2,0), (0,1)

Optimizing The Rotation Now that we know our rotation, lets look at how we can optimize Notice that different pieces have a different number of rotations. For example, the large block shape only has one rotation, and the Z shape has two rotations, as where the T shape has four rotations. Now we can break these pieces into sub-groups based on the number of rotations. Break our shapes into sub-groups, and apply rotation After each sub-group is found, rotation is simple. In high level code, if the shape is in the current state, increment or decrement depending on which function is called. The number of states to rotate is determined by the sub- group given.

Bullet Dodger: How To Optimize All Those Bullets? Code must be simple yet effective For games such as Bullet Dodger, the speed of the frames are vital. If the game had been written on a console such as the Gameboy Advance, limitations with the number of cycles would always be a factor of programming. Collision checking only potentials It would be pointless to check every single bullet to every single enemy or player unless there was a potential of harm. By using a grid-collision system, collision checking can be brought down significantly while still maintaining a solid collision checking system.

Simple Code With Effective Results Bullet patterns in commercial games All space shooting games, old and new, rely on the concept of bullet patterns. In an older game such as Space Invaders, bullets simply flew down in a straight line towards the player. Later games such as Gradius used simple angle calculations to shoot bullets at the player. Moving the bullets in a linear path Applying simple math skills, it is easy to find the calculation for bullets. The simplest way to sum this up is by imagining there is a velocity vector to each bullet. The vector consists of an angle, and a vector length. By using the following code every frame, bullets can achieve a smooth travel across the playing field: Bullet X Coordinate += cos(vector.angle) * vector.length Bullet Y Coordinate += sin(vector.angle) * vector.length This simple calculation is used in Bullet Dodger to allow for a very nice looking effect not only for the bullets fired, but also for the simple particle engine used when there is a collision.

Simple Yet Effective Bullet Patterns Applying the unit circle to a bullet spread Currently using Pi/2 + (-Pi/8 < x < Pi/8)

Collision Detection Using Grid-collision Let’s split our screen into separate grid sections. Notice how the player ship and enemies are only in a few boxes, not ALL boxes. This is the idea we will implement to our grid-collision

Observing Where Objects Can Collide In Our Grid Areas of collision Now observe the red areas, see that the only places these objects can be hit is within these red sections. So ONLY do tedious collision detection in these boxes areas, saving a vast amount of processor time.

Death Bomberman: World Manager and Optimization Managing the world is difficult However, eliminating the need for objects to be self-sufficient allows for much cleaner code. If an object tells the world its desired movement or action, the world can then dictate whether or not the object is allowed to do so. This can be applied to many different games, and has been applied to many coding schemes used by major companies. How world management optimizes games By eliminating unnecessary checks such as wall-collision, game code can run at full speed while the world takes care of all special cases. For example: when bombs explode, they create a fire burst. Instead of each fire burst checking for an object to burn, the world manager tells the object to burn, and the fire burst to die out.

Applying to Death Bomberman Utilize the manager to make the world function By applying the world manager effectively, each object in the world will behave accordingly. Bombs will be placed correctly, and maps will know which items to destroy and which to leave intact.

Questions? For more information on this presentation, feel free to visit my website at: or me at