Matrix Transformations
Vertex positions are three-dimensional vectors with values. Operations can be performed on these positions, like translate, rotate, or scale, and result in a new, transformed position.
A single 4x4 matrix can encode this sequence of operations, and can be multiplied by a vector to apply its transformation.
Applying transformation to vector , results in a new vector, :
While the vectors represent 3D positions conceptually, when undergoing transformation, they're represented as having four dimensions; values representing a point in 3D space, and an extra value that is set to 1 (see Homogeneous Coordinates).
Matrices only encode relative transformations, so the same matrix can be applied to multiple vertices. For example, given a matrix that translates a vector by will add 5 to each vector's value.
Multiplying two transformation matrices together results in a new matrix that encodes both transformations in order. This allows a series of operations to be chained together, defining the sequence of transformations to be performed on a vector. For example, a vector can be transformed by a scale matrix , followed by a rotation matrix , and finally a translation matrix . Note that matrix multiplication is performed from right to left.
Encoding multiple operations as a single matrix is a powerful consequence of representing transformations as matrices. The above , , and transformations can be multiplied into a single matrix . In this example, if applying this transform to many vertices, could be cached, needing only one multiplication per vertex, rather than three.
Given a series of vertices representing a cube, and a matrix representing a scale, rotation and translation, each vertex can be multiplied by the same matrix.
Applying a scale, rotation and translation matrix to a collection of vertices is the foundation of the model matrix.
Identity Matrix
There exists an identity matrix .
Any transformation matrix , when multiplied by the identity matrix , results in .
Inverse Matrix
Multiplying a transform matrix by its own inverse matrix results in the identity matrix. Inverse, or reciprocal, matrices are often denoted as .
Inverse matrices are used to change points to be relative to a new frame of reference. Given two transformation matrices defined in the same coordinate space, a transform can then be defined relative to another transform.
For example, given two transformations defined in some shared "world" space, can be redefined relative to via multiplying by the inverse:
Column-major, row-major
Matrices are represented as arrays in OpenGL. There are two reasonable ways of interpreting these matrices in an array/1D data structure: column-major and row-major.
Interpreting the above matrix as column-major when storing as an array:
// column-major
[ m11, m21, m31, m41,
  m12, m22, m32, m42,
  m13, m23, m33, m43,
  m14, m24, m34, m44 ]
And as row-major:
// row-major
[ m11, m12, m13, m14,
  m21, m22, m23, m24,
  m31, m32, m33, m434,
  m41, m42, m43, m44 ]
Note that OpenGL conventions use column-major order and post-multiplication. Opting to instead premultiply, row-major order could be used.
Homogeneous Coordinates
The initial 3D vector is represented as a 4D vector with because affine transformations use homogeneous coordinates, requiring one extra dimension. Transform matrices allow representing a series of transforms with a single matrix, which is not possible if using a vertex's 3D Cartesian coordinates for some transformations, namely perspective.
Transformation Reference
Language constructs and math libraries should be preferred. Matrices listed here as reference.
Note that the translation, rotation and scale matrices below become the identity matrix when translating by , rotating by , or scaling by respectively, essentially becoming noops.
Translation
The following matrix translates a vector by .
Rotation
The matrices , , and rotate around the , , and axes respectively by radians. There exists other ways of generating rotation matrices, like from a quaternion, or by any axis, which may be more appropriate.
Scale
The following matrix scales a vector by .
Perspective Projection
Projection matrices are defined by their left (), right (), top (), bottom () extents and their near () and far () plane values. 3D Projection covers these matrices in more detail.
represents the general form of perspective projection.
A simplified form, can be used for symmetric projections, where and .
Orthographic projection
represents the general form of orthographic projection.
A simplified form, can be used for symmetric projections, where and .