-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdense.py
46 lines (37 loc) · 1.65 KB
/
dense.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
import numpy as np
from activations import sigmoid, sigmoid_backward
from activations import relu, relu_backward
from weights_initializers import init_weights
class Dense:
def __init__(self, input_shape, units, activation='relu', weights='glorot_uniform',
bias='zeros', weights_scale=0.05, bias_scale=0.05):
self.input_units = input_shape[-1]
self.output_units = units
self.output_shape = (None, self.output_units)
self.weights = init_weights(weights, shape=(self.input_units, self.output_units),
scale=weights_scale)
self.weights = np.array(self.weights, np.float32)
self.bias = init_weights(bias, shape=(1, self.output_units), scale=bias_scale)
self.prev_act = None
self.A = None
if activation == 'relu':
self.activation_fn = relu
self.backward_activation_fn = relu_backward
elif activation == 'sigmoid':
self.activation_fn = sigmoid
self.backward_activation_fn = sigmoid_backward
else:
raise Exception('Activation function not supported')
def forward(self, prev_act):
self.prev_act = prev_act.copy()
self.A = self.activation_fn(np.dot(prev_act, self.weights) + self.bias)
return self.A
def backprop(self, dA):
dA = self.backward_activation_fn(dA, self.A)
dW = np.dot(self.prev_act.T, dA)
db = dA.mean(axis=0, keepdims=True)
prev_dA = np.dot(dA, self.weights.T)
return prev_dA, [dW, db]
def update_params(self, opt_params):
self.weights -= opt_params[0]
self.bias -= opt_params[1]