深度学习2-PyTorch基础-张量

PyTorch 基础

PyTorch 是一个开源的深度学习框架,以其灵活性和动态计算图而广受欢迎。

PyTorch 主要有以下几个基础概念:张量(Tensor)、自动求导(Autograd)、神经网络模块(nn.Module)、优化器(optim)等。

张量

张量(Tensor)是PyTorch中的核心数据结构,用于存储和操作多维数组。

它可以视为一个多维数组,支持加速计算机的操作。

在PyTorch中,张量的概念类似于Numpy中的数组,但是PyTorch的张量可以运行在不同的设备上,比如CPU和GPU,这使得它非常适合于进行大规模并行计算,特别是在深度学习领域。

常见的张量操作如下:

复制代码
import torch
# 创建张量,和matlab一致
a = torch.zeros(3,4)
print(a)
b = torch.ones(3,4)
print(b)
c = torch.randn(3,4)
print(c)

# 从numpy数组创建张量
import numpy as np
numpy_array = np.array([[1, 2],[3, 4]])
tensor_from_numpy = torch.from_numpy(numpy_array)
print(tensor_from_numpy)

# 在指定设备上(CPU/GPU)上创建张量
d = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")
print(d)
dd = torch.randn(2,3,device = d)
print(dd)

numpy变为张量

复制代码
import numpy as np
# 生成numpy数组
a = np.arange(1,6,1)
print(a)
b = np.linspace(1,6,6)
print(b)

import torch
c = torch.arange(1,6,1)
print(c)

#将numpy的数组转为tensor
d = torch.from_numpy(a)
print(d)

torch.from_numpy()可以将numpy数组变为张量。

直接由数组创建张量

复制代码
e = torch.tensor([1,2,3,4,5])

tensor张量的形状

复制代码
f = torch.tensor([[1, 2, 3],[4,5,6]])
print(f)
print(f.size())

打印出来是

复制代码
tensor([[1, 2, 3],
        [4, 5, 6]])
torch.Size([2, 3])

可见,[1,2,3]代表的是行向量,[1,2,3]之后的逗号,是指下一个行向量往下一行放置。因此,它是2行,3列。

张量转置

复制代码
f = torch.tensor([[1, 2, 3],[4,5,6]])
print(f)
print(f.size())

g = f.T
print(g)

.T表示转置。

单元素的张量转变为python标量

\ 复制代码
single_value = torch.tensor(12.3) #.item()是将Pytorch张量转换为Python标量的方法,只能用于单元素张量
print(f"Single Element,{single_value.item():.4f}") #保留4位小数,进行格式化输出

loss = torch.tensor(0.7543)

# 需要将损失值记录到日志或打印
print(f"Loss: {loss.item():.4f}")  # Loss: 0.7543

# 或者用于条件判断
if loss.item() < 1.1:
    print("损失已足够小!")

这里的.item()就是将一个张量变为了python标量。比如我输入以下代码:

复制代码
print(type(loss.item()))

f = 0.5
print(type(f))

输出为:

复制代码
<class 'float'>
<class 'float'>

这表示两个都是浮点数类型。

张量的各种操作

复制代码
# 创建一个2D张量
a = torch.tensor([[1,2,3],[4,5,6]],dtype=torch.float)
# 张量的属性
print("Tensor:\n",a)
print("Shape:",a.shape)                 #获取形状
print("Size:",a.size())                 #获取形状的另一种方法
print("Data Type:",a.dtype)             #数据类型
print("Device:",a.device)               #设备
print("Dimensions:",a.dim())            #维度数
print("Total Element:",a.numel())       #元素总数
print("Requires Grad:",a.retains_grad)  #是否启用梯度
print("Is CUDA:",a.is_cuda)             #是否再GPU上
print("Is contiguous:",a.contiguous())  #是否连续存储
# 获取某个元素指

single_value = torch.tensor(12.3) #.item()是将Pytorch张量转换为Python标量的方法,只能用于单元素张量
print(f"Single Element,{single_value.item():.4f}") #保留4位小数,进行格式化输出
```
相关推荐
得贤招聘官2 小时前
AI 面试智能体:破解招聘瓶颈的智能化解决方案
人工智能
轻竹办公PPT2 小时前
AI自动写年终总结PPT
人工智能·python·powerpoint
ARM+FPGA+AI工业主板定制专家2 小时前
基于JETSON/RK3588+FPGA+AI农业机器人视觉感知方案
人工智能·计算机视觉·fpga开发·机器人
lomocode2 小时前
大模型本地部署与预热全攻略:让首次响应速度提升 5 倍
人工智能
生信大表哥2 小时前
如何在服务器上使用 Gemini 3 进行生信分析:从入门到进阶
linux·人工智能·语言模型·数信院生信服务器·生信云服务器
某林2122 小时前
SLAM 建图系统配置与启动架构
人工智能·stm32·单片机·嵌入式硬件·算法
cooldream20092 小时前
深入理解 Cursor 规则体系
人工智能·cursor
AI浩2 小时前
【Qwen3-VL-4B-Instruct实战】推理图片和视频、加速
人工智能
腾飞开源2 小时前
26_Spring AI 干货笔记之 OCI GenAI Cohere 聊天
人工智能·自动配置·依赖管理·springai·聊天模型·运行时选项·oci cohere