-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathexample.py
More file actions
48 lines (35 loc) · 1.57 KB
/
Copy pathexample.py
File metadata and controls
48 lines (35 loc) · 1.57 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
"""
Copyright 2019 Archie Shahidullah
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
"""
import numpy as np
from gliaml import NetworkLayer, NeuralNetwork
np.random.seed(1) # to recreate results
# following block generates activation function IDs and initialises layers
activations1 = [1 for i in range(0, 4)]
activations2 = [1]
layer1 = NetworkLayer(3, 4, activations1, True)
layer2 = NetworkLayer(4, 1, activations2, True)
# creates network
network = NeuralNetwork(0.002, layer1, layer2)
# 7 training samples in a 2D NumPy array
inputs = np.array([[1, 1, 0], [1, 0, 1], [1, 1, 1], [0, 1, 0],
[0, 0, 1], [0, 1, 1], [0, 0, 0]])
# Solution: Apply XOR gate to 2nd and 3rd values
# Transposed to match inputs array
outputs = np.array([[1, 1, 0, 1, 1, 0, 0]]).T
# specify how many iterations to change
# can add learning rates if so desired
network.train_mean_squared_error(inputs, outputs, 1000, 0.1, 0.05)
# answer will contain the output for every neuron in every layer
answer = network.think(np.array([1, 0, 0]))
# return the last layer's output
print(answer[-1]) # Expected answer: [0.99957869]