A vector is represented traditionally with respect to a coordinate system. More generally it is represented by a set of basis vectors - two vectors which are linearly independent and form a vector subspace. A vector is therefore a linear combination of these basis vectors. In a global cartesian coordinate system these are the unit vectors \(\hat{x}\), \(\hat{y}\), and \(\hat{z}\). A vector can be represented in another coordinate system by changing its basis vectors.
Definitions
With:
- \(M\), a basis matrix containing the basis vectors as columns
- \(\vec{v}\), a column vector in the basis vector space \(M\)
When written as:
the vector \(\hat{a}\) is the vector in global coordinates.
The reverse can be achieved to determine a vector defined by a different basis:
This works both for 2-D and 3-D vectors.
Example
Let a set of basis vectors be defined as:
and
The basis matrix being:
These basis vectors result in the following grid when plotted:
data:image/s3,"s3://crabby-images/953e8/953e836c1ba80a7a3a9192dcbb0eebe0ea4d58fc" alt=""
Conversion to Global Coordinates
Set a vector in this space equal to \(\begin{bmatrix}-2&3\end{bmatrix}\).
This vector using basis coordinates is plotted as the following:
data:image/s3,"s3://crabby-images/bed45/bed4511d40ed23417eefcb4220b318648b229b39" alt=""
The vector \(\vec{a}\) (in global coordinates) is calculated with Eq 1. and is therefore equal to
data:image/s3,"s3://crabby-images/e3801/e38018919c24ed4fe07392fd1ef04b76bf0a0996" alt=""
Converstion to Basis Coordinates
Using a vector in global coordinates of:
we have:
data:image/s3,"s3://crabby-images/e9544/e9544886c7c06f43c24cf4d5a9ae2805beaeacbb" alt=""
And to convert it to the basis space, we multiply the vector by the inverse of the basis matrix.
data:image/s3,"s3://crabby-images/1031e/1031e260f95ac941abc00c3fdfc4000dd60438f5" alt=""
Transformation Matrix
Change of basis can be used to derive transformation matices.
Rotation
Counter-clockwise rotation by an angle \(\theta\) is developed using unit vectors established by this angle:
data:image/s3,"s3://crabby-images/27825/2782585b61ca25213e57d257b351a645fe5ed337" alt=""
Scale
With scaling, the global unit vectors maintain the same orientation but are scaled in length by a scale factor, \(s\). The new basis vectors are then the following:
data:image/s3,"s3://crabby-images/ccede/ccedea5d7b5d64b5cc8c35c63ed8e9d19f7842ba" alt=""
Shear
Shearing along a principal axis may be derived as follows, for example when along the x-axis:
data:image/s3,"s3://crabby-images/95512/95512a05e808ed9706625378dbf63d0323348ea8" alt=""
Polygon Transformation
As an example of transformation matrices, let's create and transform a generic polygon using Python and matplotlib.
Using the following points as definition:
xy = np.array([[0,0],[2,3],[1,3],[3,6],[5,3],[4,3],[6,0]])
we obtain this polygon:
data:image/s3,"s3://crabby-images/ad962/ad962429610a6f0972f7e05caf1e5da591fef48d" alt=""
Rotation
For a rotation of 45 degrees, counter-clockwise about the origin, the transformation matrix becomes:
rotation = np.radians(45)
x = np.array([ np.cos(rotation), np.sin(rotation) ])
y = np.array([ -np.sin(rotation), np.cos(rotation) ])
M = np.hstack( (x.reshape(-1,1), y.reshape(-1,1)) )
>>> print(M)
[[ 0.70710678 -0.70710678]
[ 0.70710678 0.70710678]]
The new polygon points are then calculated with:
xy_new = np.dot(M,xy.T)
Adding the rotated polygon to the plot:
data:image/s3,"s3://crabby-images/78eb9/78eb92776dc9eea7e3f893c57b79d6c4d1efe951" alt=""
Scale
Using scale factors of 1.9 and 1.4 for the x and y axis, respectively:
sx = 1.9
sy = 1.4
x = np.array([ sx, 0 ])
y = np.array([ 0, sy ])
M = np.hstack( (x.reshape(-1,1), y.reshape(-1,1)) )
>>> print(M)
[[1.9 0. ]
[0. 1.4]]
We calculate the points for the scaled polygon the same way:
xy_new = np.dot(M,xy.T)
poly_scaled = Polygon(xy_new.T, fill=False, edgecolor='blue')
And plotting:
data:image/s3,"s3://crabby-images/3728d/3728d8797b12923516698d3719801c386fdb27a5" alt=""
Shear
Here we will shear along the x-axis by 45 degrees. The transformation matrix is:
angle = 45
x = np.array([ 1, 0 ])
y = np.array([ np.sin(np.radians(angle)), 1 ])
M = np.hstack( (x.reshape(-1,1), y.reshape(-1,1)) )
>>> print(M)
[[1. 0.70710678]
[0. 1. ]]
And the sheared polygon is calculated using matrix multiplication again:
xy_new = np.dot(M,xy.T)
poly_scaled = Polygon(xy_new.T, fill=False, edgecolor='blue')
data:image/s3,"s3://crabby-images/48403/48403db7840e7c460451dd0f6e113fe6ac893670" alt=""