Many approaches exist for reducing the dimension of feature vectors while still optimizing model evaluations. The subset selection approach is very useful and regularly applied. On the other hand, this approach may not reveal underlying relationships between the features or describe why certain features work well together while others do not. To do this, it is necessary to develop algorithms and compute recipes for mixing the most relevant features. Principal Component Analysis (PCA) is arguably one of the popular methodologies for achieving this goal.
Principal Components
Principal components analysis is one of the most common methods used for linear dimension reduction. The motivation behind dimension reduction is that the process gets unwieldy with a large number of variables, while the large number does not add any new information to the process. An analogy may be drawn with variance inflation factors in multiple regression. If VIF corresponding to any predictor is large, that predictor is not included in the model, as that variable does not contribute any new information. On the other hand, because of linear dependence, the regression matrix may become singular. In a multivariate situation, it may well happen that a few (or a large number of) variables have high interdependence. A linear combination of variables is then considered, which are orthogonal to one another, but the total variability within the sample is preserved as much as possible.
Suppose the data is 10-dimensional but needs to be reduced to 2-dimensional. The idea of principal component analysis is to use two directions that capture the variation in the data as much as possible.
[Keep in mind that the dimensions to which data needs to be reduced are usually not pre-fixed. After taking a look at the total proportion of variability captured, the reduction in dimension is determined. Here reduction of 10-dimensional space to 2-dimension space is for illustration only]
The sample covariance matrix of X is given as:
If you do the Eigen decomposition of :
It turns out that if you have done the singular value decomposition, then you already have the Eigenvalue decomposition for .
The is the diagonal part of matrix D with every element on the diagonal squared.
Also, we should point out that we can show using linear algebra that
is a semi-positive definite matrix. This means that all of the
eigenvalues are guaranteed to be non-negative. The eigenvalues are in
matrix
. Since these values are squared, every diagonal element
is non-negative.
The eigenvectors of ,
, can be obtained either by
doing an Eigen decomposition of
or by doing a singular value
decomposition from X. These vjs are called principal component directions of X. If you project X onto the directions of the principal components, you get the principal components.
- It's easy to see that
. Hence
is simply the projection of the row vectors of
, i.e., the input predictor vectors, on the direction
, scaled by
. For example:
- The principal components of
are
.
- The first principal component of
,
, has the largest sample variance amongst all normalized linear combinations of the columns of
.
- Subsequent principal components
have maximum variance
, subject to being orthogonal to the earlier ones.
Why are we interested in this? Consider an extreme case (lower right) where your data all lie in one direction. Although two features represent the data, we can reduce the dimension of the dataset to one using a single linear combination of the features (as given by the first principal component).
Just to summarize the way you do dimension reduction: First, you have
X, and you remove the means. On X, you do a singular value
decomposition and obtain matrices U, D, and V. Then you call every
column vector in V, , where j = 1, ... , p. This vj
is called the direction of the principal component. Let's say your original
dimension is 10, and we wish to reduce this to 2 dimensions. What would
we do? We would take
and
and project X to
and X
to
. To project, multiply X by
for a column vector of
size N. X times
gives you another column vector of size N. These two column vectors reduce the dimensions, so you have: