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 转换,是每一位算法工程师的必修课。

相关推荐
曲幽6 小时前
FastAPI 身份验证总踩坑?这份 FastAPI Users “避坑指南”请收好
python·fastapi·web·jwt·oauth2·user·authentication
WPF工业上位机6 小时前
YXGK.FakeVM深度学习之5语义分割
人工智能·深度学习
落叶无情6 小时前
ICEF认知操作系统:四类约束全维度全覆盖,是全谱系系统化约束体系
人工智能
碳基硅坊6 小时前
Gemma 4 12B 让AI创作更私密更高效
人工智能·gemma-4-12b
weixin_468466856 小时前
大模型新手入门与实战指南
人工智能·深度学习·ai·大模型
装不满的克莱因瓶6 小时前
掌握 RNN 与 LSTM 模型结构
人工智能·python·rnn·深度学习·神经网络·ai·lstm
jeffer_liu6 小时前
Spring AI 生产级实战:裁判员
java·人工智能·后端·spring·大模型
何以解忧,唯有..7 小时前
Python包管理工具pip:从入门到精通
开发语言·python·pip
weixin_446260857 小时前
Agent 会自行回避吗?测量 LLM 智能体合规性的带内访问拒绝信号
人工智能