Python, NumPy: учебник по нейросетям, ValueError: фигуры не выровнены - PullRequest
0 голосов
/ 08 мая 2019

Я пытаюсь закодировать нейронную сеть с 3 входными узлами, скрытым слоем с 4 узлами и 1 выходным узлом. (Это изменится в окончательной версии, поэтому я превратил их в переменные.) Несмотря на то, что я сравнил свой код с учебными пособиями, и я не вижу в этом ничего плохого, когда я пытаюсь его запустить, он дает мне ValueError, говоря, что он не может умножить эти массивы на точки.

Так как это мой первый проект с использованием NumPy, я не знаю, что мне делать.

Вот мой код:

import numpy as np
import math

# neurons
n_in = 3
n_hidden = 4
n_out = 1
batchsize = 60

def sigmoid(x, deriv=False):
    if deriv:
        return x*(1-x)
    return 1/(1+np.exp(-x))

def error(expected, actual):
    rawError = expected - actual
    for cell in rawError:
        cell = cell * cell
    return rawError

# input data
X = np.array([
    [0, 0, 1],
    [1, 1, 1],
    [1, 0, 1],
    [0, 1, 1]
])

# answer data
Y = np.array([0, 1, 1, 0]).T

np.random.seed(0)

# synapses
syn0 = 2 * np.random.random((n_in, n_hidden)) - 1
syn1 = 2 * np.random.random((n_hidden, n_out)) - 1

# train
for j in range(60000):
    # feed forward to hidden
    l1 = sigmoid(np.dot(X, syn0))
    # feed forward to out
    l2 = sigmoid(np.dot(l1, syn1))
    # calculate error in new array
    l2_error = error(Y, l2)
    if j % 10000 == 9999:
        print(np.sum(l2_error))

    # gradient descent:
    # multiply the error by the input, then the gradient of sigmoid
    l2_nudge = l2_error * sigmoid(l2, deriv=True)
    l1_nudge = l2_nudge.dot(syn1.T) * sigmoid(l1, deriv=True)
    syn1 += l1.T.dot(l2_nudge)
    syn0 += l0.T.dot(l1_nudge)
print(l2)

Я ожидал, что программа хотя бы запустится, но выдает следующую ошибку:

Traceback (most recent call last):
  File "neural-network.py", line 68, in <module>
    l1_nudge = l2_nudge.dot(syn1.T) * sigmoid(l1, deriv=True)
ValueError: shapes (4,4) and (1,4) not aligned: 4 (dim 1) != 1 (dim 0)

1 Ответ

0 голосов
/ 08 мая 2019

Я нашел свою проблему: я делал точечный продукт для l1_error задом наперед!

l1_error = np.dot(l2_nudge, syn1.T)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...