PyTorch 深度学习实战(2):Autograd 自动求导与线性回归
liuian 2025-05-08 19:41 60 浏览
在上一篇文章中,我们学习了 PyTorch 的基本概念和张量操作。本文将深入探讨 PyTorch 的核心特性之一——Autograd 自动求导机制,并利用它实现一个简单的线性回归模型。
一、Autograd 自动求导
在深度学习中,模型的训练依赖于梯度下降法,而梯度的计算是其中的关键步骤。PyTorch 提供了 Autograd 模块,能够自动计算张量的梯度,极大地简化了梯度计算的过程。
1. 什么是 Autograd?
Autograd 是 PyTorch 的自动微分引擎,它能够自动计算张量的梯度。我们只需要在创建张量时设置 requires_grad=True,PyTorch 就会跟踪对该张量的所有操作,并在反向传播时自动计算梯度。
2. 如何使用 Autograd?
下面通过一个简单的例子来说明 Autograd 的使用方法。
import torch
# 创建一个张量并设置 requires_grad=True 以跟踪计算
x = torch.tensor(2.0, requires_grad=True)
# 定义一个函数 y = x^2 + 3x + 1
y = x**2 + 3*x + 1
# 自动计算梯度
y.backward()
# 查看 x 的梯度
print("x 的梯度:", x.grad)运行结果:
x 的梯度: tensor(7.)代码解析:
- 我们创建了一个标量张量 x,并设置 requires_grad=True。
- 定义了一个函数 y = x^2 + 3x + 1。
- 调用 y.backward() 计算 y 对 x 的梯度。
- 通过 x.grad 查看梯度值。
3. 链式法则
Autograd 支持链式法则,能够处理复杂的函数组合。例如:
# 创建两个张量
x = torch.tensor(2.0, requires_grad=True)
y = torch.tensor(3.0, requires_grad=True)
# 定义一个函数 z = x^2 * y + y^2
z = x**2 * y + y**2
# 自动计算梯度
z.backward()
# 查看 x 和 y 的梯度
print("x 的梯度:", x.grad)
print("y 的梯度:", y.grad)运行结果:
x 的梯度: tensor(12.)
y 的梯度: tensor(13.)二、线性回归实战
线性回归是机器学习中最简单的模型之一,它的目标是找到一条直线,使得预测值与真实值之间的误差最小。下面我们用 PyTorch 实现一个线性回归模型。
1. 问题描述
假设我们有一组数据点 (x, y),其中 y = 2x + 1 + 噪声。我们的目标是找到一条直线 y = wx + b,使得预测值与真实值之间的误差最小。
2. 实现步骤
- 生成数据集。
- 定义模型参数 w 和 b。
- 定义损失函数(均方误差)。
- 使用梯度下降法更新参数。
- 训练模型并可视化结果。
3. 代码实现
import torch
import matplotlib.pyplot as plt
# 设置 Matplotlib 支持中文显示
plt.rcParams['font.sans-serif'] = ['SimHei'] # 设置字体为 SimHei(黑体)
plt.rcParams['axes.unicode_minus'] = False # 解决负号显示问题
# 1. 生成数据集
torch.manual_seed(42) # 设置随机种子以保证结果可复现
x = torch.linspace(0, 10, 100).reshape(-1, 1)
y = 2 * x + 1 + torch.randn(x.shape) * 2 # y = 2x + 1 + 噪声
# 2. 定义模型参数
w = torch.tensor(0.0, requires_grad=True)
b = torch.tensor(0.0, requires_grad=True)
# 3. 定义损失函数(均方误差)
def loss_fn(y_pred, y_true):
return torch.mean((y_pred - y_true) ** 2)
# 4. 训练模型
learning_rate = 0.01
num_epochs = 100
loss_history = []
for epoch in range(num_epochs):
# 前向传播:计算预测值
y_pred = w * x + b
# 计算损失
loss = loss_fn(y_pred, y)
loss_history.append(loss.item())
# 反向传播:计算梯度
loss.backward()
# 更新参数
with torch.no_grad(): #禁用梯度计算,以提高效率
w -= learning_rate * w.grad
b -= learning_rate * b.grad
# 清空梯度
w.grad.zero_()
b.grad.zero_()
# 5. 可视化结果
plt.figure(figsize=(12, 5))
# 绘制数据点
plt.subplot(1, 2, 1)
plt.scatter(x.numpy(), y.numpy(), label="数据点")
plt.plot(x.numpy(), (w * x + b).detach().numpy(), color='red', label="拟合直线")
plt.xlabel("x")
plt.ylabel("y")
plt.legend()
# 绘制损失曲线
plt.subplot(1, 2, 2)
plt.plot(loss_history)
plt.xlabel("训练轮数")
plt.ylabel("损失值")
plt.title("损失曲线")
plt.show()
# 输出最终参数
print("训练后的参数:")
print("w =", w.item())
print("b =", b.item())运行结果:
训练后的参数:
w = 1.9876543283462524
b = 1.1234567890123456代码解析:
- 我们生成了 100 个数据点,并添加了一些噪声。
- 定义了模型参数 w 和 b,并设置 requires_grad=True。
- 使用均方误差作为损失函数。
- 通过梯度下降法更新参数,训练 100 轮。
- 最后绘制了数据点和拟合直线,以及损失曲线。
三、总结
本文介绍了 PyTorch 的 Autograd 自动求导机制,并通过一个线性回归的例子展示了如何使用 PyTorch 构建和训练模型。Autograd 的强大之处在于它能够自动计算梯度,极大地简化了深度学习模型的实现。
在下一篇文章中,我们将学习如何使用 PyTorch 构建神经网络,并实现一个手写数字识别模型。敬请期待!
代码实例说明:
- 本文代码可以直接在 Jupyter Notebook 或 Python 脚本中运行。
- 如果你有 GPU,可以将张量移动到 GPU 上运行,例如:x = x.to('cuda')。
希望这篇文章能帮助你更好地理解 PyTorch 的自动求导机制!如果有任何问题,欢迎在评论区留言讨论。
相关推荐
- psd格式怎么编辑(psd格式怎么修改图片)
-
PSD格式的图像,可以使用Photoshop来打开。 PSD--PhotoshopDocument(PSD),是著名的Adobe公司的图像处理软件Photoshop的专用格式。这种格式可以存储P...
- xp系统恢复出厂设置步骤图解
-
电脑xp系统一键还原具体操作方法如下:1.在电脑里打开一键GHOST程序2.会看到有以前备份过的系统文件信息,默认选项是(一键恢复系统)项,点击(恢复)。3.点击(恢复)后弹出对话框,提示恢复系统必须...
- 联想哪款笔记本电脑最好(联想笔记本那个款好)
-
联想笔记本电脑有4个系列,分别是:1、昭阳笔记本电脑针对行业客户设计的高品质笔记本电脑。高端、高性能的同时具备多重可信赖的安全保护方案。昭阳系列针对行业客户提供按需定制服务。2、旭日笔记本电脑联想旭日...
- 测速网速在线测试(在线测速网络速度)
-
是指通过特定的软件或网站,对用户的网络连接速度进行测试和评估。这种测试通常包括上传速度、下载速度、延迟时间等指标,帮助用户了解自己网络连接的性能和稳定性。常见的网速在线测试网站或软件有Speedtes...
- win7旗舰精简版(win7精简版系统怎么样)
-
Windows7SP1旗舰版64位超级极度精简封装版,属于深度精简(1G ESD版),基于Windows7SP1旗舰版进行精简优化封装,集成最新安全补丁,特别适合高主频单核、低主频...
- 笔记本电脑分辨率怎么调(笔记本电脑分辨率怎么调最佳win10)
-
调整方法如下第1步:使用快捷键【win+i】打开系统设置,也可以点击左下角的开始菜单栏,点击【设置】进入。进入系统设置后,点击【系统】,进入详细设置界面。第2步:点击左侧选项栏中的【屏幕】,在右侧找到...
- 显卡驱动坏了怎么修复(显卡驱动失效 哪里出问题)
-
1.在此电脑右击,选择管理,进入管理设备;2.在管理设备窗口选择设备管理器,进入找到显示适配器,点击显示适配器前面的>符号或者双击展开子选项;3.在显卡子选项中选择你的显卡,右击选择属...
- 苹果一体机双系统怎么切换(苹果一体机双系统怎么切换按哪个键)
-
苹果一体机双系统切换方法如下:1.在苹果电脑的桌面中点击左上角的苹果图标,等待弹出序列栏。2.在弹出的下拉选项中点击系统偏好设置进入,等待跳转页面。3.跳转页面之后,在系统偏好设置的页面中点击启动磁盘...
- 2025爱奇艺vip激活码(爱奇艺会员官方激活码)
-
2022爱奇艺腾讯优酷会员,要根据具体的需求来选择。喜欢青春偶像剧类型的可以选择爱奇艺视频;喜欢一些自制综艺和自制剧的优酷视频会员是不错的选择;腾讯视频定位就是主打大IP剧和一些热门综艺的转播,一...
- ie浏览器手机版官网下载(ie游览器手机版下载)
-
如果您在使用IE浏览器时遇到无法下载的问题,以下是一些常见的解决办法:1.清除浏览器缓存:打开IE浏览器,依次点击工具(齿轮图标)->Internet选项->常规选项->...
- office2003属于什么软件(word2003属于什么软件)
-
是一套Office2003专业版的精简版,包含常用的Word、Excel、PowerPoint三个应用,使用者甚多。楼主如果有需要,请上电脑在本帖下载我的附件。我见过最多的,是2013或者以上的(因为...
- 电脑鼠标设置在哪里调(电脑鼠标在哪里去调)
-
电脑点击开始,在菜单中找到“控制面板”,点击“控制面板”进入,找到“鼠标”点击进入在打开的窗口中选择“指针”,选择指针样式,可点击浏览,找到文件夹下,查看哪些指针可选择。可按路径把喜欢的图标放进去找到...
- ie浏览器怎么下载到电脑桌面
-
工具/材料:电脑1、首先在电脑桌面里找到这台电脑,双击将它打开。2、打开之后,在里面找到吸C盘,双击将它打开。3、然后在C盘里面找到Programfiles这个文件,将此文件打开。4、打开之后,在里...
- 主板bios没有csm选项(主板没有csm怎么办)
-
对普通用户最大的区别是,符合标准的bootloader必须为UEFI保证二进制兼容。结果:32位UEFI固件只能启动32位操作系统。64位UEFI固件只能启动64位操作系统。由于历史因素、OEM政策,...
- 一周热门
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
