-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLogisticRegression.py
131 lines (112 loc) · 3.64 KB
/
LogisticRegression.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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
from sklearn.linear_model import LogisticRegression
import numpy as np
import pandas as pd
from auxiliary.data_clean2 import *
from sklearn.preprocessing import StandardScaler
from feature_selection import y_classify_five, y_classify
from sklearn.model_selection import train_test_split
from sklearn.model_selection import GridSearchCV
from sklearn.model_selection import cross_val_score
import matplotlib.pyplot as plt
from sklearn import metrics
import os
# Step 1 Data Preparing
# Read Data
data = pd.read_csv(os.getcwd()+'/dataset/GSMArena_dataset_2020.csv', index_col=0)
data_features = data[all_features]
# Clean data
data_features = clean_data(data_features)
# Drop features
df = data_features
# drop # 1st line: key_index and 7th line: misc_price
temp1 = df.values[:,1:8]
temp2 = df.values[:,9:]
td = np.concatenate((temp1,temp2),axis=1)
mX = td
mY = df["misc_price"].astype("int").values.reshape(-1,1)
# Divide price into 3 catagories bt function y_classify()
tempList = []
mY = mY.reshape(-1)
for item in mY:
tempList.append(y_classify(item))
mY = tempList
# Do standard scaler for data in X
sc = StandardScaler()
sc.fit(mX)
mX = sc.transform(mX)
# Split data into train, test
X_train, X_test, Y_train, Y_test = train_test_split(mX, mY, test_size=.2, random_state=0)
# Step 2 Logistic Regression
penaltys = ['l1','l2']
Cs = [1, 10, 100, 1000,10000]
solvers = ['liblinear', 'newton-cg', 'sag', 'lbfgs']
parameters = dict(penalty = penaltys, C = Cs, solver = solvers)
logistic_GS= LogisticRegression()
grid= GridSearchCV(logistic_GS, parameters, scoring='neg_log_loss')
grid.fit(X_train,Y_train)
test_means = grid.cv_results_[ 'mean_test_score' ]
#print(-np.array(test_means).reshape(5,2,4))
# Step3 plot graphs
def auto_label(rects, decimal=6):
for rect in rects:
width = rect.get_x()+rect.get_width()/2.-0.25
height = rect.get_height()
if(decimal==6):
plt.text(width, height + 0.001, '%0.6s' % float(height))
elif(decimal==4):
plt.text(width, height + 0.001, '%0.4s' % float(height))
def getAxis():
width = 5
num = 5
axis = width/2
x = []
for i in range(5):
x.append(axis)
axis += width*num
return np.array(x)
full_table = np.array(test_means).reshape(5,2,4)
# penalty = l1
plt.figure(0)
l1_list = -full_table[:,0,0]
#print(l1_list)
a = plt.bar(range(len(l1_list)), l1_list, tick_label=['c=1','c=10','c=100','c=1000','c=10000'], label='liblinear', fc='#7294d4')
plt.title('penalty=\'l1\'')
plt.xlabel('Cs')
plt.ylabel('Accuracy')
plt.ylim((0.72, 0.76))
plt.legend(loc = 'lower left')
auto_label(a,decimal=6)
#plt.show()
plt.savefig('l1.png')
# penalty = l2
plt.figure(1)
l2_list = -full_table[:,1,:]
#print(l2_list)
size = 5
x = np.arange(size)
liblinear = l2_list[:,0]
newton_cg = l2_list[:,1]
sag = l2_list[:,2]
lbfgs = l2_list[:,3]
x = getAxis()
a = plt.bar(x, liblinear, width=5, label='liblinear', fc='#e6a0c4')
b = plt.bar(x + 5, newton_cg, width=5, label='newton-cg', tick_label=['c=1','c=10','c=100','c=1000','c=10000'], fc='#c6cdf7')
c = plt.bar(x + 10, sag, width=5, label='sag', fc='#d8a499')
d = plt.bar(x + 15, lbfgs, width=5, label='lbfgs', fc='#7294d4')
plt.title('penalty=\'l2\'')
plt.xlabel('Cs')
plt.ylabel('Accuracy')
plt.ylim((0.72, 0.78))
auto_label(a,decimal=4)
auto_label(b,decimal=4)
auto_label(c,decimal=6)
auto_label(d,decimal=4)
plt.legend(loc = 'lower left')
#plt.show()
plt.savefig('l2.png')
# test the chosen parameters
logistic = LogisticRegression(penalty='l2', C = 10000, solver='sag')
logistic.fit(X_train,Y_train)
logistz = logistic.predict(X_test)
#print(set(logistz))
print("Accuracy for Logistic Regression is:", str(metrics.accuracy_score(logistz, Y_test)))