200_深度学习的地基:PyTorch 数据操作与 Pandas 预处理实战

在机器学习中,N 维数组(Tensor) 是最核心的数据结构。无论是图像、语音还是文本,最终都会转化为数组进行计算。本篇将从 Tensor 的基本操作出发,带你走进数据预处理的真实世界。

1. N 维数组:神经网络的语言

N 维数组(在 PyTorch 中称为 Tensor)是存储和变换数据的核心工具。

  • 0维:标量(Scalar),如一个数字。
  • 1维:向量(Vector),如特征列表。
  • 2维:矩阵(Matrix),如一张灰度图或一个表格。
  • 3维及以上:张量(Tensor),如彩色图片(宽、高、通道)。

2. 核心代码:张量的创建与计算

文件展示了 PyTorch 中最常用的几种 Tensor 操作方法:

Python

复制代码
import torch

# 1. 创建 Tensor
x = torch.arange(12) # 创建 0-11 的一维张量
print(x.shape)      # 查看形状:torch.Size([12])
print(x.numel())    # 查看元素总数:12

# 2. 改变形状 (Reshape)
X = x.reshape(3, 4) # 变为 3 行 4 列的矩阵

# 3. 特殊张量
torch.zeros((2, 3, 4)) # 全 0 张量
torch.ones((2, 3, 4))  # 全 1 张量
torch.randn(3, 4)      # 标准正态分布随机张量

# 4. 张量连接 (Cat)
Y = torch.tensor([[2, 1, 4, 3], [1, 2, 3, 4], [4, 3, 2, 1]])
# 按行连接 (dim=0) 或按列连接 (dim=1)
torch.cat((X, Y), dim=0)

3. 数据预处理:从 CSV 到 Tensor

在现实任务中,数据通常存储在 CSV 文件中,且往往存在缺失值(NaN) 。文件演示了如何利用 pandas 库进行数据清洗。

实战:处理房屋数据

假设我们有一个简单的房屋数据集,其中包含缺失值:

Python

复制代码
import os
import pandas as pd

# 1. 创建虚拟数据集
os.makedirs(os.path.join('.', '01_Data'), exist_ok=True)
data_file = os.path.join('.', '01_Data', '01_house_tiny.csv')
with open(data_file, 'w') as f:
    f.write('NumRooms,Alley,Price\n')
    f.write('NA,Pave,127500\n')
    f.write('2,NA,106000\n')
    f.write('4,NA,178100\n')
    f.write('NA,NA,140000\n')

# 2. 读取数据
data = pd.read_csv(data_file)

# 3. 处理缺失值:对数值型列用均值填充
inputs, outputs = data.iloc[:, 0:2], data.iloc[:, 2]
inputs = inputs.fillna(inputs.mean())

# 4. 处理类别型缺失值:独热编码 (One-Hot Encoding)
# dummy_na=True 会将 NaN 也作为一个类别处理
inputs = pd.get_dummies(inputs, dummy_na=True)
print(inputs)

# 5. 转换为 PyTorch Tensor
X, y = torch.tensor(inputs.values), torch.tensor(outputs.values)
print(X)

4. 关键技巧解析

广播机制 (Broadcasting Mechanism)

当两个形状不同的 Tensor 进行按元素运算时,PyTorch 会触发广播机制:

  • 自动复制行或列,使两个 Tensor 形状一致后再相加。
  • 条件:至少有一个维度是 1,且其他维度兼容。

内存节省

在进行大规模运算时,频繁的赋值(如 Y = X + Y)会开辟新内存。

  • 建议 :使用原地操作(In-place operation),如 Y += XY[:] = X + Y,以减少内存开销。

5. 总结:数据处理的闭环

通过对该文件的分析,我们可以梳理出进入模型前的标准步骤:

  1. 读取:用 Pandas 加载原始数据。
  2. 清洗:填充数值型缺失值,转换类别型数据。
  3. 转换:将 Pandas 的 DataFrame 转换为 Torch Tensor。
  4. 计算:利用 Tensor 的高效算子进行前向计算。

💡 学习小结

"Garbage in, Garbage out." 预处理的好坏直接决定了模型的上限。熟练掌握 torch 操作和 pandas 转换,是每一位算法工程师的必修课。

相关推荐
123_不打狼18 小时前
基于UNET的语义分割
人工智能·语义分割
实在智能RPA18 小时前
Agent 如何处理流程中的异常情况?2026年AI Agent架构工程与自愈机制深度拆解
人工智能·ai·架构
吕源林18 小时前
C#怎么实现EF Core迁移 C#如何用Entity Framework Core进行数据库迁移和更新表结构【数据库】
jvm·数据库·python
十铭忘18 小时前
局部重绘3——FLUX-Fill的Lora训练
人工智能·深度学习·机器学习
碳基硅坊18 小时前
Dify v1.13.x 版本更新速览:从人机协作到架构升级
人工智能·dify
qq_2069013918 小时前
JavaScript中箭头函数在对象字面量方法中的潜在错误
jvm·数据库·python
IT_陈寒18 小时前
SpringBoot自动配置把我都整不会了
前端·人工智能·后端
w_t_y_y18 小时前
python AI工程(二)python实现skill+cli
人工智能
朝新_18 小时前
【Spring AI 】核心知识体系梳理:从入门到实战
java·人工智能·spring
人工智能AI技术18 小时前
C#调用大模型
人工智能