forked from vsmolyakov/ml_algo_in_depth
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpca.py
45 lines (33 loc) · 1.21 KB
/
pca.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
import numpy as np
import matplotlib.pyplot as plt
np.random.seed(42)
class PCA():
def __init__(self, n_components = 2):
self.n_components = n_components
def covariance_matrix(self, X, Y=None):
if Y is None:
Y = X
n_samples = np.shape(X)[0]
covariance_matrix = (1 / (n_samples-1)) * (X - X.mean(axis=0)).T.dot(Y - Y.mean(axis=0))
return covariance_matrix
def transform(self, X):
Sigma = self.covariance_matrix(X)
eig_vals, eig_vecs = np.linalg.eig(Sigma)
#sort from largest to smallest and select the first n_components
idx = eig_vals.argsort()[::-1]
eig_vals = eig_vals[idx][:self.n_components]
eig_vecs = np.atleast_1d(eig_vecs[:,idx])[:, :self.n_components]
#project the data onto principal components
X_transformed = X.dot(eig_vecs)
return X_transformed
if __name__ == "__main__":
n = 20
d = 5
X = np.random.rand(n,d)
pca = PCA(n_components = 2)
X_pca = pca.transform(X)
print(X_pca)
plt.figure()
plt.scatter(X_pca[:,0], X_pca[:,1], color='b', alpha=0.5)
plt.title("Principal Component Analysis"); plt.xlabel("X1"); plt.ylabel("X2")
plt.show()