machine-learning - 偏差在神经网络中的作用是什么?

标签 machine-learning neural-network artificial-intelligence backpropagation

我知道梯度下降和反向传播算法。我不明白的是:什么时候使用偏差很重要以及如何使用它?

例如,映射 AND 时函数,当我使用两个输入和一个输出时,它没有给出正确的权重。但是,当我使用三个输入(其中之一是偏差)时,它会给出正确的权重。

最佳答案

我认为偏见几乎总是有帮助的。实际上,偏置值允许您将激活函数向左或向右移动,这对于成功学习可能至关重要。

看一个简单的例子可能会有所帮助。考虑这个没有偏差的 1 输入、1 输出网络:

simple network

网络的输出是通过将输入 (x) 乘以权重 (w0) 并将结果传递给某种激活函数(例如 sigmoid 函数)来计算的。

这是该网络针对不同的 w0 值计算的函数:

network output, given different w0 weights

改变权重 w0 本质上改变了 sigmoid 的“陡度”。这很有用,但是如果您希望网络在 x 为 2 时输出 0 该怎么办?仅改变 sigmoid 的陡度并不会真正起作用 - 您希望能够将整个曲线向右移动

这正是偏见允许你做的事情。如果我们向该网络添加偏差,如下所示:

simple network with a bias

...那么网络的输出就变成了 sig(w0*x + w1*1.0)。以下是 w1 的各种值的网络输出:

network output, given different w1 weights

w1 的权重为 -5 会使曲线向右移动,这使我们能够拥有一个当 x 为 2 时输出 0 的网络。

关于machine-learning - 偏差在神经网络中的作用是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2480650/

相关文章:

machine-learning - 如何正确推导二次成本函数

python - 提供了断言错误 : The algorithm only supports <class 'gym.spaces.box.Box' > as action spaces but Box(-1. 0, 1.0, (3,), float32)

azure - LUIS API - 检索所有端点话语及其分数

machine-learning - 使用 Keras 进行迁移学习,验证准确性不会从一开始就提高(超出原始基线),而训练准确性会提高

java - (Java)用于隐层反向传播的偏导数

python - scikit-learn MLPRegressor 预测结果总是变化且不一致

artificial-intelligence - 可接受的启发式函数

image-processing - 使用 keras.preprocessing.image.ImageDataGenerator 的图像数据增强技术?

tensorflow - keras 模型适合 : ValueError: Failed to find data adapter that can handle input: <class 'method' >, <类 'NoneType' >

python - 为什么带有 1 个估计器的 adaboost 比简单的决策树更快?