data:image/s3,"s3://crabby-images/754a0/754a01d51973f1465c9fd004965001ec17e7895a" alt="DSA Takeover Cheatsheet"
Open-Source Internship opportunity by OpenGenus for programmers. Apply now.
Reading time: 30 minutes
A graphics processing unit (GPU) is a processor like CPU and TPU for faster graphics processing. Specifically, it designed to rapidly manipulate and alter memory to accelerate the creation of images in a frame buffer to be displayed on a screen.
The parallel structure of a GPU makes it more efficient for algorithms where several components can be executed in parallel such as Machine Learning algorithms/ inference.
In this article, we have explored some of the basic architecture concepts in Graphics Processing Unit (GPU).
Graphics Pipeline
This image summaries the graphics pipeline in a GPU:
data:image/s3,"s3://crabby-images/e490f/e490f513b3b3a71afad12fb20dd22d74d3e8edbb" alt="graphics pipeline in GPU"
You need to understand the following ideas:
- Vector processing
- Primitive Processing
- Rasterization
- Fragment processing
- Pixel operations
Vector processing
Each vector is transformed in screen space and processed independently.
data:image/s3,"s3://crabby-images/8d215/8d21581cfb2bebd344824f3d5207d6cbbac69b18" alt="vector processing in GPU"
Primitive Processing
The vertices are organized into primitives that are clipped.
data:image/s3,"s3://crabby-images/02b65/02b65bf199a66272f0310975a4167a0f713642d5" alt="primitive processing in GPU"
Rasterization
Primitives are rasterized into “pixel fragments”. Each primitive is rasterized independently.
data:image/s3,"s3://crabby-images/b32f4/b32f440366a4528eb2874869f422b126685fe387" alt="rasterization in GPU"
Fragment processing
Fragments are shaded to compute a color at each pixel. Each fragment is processed independently.
data:image/s3,"s3://crabby-images/b4a29/b4a29580578cf4c0415c88ca6ad8e367f5a23dc9" alt="fragment processing in GPU"
Pixel operations
Fragments are blended into the frame buffer at their pixel locations (z-buffer determines visibility).
data:image/s3,"s3://crabby-images/506ab/506abb3ed6f6b59526357bde3cf68bcb2e6d296b" alt="pixel operations in GPU"
There are five pipeline entities:
- Vertices
- Primitives
- Fragments
- Shaded fragments
- Pixels
data:image/s3,"s3://crabby-images/ceecb/ceecb0ae27f5f0794d3495bdaecf78c844b25c9c" alt="five pipeline entities in GPU"
Graphics architectures
In this section, we will take a look at how the Graphics pipeline is implemented and how the independent nature of the operations are maintained.
This image demonstrates the architecture of NVIDIA GeForce 8800 developed in 2006:
data:image/s3,"s3://crabby-images/56975/56975a1ca7a594df8166854ef7e182e18d954d5f" alt="NVIDIA GeForce 8800 architecture"
The above architecture uses the concept of unified shading which is a significant improvement over the basic CPU architecture and is one of the secrets of GPU's speed.
Shader programming model
Shader programming model follows the following ideas:
-
Fragments are processed independently but there is no explicit parallel programming
-
Independent logical sequence of control per fragment.
Shader programming and improvements in this field gives GPU an enormous boost in speed. Check out this article to understand the intuition behind Shader Programming in CPU