【Pytorch笔记】2.张量操作

参考视频:
深度之眼官方账号 - 01-03-mp4-张量操作与线性回归

torch.cat()

功能:将两个tensor按照给定的维度进行拼接。

python 复制代码
torch.cat(tensors,
          dim=0,
          out=None)

tensors:包含一坨tensor的list或tuple;

dim:指定拼接的维度;

out:输出到哪个tensor中。

python 复制代码
import numpy as np
import torch

t1 = torch.ones((4, 4))
t2 = torch.zeros((4, 3))
t3 = torch.cat((t1, t2), dim=1)
print(t3)

输出:

python 复制代码
tensor([[1., 1., 1., 1., 0., 0., 0.],
        [1., 1., 1., 1., 0., 0., 0.],
        [1., 1., 1., 1., 0., 0., 0.],
        [1., 1., 1., 1., 0., 0., 0.]])

torch.stack()

功能:将多个tensor按照指定的维度进行堆叠(stack),创建一个新的张量。

python 复制代码
torch.stack(tensors,
            dim=0,
            out=None)
python 复制代码
import numpy as np
import torch

t1 = torch.ones((2, 2))
t2 = torch.zeros((2, 2))
t3 = torch.stack((t1, t2), dim=2)
print(t3)

输出:

python 复制代码
tensor([[[1., 0.],
         [1., 0.]],

        [[1., 0.],
         [1., 0.]]])

两个tensor只能在dim维度上不同,其他维度的大小必须相同。

torch.chunk()

功能:将一个tensor在给定维度上进行均等切分,若不能均等切分,最后一份切片的大小小于其他切片。

python 复制代码
torch.chunk(input,
            chunks,
            dim=0)

input:被切分的tensor;

chunks:切分份数;

dim:在dim维度上进行切分

python 复制代码
import numpy as np
import torch

t1 = torch.ones((4, 2))
t_list = torch.chunk(t1, chunks=2, dim=0)
print(t_list)

输出:

python 复制代码
(tensor([[1., 1.],
        [1., 1.]]), tensor([[1., 1.],
        [1., 1.]]))

torch.split()

功能:将tensor按照给定的长度进行切分。

python 复制代码
torch.split(tensor,
            split_size_or_sections,
            dim=0)

split_size_or_sections:如果是int,则切出的长度全为这个值;如果是列表,则按列表中的数作为尺寸来切。

dim:在dim维度上进行切分。

python 复制代码
import numpy as np
import torch

t1 = torch.ones((4, 2))
t_list = torch.split(t1, (1, 2, 1), dim=0)
print(t_list)

输出:

python 复制代码
(tensor([[1., 1.]]), tensor([[1., 1.],
        [1., 1.]]), tensor([[1., 1.]]))

torch.index_select()

功能:在维度dim上,按index索引数据,返回依据index索引拼接的tensor。

python 复制代码
torch.index_select(input,
                   dim,
                   index,
                   out=None)

input:待搜索数据的tensor;

dim:在维度dim上的维度;

index:包含所有索引需求的tensor。

python 复制代码
import numpy as np
import torch

t1 = torch.tensor([[2, 3], [4, 5], [6, 7]])
t2 = torch.tensor([0, 2])
t_out = torch.index_select(t1, dim=0, index=t2)
print(t_out)

输出:

python 复制代码
tensor([[2, 3],
        [6, 7]])

torch.masked_select()

功能:在维度dim上,按mask索引数据,返回依据mask索引拼接的tensor。

python 复制代码
torch.masked_select(input,
                    mask,
                    out=None)

input:待搜索数据的tensor;

mask:在维度dim上需要索引的位置为True,不需要索引的位置为False,形成一个全为布尔量的tensor。该tensor与input同形状。

python 复制代码
import numpy as np
import torch

t1 = torch.tensor([[2, 3], [4, 5], [6, 7]])
t2 = torch.tensor([[True, False],[True, True], [False, True]])
t_out = torch.masked_select(t1, mask=t2)
print(t_out)

输出

python 复制代码
tensor([2, 4, 5, 7])

torch.reshape()

功能:变换张量形状。

(当张量在内存中连续时,reshape后的tensor将存储在原来的地址内)

python 复制代码
torch.reshape(input, 
              shape)

input:待变换形状的tensor;

shape:变换后的形状。(形状中至多一位可以填为-1,由于原tensor中的元素数量是固定的,-1的位置应该填写的数会自动算出)

python 复制代码
import numpy as np
import torch

t1 = torch.tensor([[2, 3, 4], [5, 6, 7]])
t2 = torch.reshape(t1, (3, 2))
print(t2)

输出:

python 复制代码
tensor([[2, 3],
        [4, 5],
        [6, 7]])

torch.transpose()

功能:交换张量的两个维度。

python 复制代码
torch.transpose(input,
                dim0,
                dim1)

dim0、dim1:被交换的两个维度。

python 复制代码
import numpy as np
import torch

t = torch.tensor([[2, 3, 4], [5, 6, 7]])
t1 = torch.transpose(t, 0, 1)
print(t1)

输出:

python 复制代码
tensor([[2, 5],
        [3, 6],
        [4, 7]])

torch.t()

功能:仅限于二维tensor的维度交换。

(二维tensor中,等价于torch.transpose(input, 0, 1)

python 复制代码
torch.t(input)

input:待进行维度交换的tensor。

python 复制代码
import numpy as np
import torch

t = torch.tensor([[2, 3, 4], [5, 6, 7]])
t1 = torch.t(t)
print(t1)

输出:

python 复制代码
tensor([[2, 5],
        [3, 6],
        [4, 7]])

torch.squeeze()

功能:压缩维度为1的轴。

python 复制代码
torch.squeeze(input,
              dim=None,
              out=None)

dim:指定维度进行压缩,这个维度的长度必须为1。

python 复制代码
import numpy as np
import torch

t = torch.tensor([[2], [3], [4], [5], [6]])
t1 = torch.squeeze(t)
print(t1)

输出:

python 复制代码
tensor([2, 3, 4, 5, 6])

torch.unsqueeze()

功能:依据维度dim扩展维度。

python 复制代码
torch.unsqueeze(input,
                dim,
                out=None)

dim:指定维度dim进行扩展,不同于torch.squeeze()的默认为0,这里必须要指明dim的数值。

python 复制代码
import numpy as np
import torch

t = torch.tensor([2, 3, 4, 5, 6])
t1 = torch.unsqueeze(t, dim=0)
print(t1)

输出:

python 复制代码
tensor([[2, 3, 4, 5, 6]])
相关推荐
wydxry6 分钟前
MOE架构详解:原理、应用与PyTorch实现
人工智能·pytorch·架构
MUTA️14 分钟前
SAM附录详解
图像处理·人工智能·计算机视觉
热心不起来的市民小周26 分钟前
基于 BiLSTM+自注意力机制(改进双塔神经网络) 的短文本语义匹配
人工智能·深度学习·神经网络
奇墨 ITQM28 分钟前
FastGPT + Kymo AI生态创新平台,搭建企业智能化知识管理
人工智能
说私域1 小时前
零售新范式:开源AI大模型、AI智能名片与S2B2C商城小程序源码驱动下的圈层渗透革命
人工智能·开源·零售
Eli_Optics1 小时前
《通信原理》学习笔记——第六章
笔记·学习
柠檬味拥抱1 小时前
基于YOLOv8的无人机位置捕捉识别项目|完整源码数据集+PyQt5界面+完整训练流程+开箱即用!
人工智能
算家计算1 小时前
告别“AI味”图像!最新开源AI模型FLUX.1-Krea实现真实光影生成
人工智能·开源·aigc
用户46175752470651 小时前
小白也能懂---Transformer中Look-Ahead Mask 的实现
人工智能
嵌入式小小怪下士2 小时前
ATF 运行时服务
笔记·lx2160/lx2080