Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Sklearn PCA is pca.components_ the loadings?

Sklearn PCA is pca.components_ the loadings? I am pretty sure it is, but I am trying to follow along a research paper and I am getting different results from their loadings. I can't find it within the sklearn documentation.

like image 465
ashish trehan Avatar asked Apr 03 '16 00:04

ashish trehan


1 Answers

pca.components_ is the orthogonal basis of the space your projecting the data into. It has shape (n_components, n_features). If you want to keep the only the first 3 components (for instance to do a 3D scatter plot) of a datasets with 100 samples and 50 dimensions (also named features), pca.components_ will have shape (3, 50).

I think what you call the "loadings" is the result of the projection for each sample into the vector space spanned by the components. Those can be obtained by calling pca.transform(X_train) after calling pca.fit(X_train). The result will have shape (n_samples, n_components), that is (100, 3) for our previous example.

like image 54
ogrisel Avatar answered Oct 16 '22 13:10

ogrisel