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

相关推荐
研究点啥好呢2 小时前
3月26日Github热榜推荐 | AI代理工具链专栏
人工智能·驱动开发·python·ai
钝挫力PROGRAMER2 小时前
Linux systemd服务获取不到用户环境变量
linux·运维·python
进击的小头2 小时前
第19篇:卡尔曼滤波器与MPC模型预测控制器的结合实战
python·算法
灵机一物2 小时前
灵机一物AI智能电商小程序(已上线)-告别“人肉电商“:我们如何用 AI 数字员工,实现智能电商小程序自动化运营
人工智能·自动化·数字员工·养龙虾·自动化运营
wanzehongsheng2 小时前
北京万泽宏盛科技:以创新光伏产品赋能绿色生活
人工智能·科技·生活
skywalk81632 小时前
windows10安装python3.14
开发语言·python
wangchilong2 小时前
Flask:后端框架使用
后端·python·flask
Jackson@ML2 小时前
2026最新版MINIMAX AI安装应用开发指南
人工智能·mini max·m2.7
guoji77882 小时前
ChatGPT官网镜像实战:生产环境内存泄漏排查与修复全记录
人工智能·chatgpt