python pytorch view()函數

本文详细介绍了PyTorch中的view函数如何用于改变张量的形状,包括使用-1参数进行自适应调整的例子,展示了从一维到多维张量的转换过程。
部署运行你感兴趣的模型镜像

view是改变tensor的形状,并不只是简单的只是多行tensor拼接成一行,view中的-1是自适应的调整

A = torch.arange(0, 16)
print(A)
#tensor([ 0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13, 14, 15])
B = A.view(-1,2)
print(B)
#tensor([[ 0,  1],
        [ 2,  3],
        [ 4,  5],
        [ 6,  7],
        [ 8,  9],
        [10, 11],
        [12, 13],
        [14, 15]])
B = A.view(2,-1)
print(B)
#tensor([[ 0,  1,  2,  3,  4,  5,  6,  7],
        [ 8,  9, 10, 11, 12, 13, 14, 15]])
C = A.view(-1,2,2)
print(C)
#tensor([[[ 0,  1],
         [ 2,  3]],

        [[ 4,  5],
         [ 6,  7]],

        [[ 8,  9],
         [10, 11]],

        [[12, 13],
         [14, 15]]])
C = A.view(2,2,-1)
print(C)
#tensor([[[ 0,  1,  2,  3],
         [ 4,  5,  6,  7]],

        [[ 8,  9, 10, 11],
         [12, 13, 14, 15]]])


 

您可能感兴趣的与本文相关的镜像

PyTorch 2.9

PyTorch 2.9

PyTorch
Cuda

PyTorch 是一个开源的 Python 机器学习库,基于 Torch 库,底层由 C++ 实现,应用于人工智能领域,如计算机视觉和自然语言处理

### 关于 PythonPyTorch 的使用示例 以下是几个典型的 PyTorch 使用场景及其对应的代码实现: #### 1. 安装并验证 PyTorch 如果使用 Anaconda 作为 Python 发行版,可以通过以下命令安装 PyTorch 及其相关依赖项: ```bash conda install pytorch torchvision torchaudio -c pytorch ``` 完成安装后,可通过以下代码片段验证 PyTorch 是否成功安装[^1]: ```python import torch print(torch.__version__) print(torch.cuda.is_available()) # 检查CUDA支持 ``` #### 2. 加载数据集 加载 Fashion-MNIST 数据集的示例如下所示。此代码会从指定路径下载训练集,并将其转换为张量形式以便后续处理[^2]: ```python from torchvision import datasets, transforms train_set = datasets.FashionMNIST( root='D:\\temp\\fashion_mnist', train=True, download=True, transform=transforms.Compose([ transforms.ToTensor() ]) ) test_set = datasets.FashionMNIST( root='D:\\temp\\fashion_mnist', train=False, download=True, transform=transforms.Compose([ transforms.ToTensor() ]) ) ``` #### 3. 构建简单神经网络 定义一个基本的全连接神经网络用于分类任务[^3]: ```python import torch.nn as nn import torch.nn.functional as F class SimpleNet(nn.Module): def __init__(self): super(SimpleNet, self).__init__() self.fc1 = nn.Linear(784, 128) # 输入层到隐藏层 self.fc2 = nn.Linear(128, 64) # 隐藏层到中间层 self.fc3 = nn.Linear(64, 10) # 中间层到输出层 def forward(self, x): x = x.view(-1, 784) # 将输入展平 x = F.relu(self.fc1(x)) # ReLU激活函数 x = F.relu(self.fc2(x)) x = self.fc3(x) return F.log_softmax(x, dim=1) # 输出概率分布 model = SimpleNet() print(model) ``` #### 4. 动态计算图的应用 PyTorch 支持动态计算图,在运行时可以根据条件调整操作流程。以下是一个简单的例子展示如何基于条件更新变量[^4]: ```python x = torch.randn(3, requires_grad=True) y = x * 2 while y.data.norm() < 1000: y = y * 2 print(y) ``` 以上代码展示了 PyTorch 在实际应用中的灵活性以及强大的功能。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值