反向传播算法是否存在输出概率的版本?

我想创建一个前馈神经网络,其中训练数据中的输出是布尔值,0 或 1。

但在使用中,我希望输出是该输入产生 0 或 1 的期望概率。

鉴于最常见的反向传播形式采用 sigmoid 激活函数,因此这似乎不太可能产生实际的概率作为输出(sigmoid 曲线看起来并不像是“概率”函数 – 抱歉,我知道这有点牵强)。

或者也许我错了。使用 sigmoid 激活函数并使用反向传播训练的前馈神经网络的输出,是否可以安全地被视为获得 1 而不是 0 的实际概率?


回答:

是的,如果你使用标准的 sigmoid 激活函数,这将以你期望的方式工作。

证明这一点的数学有些复杂,但它实际上归结为你正在训练 sigmoid 函数来生成输出训练集的平均值(这是在普通反向传播中使用平方误差函数的结果)。由于两个可能的值是 0 和 1,因此平均值正好等于获得 1 的概率。

Related Posts

L1-L2正则化的不同系数

我想对网络的权重同时应用L1和L2正则化。然而,我找不…

使用scikit-learn的无监督方法将列表分类成不同组别,有没有办法?

我有一系列实例,每个实例都有一份列表,代表它所遵循的不…

f1_score metric in lightgbm

我想使用自定义指标f1_score来训练一个lgb模型…

通过相关系数矩阵进行特征选择

我在测试不同的算法时,如逻辑回归、高斯朴素贝叶斯、随机…

可以将机器学习库用于流式输入和输出吗?

已关闭。此问题需要更加聚焦。目前不接受回答。 想要改进…

在TensorFlow中,queue.dequeue_up_to()方法的用途是什么?

我对这个方法感到非常困惑,特别是当我发现这个令人费解的…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注