Linear Transformations#
import numpy as np
import scipy.linalg as la
import matplotlib.pyplot as plt
Matrix Multiplication#
Let’s create an asymmetrical figure in the xy-plane by defining lists of \(x\) and \(y\) coordinates.
x = [0.,-1.,-2.,0.,2.,1.,0.,1.]
y = [0.,2.,0.,-2.,0.,2.,0.,0.]
plt.plot(x,y,'.-'), plt.grid(True), plt.axis('equal')
plt.show()
data:image/s3,"s3://crabby-images/66595/665953558075103c404055b46e32b9532996ca04" alt="../_images/1ea8f01cc06f630ffc737e87f80bce43664f020cd87b80946eada5b5f0fc8031.png"
Note that we use the command plt.grid(True)
to include a grid in the figure and plt.axis('equal')
plots the figure with equal scaling in the \(x\) and \(y\) directions.
Stack the vectors of \(x\) and \(y\) coordinates to create a matrix \(X\). The columns of \(X\) are the coordinates of the points defining the vertices of the figure above. The row at index 0 are the \(x\)-coordinates and the row at index 1 are the \(y\)-coordinates.
X = np.row_stack([x,y])
print(X)
[[ 0. -1. -2. 0. 2. 1. 0. 1.]
[ 0. 2. 0. -2. 0. 2. 0. 0.]]
plt.plot(X[0,:],X[1,:],'.-'), plt.grid(True), plt.axis('equal')
plt.show()
data:image/s3,"s3://crabby-images/66595/665953558075103c404055b46e32b9532996ca04" alt="../_images/1ea8f01cc06f630ffc737e87f80bce43664f020cd87b80946eada5b5f0fc8031.png"
Any linear transformation of \(\mathbb{R}^2\) can be written as a 2 by 2 matrix with respect to the standard basis. Therefore we can apply to the figure above a linear transformation given by matrix \(A\) by computing matrix multiplication:
where column at index \(k\) corresponds to the point \((x_k,y_k) \in \mathbf{R}^2\). In other words, the column at index \(k\) in the product \(AX\) are the coordinates of the transformed point \(A \begin{bmatrix} x_k \\ y_k \end{bmatrix}\).
Rotation Matrix#
A rotation matrix is given by
The linear transformation corresponding to \(R_{\theta}\) is rotation about the origin clockwise by \(\theta\) radians.
theta = np.pi/6
R = np.array([[np.cos(theta),np.sin(theta)],[-np.sin(theta),np.cos(theta)]])
RX = R@X
plt.plot(X[0,:],X[1,:],'.-',alpha=0.2)
plt.plot(RX[0,:],RX[1,:],'.-'), plt.axis('equal'), plt.grid(True)
plt.show()
data:image/s3,"s3://crabby-images/55828/558282da6192f42206bae964b0e6d76c82f54ccc" alt="../_images/9e2c6ad775fe9ec7324b0216bb7406f36f082a1721cbd0ccaa1fe6c6b4fc4ff3.png"
Scaling Matrix#
A scaling matrix is given by
The linear transformation corresponding to \(C_{a,b}\) is scaling by \(a\) is the \(x\)-direction and scaling by \(b\) in the \(y\)-direction.
a = 3; b = 1/2;
C = np.diag([a,b])
CX = C@X
plt.plot(X[0,:],X[1,:],'.-',alpha=0.2)
plt.plot(CX[0,:],CX[1,:],'.-'), plt.axis('equal'), plt.grid(True)
plt.show()
data:image/s3,"s3://crabby-images/18633/1863307b84060a2fe682ada364ca2ab0f1911896" alt="../_images/1a30a1dfeeadd3d99f1c3c318149d8a22a67f1dd0c7178ae3762543f86d15a6e.png"
Shear Matrix#
A shear matrix is given by
The linear transformation corresponding to \(S_u\) is shear by factor \(u\) in the \(x\)-direction.
u = 1
S = np.array([[1,u],[0,1]])
SX = S@X
plt.plot(X[0,:],X[1,:],'.-',alpha=0.2)
plt.plot(SX[0,:],SX[1,:],'.-'), plt.axis('equal'), plt.grid(True)
plt.show()
data:image/s3,"s3://crabby-images/c9d93/c9d93219e9940bd6198920924b2e16a17e96b696" alt="../_images/1efca1dd31c3703c0d83e16926eb1cac463dcfec8c6523d7c682c8ef944ad05b.png"
Projection Matrix#
The matrix which projects onto the line at angle \(\theta\) with the \(x\)-axis is given by
theta = -np.pi/4
P = np.array([[np.cos(theta)**2,np.cos(theta)*np.sin(theta)],
[np.cos(theta)*np.sin(theta),np.sin(theta)**2]])
PX = P@X
plt.plot(X[0,:],X[1,:],'.-',alpha=0.2)
plt.plot(PX[0,:],PX[1,:],'.-'), plt.axis('equal'), plt.grid(True)
plt.show()
data:image/s3,"s3://crabby-images/19e5f/19e5f3d834862129326c9429959f11fd4475e90a" alt="../_images/caada88572c4e9a35e804d6d5e955c23536390956cef8af33571acc535b9cc8f.png"
Reflection Matrix#
The matrix which refelcts through the line at angle \(\theta\) with the \(x\)-axis is given by
theta = -np.pi/4
F = np.array([[np.cos(2*theta),np.sin(2*theta)],
[np.sin(2*theta),-np.cos(2*theta)]])
FX = F@X
plt.plot(X[0,:],X[1,:],'.-',alpha=0.2)
plt.plot(FX[0,:],FX[1,:],'.-'), plt.axis('equal'), plt.grid(True)
plt.show()
data:image/s3,"s3://crabby-images/caa28/caa2814edd052cde56cb09d860a3034ef87d955b" alt="../_images/2c1e55be2478377c443e41ef4caa8c58d1baee12485d0a4e639731452ee528d6.png"