@antonello/

# Python: Redes Neurais Exemplo 3 XOR

## No description

Files
• main.py
main.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
```
```# Fonte: https://github.com/RohitSaha/Neural-Net-XOR-Problem-/blob/master/operation.py

import numpy as np

# Possible Inputs for XOR operation.
layer1 = np.array([[0,0,1], [0,1,1], [1,0,1], [1,1,1]])
#2 classes : 0 and 1
target_output = np.array([[0, 1, 1, 0]]).T

#Random initialisation of weights
np.random.seed(1)
weights_1 = np.random.random((3, 2))
weights_2 = np.random.random((3, 1))
bias = np.ones((1, 4))

def sigmoid(g):
return 1/(1 + np.exp(-g))

return g*(1 - g)

for iter in range(100000):
a2 = sigmoid(np.dot(layer1, weights_1))
a2 = a2.T
a2 = np.vstack((a2, bias)).T
a3 = sigmoid(np.dot(a2, weights_2))

a3_error = target_output - a3
a2_error = np.dot(a3_error, weights_2[0:2, :].T)*sigmoid(np.dot(layer1, weights_1))

weights_2 += np.dot(a2.T, a3_delta)
weights_1 += np.dot(layer1.T, a2_delta)

print( "After training : " )
print( a3 )```