python - pybrain activate() 输出表示

标签 python pybrain

我使用 pybrain 构建这个示例:

from pybrain.tools.shortcuts import buildNetwork
from pybrain.datasets import SupervisedDataSet
from pybrain.supervised.trainers import BackpropTrainer

net = buildNetwork(3, 3, 1)

dataSet = SupervisedDataSet(3, 1)
dataSet.addSample((0, 0, 0), (0))
dataSet.addSample((1, 1, 1), (0))
dataSet.addSample((1, 0, 0), (1))
dataSet.addSample((0, 1, 0), (1))
dataSet.addSample((0, 0, 1), (1))

trainer = BackpropTrainer(net, dataSet)

trainer.trainUntilConvergence()

result = net.activate([0, 0, 0])
print result

输出是:[0.10563189]

我不明白 activate() 的输出是什么。网络经过训练,我用其中一个训练样本测试它的输出,所以我期望值与训练样本中的值完全一样。输入 [0, 0, 0] 应该得到输出 0。我在这里缺少什么?如何获得有效结果?

更令人困惑的是,每次运行这段代码时,我都会得到不同的结果。我显然做错了什么。这是什么?

最佳答案

训练网络直到收敛并不意味着训练集被完美地记住了。原因有很多:隐藏层的大小、激活函数、学习率等。所有这些参数都需要调整。

关于python - pybrain activate() 输出表示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14557103/

相关文章:

python - PyBrain:从头开始创建网络时,您如何以及在何处创建偏差?

python - 如何绘制byprain神经网络结构

python - 如何添加声音并仅听1次,而不是反复听。 ( python )

python - PyBrain 预测错误

python - 间接训练前馈神经网络

python - 从 pytorch 的 torchtext 库中保存词汇对象

python - PyBrain:使用 numpy.loadtxt 加载数据?

python - "InvalidArgumentError: Incompatible shapes: [64,40000] vs. [64] [Op:Mul]"在张量之间进行运算时?

python - 将字符串包裹在单引号内

python - 如何在 pandas.DataFrame 中插入满足条件的行值