Python, NumPy: 神经网络教程, ValueError: 形状不一致

2024-04-19 17:10:51 发布

您现在位置:Python中文网/ 问答频道 /正文

我试着编写一个有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)

Tags: inl1节点npcellrandomerrorout