torch.ones(*sizes, out=None) → Tensor
返回一个全为1 的张量,形状由可变参数sizes定义
torch.ones(2, 3)
#output
1 1 1
1 1 1
[torch.FloatTensor of size 2x3]
torch.arange(start, end, step=1, out=None) → Tensor
返回一个1维张量,长度为 floor((end−start)/step)。包含从start到end,以step为步长的一组序列值(默认步长为1)。
参数:
torch.arange(floor)
举一个yolov5的例子
ai = torch.arange(na, device=targets.device).float().view(na, 1).repeat(1, nt)
torch.cat(inputs, dimension=0) → Tensor
在给定维度上对输入的张量序列seq 进行连接操作。
dimension=0:竖直方向上
dimension=1:水平方向
返回一个有相同数据但size不同的tensor。 返回的tensor必须有与原tensor相同的数据和相同数目的元素,但可以有不同的size。
沿着指定的维度重复tensor。 不同于expand(),本函数复制的是tensor中的数据。
参数:
多层切片操作经常把我搞昏迷,也记录一下
>>>a[:8][2:5][-1:]
>>> [4]
相当于:
a[:8]=[0, 1, 2, 3, 4, 5, 6, 7]
a[:8][2:5]= [2, 3, 4]
a[:8][2:5][-1:] = [4]
理论上可无限次多层切片操作,只要上一次返回的是非空可切片对象即可。