-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathNeural_Network.py
100 lines (86 loc) · 2.8 KB
/
Neural_Network.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
import numpy as np
def prediction(X,W_L_1,W_L_2,L_1_b,L_2_b,Y):
for i in range(100):
l = np.array([X[i]])
L_1_Z = forwar_Pass(l.T, W_L_1, L_1_b)
L_1_A = tanh(L_1_Z)
L_2_Z = forwar_Pass(L_1_A, W_L_2, L_2_b)
activation = tanh(L_2_Z)
label = 0 if activation < 0 else 1
print("activation={}; predicted_label={}, true_label={}".format(activation, label, Y[i]))
def tanh_derivative(Z):
return 1-np.power(Z,2)
def tanh(X):
return (np.exp(X)-np.exp(-X)) / (np.exp(X)+np.exp(-X))
def sigmoid(Z):
return (1 / (1 + np.exp(-Z)))
def relu():
return
def sigmoid_derivative(X):
return sigmoid(X) * (1 - sigmoid(X))
def forwar_Pass(X,W,b):
return np.dot(W,X) + b
def backward_Pass():
return
def derivative_w_r_t_to_weights(dz, A, m):
return (np.dot(dz,A) / m )
def Getting_Data_Set_Ready():
b_1 = b_2 = 1
split = 850
data_set = np.genfromtxt('Data-set_2.csv',delimiter = ',')
np.random.shuffle(data_set)
print("Shape of the data-set ",data_set.shape)
print("Shape of the data is ",data_set.shape)
train,test = data_set[:split,:],data_set[split:,:]
W_1 = np.random.rand(4,4)
W_2 = np.random.rand(1,4)
#Now slicing the input the data and output data
X,Y = train[:,:-1],train[:,-1]
X = X.T
Y = np.array([Y])
print("++++++++++++++++++++++++++++++++")
print("shape of X ",X.shape)
print("Shape of Y ",Y.shape)
print("shape of Layer 1 weights ",W_1.shape)
print("Shape of Layer 2 weights ",W_2.shape)
print("+++++++++++++++++++++++++++++++++")
return X,Y,test,W_1,W_2,b_1,b_2
def Neural_Network():
np.random.seed(0)
X,Y,test,W_L_1,W_L_2,L_1_b,L_2_b = Getting_Data_Set_Ready()
m = 850 # data points
regularization = 0.01
learning_rate = 0.01
for i in range(2000):
L_1_Z = forwar_Pass(X, W_L_1, L_1_b)
L_1_A = np.tanh(L_1_Z)
L_2_Z = forwar_Pass(L_1_A, W_L_2, L_2_b)
L_2_A = sigmoid(L_2_Z)
#Now backward Pass
L_2_dz = L_2_A - Y
#print("shape of L_2_dz ",L_2_dz.shape)
#print("shape of L_1_A",L_1_A.shape)
L_2_dw = derivative_w_r_t_to_weights(L_2_dz, L_1_A.T,m)
L_2_db = np.sum(L_2_dz, axis = 1, keepdims = True)
#print("shape of W_L_2 ",W_L_2.shape)
L_1_dz = np.dot(W_L_2.T,L_2_dz) * tanh_derivative(L_1_A)
L_1_dw = derivative_w_r_t_to_weights(L_1_dz, X.T, m)
L_1_db = (np.sum(L_1_dz, axis = 1, keepdims = True))
error_1 = np.sum(L_1_dz**2)
error_2 = np.sum(L_2_dz**2)
print("For layer 1 error is ",error_1)
print(" For layer 2 error is ", error_2)
L_1_dw += regularization*W_L_1
L_2_dw += regularization*W_L_2
W_L_1 += -learning_rate* L_1_dw
W_L_2 += -learning_rate* L_2_dw
L_1_b -= learning_rate * L_1_db
L_2_b -= learning_rate * L_2_db
New_X, New_Y = test[:,:-1],test[:,-1]
New_Y = np.array([New_Y])
print("W_1",W_L_1.shape)
print("X ",New_X.shape)
print("Y ",New_Y.shape)
prediction(New_X,W_L_1,W_L_2,L_1_b,L_2_b,New_Y.T)
#Getting_Data_Set_Ready()
Neural_Network()