hi
WTF
is a
GPU
@omershapira
Raytracing
data:image/s3,"s3://crabby-images/8a7ba/8a7baad3d80a40c8083895499a10bc280f75a15f" alt=""
Accurate
RayTracing
- Striaghtforward simulation
- Mathematically correct
- Can approximate physical phenomena
- Is really, really slow
- Can't currently be used for real time (one day it will).
GPUs Are Fast
CPU
Like 4*
Apex of technology
Like 8GB*
Entire program at once
GPU
Like 400*
Pretty much a microbe
Like 1GB*
One element (pixel, vertex etc) at once
Cores
Complexity
RAM
Program
data:image/s3,"s3://crabby-images/78e26/78e2657ce1077a443951b7d771cfb2200a59f39f" alt=""
* For computers in 2014
A GPU is a computer inside a computer.
Raytracer
- Artist thinks of a sphere
- Creates NURBS sphere
- Renders
- Life is good
Z-Buffer
- Artist thinks of a sphere
- Makes a polygon instead.
- Sends polygon into VBO
- Calculates model, view and projection matrix
- Debugs tesselation shader
- Fakes lights in fragment shader
- Attaches shaders, textures and properties
- Creates an FBO for post-processing
- Makes janky vignette effect
- Oops, draw call count is too high
- I just wanted to make pong, 'the fuck is this
- Retires at 23, spends rest of life in Fiji
How pixels are put on screens
data:image/s3,"s3://crabby-images/5e947/5e947625988a458729ec6292c81b4966fec7c5d6" alt=""
Vertex Shader
Small program that processes each vertex in the model geometry.
Can do:
- Scaling/Rotation/Translation
- Move polygons to screen space
- Read texture and geometry info
- Paint vertices
//Bad vertex shader
//set vertex color to magenta
gl_FrontColor = vec4(1,0,1,1);
//set the UV coordinate
gl_TexCoord[0] = gl_MultiTexCoord0;
//set the XYZ coordinate
gl_Position = modelViewProjectionMatrix * gl_Vertex;
Vertex Shader
Example: Normal Extrusion
gl_Position.xyz += normal * ExtrusionAmount;
data:image/s3,"s3://crabby-images/71f5f/71f5ffe453fa0b551290398e4308e4137ba20f8e" alt=""
data:image/s3,"s3://crabby-images/4db72/4db7258ea6786f12a19bc87f04f011742a46ce91" alt=""
Images (c) Unity Technologies
Fragment Shader
Paints pixel components (fragments) in screen space.
Can do:
- Read textures and (poor) geometry info
- Move nothing
- Paint every single pixel on the screen
//read the UV coords from a texture
vec4 img = texture2D(texture, uv);
//premultiply alpha
img.rgb *= img.a;
//assign to the output fragment
gl_FragCoord = img
Fragment Shader
Example: Discarding Pixels
data:image/s3,"s3://crabby-images/11a5d/11a5df7c2775d6f91fdf4384006e3951f161f4a0" alt=""
data:image/s3,"s3://crabby-images/5555c/5555c00cf8fc32fb982f6cfab80ba76bc97d4197" alt=""
Example: Normals To Colors
gl_FragColor *= abs(normal);
Images (c) Unity Technologies
float value= frac((pos.y + pos.z*.1) * 5);
if(value < 0.5) {
discard;
}
Tesselation
The tesselator determines where tesselation needs to occur and:
- Subdivides iffy triangles to less iffy triangles
- Attemps to reduce curvature
- Avoids large triangles in screen space
data:image/s3,"s3://crabby-images/de911/de9118f30b877e1e048607914c2fea381d758b16" alt=""
The Z-Buffer Pipeline
- Buffer VBOs
- Load textures
- Bind a specific shader program (vert + tess + frag)
- Draw calls:
- Vertex shader, then
- Tesselation shader, then
- Rasterizer, then
- Fragment shader
- After all draw calls, Depth Sorting.
Depth Sorting
data:image/s3,"s3://crabby-images/753da/753da29fcaf5dfa9633fb5084605f0328965e649" alt=""
This is easy in Raytrcing
but hard in Realtime
data:image/s3,"s3://crabby-images/0fb02/0fb02336738bbc6b32e8ef097167e5edbc62c9b8" alt=""
Realtime Artists worry about:
- Number of draw calls
- Number of triangles / vertices on screen
- Time it takes shaders to run (shaders can time out)
- Number of transparent / blended layers
- Scripts that may clog the pipeline
- WHY IS EVERYTHING AROUND ME ON FIRE
Non-RT Artists Worry about:
- Occasionally, too many photons make the render long
- That cyan is physically accurate, but isn't exactly my cup of Kombucha
Lighting
Expensive: Deferred Lighting
data:image/s3,"s3://crabby-images/3bbf7/3bbf78667e829070f6336f1dc45dca4439a35179" alt=""
data:image/s3,"s3://crabby-images/23afb/23afb36104c6560bb0562def2a553976192fd9ed" alt=""
data:image/s3,"s3://crabby-images/5f273/5f273190d86b1203190d682190e812020a02a917" alt=""
data:image/s3,"s3://crabby-images/f5e65/f5e65f3a4c3c5177ee8b0b892c26632dc762125b" alt=""
Diffuse Pass
Depth Pass
Normal Pass
Final Composite
Lighting
Cheaper: Forward
Calculate all of the color information from a list of lights, one after another, directly on the material.
data:image/s3,"s3://crabby-images/f3845/f38456fb3a27a8138e57c3663d845bf8c26c75a5" alt=""
Lighting
Cheapest: Baked
Baked lighting can get raytracer-quality textures for elements that don't change.
data:image/s3,"s3://crabby-images/5fd23/5fd23945a4ed45060398b8f0dfd0f14605175ee2" alt=""
data:image/s3,"s3://crabby-images/14cad/14cade692f292134bd8a31ae7245f01114958d66" alt=""
Gears of War
Shadows
Expensive: ShadowMapping
Pretend each light source is a camera, and paint that "camera"'s screenspace with light.
The remaining dark pixels are the shadows.
Expensive because it requires multiple geo->screen renders.
data:image/s3,"s3://crabby-images/d0154/d015402747a03a378e14fa3f1c9f5d9fcb1c3040" alt=""
data:image/s3,"s3://crabby-images/021d6/021d62923f28f04d3ab4911c5b05ebd5a65c97ae" alt=""
Shadows
Better: Blob shadows, Cookies
Create a "Dark light" from a directional source with a small footprint, and add tags to specific materials affected.
data:image/s3,"s3://crabby-images/bc3ef/bc3ef9e3f2ea51121359b0afb3fa4e788ea4222c" alt=""
data:image/s3,"s3://crabby-images/fc73b/fc73b09396bf2764a9069a90dd8c1ac867118a96" alt=""
Images (c) Unity Technologies
Shadows
Cheap: Baked
Raytrace the whole thing.
data:image/s3,"s3://crabby-images/9eb94/9eb94b6bf1d927591c3a55b80cd7ff74a879b948" alt=""
Far Cry 2
Animation
Spritesheets are still good. Sometimes videos are too.
data:image/s3,"s3://crabby-images/2b8d8/2b8d8dd498b16455b443623e6d3355c93b0a6df3" alt=""
Braid
Animation
Principles
Game animation should be:
- Looping
- Stateful (run->walk etc)
- Centered around a pivot
Tools:
- GPUs support skinned meshes
- Bones are native to most programs
- Cloths are not
data:image/s3,"s3://crabby-images/f529f/f529f179f173c3a73d6a1a1522e56a6bb03550e5" alt=""
Procedural
If it:
- Has too many states that don't really matter
- Acting kinda predictably, but hard to keyframe
- Depends on exact interaction
Maybe it's easier to do in code.
data:image/s3,"s3://crabby-images/10c41/10c418064bbccaedfd47e77dc0d56c5954d55fab" alt=""
Boids
Postprocessing
Glow
data:image/s3,"s3://crabby-images/2663b/2663bad532fba7002c76fdf11ce408bc26fd6865" alt=""
Unreal Engine 4
Postprocessing
Lens Distortion
data:image/s3,"s3://crabby-images/e6f25/e6f25e62fdbfb0918e79ea44496215f75b3c7d1b" alt=""
Unreal Engine 3
Postprocessing
- No cheap way for pixels to know about their neighbors.
- No cheap way to oversample.
- Involves copying every single pixel to a new buffer. Expensive.
Antialiasing
- In advanced cards, happens automatically in pixel space.
- Never happens in geometry space. If a triangle is too small, it's either in or out.
data:image/s3,"s3://crabby-images/76a2e/76a2ec65a82a3ce4f387c10dff4b9d5869ae0d42" alt=""
MIP Maps
- The GPU solution for seamless zooming
- Each MIP level is 1/2 the size of the previous one
- Takes another 1/3 of the image space
- Precomputed when loading the texture
- Relatively cheap to read
data:image/s3,"s3://crabby-images/ced04/ced043e0f4c79f85f1d04c7c4accd3d0b3aa266e" alt=""
data:image/s3,"s3://crabby-images/b6693/b6693336864cb99d7a6a2a7577e328ebed4c09e1" alt=""
Faking it
- Flares as textures
- Glows as textures
- Noise as textures
- You get the deal
- Sometimes, all of the above can be generative, but sparingly
data:image/s3,"s3://crabby-images/64094/64094a665d34d1dfdd551f881b3b51e4aa9205f2" alt=""
data:image/s3,"s3://crabby-images/811c4/811c4086b6e74bd39ed11e0cb7b4f357993253bc" alt=""
Faking it
Volumetric effects can be faked with use of the depth buffer
data:image/s3,"s3://crabby-images/95366/9536646cee010f3871cd6f3a485f65d471a4a31a" alt=""
Inigo Quilez
Faking IT
Screen Space Ambient Occlusion
data:image/s3,"s3://crabby-images/4b342/4b34226116cb984a65ee5ef8707417216c27dfed" alt=""
Splinter Cell
data:image/s3,"s3://crabby-images/14950/149508ece97c2e31c1f809408ef10943ccf0e1fb" alt=""
Thanks
WTF is a GPU (Framestore, September 2014)
By Omer Shapira
WTF is a GPU (Framestore, September 2014)
- 3,004