pytorch 中的 unsqueeze() 函数详解
本文将详细解释 PyTorch 中 unsqueeze() 函数的功能和用法。unsqueeze() 函数可以为张量添加一个维度,其大小为 1。这在处理神经网络中的数据时非常有用,例如将批大小为 1 的样本添加到批处理维度中。

unsqueeze() 函数参数:
input (Tensor): 输入张量。 支持 int、float、complex 或 bool 类型。dim (int): 要插入新维度的维度索引。 dim 可以是负数,表示从后往前计数。例如,dim=-1 表示在最后一个维度之后添加新维度。
unsqueeze() 函数用法:
unsqueeze() 函数可以以两种方式使用:
作为 torch.unsqueeze() 函数调用:
import torchtensor = torch.tensor([1, 2, 3])new_tensor = torch.unsqueeze(input=tensor, dim=0) # 在维度 0 添加一个维度print(new_tensor) # 输出: tensor([[1, 2, 3]])
作为张量的方法调用:
import torchtensor = torch.tensor([1, 2, 3])new_tensor = tensor.unsqueeze(0) # 在维度 0 添加一个维度print(new_tensor) # 输出: tensor([[1, 2, 3]])
示例:
以下示例演示了 unsqueeze() 函数在不同维度上添加新维度的效果:
import torchmy_tensor = torch.tensor([[0, 1, 2], [3, 4, 5], [6, 7, 8], [10, 11, 12]])print("原始张量:n", my_tensor)print("n在维度 0 添加维度:n", torch.unsqueeze(input=my_tensor, dim=0))print("n在维度 1 添加维度:n", torch.unsqueeze(input=my_tensor, dim=1))print("n在维度 2 添加维度:n", torch.unsqueeze(input=my_tensor, dim=2))print("n在维度 -1 添加维度:n", torch.unsqueeze(input=my_tensor, dim=-1)) # 等同于dim=2# 测试不同数据类型my_tensor_float = torch.tensor([[0., 1., 2.], [3., 4., 5.]])my_tensor_complex = torch.tensor([[0.+0.j, 1.+0.j], [2.+0.j, 3.+0.j]])my_tensor_bool = torch.tensor([[True, False], [False, True]])print("n浮点数张量在维度0添加维度:n", torch.unsqueeze(input=my_tensor_float, dim=0))print("n复数张量在维度0添加维度:n", torch.unsqueeze(input=my_tensor_complex, dim=0))print("n布尔型张量在维度0添加维度:n", torch.unsqueeze(input=my_tensor_bool, dim=0))
总结:
unsqueeze() 函数是 PyTorch 中一个非常实用的工具,可以方便地为张量添加维度,从而适应不同的模型输入要求。 记住 dim 参数的正负索引方式,可以灵活地控制新维度的插入位置。
以上就是在 PyTorch 中解压的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1355295.html
微信扫一扫
支付宝扫一扫