- 96 Views
- Uploaded on
- Presentation posted in: General

General-Purpose Computation on Graphics Hardware

Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author.While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server.

- - - - - - - - - - - - - - - - - - - - - - - - - - E N D - - - - - - - - - - - - - - - - - - - - - - - - - -

General-Purpose Computation on Graphics Hardware

Adapted from: David Luebke (University of Virginia) and NVIDIA

- Everyone Must attend
- 10% loss of presentation points if a day is missed

- Grades are given to the group, not individual

- Overview / Motivation
- GPU Architecture Fundamentals
- GPGPU Programming and Usage
- New NVIDIA Architectures (FERMI)
- More Infromation

- GPUs are fast…
- 3 GHz Pentium4 theoretical: 6 GFLOPS, 5.96 GB/sec peak
- GeForceFX 5900 observed: 20 GFLOPS, 25.3 GB/sec peak
- GeForce 6800 Ultra observed: 53 GFLOPS, 35.2 GB/sec peak
- GeForce 8800 GTX: estimated at 520 GFLOPS, 86.4 GB/sec peak (reference here)
- That’s almost 100 times faster than a 3 Ghz Pentium4!

- GPUs are getting faster, faster
- CPUs: annual growth 1.5× decade growth 60×
- GPUs: annual growth > 2.0× decade growth > 1000

Courtesy Kurt Akeley,Ian Buck & Tim Purcell, GPU Gems (see course notes)

GPU

CPU

Courtesy Naga Govindaraju

multiplies per second

NVIDIA NV30, 35, 40

ATI R300, 360, 420

GFLOPS

Pentium 4

July 01

Jan 02

July 02

Jan 03

July 03

Jan 04

Courtesy Ian Buck

- Why are GPUs getting faster so fast?
- Arithmetic intensity: the specialized nature of GPUs makes it easier to use additional transistors for computation not cache
- Economics: multi-billion dollar video game market is a pressure cooker that drives innovation

- Modern GPUs are deeply programmable
- Programmable pixel, vertex, video engines
- Solidifying high-level language support

- Modern GPUs support high precision
- 32 bit floating point throughout the pipeline
- High enough for many (not all) applications

- The power and flexibility of GPUs makes them an attractive platform for general-purpose computation
- Example applications range from in-game physics simulation to conventional computational science
- Goal: make the inexpensive power of the GPU available to developers as a sort of computational coprocessor

- GPUs designed for and driven by video games
- Programming model is unusual & tied to computer graphics
- Programming environment is tightly constrained

- Underlying architectures are:
- Inherently parallel
- Rapidly evolving (even in basic feature set!)
- Largely secret

- Can’t simply “port” code written for the CPU!

- A simplified graphics pipeline
- Note that pipe widths vary
- Many caches, FIFOs, and so on not shown

CPU

GPU

Graphics State

Application

Transform

Rasterizer

Shade

VideoMemory(Textures)

Vertices(3D)

Xformed,LitVertices(2D)

Fragments(pre-pixels)

Finalpixels(Color, Depth)

Render-to-texture

Programmable vertex processor!

Programmable pixel processor!

CPU

GPU

Graphics State

VertexProcessor

FragmentProcessor

Application

VertexProcessor

Rasterizer

PixelProcessor

VideoMemory(Textures)

Vertices(3D)

Xformed,LitVertices(2D)

Fragments(pre-pixels)

Finalpixels(Color, Depth)

Render-to-texture

- Vertex Processor (multiple operate in parallel)
- Transform from “world space” to “image space”
- Compute per-vertex lighting

- Rasterizer
- Convert geometric rep. (vertex) to image rep. (fragment)
- Fragment = image fragment
- Pixel + associated data: color, depth, stencil, etc.

- Fragment = image fragment
- Interpolate per-vertex quantities across pixels

- Convert geometric rep. (vertex) to image rep. (fragment)

- Fragment Processors (multiple in parallel)
- Compute a color for each pixel
- Optionally read colors from textures (images)

- GPU: Each vertex / fragment is independent
- Temporary registers are zeroed
- No static data
- No read-modify-write buffers

- Data parallel processing
- Best for ALU-heavy architectures: GPUs
- Multiple vertex & pixel pipelines

- Hide memory latency (with more computation)

- Best for ALU-heavy architectures: GPUs

Courtesy of Ian Buck

- Lots of ops per word transferred
- GPGPU demands high arithmetic intensity for peak performance
- Ex: solving systems of linear equations
- Physically-based simulation on lattices
- All-pairs shortest paths

Courtesy of Pat Hanrahan

- Streams
- Collection of records requiring similar computation
- Vertex positions, Voxels, FEM cells, etc.

- Provide data parallelism

- Collection of records requiring similar computation
- Kernels
- Functions applied to each element in stream
- Transforms, PDE, …

- No dependencies between stream elements
- Encourage high arithmetic intensity

- Functions applied to each element in stream

Courtesy of Ian Buck

- Common GPGPU computation style
- Textures represent computational grids = streams

- Many computations map to grids
- Matrix algebra
- Image & Volume processing
- Physical simulation
- Global Illumination
- ray tracing, photon mapping, radiosity

- Non-grid streams can be mapped to grids

- Grid Simulation algorithm
- Made up of steps
- Each step updates entire grid
- Must complete before next step can begin

- Grid is a stream, steps are kernels
- Kernel applied to each stream element

- Grid communication
- Grid cells share information

- Programmable parallel processors
- Vertex & Fragment pipelines

- Rasterizer
- Mostly useful for interpolating addresses (texture coordinates) and per-vertex constants

- Texture unit
- Read-only memory interface

- Render to texture
- Write-only memory interface

- Fully programmable (SIMD / MIMD)
- Processes 4-vectors (RGBA / XYZW)
- Capable of scatter but not gather
- Can change the location of current vertex
- Cannot read info from other vertices
- Can only read a small constant memory

- Future hardware enables gather!
- Vertex textures

- Fully programmable (SIMD)
- Processes 4-vectors (RGBA / XYZW)
- Random access memory read (textures)
- Capable of gather but not scatter
- No random access memory writes
- Output address fixed to a specific pixel

- Typically more useful than vertex processor
- More fragment pipelines than vertex pipelines
- RAM read
- Direct output

- CPU programming is familiar
- GPU programming is graphics-centric

- Analogies can aid understanding

CPU GPU

Stream / Data Array = Texture

Memory Read = Texture Sample

Loop body / kernel / algorithm step = Fragment Program

CPU

GPU

- Each algorithm step depend on the results of previous steps
- Each time step depends on the results of the previous time step

- ABS - absolute value
- LOG - logarithm base 2 (approximate)
- MAD - multiply and add
- MAX - maximum
- MIN - minimum
- MOV - move
- MUL - multiply
- POW - exponentiate
- RCP – reciprocal
- RSQ - reciprocal square root
- SGE - set on greater than or equal
- SLT - set on less than
- SUB - subtract
- SWZ - extended swizzle
- XPD - cross product

- ABS - absolute value
- ADD - add
- ARL - address register load
- DP3 - 3-component dot product
- DP4 - 4-component dot product
- DPH - homogeneous dot product
- DST - distance vector
- EX2 - exponential base 2
- EXP - exponential base 2 (approximate)
- FLR - floor
- FRC - fraction
- LG2 - logarithm base 2
- LIT - compute light coefficients

IU

IU

IU

IU

IU

IU

IU

IU

IU

IU

IU

IU

IU

IU

IU

IU

SP

SP

SP

SP

SP

SP

SP

SP

SP

SP

SP

SP

SP

SP

SP

SP

Shared

Memory

Shared

Memory

Shared

Memory

Shared

Memory

Shared

Memory

Shared

Memory

Shared

Memory

Shared

Memory

Shared

Memory

Shared

Memory

Shared

Memory

Shared

Memory

Shared

Memory

Shared

Memory

Shared

Memory

Shared

Memory

TEX L1

TEX L1

TEX L1

TEX L1

TEX L1

TEX L1

TEX L1

TEX L1

TF

TF

TF

TF

TF

TF

TF

TF

L2

L2

L2

L2

L2

L2

Memory

Memory

Memory

Memory

Memory

Memory

- GeForce-8 Series
- 12,288 concurrent threads, hardware managed
- 128 Thread Processor cores at 1.35 GHz == 518 GFLOPS peak

Work Distribution

Host CPU

- Each SM contains
- 32 Cores
- 16 Load/Store units
- 32,768 registers

- Newer FP representation
- IEEE 754-2008

- Two units
- Floating point
- Integer

- Simultaneous execution possible

- Includes lots of sample applications
- Ray-tracer
- FFT
- Image segmentation
- Linear algebra

2-3x faster than CPU implementation

ATI Radeon 9800 XT

NVIDIA GeForce 6800

- GPUs still lose against SSE
- cache friendly code.
- Super-optimizations
- ATLAS
- FFTW

- compared against 3GHz P4:
- Intel Math Library
- FFTW
- Custom cached-blocked
- segment C code

- Fluids
- Reaction/Diffusion
- Multigrid
- Tone mapping