Skip to main content

Section 7.6 Using Singular Value Decompositions

We’ve now seen what singular value decompositions are, how to construct them, and how they provide important information about a matrix such as orthonormal bases for the four fundamental subspaces. This puts us in a good position to begin using singular value decompositions to solve a wide variety of problems.
Given the fact that singular value decompositions so immediately convey fundamental data about a matrix, it seems natural that some of our previous work can be reinterpreted in terms of singular value decompositions. Therefore, we’ll take some time in this section to revisit some familiar issues, such as least squares problems and principal component analysis, while also looking at some new applications.

Preview Activity 7.6.1.

Suppose that \(A = U\Sigma V^{\transpose}\) where
\begin{equation*} \Sigma = \begin{bmatrix} 13 \amp 0 \amp 0 \amp 0 \\ 0 \amp 8 \amp 0 \amp 0 \\ 0 \amp 0 \amp 2 \amp 0 \\ 0 \amp0 \amp 0 \amp 0 \\ 0 \amp0 \amp 0 \amp 0 \end{bmatrix}, \end{equation*}
vectors \(\uvec_j\) form the columns of \(U\text{,}\) and vectors \(\vvec_j\) form the columns of \(V\text{.}\)
  1. What are the shapes of the matrices \(A\text{,}\) \(U\text{,}\) and \(V\text{?}\)
  2. What is the rank of \(A\text{?}\)
  3. Describe how to find an orthonormal basis for \(\col(A)\text{.}\)
  4. Describe how to find an orthonormal basis for \(\nul(A)\text{.}\)
  5. If the columns of \(Q\) form an orthonormal basis for \(\col(A)\text{,}\) what is \(Q^{\transpose}Q\text{?}\)
  6. How would you form a matrix that projects vectors orthogonally onto \(\col(A)\text{?}\)
Solution.
  1. \(A\) is \(5\by4\text{,}\) \(U\) is \(5\by5\text{,}\) and \(V\) is \(4\by4\text{.}\)
  2. \(\rank(A)=3\) since there are three nonzero singular values.
  3. The first three columns, \(\uvec_1\text{,}\) \(\uvec_2\text{,}\) and \(\uvec_3\text{,}\) of \(U\) form an orthonormal basis for \(\col(A)\text{.}\)
  4. The last column \(\vvec_4\) of \(V\) is a basis for \(\nul(A)\text{.}\)
  5. \(Q^{\transpose}Q=I\) since each entry is a dot product of two vectors in an orthonormal set.
  6. \(QQ^{\transpose}\) projects vectors orthogonally onto \(\col(A)\text{.}\)

Subsection 7.6.1 Least squares problems

Least squares problems, which we explored in Section 6.5, arise when we are confronted with an inconsistent linear system \(A\xvec=\bvec\text{.}\) Since there is no solution to the system, we instead find the vector \(\xvec\) minimizing the distance between \(\bvec\) and \(A\xvec\text{.}\) That is, we find the vector \(\xhat\text{,}\) the least squares approximate solution, by solving \(A\xhat=\bhat\) where \(\bhat\) is the orthogonal projection of \(\bvec\) onto the column space of \(A\text{.}\)
If we have a singular value decomposition \(A=U\Sigma V^{\transpose}\text{,}\) then the number of nonzero singular values \(r\) tells us the rank of \(A\text{,}\) and the first \(r\) columns of \(U\) form an orthonormal basis for \(\col(A)\text{.}\) This basis may be used to project vectors onto \(\col(A)\) and hence to solve least squares problems.
Recall that we can compute the reduced singular value decomposition of a matrix using np.linalg.svd() and that only the diagonal entries of \(\Sigma\) (i.e., the singular values) are returned.

Activity 7.6.2.

Consider the equation \(A\xvec=\bvec\) where
\begin{equation*} \begin{bmatrix} 1 \amp 0 \\ 1 \amp 1 \\ 1 \amp 2 \end{bmatrix} \xvec = \threevec{-1}36 \end{equation*}
  1. Find a singular value decomposition for \(A\) using the Python cell below. What are singular values of \(A\text{?}\)
  2. What is \(r\text{,}\) the rank of \(A\text{?}\) How can we identify an orthonormal basis for \(\col(A)\text{?}\)
  3. Form the reduced singular value decomposition \(U_r\Sigma_rV_r^{\transpose}\) by constructing the matrix \(U_r\text{,}\) consisting of the first \(r\) columns of \(U\text{,}\) the matrix \(V_r\text{,}\) consisting of the first \(r\) columns of \(V\text{,}\) and \(\Sigma_r\text{,}\) a square \(r\by r\) diagonal matrix. Verify that \(A=U_r\Sigma_r V_r^{\transpose}\text{.}\)
    You may find it convenient to remember that if B is a matrix defined in Python, then B[:, slice] and B[slice, :] can be used to extract columns or rows from B where slice enumerates the desired columns or rows. For instance, B[0:2, :]) provides a matrix formed from the first three rows of B.
  4. How does the reduced singular value decomposition provide a matrix whose columns are an orthonormal basis for \(\col(A)\text{?}\)
  5. Explain why a least squares approximate solution \(\xhat\) satisfies
    \begin{equation*} A\xhat = U_rU_r^{\transpose}\bvec. \end{equation*}
  6. What is the product \(V_r^{\transpose}V_r\) and why does it have this form?
  7. Explain why
    \begin{equation*} \xhat = V_r\Sigma_r^{-1}U_r^{\transpose}\bvec \end{equation*}
    is the least squares approximate solution, and use this expression to find \(\xhat\text{.}\)
Answer.
  1. \(\sigma_1 = 2.67\) and \(\sigma_2 = 0.92\text{.}\)
  2. \(\rank(A) = 2\) and the first two columns of \(U\) form an orthonormal basis for \(\col(A)\text{.}\)
  3. We have
    \begin{equation*} U_r = \begin{bmatrix} -0.22 \amp 0.89 \\ -0.52 \amp 0.25 \\ -0.83 \amp -0.39 \end{bmatrix},\hspace{24pt} \Sigma_r = \begin{bmatrix} 2.7 \amp 0.00 \\ 0.00 \amp 0.92 \end{bmatrix},\hspace{24pt} V_r = \begin{bmatrix} -0.58 \amp 0.81 \\ -0.81 \amp -0.58 \end{bmatrix}\text{.} \end{equation*}
  4. The columns of \(U_r\) form an orthonormal basis for \(\col(A)\text{.}\)
  5. \(\displaystyle \bhat=U_rU_r^{\transpose}\bvec\)
  6. \(\displaystyle V_r^{\transpose}V_r = I\)
  7. \(\displaystyle \xhat=\twovec{-0.83}{3.50}\)
Solution.
  1. The singular values are \(\sigma_1 = 2.67\) and \(\sigma_2 = 0.92\text{.}\)
  2. There are two nonzero singular values so \(\rank(A) = 2\text{.}\) The first two columns of \(U\) form an orthonormal basis for \(\col(A)\text{.}\)
  3. We have
    \begin{equation*} U_r = \begin{bmatrix} -0.22 \amp 0.89 \\ -0.52 \amp 0.25 \\ -0.83 \amp -0.39 \end{bmatrix},\hspace{24pt} \Sigma_r = \begin{bmatrix} 2.7 \amp 0.00 \\ 0.00 \amp 0.92 \end{bmatrix},\hspace{24pt} V_r = \begin{bmatrix} -0.58 \amp 0.81 \\ -0.81 \amp -0.58 \end{bmatrix}\text{.} \end{equation*}
  4. The columns of \(U_r\) form an orthonormal basis for \(\col(A)\text{.}\)
  5. Since \(\bhat=U_rU_r^{\transpose}\bvec\text{,}\) we obtain the equation \(A\xhat = U_rU_r^{\transpose}\bvec\text{.}\)
  6. \(V_r^{\transpose}V_r = I\) since this product computes the dot products of the columns.
  7. We have the equation \(A\xhat = U_rU_r^{\transpose}\bvec\text{,}\) which gives
    \begin{equation*} \begin{aligned} A\xhat \amp = U_rU_r^{\transpose}\bvec \\ U_r\Sigma_rV_r^{\transpose}\xhat \amp = U_rU_r^{\transpose}\bvec \\ \Sigma_rV_r^{\transpose}\xhat \amp = U_r^{\transpose}\bvec \\ V_r^{\transpose}\xhat \amp = \Sigma_r^{-1}U_r^{\transpose}\bvec \\ \xhat \amp = V_r\Sigma_r^{-1}U_r^{\transpose}\bvec \\ \end{aligned} \end{equation*}
This activity demonstrates the power of a singular value decomposition to find a least squares approximate solution for an equation \(A\xvec = \bvec\text{.}\) Because it immediately provides an orthonormal basis for \(\col(A)\text{,}\) something that we’ve had to construct using the Gram-Schmidt process in the past, we can easily project \(\bvec\) onto \(\col(A)\text{,}\) which results in a simple expression for \(\xhat\text{.}\)
If the columns of \(A\) are linearly independent, then the equation \(A\xhat = \bhat\) has only one solution so there is a unique least squares approximate solution \(\xhat\text{.}\) Otherwise, the expression in Proposition 7.6.1 produces the solution to \(A\xhat=\bhat\) having the shortest length.
The matrix \(A^+ = V_r\Sigma_r^{-1}U_r^{\transpose}\) is known as the Moore-Penrose psuedoinverse of \(A\text{.}\) When \(A\) is invertible, \(A^+ = A^{-1} \text{.}\)

Subsection 7.6.2 Rank \(k\) approximations

If we have a singular value decomposition for a matrix \(A\text{,}\) we can form a sequence of matrices \(A_k\) that approximate \(A\) with increasing accuracy. This may feel familiar to calculus students who have seen the way in which a function \(f(x)\) can be approximated by a linear function, a quadratic function, and so forth with increasing accuracy.
We’ll begin with a singular value decomposition of a rank \(r\) matrix \(A\) so that \(A=U\Sigma V^{\transpose}\text{.}\) To create the approximating matrix \(A_k\text{,}\) we keep the first \(k\) singular values and set the others to zero. For instance, if
\begin{equation*} \Sigma = \begin{bmatrix} 22 \amp 0 \amp 0 \amp 0 \amp 0 \\ 0 \amp 14 \amp 0 \amp 0 \amp 0 \\ 0 \amp 0 \amp 3 \amp 0 \amp 0 \\ 0 \amp 0 \amp 0 \amp 0 \amp 0 \\ \end{bmatrix}\text{,} \end{equation*}
we can form matrices
\begin{equation*} \Sigma^{(1)} = \begin{bmatrix} 22 \amp 0 \amp 0 \amp 0 \amp 0 \\ 0 \amp 0 \amp 0 \amp 0 \amp 0 \\ 0 \amp 0 \amp 0 \amp 0 \amp 0 \\ 0 \amp 0 \amp 0 \amp 0 \amp 0 \\ \end{bmatrix}, \hspace{24pt} \Sigma^{(2)} = \begin{bmatrix} 22 \amp 0 \amp 0 \amp 0 \amp 0 \\ 0 \amp 14 \amp 0 \amp 0 \amp 0 \\ 0 \amp 0 \amp 0 \amp 0 \amp 0 \\ 0 \amp 0 \amp 0 \amp 0 \amp 0 \\ \end{bmatrix} \end{equation*}
and define \(A_1 = U\Sigma^{(1)}V^{\transpose}\) and \(A_2 = U\Sigma^{(2)}V^{\transpose}\text{.}\) Because \(A_k\) has \(k\) nonzero singular values, we know that \(\rank(A_k) = k\text{.}\) In fact, there is a sense in which \(A_k\) is the closest matrix to \(A\) among all rank \(k\) matrices.

Activity 7.6.3.

Let’s consider a matrix \(A=U\Sigma V^{\transpose}\) where
\begin{align*} \amp U = \begin{bmatrix} \frac{1}{2} \amp \frac{1}{2} \amp \frac{1}{2} \amp \frac{1}{2} \\ \frac{1}{2} \amp \frac{1}{2} \amp -\frac{1}{2} \amp -\frac{1}{2} \\ \frac{1}{2} \amp -\frac{1}{2} \amp \frac{1}{2} \amp -\frac{1}{2} \\ \frac{1}{2} \amp -\frac{1}{2} \amp -\frac{1}{2} \amp \frac{1}{2} \\ \end{bmatrix},\hspace{10pt} \Sigma = \begin{bmatrix} 500 \amp 0 \amp 0 \amp 0 \\ 0 \amp 100 \amp 0 \amp 0 \\ 0 \amp 0 \amp 20 \amp 0 \\ 0 \amp 0 \amp 0 \amp 4 \end{bmatrix}\\ \amp V = \begin{bmatrix} \frac{1}{2} \amp \frac{1}{2} \amp \frac{1}{2} \amp \frac{1}{2} \\ \frac{1}{2} \amp -\frac{1}{2} \amp -\frac{1}{2} \amp \frac{1}{2} \\ -\frac{1}{2} \amp -\frac{1}{2} \amp \frac{1}{2} \amp \frac{1}{2} \\ -\frac{1}{2} \amp \frac{1}{2} \amp -\frac{1}{2} \amp \frac{1}{2} \end{bmatrix} \end{align*}
Evaluating the following cell will create the matrices U, V, and Sigma. Notice how the diagonal_matrix command provides a convenient way to form the diagonal matrix \(\Sigma\text{.}\)
  1. Form the matrix \(A=U\Sigma V^{\transpose}\text{.}\) What is \(\rank(A)\text{?}\)
  2. Now form the approximating matrix \(A_1=U\Sigma^{(1)} V^{\transpose}\text{.}\) What is \(\rank(A_1)\text{?}\)
  3. Find the error in the approximation \(A\approx A_1\) by finding \(A-A_1\text{.}\)
  4. Now find \(A_2 = U\Sigma^{(2)} V^{\transpose}\) and the error \(A-A_2\text{.}\) What is \(\rank(A_2)\text{?}\)
  5. Find \(A_3 = U\Sigma^{(3)} V^{\transpose}\) and the error \(A-A_3\text{.}\) What is \(\rank(A_3)\text{?}\)
  6. What would happen if we were to compute \(A_4\text{?}\)
  7. What do you notice about the error \(A-A_k\) as \(k\) increases?
Answer.
  1. \(A = \begin{bmatrix} 156 \amp 96 \amp -144 \amp -104 \\ 144 \amp 104 \amp -156 \amp -96 \\ 104 \amp 144 \amp -96 \amp -156 \\ 96 \amp 156 \amp -104 \amp -144 \end{bmatrix}\text{.}\)
  2. \(A_1=\begin{bmatrix} 125 \amp 125 \amp -125 \amp -125 \\ 125 \amp 125 \amp -125 \amp -125 \\ 125 \amp 125 \amp -125 \amp -125 \\ 125 \amp 125 \amp -125 \amp -125 \end{bmatrix}\text{.}\)
  3. \(\displaystyle A-A_1 = \begin{bmatrix} 31 \amp -29 \amp -19 \amp 21 \\ 19 \amp -21 \amp -31 \amp 29 \\ -21 \amp 19 \amp 29 \amp -31 \\ -29 \amp 31 \amp 21 \amp -19 \end{bmatrix}\)
  4. \(A_2 = \begin{bmatrix} 150 \amp 100 \amp -150 \amp -100 \\ 150 \amp 100 \amp -150 \amp -100 \\ 100 \amp 150 \amp -100 \amp -150 \\ 100 \amp 150 \amp -100 \amp -150 \end{bmatrix}\) and \(A-A_2 = \begin{bmatrix} 6 \amp -4 \amp 6 \amp -4 \\ -6 \amp 4 \amp -6 \amp 4 \\ 4 \amp -6 \amp 4 \amp -6 \\ -4 \amp 6 \amp -4 \amp 6 \end{bmatrix}\text{.}\)
  5. \(A_3 = \begin{bmatrix} 155 \amp 95 \amp -145 \amp -105 \\ 145 \amp 105 \amp -155 \amp -95 \\ 105 \amp 145 \amp -95 \amp -155 \\ 95 \amp 155 \amp -105 \amp -145 \end{bmatrix}\) and \(A-A_3 = \begin{bmatrix} 1 \amp 1 \amp 1 \amp 1 \\ -1 \amp -1 \amp -1 \amp -1 \\ -1 \amp -1 \amp -1 \amp -1 \\ 1 \amp 1 \amp 1 \amp 1 \end{bmatrix}\text{.}\)
  6. \(\displaystyle A_4=A\)
  7. The entries get closer to \(0\text{.}\)
Solution.
  1. We find that \(A\) is the rank \(4\) matrix: \(\begin{bmatrix} 156 \amp 96 \amp -144 \amp -104 \\ 144 \amp 104 \amp -156 \amp -96 \\ 104 \amp 144 \amp -96 \amp -156 \\ 96 \amp 156 \amp -104 \amp -144 \end{bmatrix}\text{.}\)
  2. Because it has one nonzero singular value, \(A_1\) has rank \(1\) and has the form: \(A_1=\begin{bmatrix} 125 \amp 125 \amp -125 \amp -125 \\ 125 \amp 125 \amp -125 \amp -125 \\ 125 \amp 125 \amp -125 \amp -125 \\ 125 \amp 125 \amp -125 \amp -125 \end{bmatrix}\text{.}\)
  3. \(\displaystyle A-A_1 = \begin{bmatrix} 31 \amp -29 \amp -19 \amp 21 \\ 19 \amp -21 \amp -31 \amp 29 \\ -21 \amp 19 \amp 29 \amp -31 \\ -29 \amp 31 \amp 21 \amp -19 \end{bmatrix}\)
  4. \(A_2\) is the rank \(2\) matrix \(\begin{bmatrix} 150 \amp 100 \amp -150 \amp -100 \\ 150 \amp 100 \amp -150 \amp -100 \\ 100 \amp 150 \amp -100 \amp -150 \\ 100 \amp 150 \amp -100 \amp -150 \end{bmatrix}\) and \(A-A_2 = \begin{bmatrix} 6 \amp -4 \amp 6 \amp -4 \\ -6 \amp 4 \amp -6 \amp 4 \\ 4 \amp -6 \amp 4 \amp -6 \\ -4 \amp 6 \amp -4 \amp 6 \end{bmatrix}\text{.}\)
  5. \(A_3\) is the rank \(3\) matrix \(\begin{bmatrix} 155 \amp 95 \amp -145 \amp -105 \\ 145 \amp 105 \amp -155 \amp -95 \\ 105 \amp 145 \amp -95 \amp -155 \\ 95 \amp 155 \amp -105 \amp -145 \end{bmatrix}\) with \(A-A_3 = \begin{bmatrix} 1 \amp 1 \amp 1 \amp 1 \\ -1 \amp -1 \amp -1 \amp -1 \\ -1 \amp -1 \amp -1 \amp -1 \\ 1 \amp 1 \amp 1 \amp 1 \end{bmatrix}\text{.}\)
  6. \(A_4=A\) since \(A\) is a rank \(4\) matrix.
  7. As \(k\) increases, the entries in the \(A-A_k\) get closer to \(0\text{.}\) This means that our approximations \(A\approx A_k\) are improving.
In this activity, the approximating matrix \(A_k\) has rank \(k\) because its singular value decomposition has \(k\) nonzero singular values. We then saw how the difference between \(A\) and the approximations \(A_k\) decreases as \(k\) increases, which means that the sequence \(A_k\) forms better approximations as \(k\) increases.
Another way to represent \(A_k\) is with a reduced singular value decomposition so that \(A_k = U_k\Sigma_kV_k^{\transpose}\) where
\begin{equation*} U_k = \begin{bmatrix} \uvec_1 \amp \ldots \amp \uvec_k \end{bmatrix},\hspace{10pt} \Sigma_k = \begin{bmatrix} \sigma_1 \amp 0 \amp \ldots \amp 0 \\ 0 \amp \sigma_2 \amp \ldots \amp 0 \\ \vdots \amp \vdots \amp \ddots \amp \vdots \\ 0 \amp 0 \amp \ldots \amp \sigma_k \end{bmatrix},\hspace{10pt} V_k = \begin{bmatrix} \vvec_1 \amp \ldots \amp \vvec_k \end{bmatrix}\text{.} \end{equation*}
Notice that the rank \(1\) matrix \(A_1\) then has the form \(A_1 = \uvec_1\begin{bmatrix}\sigma_1\end{bmatrix} \vvec_1^{\transpose} = \sigma_1\uvec_1\vvec_1^{\transpose}\) and that we can similarly write:
\begin{align*} A \approx A_1 \amp = \sigma_1\uvec_1\vvec_1^{\transpose}\\ A \approx A_2 \amp = \sigma_1\uvec_1\vvec_1^{\transpose} + \sigma_2\uvec_2\vvec_2^{\transpose}\\ A \approx A_3 \amp = \sigma_1\uvec_1\vvec_1^{\transpose} + \sigma_2\uvec_2\vvec_2^{\transpose} + \sigma_3\uvec_3\vvec_3^{\transpose}\\ \vdots \amp\\ A = A_r \amp = \sigma_1\uvec_1\vvec_1^{\transpose} + \sigma_2\uvec_2\vvec_2^{\transpose} + \sigma_3\uvec_3\vvec_3^{\transpose} + \ldots + \sigma_r\uvec_r\vvec_r^{\transpose}\text{.} \end{align*}
Given two vectors \(\uvec\) and \(\vvec\text{,}\) the matrix \(\uvec~\vvec^{\transpose}\) is called the outer product of \(\uvec\) and \(\vvec\text{.}\) (The dot product \(\uvec\cdot\vvec=\uvec^{\transpose}\vvec\) is sometimes called the inner product.) An outer product will always be a rank \(1\) matrix so we see above how \(A_k\) is obtained by adding together \(k\) rank \(1\) matrices, each of which gets us one step closer to the original matrix \(A\text{.}\)

Subsection 7.6.3 Principal component analysis

In Section 7.4, we explored principal component analysis as a technique to reduce the dimension of a dataset. In particular, we constructed the covariance matrix \(S\) from a demeaned data matrix and saw that the eigenvalues and eigenvectors of \(S\) tell us about the variance of the dataset in different directions. We referred to the eigenvectors of \(S\) as principal components and found that projecting the data onto a subspace defined by the first few principal components frequently gave us a way to visualize the dataset. As we added more principal components, we retained more information about the original dataset. This feels similar to the rank \(k\) approximations we have just seen so let’s explore the connection.
Suppose that we have a dataset with \(n\) points, that \(X\) represents the demeaned column-variate data matrix, that \(X = U\Sigma V^{\transpose}\) is a singular value decomposition, and that the singular values of \(X\) are denoted as \(\sigma_i\text{.}\) It follows that the covariance matrix
\begin{equation*} S = \frac1{n-1} X^{\transpose}X = \frac1{n-1} (U\Sigma V^{\transpose})^{\transpose} (U\Sigma V^{\transpose}) = V\left(\frac1{n-1} \Sigma^{\transpose} \Sigma \right) V^{\transpose}. \end{equation*}
Notice that \(\frac1{n-1} \Sigma^{\transpose} \Sigma \) is a diagonal matrix whose diagonal entries are \(\frac1{n-1}\sigma_i^2\text{.}\) Therefore, it follows that
\begin{equation*} S = V\left(\frac1{n-1} \Sigma^{\transpose} \sigma \right) V^{\transpose} \end{equation*}
is an orthgonal diagonalization of \(S\) showing that
  • the principal components of the dataset, which are the eigenvectors of \(S\text{,}\) are given by the columns of \(V\text{.}\) In other words, the right singular vectors of \(X\) are the principal components of the dataset.
  • the variance in the direction of a principal component is the associated eigenvalue of \(S\) and therefore
    \begin{equation*} V_{\uvec_i} = \frac1{n-1}\sigma_i^2. \end{equation*}

Activity 7.6.4.

Let’s revisit the iris data set that we studied in Section 7.4. Remember that there are four measurements given for each of 150 irises and that each iris belongs to one of three species.
Evaluating the following cell will load the dataset and define the demeaned column-variate data matrix \(X\) whose shape is \(150 \by 4\text{.}\)
  1. Find the singular values of \(X_iris\) using the command np.linalg.svd() and use them to determine the variance \(V_{\uvec_j}\) in the direction of each of the four principal components. What is the fraction of variance retained by the first two principal components?
  2. We will now write the matrix \(\Gamma = \Sigma V^{\transpose}\) so that \(X = U\Gamma\text{.}\) Suppose that a demeaned data point, say, the 100th column of \(X\text{,}\) is written as a linear combination of principal components:
    \begin{equation*} \xvec = c_1\uvec_1+c_2\uvec_2+c_3\uvec_3+c_4\uvec_4. \end{equation*}
    Explain why \(\fourvec{c_1}{c_2}{c_3}{c_4}\text{,}\) the vector of coordinates of \(\xvec\) in the basis of principal components, appears as 100th column of \(\Gamma\text{.}\)
  3. Suppose that we now project this demeaned data point \(\xvec\) orthogonally onto the subspace spanned by the first two principal components \(\uvec_1\) and \(\uvec_2\text{.}\) What are the coordinates of the projected point in this basis and how can we find them in the matrix \(\Gamma\text{?}\)
  4. Alternatively, consider the approximation \(A_2=U_2\Sigma_2V_2^{\transpose}\) of the demeaned data matrix \(A\text{.}\) Explain why the 100th column of \(A_2\) represents the projection of \(\xvec\) onto the two-dimensional subspace spanned by the first two principal components, \(\uvec_1\) and \(\uvec_2\text{.}\) Then explain why the coefficients in that projection, \(c_1\uvec_1 + c_2\uvec_2\text{,}\) form the two-dimensional vector \(\twovec{c_1}{c_2}\) that is the 100th column of \(\Gamma_2=\Sigma_2 V_2^{\transpose}\text{.}\)
  5. Now we’ve seen that the columns of \(\Gamma_2 = \Sigma_2 V_2^{\transpose}\) form the coordinates of the demeaned data points projected on to the two-dimensional subspace spanned by \(\uvec_1\) and \(\uvec_2\text{.}\) In the cell below, find a singular value decomposition of \(A\) and use it to form the matrix Gamma2. When you evaluate this cell, you will see a plot of the projected demeaned data plots, similar to the one we created in Section 7.4.
Answer.
  1. The fraction of the total variance represented by the first two principal components is \(97.8\%\text{.}\)
  2. If \(\xvec = c_1\uvec_1+c_2\uvec_2+c_3\uvec_3+c_4\uvec_4\text{,}\) then \(\fourvec{c_1}{c_2}{c_3}{c_4}\) is the corresponding column of \(U^{\transpose}A\text{.}\)
  3. We just need the first two components of the corresponding column of \(\Gamma\text{.}\)
  4. \(\twovec{c_1}{c_2}\) is the corresponding column of \(U_2^{\transpose}A\text{.}\)
  5. We can construct \(\Gamma_2=\Sigma_2 V_2^{\transpose}\) or just pull out the first two rows of \(\Gamma=\Sigma V^{\transpose}\text{.}\)
Solution.
  1. The singular values are \(\sigma_1=25.1\text{,}\) \(\sigma_2 = 6.0\text{,}\) \(\sigma_3=3.4\) and \(\sigma_4 = 1.9\text{.}\) Since \(V_{\uvec_i} = \frac{1}{150} \sigma_i^2\text{,}\) the variances are \(4.20\text{,}\) \(0.24\text{,}\) \(0.08\text{,}\) and \(0.02\text{.}\) The fraction of the total variance represented by the first two principal components is \(97.8\%\text{.}\)
  2. If \(\xvec\) is the \(100^{th}\) column of \(A\text{,}\) then \(\fourvec{c_1}{c_2}{c_3}{c_4}\) is the \(100^{th}\) column of \(U^{\transpose}A = U^{\transpose}(U\Sigma V^{\transpose}) = \Sigma V^{\transpose} = \Gamma\text{.}\)
  3. The projected data point is \(\xhat = c_1\uvec_1 + c_2\uvec_2\) since \(c_3\uvec_3+c_4\uvec_4\) is orthogonal to the subspace spanned by the first two principal components. Therefore, the coordinates of the projected data point are the first two components of the corresponding column of \(\Gamma\text{.}\) The coordinates of all the projected data points are given by the first two rows of \(\Gamma\text{.}\)
  4. Once again, suppose that \(\xvec=c_1\uvec_1+c_2\uvec_2+c_3\uvec_3+c_4\uvec_4\) is a column of \(A\) and that \(U_2 = \begin{bmatrix}\uvec_1 \amp \uvec_2 \end{bmatrix}\text{.}\) Then \(\twovec{c_1}{c_2}\) is the corresponding column of \(U_2^{\transpose}A = U_2(U\Sigma V^{\transpose}) = \begin{bmatrix} 1 \amp 0 \amp 0 \amp 0 \\ 0 \amp 1 \amp 0 \amp 0 \\ \end{bmatrix}\Sigma V^{\transpose} = \Sigma_2 V_2^{\transpose}=\Gamma_2\text{.}\)
  5. We can construct \(\Gamma_2=\Sigma_2 V_2^{\transpose}\) or just pull out the first two rows of \(\Gamma=\Sigma V^{\transpose}\text{.}\)
In our first encounter with principal component analysis, we began with a demeaned data matrix \(A\text{,}\) formed the covariance matrix \(S\text{,}\) and used the eigenvalues and eigenvectors of \(S\) to project the demeaned data onto a smaller dimensional subspace. In this section, we have seen that a singular value decomposition of \(A\) provides a more direct route: the left singular vectors of \(A\) form the principal components and the approximating matrix \(A_k\) represents the data points projected onto the subspace spanned by the first \(k\) principal components. The coordinates of a projected demeaned data point are given by the columns of \(\Gamma_k = \Sigma_kV_k^{\transpose}\text{.}\)

Subsection 7.6.4 Image compressing and denoising

In addition to principal component analysis, the approximations \(A_k\) of a matrix \(A\) obtained from a singular value decomposition can be used in image processing. Remember that we studied the JPEG compression algorithm, whose foundation is the change of basis defined by the Discrete Cosine Transform, in Section 4.4. We will now see how a singular value decomposition provides another tool for both compressing images and removing noise in them.

Example 7.6.2.

Applying the singular value decomposition to an image provides an interesting way to do image compression. The rank \(k\) approximations get better as \(k\) increases, and the singular values indicate how quickly the approximations improve. If there are only a relatively small number of singular values that are large, a rank \(k\) approximation with a relatively small \(k\) may provide an acceptabley good approximation to the image.
The following cell loads a gray-scale image of a lily and displays it.
Now let’s compute the (reduced) SVD for the image matrix and inspect the shapes of each piece, comparing them to the shape of the original image.
We can construct the matrix for our image and confirm that (up to a bit of rounding) we get back our orignal image. Broadcasting in Python allows us to do this without creating the diagonal matrix \(\Sigma\text{.}\)
Now let’s create a function that computes the rank \(k\) approximation from the SVD. And plot the first few approximations. Feel free to try some other values of \(k\) as well.
The singular values shrink quite rapidly, suggesting that a rank 20 or 30 approximation might provide a reasonable approximation to the image.

Activity 7.6.5.

Evaluating the following cell loads some data that we’ll use in this activity. To begin, it defines and displays a \(25\by15\) matrix \(A\text{.}\)
  1. If we interpret 0 as black and 1 as white, this matrix represents an image as shown below.
    We will explore how the singular value decomposition helps us to compress this image.
    1. By inspecting the image represented by \(A\text{,}\) identify a basis for \(\col(A)\) and determine \(\rank(A)\text{.}\)
    2. The following cell plots the singular values of \(A\text{.}\) Explain how this plot verifies that the rank is what you found in the previous part.
    3. There is a command approximate(A, k) that creates the approximation \(A_k\text{.}\) Use the cell below to define \(k\) and look at the images represented by the first few approximations. What is the smallest value of \(k\) for which \(A=A_k\text{?}\)
    4. Now we can see how the singular value decomposition allows us to compress images. Since this is a \(25\by15\) matrix, we need \(25\cdot15=375\) numbers to represent the image. However, we can also reconstruct the image using a small number of singular values and vectors:
      \begin{equation*} A = A_k = \sigma_1\uvec_1\vvec_1^{\transpose} + \sigma_2\uvec_2\vvec_2^{\transpose} + \ldots + \sigma_k\uvec_k\vvec_k^{\transpose}. \end{equation*}
      What are the dimensions of the singular vectors \(\uvec_i\) and \(\vvec_i\text{?}\) Between the singular vectors and singular values, how many numbers do we need to reconstruct \(A_k\) for the smallest \(k\) for which \(A=A_k\text{?}\) This is the compressed size of the image.
    5. The compression ratio is the ratio of the uncompressed size to the compressed size. What compression ratio does this represent?
  2. Next we’ll explore an example based on a photograph.
    1. Consider the following image consisting of an array of \(316\by310\) pixels stored in the matrix \(A\text{.}\)
      Plot the singular values of \(A\text{.}\)
    2. Use the cell below to study the approximations \(A_k\) for \(k=1, 10, 20, 50, 100\text{.}\)
      Notice how the approximating image \(A_k\) more closely approximates the original image \(A\) as \(k\) increases.
      What is the compression ratio when \(k=50\text{?}\) What is the compression ratio when \(k=100\text{?}\) Notice how a higher compression ratio leads to a lower quality reconstruction of the image.
  3. A second, related application of the singular value decomposition to image processing is called denoising. For example, consider the image represented by the matrix \(A\) below.
    This image is similar to the image of the letter "O" we first studied in this activity, but there are splotchy regions in the background that result, perhaps, from scanning the image. We think of the splotchy regions as noise, and our goal is to improve the quality of the image by reducing the noise.
    1. Plot the singular values below. How are the singular values of this matrix similar to those represented by the clean image that we considered earlier and how are they different?
    2. There is a natural point where the singular values dramatically decrease so it makes sense to think of the noise as being formed by the small singular values. To denoise the image, we will therefore replace \(A\) by its approximation \(A_k\text{,}\) where \(k\) is the point at which the singular values drop off. This has the effect of setting the small singular values to zero and hence eliminating the noise. Choose an appropriate value of \(k\) below and notice that the new image appears to be somewhat cleaned up as a result of removing the noise.
Answer.
    1. \(\displaystyle \rank(A) = 3\)
    2. \(\displaystyle \rank(A) = 3\)
    3. \(\displaystyle k=3\)
    4. \(\displaystyle 123\)
    5. The compression ratio is \(375/123=3.0\)
    1. The singular values fall off steeply but never reach \(0\text{.}\)
    2. When \(k=50\text{,}\) the compression ratio is about \(3.1\text{.}\) When \(k=100\text{,}\) the compression ratio is about \(1.6\text{.}\)
    1. The singular values are similar, but they never reach \(0\text{.}\)
    2. \(k=3\) seems like a natural approximation
Solution.
    1. \(\rank(A) = 3\) because there are three distinct columns represented by the first, third, and sixth columns.
    2. There are three nonzero singular values so \(\rank(A) =3\) as we suspected.
    3. The smallest value is \(k=3\) since \(\rank(A) = 3\text{.}\)
    4. The left singular vectors are \(25\)-dimensional and the right singular vectors are \(15\)-dimensional. If we keep three singular values, left singular vectors, and right singular vectors, we have \(3(1+25+15) = 123\text{.}\)
    5. The compression ratio is \(375/123=3.0\) so the data is compressed by a factor of \(3\text{.}\)
    1. The singular values fall off steeply but never reach \(0\text{.}\)
    2. When \(k=50\text{,}\) the compression ratio is about \(3.1\text{.}\) When \(k=100\text{,}\) the compression ratio is about \(1.6\text{.}\)
    1. The singular values are similar, but they never reach \(0\text{.}\)
    2. \(k=3\) seems like a natural approximation since that’s the place where the singular values become almost \(0\text{.}\)
Several examples illustrating how the singular value decomposition compresses images are available at this page from Tim Baumann. 1 

Subsection 7.6.5 Analyzing Supreme Court cases

As we’ve seen, a singular value decomposition concentrates the most important features of a matrix into the first singular values and singular vectors. We will now use this observation to extract meaning from a large dataset giving the voting records of Supreme Court justices. A similar analysis appears in the paper A pattern analysis of the second Rehnquist U.S. Supreme Court 2  by Lawrence Sirovich.
The makeup of the Supreme Court was unusually stable during a period from 1994-2005 when it was led by Chief Justice William Rehnquist. This is sometimes called the second Rehnquist court. The justices during this period were:
  • William Rehnquist
  • Antonin Scalia
  • Clarence Thomas
  • Anthony Kennedy
  • Sandra Day O’Connor
  • John Paul Stevens
  • David Souter
  • Ruth Bader Ginsburg
  • Stephen Breyer
During this time, there were 911 cases in which all nine judges voted. We would like to understand patterns in their voting.

Activity 7.6.6.

Evaluating the following cell loads and displays a dataset describing the votes of each justice in these 911 cases. More specifically, an entry of +1 means that the justice represented by the row voted with the majority in the case represented by the column. An entry of -1 means that justice was in the minority. This information is also stored in the \(9\by911\) matrix \(A\text{.}\)
The justices are listed, very roughly, in order from more conservative to more progressive.
In this activity, it will be helpful to visualize the entries in various matrices and vectors. The next cell displays the first 50 columns of the matrix \(A\) with white representing an entry of +1, red representing -1, and black representing 0.
  1. Plot the singular values of \(A\) below. Describe the significance of this plot, including the relative contributions from the singular values \(\sigma_k\) as \(k\) increases.
  2. Form the singular value decomposition \(A=U\Sigma V^{\transpose}\) and the matrix of coefficients \(\Gamma\) so that \(A=U\Gamma\text{.}\)
  3. We will now study a particular case, the second case which appears as the column of \(A\) indexed by 1. There is a command display_column(A, k) that provides a visual display of the \(k^{th}\) column of a matrix \(A\text{.}\) Describe the justices’ votes in the second case.
  4. Also, display the first left singular vector \(\uvec_1\text{,}\) the column of \(U\) indexed by \(0\text{,}\) and the column of \(\Gamma\) holding the coefficients that express the second case as a linear combination of left singular vectors.
    What does this tell us about how the second case is constructed as a linear combination of left singular vectors? What is the significance of the first left singular vector \(\uvec_1\text{?}\)
  5. Let’s now study the \(48^{th}\) case, which is represented by the column of \(A\) indexed by 47. Describe the voting pattern in this case.
  6. Display the second left singular vector \(\uvec_2\) and the vector of coefficients that express the \(48^{th}\) case as a linear combination of left singular vectors.
    Describe how this case is constructed as a linear combination of singular vectors. What is the significance of the second left singular vector \(\uvec_2\text{?}\)
  7. The data in Table 7.6.3 describes the number of cases decided by each possible vote count.
    Table 7.6.3. Number of cases by vote count
    Vote count # of cases
    9-0 405
    8-1 89
    7-2 111
    6-3 118
    5-4 188
    How do the singular vectors \(\uvec_1\) and \(\uvec_2\) reflect this data? Would you characterize the court as leaning toward the conservatives or progressives? Use these singular vectors to explain your response.
  8. Cases decided by a 5-4 vote are often the most impactful as they represent a sharp divide among the justices and, often, society at large. For that reason, we will now focus on the 5-4 decisions. Evaluating the next cell forms the \(9\by188\) matrix \(B\) consisting of 5-4 decisions.
    Form the singular value decomposition of \(B=U\Sigma V^{\transpose}\) along with the matrix \(\Gamma\) of coefficients so that \(B=U\Gamma\) and display the first left singular vector \(\uvec_1\text{.}\) Study how the \(7^{th}\) case, indexed by 6, is constructed as a linear combination of left singular vectors.
    What does this singular vector tell us about the make up of the court and whether it leans towards the conservatives or progressives?
  9. Display the second left singular vector \(\uvec_2\) and study how the \(6^{th}\) case, indexed by 5, is constructed as a linear combination of left singular vectors.
    What does \(\uvec_2\) tell us about the relative importance of the justices’ voting records?
  10. By a swing vote, we mean a justice who is less inclined to vote with a particular bloc of justices but instead swings from one bloc to another with the potential to sway close decisions. What do the singular vectors \(\uvec_1\) and \(\uvec_2\) tell us about the presence of voting blocs on the court and the presence of a swing vote? Which justice represents the swing vote?
Answer.
  1. The first two singular values contribute most significantly.
  2. \(\Gamma\) is a \(9\by911\) matrix that expresses the cases as linear combinations of the left singular vectors.
  3. This is a unanimous decision.
  4. \(\uvec_1\) represents a unanimous decision.
  5. This is a 5-4 decision with the 5 conservative justices voting in the majority.
  6. \(\uvec_2\) represents a 5-4 decision.
  7. The most frequently occurring decisions are unanimous and the second most frequently occurring are 5-4.
  8. \(\uvec_1\) represents a case where the five conservative justices are voting together.
  9. The second left singular vector \(\uvec_2\) essentially records the vote of Sandra Day O’Connor.
  10. Sandra Day O’Connor
Solution.
  1. The first two singular values contribute most significantly.
  2. \(\Gamma\) is a \(9\by911\) matrix that expresses the cases as linear combinations of the left singular vectors.
  3. This is a unanimous decision.
  4. The unanimous decision is essentially represented as \(-\uvec_1\) so \(\uvec_1\) represents a unanimous decision.
  5. This is a 5-4 decision with the 5 conservative justices voting in the majority.
  6. This 5-4 decision is essentially represented as \(\uvec_2\text{,}\) the second most important left singular vector.
  7. We see that the most decisions are unanimous, which is why \(\uvec_1\) represents unanimous decisions. The second most frequently occurring decisions is a 5-4 decision, which is why \(\uvec_2\) represents a 5-4 decision that leans to the conservative justices.
  8. The first singular vector \(\uvec_1\) represents a case where the five conservative justices are voting together. From this we conclude that the court leans toward the conservatives.
  9. The second left singular vector \(\uvec_2\) essentially records the vote of Sandra Day O’Connor and shows how her vote has the power to swing a 5-4 decision from a conservative majority to a progressive majority.
  10. Sandra Day O’Connor would be the swing vote.

Subsection 7.6.6 Summary

This section has demonstrated some uses of the singular value decomposition. Because the singular values appear in decreasing order, the decomposition has the effect of concentrating the most important features of the matrix into the first singular values and singular vectors.
  • Because the first left singular vectors form an orthonormal basis for \(\col(A)\text{,}\) a singular value decomposition provides a convenient way to project vectors onto \(\col(A)\) and therefore to solve least squares problems.
  • A singular value decomposition of a rank \(r\) matrix \(A\) leads to a series of approximations \(A_k\) of \(A\) where
    \begin{align*} A \approx A_1 \amp = \sigma_1\uvec_1\vvec_1^{\transpose}\\ A \approx A_2 \amp = \sigma_1\uvec_1\vvec_1^{\transpose} + \sigma_2\uvec_2\vvec_2^{\transpose}\\ A \approx A_3 \amp = \sigma_1\uvec_1\vvec_1^{\transpose} + \sigma_2\uvec_2\vvec_2^{\transpose} + \sigma_3\uvec_3\vvec_3^{\transpose}\\ \vdots \amp\\ A = A_r \amp = \sigma_1\uvec_1\vvec_1^{\transpose} + \sigma_2\uvec_2\vvec_2^{\transpose} + \sigma_3\uvec_3\vvec_3^{\transpose} + \ldots + \sigma_r\uvec_r\vvec_r^{\transpose} \end{align*}
    In each case, \(A_k\) is the rank \(k\) matrix that is closest to \(A\text{.}\)
  • If \(A\) is a demeaned data matrix, the left singular vectors give the principal components of \(A\) and the variance in the direction of a principal component can be simply expressed in terms of the corresponding singular value.
  • The singular value decomposition has many applications. In this section, we looked at how the decomposition is used in image processing through the techniques of compression and denoising.
  • Because the first few left singular vectors contain the most important features of a matrix, we can use a singular value decomposition to extract meaning from a large dataset as we did when analyzing the voting patterns of the second Rehnquist court.

Exercises 7.6.7 Exercises

1.

Suppose that
\begin{equation*} A = \begin{bmatrix} 2.1 \amp -1.9 \amp 0.1 \amp 3.7 \\ -1.5 \amp 2.7 \amp 0.9 \amp -0.6 \\ -0.4 \amp 2.8 \amp -1.5 \amp 4.2 \\ -0.4 \amp 2.4 \amp 1.9 \amp -1.8 \end{bmatrix}. \end{equation*}
  1. Find the singular values of \(A\text{.}\) What is \(\rank(A)\text{?}\)
  2. Find the sequence of matrices \(A_1\text{,}\) \(A_2\text{,}\) \(A_3\text{,}\) and \(A_4\) where \(A_k\) is the rank \(k\) approximation of \(A\text{.}\)

2.

Suppose we would like to find the best quadratic function
\begin{equation*} \beta_0 + \beta_1x + \beta_2x^2=y \end{equation*}
fitting the points
\begin{equation*} (0,1), (1,0), (2,1.5), (3,4), (4,8). \end{equation*}
  1. Set up a linear system \(A\xvec = \bvec\) describing the coefficients \(\xvec = \threevec{\beta_0}{\beta_1}{\beta_2}\text{.}\)
  2. Find the singular value decomposition of \(A\text{.}\)
  3. Use the singular value decomposition to find the least squares approximate solution \(\xhat\text{.}\)

3.

Remember that the outer product of two vector \(\uvec\) and \(\vvec\) is the matrix \(\uvec~\vvec^{\transpose}\text{.}\)
  1. Suppose that \(\uvec = \twovec{2}{-3}\) and \(\vvec=\threevec201\text{.}\) Evaluate the outer product \(\uvec~\vvec^{\transpose}\text{.}\) To get a clearer sense of how this works, perform this operation without using technology.
    How is each of the columns of \(\uvec~\vvec^{\transpose}\) related to \(\uvec\text{?}\)
  2. Suppose \(\uvec\) and \(\vvec\) are general vectors. What is \(\rank(\uvec~\vvec^{\transpose})\) and what is a basis for its column space \(\col(\uvec~\vvec^{\transpose})\text{?}\)
  3. Suppose that \(\uvec\) is a unit vector. What is the effect of multiplying a vector by the matrix \(\uvec~\uvec^{\transpose}\text{?}\)

4.

Evaluating the following cell loads in a dataset recording some features of 1057 houses. Notice how the lot size varies over a relatively small range compared to the other features. For this reason, in addition to demeaning the data, we’ll scale each feature by dividing by its standard deviation so that the range of values is similar for each feature. The column-variate matrix \(X\) holds the result.
  1. Find the singular values of \(X\) and use them to determine the variance in the direction of the principal components.
  2. For what fraction of the variance do the first two principal components account?
  3. Find a singular value decomposition of \(A\) and construct the \(2\by1057\) matrix \(B\) whose entries are the coordinates of the demeaned data points projected on to the two-dimensional subspace spanned by the first two principal components. You can plot the projected data points using list_plot(B.columns()).
  4. Study the entries in the first two principal components \(\uvec_1\) and \(\uvec_2\text{.}\) Would a more expensive house lie on the left, right, top, or bottom of the plot you constructed?
  5. In what ways does a house that lies on the far left of the plot you constructed differ from an average house? In what ways does a house that lies near the top of the plot you constructed differ from an average house?

5.

Let’s revisit the voting records of justices on the second Rehnquist court. Evaluating the following cell will load the voting records of the justices in the 188 cases decided by a 5-4 vote and store them in the matrix \(A\text{.}\)
  1. The cell above also defined the 188-dimensional vector \(\vvec\) whose entries are all 1. What does the product \(A\vvec\) represent? Use the following cell to evaluate this product.
  2. How does the product \(A\vvec\) tell us which justice voted in the majority most frequently? What does this say about the presence of a swing vote on the court?
  3. How does this product tell us whether we should characterize this court as leaning conservative or progressive?
  4. How does this product tell us about the presence of a second swing vote on the court?
  5. Study the left singular vector \(\uvec_3\) and describe how it reinforces the fact that there was a second swing vote. Who was this second swing vote?

6.

The following cell loads a dataset that describes the percentages with which justices on the second Rehnquist court agreed with one another. For instance, the entry in the first row and second column is 72.78, which means that Justices Rehnquist and Scalia agreed with each other in 72.78% of the cases.
  1. Examine the matrix \(A\text{.}\) What special structure does this matrix have and why should we expect it to have this structure?
  2. Plot the singular values of \(A\) below. For what value of \(k\) would the approximation \(A_k\) be a reasonable approximation of \(A\text{?}\)
  3. Find a singular value decomposition \(A=U\Sigma V^{\transpose}\) and examine the matrices \(U\) and \(V\) using, for instance, n(U, 3). What do you notice about the relationship between \(U\) and \(V\) and why should we expect this relationship to hold?
  4. The command approximate(A, k) will form the approximating matrix \(A_k\text{.}\) Study the matrix \(A_1\) using the display_matrix command. Which justice or justices seem to be most agreeable, that is, most likely to agree with other justices? Which justice is least agreeable?
  5. Examine the difference \(A_2-A_1\) and describe how this tells us about the presence of voting blocs and swing votes on the court.

7.

Suppose that \(A=U_r\Sigma_rV_r^{\transpose}\) is a reduced singular value decomposition of the \(m\by n\) matrix \(A\text{.}\) The matrix \(A^+ = V_r\Sigma_r^{-1}U_r^{\transpose}\) is called the Moore-Penrose inverse of \(A\text{.}\)
  1. Explain why \(A^+\) is an \(n\by m\) matrix.
  2. If \(A\) is an invertible, square matrix, explain why \(A^+=A^{-1}\text{.}\)
  3. Explain why \(AA^+\bvec=\bhat\text{,}\) the orthogonal projection of \(\bvec\) onto \(\col(A)\text{.}\)
  4. Explain why \(A^+A\xvec=\xhat\text{,}\) the orthogonal projection of \(\xvec\) onto \(\col(A^{\transpose})\text{.}\)

8.

In Subsection 4.7.1, we saw how some linear algebraic computations are sensitive to round off error made by a computer. A singular value decomposition can help us understand when this situation can occur.
For instance, consider the matrices
\begin{equation*} A = \begin{bmatrix} 1.0001 \amp 1 \\ 1 \amp 1 \\ \end{bmatrix},\hspace{24pt} B = \begin{bmatrix} 1 \amp 1 \\ 1 \amp 1 \\ \end{bmatrix}. \end{equation*}
The entries in these matrices are quite close to one another, but \(A\) is invertible while \(B\) is not. It seems like \(A\) is almost singular. In fact, we can measure how close a matrix is to being singular by forming the condition number, \(\sigma_1/\sigma_n\text{,}\) the ratio of the largest to smallest singular value. If \(A\) were singular, the condition number would be undefined because the singular value \(\sigma_n=0\text{.}\) Therefore, we will think of matrices with large condition numbers as being close to singular.
  1. Define the matrix \(A\) and find a singular value decomposition. What is the condition number of \(A\text{?}\)
  2. Define the left singular vectors \(\uvec_1\) and \(\uvec_2\text{.}\) Compare the results \(A^{-1}\bvec\) when
    1. \(\bvec=\uvec_1+\uvec_2\text{.}\)
    2. \(\bvec=2\uvec_1+\uvec_2\text{.}\)
    Notice how a small change in the vector \(\bvec\) leads to a small change in \(A^{-1}\bvec\text{.}\)
  3. Now compare the results \(A^{-1}\bvec\) when
    1. \(\bvec=\uvec_1+\uvec_2\text{.}\)
    2. \(\bvec=\uvec_1+2\uvec_2\text{.}\)
    Notice now how a small change in \(\bvec\) leads to a large change in \(A^{-1}\bvec\text{.}\)
  4. Previously, we saw that, if we write \(\xvec\) in terms of left singular vectors \(\xvec=c_1\vvec_1+c_2\vvec_2\text{,}\) then we have
    \begin{equation*} \bvec=A\xvec = c_1\sigma_1\uvec_1 + c_2\sigma_2\uvec_2. \end{equation*}
    If we write \(\bvec=d_1\uvec_1+d_2\uvec_2\text{,}\) explain why \(A^{-1}\bvec\) is sensitive to small changes in \(d_2\text{.}\)
Generally speaking, a square matrix \(A\) with a large condition number will demonstrate this type of behavior so that the computation of \(A^{-1}\) is likely to be affected by round off error. We call such a matrix ill-conditioned.

9. SVD compression of color images.

  1. Load a color image into Python and compute the SVD for each color channel.
  2. Plot the singular values for each color channel and use those plots to pick an appropriate rank \(k\) approximation for each.
  3. Recombine the three compressed color channels and plot the resulting image.
  4. How much does the image degrade if you cut the rank of the compressions in half? How much does the image improve if you double the rank of the compressions?

10. How much space does a rank \(k\) SVD approximation save?

Suppose the original matrix is \(m \by n\text{.}\) That matrix has \(mn\) entries. If you compute a reduced rank SVD for \(A\) and use it to create a rank \(k\) approximation, how many entries must you store? Be clever and only store what is necessary. For example, you only need to store the diagonal entries of \(\Sigma\) since we know the rest will be 0.
timbaumann.info/projects.html
gvsu.edu/s/21F