forked from Kaleab213/Machine-Learning-Classifier-Models
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMnisit_logistic.py
More file actions
62 lines (41 loc) · 1.83 KB
/
Mnisit_logistic.py
File metadata and controls
62 lines (41 loc) · 1.83 KB
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
from logistic_regression import LogisticRegression
import math
import random
import matplotlib.pyplot as plt
from minist.extract_features import MNISTFeatures
features = MNISTFeatures()
X_train, Y_train, X_test, Y_test = features.load_mnist_data()
pixel_X_train = [features.pixel_intensity_feature(row) for row in X_train]
pixel_X_test = [features.pixel_intensity_feature(row) for row in X_test]
hog_X_train = [features.hog_feature(row) for row in X_train]
hog_X_test = [features.hog_feature(row) for row in X_test]
pca = features.pca_feature(pixel_X_train)
pca_X_train = [features.extract_features(row, pca) for row in pixel_X_train]
pca_X_test = [features.extract_features(row, pca) for row in pixel_X_test]
learning_rates = [0.0001, 0.001, 0.01, 0.1, 1.0, 1.5]
# Pixel features
pixel_accuracies = []
for learning_rate in learning_rates:
log_reg = LogisticRegression(reg_lambda=0.01, iterations=30, alpha=learning_rate, num_classes=10)
log_reg.fit(pixel_X_train, Y_train)
accuracy = log_reg.predict(pixel_X_test, Y_test)
pixel_accuracies.append(accuracy)
# HOG features
hog_accuracies = []
for learning_rate in learning_rates:
log_reg = LogisticRegression(reg_lambda=0.01, iterations=30, alpha=learning_rate, num_classes=10)
log_reg.fit(hog_X_train, Y_train)
accuracy = log_reg.predict(hog_X_test, Y_test)
hog_accuracies.append(accuracy)
# PCA features
pca_accuracies = []
for learning_rate in learning_rates:
log_reg = LogisticRegression(reg_lambda=0.01, iterations=30, alpha=learning_rate, num_classes=10)
log_reg.fit(pca_X_train, Y_train)
accuracy = log_reg.predict(pca_X_test, Y_test)
pca_accuracies.append(accuracy)
plt.plot(learning_rates, pixel_accuracies)
plt.title('Pixel Accuracy vs. Learning Rate')
plt.plot(learning_rates, hog_accuracies)
plt.plot(learning_rates, pca_accuracies)
plt.show()