机器学习入门(14)— 神经网络学习整体流程、误差反向传播代码实现、误差反向传播梯度确认、误差反向传播使用示例

1. 神经网络学习整体流程

神经网络学习的步骤如下所示。

  • 前提
    神经网络中有合适的权重和偏置,调整权重和偏置以便拟合训练数据的过程称为学习。神经网络的学习分为下面 4 个步骤。
  • 步骤1(mini-batch)
    从训练数据中随机选择一部分数据。
  • 步骤2(计算梯度)
    计算损失函数关于各个权重参数的梯度。
  • 步骤3(更新参数)
    将权重参数沿梯度方向进行微小的更新。
  • 步骤4(重复)
    重复步骤1、步骤2、步骤3。

之前介绍的误差反向传播法会在步骤2 中出现。我们可以利用数值微分求得了这个梯度。数值微分虽然实现简单,但是计算要耗费较多的时间。和需要花费较多时间的数值微分不同,误差反向传播法可以快速高效地计算梯度。

2. 误差反向传播代码实现

3. 误差反向传播梯度确认

4. 误差反向传播使用示例

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的神经网络算法的 Python 代码示例: ``` import numpy as np # 定义激活函数 def sigmoid(x): return 1/(1+np.exp(-x)) # 定义神经网络类 class NeuralNetwork: def __init__(self, input_dim, hidden_dim, output_dim): # 初始化权重矩阵 self.weights1 = np.random.randn(input_dim, hidden_dim) self.weights2 = np.random.randn(hidden_dim, output_dim) def forward(self, X): # 前向传播 self.z2 = np.dot(X, self.weights1) self.a2 = sigmoid(self.z2) self.z3 = np.dot(self.a2, self.weights2) y_hat = sigmoid(self.z3) return y_hat def backward(self, X, y, y_hat, learning_rate): # 反向传播 delta3 = (y_hat - y) * sigmoid(self.z3) * (1 - sigmoid(self.z3)) d_weights2 = np.dot(self.a2.T, delta3) delta2 = np.dot(delta3, self.weights2.T) * sigmoid(self.z2) * (1 - sigmoid(self.z2)) d_weights1 = np.dot(X.T, delta2) # 更新权重矩阵 self.weights2 -= learning_rate * d_weights2 self.weights1 -= learning_rate * d_weights1 def train(self, X, y, learning_rate, epochs): for i in range(epochs): y_hat = self.forward(X) self.backward(X, y, y_hat, learning_rate) # 测试 X = np.array([[0,0],[0,1],[1,0],[1,1]]) y = np.array([[0],[1],[1],[0]]) nn = NeuralNetwork(input_dim=2, hidden_dim=4, output_dim=1) nn.train(X, y, learning_rate=0.1, epochs=10000) # 预测 y_pred = nn.forward(X) print(y_pred) ``` 这是一个简单的三层神经网络使用 sigmoid 作为激活函数,采用随机梯度下降法更新权重矩阵。你可以根据具体需求修改代码,例如更改激活函数、优化算法等等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值