百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

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. 实现步骤

  1. 生成数据集。
  2. 定义模型参数 w 和 b。
  3. 定义损失函数(均方误差)。
  4. 使用梯度下降法更新参数。
  5. 训练模型并可视化结果。

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

代码解析:

  1. 我们生成了 100 个数据点,并添加了一些噪声。
  2. 定义了模型参数 w 和 b,并设置 requires_grad=True。
  3. 使用均方误差作为损失函数。
  4. 通过梯度下降法更新参数,训练 100 轮。
  5. 最后绘制了数据点和拟合直线,以及损失曲线。

三、总结

本文介绍了 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政策,...