Pytorch深度学习(二):反馈神经网络(BPNN)

Pytorch深度学习(二):反馈神经网络(BPNN)

本文浅学反馈神经网络(Back Propagation Neural Network)

一、反向传播(Back Propagation)

仍然以上文的线性模型为例子,其第一次“学习”过程如下:

在这里插入图片描述

其中,反向传播过程求出了误差 l o s s loss loss 关于各个变量的偏导数值,最后用于更新权重 w w w ,而这一过程,我们利用torch中的函数来实现。关键代码:l.backward()

相关预备知识:

  • 什么是张量
  • torch.Tensor的数据类型
  • w.grad.data的数据类型
  • w.grad.data.item()的数据类型

  • 读者自行了解或利用type()等进行程序实验

程序如下:

import torch
import numpy as np
from matplotlib import pyplot as plt

xdata = [1, 2, 3]
ydata = [2, 4, 6]

w = torch.Tensor([1])
w.requires_grad = True  # the default is False which will don't compute grad


costlist = []


def forward(x):
    return x * w

def loss(x, y):
    ypred = forward(x)
    return (ypred - y) ** 2



print('predict (before training)', 4, forward(4).item())

for epoch in range(100):
    cost = 0
    for x, y in zip(xdata, ydata):
        l = loss(x, y)
        l.backward()    # compute w.grad = \frac{\partial l}{\partial w}
        cost += l.item()
        print('\t grad:', x, y, w.grad.item())
        w.data = w.data - 0.01 * w.grad.data

        w.grad.data.zero_()
    costlist.append(cost/len(xdata))
    print('progress:', epoch, l.item())

print('predict (after training)', 4, forward(4).item())

plt.plot(range(100), costlist, label='BPNN')
plt.xlabel('epoch')
plt.ylabel('cost')
plt.title('BPNN')
plt.legend()
plt.show()

在这里插入图片描述

在这里插入图片描述
可见,随着迭代步数的增加,误差快速减小,结果是可靠的

二、练习

将线性模型改为以下一元二次多项式的模型,同样通过BPNN求出相关的参数 w 1 , w 2 , b w_1,w_2,b w1,w2,b ,并且预测 x = 4 x=4 x=4 y y y 的值
在这里插入图片描述


import torch
import numpy as np
from matplotlib import pyplot as plt

xdata = [1, 2, 3]
ydata = [2, 4, 6]

w1 = torch.Tensor([1])
w1.requires_grad = True  # the default is False which will don't compute grad

w2 = torch.Tensor([1])
w2.requires_grad = True  # the default is False which will don't compute grad

b = torch.Tensor([1])
b.requires_grad = True  # the default is False which will don't compute grad

costlist = []

def forward(x):
    return w1 * x**2 + w2 * x + b

def loss(x, y):
    ypred = forward(x)
    return (ypred - y) ** 2


print('predict (before training):', 4, forward(4).item())

for epoch in range(100):
    cost = 0
    for x, y in zip(xdata, ydata):
        l = loss(x, y)
        l.backward()    # compute w.grad = \frac{\partial l}{\partial w}
        cost += l.item()
        print('\t grad:', x, y, w1.grad.item(), w2.grad.item(), b.grad.item())
        w1.data = w1.data - 0.01 * w1.grad.data 
        w2.data = w2.data - 0.01 * w2.grad.data
        b.data = b.data - 0.01 * b.grad.data
        w1.grad.data.zero_()
        w2.grad.data.zero_()
        b.grad.data.zero_() 
    costlist.append(cost/len(xdata))
    print('progress:', epoch, l.item())

print('predict (after training):', 4, forward(4).item())
print('parameter:w1 = {}, w2 = {}, b = {}'.format(w1.item(), w2.item(), b.item()))

plt.figure(figsize=(10,4))
plt.subplot(1,2,1)
plt.plot(range(100), costlist)
plt.xlabel('epoch')
plt.ylabel('loss')

plt.title('BPNN error')

plt.subplot(1, 2, 2)
xx = np.linspace(0, 10, 10)
yy = w1.item()* xx**2 + w2.item()*xx +b.item()
plt.plot(xx, yy, color='red', label='fit')
plt.scatter(xdata, ydata, label='data')
plt.legend()
plt.title('BPNN fit')
plt.xlabel('x')
plt.ylabel('y')
plt.show()

在这里插入图片描述
最后一次 “学习” 的结果及相关参数和预测结果:

progress: 99 0.00631808303296566
predict (after training): 4 8.544171333312988
parameter:w1 = 0.24038191139698029, w2 = 0.9266766309738159, b = 0.99135422706604
  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PyTorch深度学习实战中,可以使用卷积神经网络来进行图像分类任务。在实战中,可以使用经典的卷积神经网络模型,如VGG、ResNet、Inception和DenseNet等。这些模型都是在深度学习的发展过程中出现的经典模型,对深度学习的学术研究和工业生产都起到了巨大的促进作用。初学者可以通过阅读论文和实现代码来全面了解这些模型。例如,可以使用PyTorch中的torchvision.models模块来加载预训练的卷积神经网络模型,如VGG-16、VGG-19和ResNet等\[1\]。其中,VGG-16和VGG-19是由卷积层、池化层和全连接层等不同组合构成的经典卷积神经网络模型\[1\]。而ResNet是一种使用残差单元连接而成的卷积神经网络模型,通过跨层的短接来突出微小的变化,使得网络对误差更加敏感,并解决了网络退化现象,具有良好的学习效果\[2\]\[3\]。因此,在PyTorch深度学习实战中,可以选择合适的卷积神经网络模型来进行图像分类任务。 #### 引用[.reference_title] - *1* *2* *3* [PyTorch深度学习实战 | 典型卷积神经网络](https://blog.csdn.net/qq_41640218/article/details/129832298)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值