pytorch的Tensor基础

torch

Tensors

torch package包含data structure和mathematics operation,和tensor序列化的实用小程序。

torch.set_default_dtype(d) 设置torch.tensor()的默认浮点类型

d (torch.dtype) – the floating point dtype to make the default

Example:

>>> torch.tensor([1.2, 3]).dtype           # initial default for floating point is torch.float32
torch.float32
>>> torch.set_default_dtype(torch.float64)
>>> torch.tensor([1.2, 3]).dtype           # a new floating point tensor
torch.float64

torch.get_default_dtype() → torch.dtype 获取当前默认的浮点数类型

>>> torch.get_default_dtype()  # initial default for floating point is torch.float32
torch.float32
>>> torch.set_default_dtype(torch.float64)
>>> torch.get_default_dtype()  # default is now changed to torch.float64
torch.float64
>>> torch.set_default_tensor_type(torch.FloatTensor)  # 另一种设置方法 setting tensor type also affects this
>>> torch.get_default_dtype()  # changed to torch.float32, the dtype for torch.FloatTensor
torch.float32

torch.numel(input) → int 返回输入张量中元素的总数。

input (Tensor) – the input tensor.

>>> a = torch.randn(1, 2, 3, 4, 5)
>>> torch.numel(a)
120
>>> a = torch.zeros(4,4)
>>> torch.numel(a)
16

torch.set_printoptions(precision=None, threshold=None, edgeitems=None, linewidth=None, profile=None, sci_mode=None)

设置打印选项。主要用于debug。

Creation Ops

torch.tensor(data, dtype=None, device=None, requires_grad=False, pin_memory=False) → Tensor

data (array_like) 初始data,可以是list,tuple,Numpy ndarray,scalar
dtype (torch.dtype, optional) e.g., torch.float32ortorch.float, torch.float64 or torch.double, torch.float16 or torch.half, torch.int32 or torch.int, torch.int64 or torch.long, torch.bool
device (torch.device, optional) e.g., torch.device('cuda:0'), torch.device('cuda', 0), 'cuda:0', 'cpu', torch.device(1) cuda Tensor, 1
requires_grad (bool, optional)
pin_memory (bool, optional)

torch.tensor()总是会复制data。如果要避免复制data,data是一个tensor, torch.Tensor.requires_grad_() or torch.Tensor.detach(). 如果有一个 ndarray,想要避免复制data,torch.as_tensor()

torch.tensor()会构造一个leaf variable(叶变量),如果x是一个tensor,torch.tensor(x) 等价于 x.clone().detach() , torch.tensor(x, requires_grad=True)等价于x.clone().detach().requires_grad_(True),推荐使用torch.Tensor.clone().detach()

torch.as_tensor(data, dtype=None, device=None) → Tensor

把数据转换成一个torch.Tensor。如果数据已经是一个具有相同dtype和设备的张量,则不进行复制,否则,如果数据张量requires_grad=True,则返回一个新的张量,并保留计算图。类似地,如果数据是相应dtype的ndarray,而设备是cpu,则不执行复制。不会复制,是指修改torch.as_tensor()返回的tensor,原数据也会被修改

Example:

>>> a = numpy.array([1, 2, 3])
>>> t = torch.as_tensor(a)
>>> t
tensor([ 1,  2,  3])
>>> t[0] = -1
>>> a
array([-1,  2,  3])

>>> a = numpy.array([1, 2, 3])
>>> t = torch.as_tensor(a, device=torch.device('cuda'))
>>> t
tensor([ 1,  2,  3])
>>> t[0] = -1
>>> a
array([1,  2,  3])

torch.from_numpy(ndarray) → Tensor
ndarray创建一个Tensor, 与ndarray 共享内存,返回的Tensor不能改变大小。

>>> a = numpy.array([1, 2, 3])
>>> t = torch.from_numpy(a)
>>> t
tensor([ 1,  2,  3])
>>> t[0] = -1
>>> a
array([-1,  2,  3])

torch.from_numpy(ndarray)torch.as_tensor(data, dtype=None, device=None)功能相似


torch.zeros(*size, out=None, dtype=None, layout=torch.strided, device=None, requires_grad=False) → Tensor

size (python:int...) – a sequence of integers
Example:

>>> torch.zeros(2, 3)
tensor([[ 0.,  0.,  0.],
        [ 0.,  0.,  0.]])

>>> torch.zeros(5)
tensor([ 0.,  0.,  0.,  0.,  0.])

torch.zeros_like(input, dtype=None, layout=None, device=None, requires_grad=False) → Tensor

torch.zeros_like(input) 等价于 torch.zeros(input.size(), dtype=input.dtype, layout=input.layout, device=input.device).

torch.ones(*size, out=None, dtype=None, layout=torch.strided, device=None, requires_grad=False) → Tensor

Example:

>>> torch.ones(2, 3)
tensor([[ 1.,  1.,  1.],
        [ 1.,  1.,  1.]])

>>> torch.ones(5)
tensor([ 1.,  1.,  1.,  1.,  1.])

torch.ones_like(input, dtype=None, layout=None, device=None, requires_grad=False) → Tensor

torch.ones_like(input, out=output)等价于torch.ones(input.size(), out=output)

torch.arange(start=0, end, step=1, out=None, dtype=None, layout=torch.strided, device=None, requires_grad=False) → Tensor
返回区间[start, end)的一维张量

Example:

>>> torch.arange(5)
tensor([ 0,  1,  2,  3,  4])
>>> torch.arange(1, 4)
tensor([ 1,  2,  3])
>>> torch.arange(1, 2.5, 0.5)
tensor([ 1.0000,  1.5000,  2.0000])

torch.linspace(start, end, steps=100, out=None, dtype=None, layout=torch.strided, device=None, requires_grad=False) → Tensor
返回在起点和终点之间等距间隔的步长的一维张量。

Example:

>>> torch.linspace(3, 10, steps=5)
tensor([  3.0000,   4.7500,   6.5000,   8.2500,  10.0000])
>>> torch.linspace(-10, 10, steps=5)
tensor([-10.,  -5.,   0.,   5.,  10.])
>>> torch.linspace(start=-10, end=10, steps=5)
tensor([-10.,  -5.,   0.,   5.,  10.])
>>> torch.linspace(start=-10, end=10, steps=1)
tensor([-10.])

torch.logspace(start, end, steps=100, base=10.0, out=None, dtype=None, layout=torch.strided, device=None, requires_grad=False) → Tensor
返回区间[base^{start}, base^{end}]的一维张量

Example:

>>> torch.logspace(start=-10, end=10, steps=5)
tensor([ 1.0000e-10,  1.0000e-05,  1.0000e+00,  1.0000e+05,  1.0000e+10])
>>> torch.logspace(start=0.1, end=1.0, steps=5)
tensor([  1.2589,   2.1135,   3.5481,   5.9566,  10.0000])
>>> torch.logspace(start=0.1, end=1.0, steps=1)
tensor([1.2589])
>>> torch.logspace(start=2, end=2, steps=1, base=2)
tensor([4.0])

torch.eye(n, m=None, out=None, dtype=None, layout=torch.strided, device=None, requires_grad=False) → Tensor
返回一个二维张量,对角线上有一个,其他位置为零。

Example:

>>> torch.eye(3)
tensor([[ 1.,  0.,  0.],
        [ 0.,  1.,  0.],
        [ 0.,  0.,  1.]])

torch.empty(*size, out=None, dtype=None, layout=torch.strided, device=None, requires_grad=False, pin_memory=False) → Tensor
返回填充有未初始化数据的张量。

torch.empty_like(input, dtype=None, layout=None, device=None, requires_grad=False) → Tensor

torch.empty_like(input) 等价于 torch.empty(input.size(), dtype=input.dtype, layout=input.layout, device=input.device).

torch.full(size, fill_value, out=None, dtype=None, layout=torch.strided, device=None, requires_grad=False) → Tensor

torch.full_like(input, fill_value, out=None, dtype=None, layout=torch.strided, device=None, requires_grad=False) → Tensor

torch.full_like(input, fill_value) 等价于torch.full(input.size(), fill_value, dtype=input.dtype, layout=input.layout, device=input.device)

Indexing, Slicing, Joining, Mutating Ops

torch.cat(tensors, dim=0, out=None) → Tensor

tensors (sequence of Tensors) 相同类型的张量的任何python序列。提供的非空张量必须具有相同的形状,但cat尺寸除外。
dim (python:int, optional)
torch.cat()可以被看为torch.split()torch.chunk()的逆运算

torch.stack(tensors, dim=0, out=None) → Tensor

将张量的序列沿新维度连接起来。所有tensor大小一样,输出tensor会增加一个新的维度,e.g., [2,3]\to[2,2,3]

torch.chunk(input, chunks, dim=0) → List of Tensors

将张量拆分为特定数量的块。如果沿着给定维度dim的张量大小无法被块整除,则最后一个块将更小。

torch.split(tensor, split_size_or_sections, dim=0)

split_size_or_sections (python:int) or (list(python:int)) – size of a single chunk or list of sizes for each chunk
可以指定块大小,或每一块的大小

torch.unbind(input, dim=0) → seq
将tensor解开,删除张量一个维度。 返回给定维度上所有切片的元组。
Example:

>>> torch.unbind(torch.tensor([[1, 2, 3],
>>>                            [4, 5, 6],
>>>                            [7, 8, 9]]))
(tensor([1, 2, 3]), tensor([4, 5, 6]), tensor([7, 8, 9]))

torch.gather(input, dim, index, out=None, sparse_grad=False) → Tensor

沿dim指定的轴收集值。
For a 3-D tensor the output is specified by:

out[i][j][k] = input[index[i][j][k]][j][k]  # if dim == 0
out[i][j][k] = input[i][index[i][j][k]][k]  # if dim == 1
out[i][j][k] = input[i][j][index[i][j][k]]  # if dim == 2

Example:

>>> t = torch.tensor([[1,2],[3,4]])
>>> torch.gather(t, 1, torch.tensor([[0,0],[1,0]]))
tensor([[ 1,  1],
        [ 4,  3]])

torch.take(input, index) → Tensor

Example:

>>> src = torch.tensor([[4, 3, 5],
                        [6, 7, 8]])
>>> torch.take(src, torch.tensor([0, 2, 5]))
tensor([ 4,  5,  8])

torch.index_select(input, dim, index, out=None) → Tensor

Example:

>>> x = torch.randn(3, 4)
>>> x
tensor([[ 0.1427,  0.0231, -0.5414, -1.0009],
        [-0.4664,  0.2647, -0.1228, -1.1068],
        [-1.1734, -0.6571,  0.7230, -0.6004]])
>>> indices = torch.tensor([0, 2])
>>> torch.index_select(x, 0, indices)
tensor([[ 0.1427,  0.0231, -0.5414, -1.0009],
        [-1.1734, -0.6571,  0.7230, -0.6004]])
>>> torch.index_select(x, 1, indices)
tensor([[ 0.1427, -0.5414],
        [-0.4664, -0.1228],
        [-1.1734,  0.7230]])

torch.masked_select(input, mask, out=None) → Tensor

Example:

>>> x = torch.randn(3, 4)
>>> x
tensor([[ 0.3552, -2.3825, -0.8297,  0.3477],
        [-1.2035,  1.2252,  0.5002,  0.6248],
        [ 0.1307, -2.0608,  0.1244,  2.0139]])
>>> mask = x.ge(0.5)
>>> mask
tensor([[False, False, False, False],
        [False, True, True, True],
        [False, False, False, True]])
>>> torch.masked_select(x, mask)
tensor([ 1.2252,  0.5002,  0.6248,  2.0139])

torch.narrow(input, dim, start, length) → Tensor

Example:

>>> x = torch.tensor([[1, 2, 3], [4, 5, 6], [7, 8, 9]])
>>> torch.narrow(x, 0, 0, 2)
tensor([[ 1,  2,  3],
        [ 4,  5,  6]])
>>> torch.narrow(x, 1, 1, 2)
tensor([[ 2,  3],
        [ 5,  6],
        [ 8,  9]])

torch.nonzero(input, *, out=None, as_tuple=False) → LongTensor or tuple of LongTensors

返回一个张量,其中包含输入的所有非零元素的索引。

Example:

>>> torch.nonzero(torch.tensor([1, 1, 1, 0, 1]))
tensor([[ 0],
        [ 1],
        [ 2],
        [ 4]])
>>> torch.nonzero(torch.tensor([[0.6, 0.0, 0.0, 0.0],
                                [0.0, 0.4, 0.0, 0.0],
                                [0.0, 0.0, 1.2, 0.0],
                                [0.0, 0.0, 0.0,-0.4]]))
tensor([[ 0,  0],
        [ 1,  1],
        [ 2,  2],
        [ 3,  3]])
>>> torch.nonzero(torch.tensor([1, 1, 1, 0, 1]), as_tuple=True)
(tensor([0, 1, 2, 4]),)
>>> torch.nonzero(torch.tensor([[0.6, 0.0, 0.0, 0.0],
                                [0.0, 0.4, 0.0, 0.0],
                                [0.0, 0.0, 1.2, 0.0],
                                [0.0, 0.0, 0.0,-0.4]]), as_tuple=True)
(tensor([0, 1, 2, 3]), tensor([0, 1, 2, 3]))
>>> torch.nonzero(torch.tensor(5), as_tuple=True)
(tensor([0]),)

torch.where(condition, x, y) → Tensor

image.png

Example:

>>> x = torch.randn(3, 2)
>>> y = torch.ones(3, 2)
>>> x
tensor([[-0.4620,  0.3139],
        [ 0.3898, -0.7197],
        [ 0.0478, -0.1657]])
>>> torch.where(x > 0, x, y)
tensor([[ 1.0000,  0.3139],
        [ 0.3898,  1.0000],
        [ 0.0478,  1.0000]])

torch.where(condition) → tuple of LongTensor

torch.where(condition) is identical to torch.nonzero(condition, as_tuple=True)


torch.reshape(input, shape) → Tensor

torch.Tensor.view()类似
Example:

>>> a = torch.arange(4.)
>>> torch.reshape(a, (2, 2))
tensor([[ 0.,  1.],
        [ 2.,  3.]])
>>> b = torch.tensor([[0, 1], [2, 3]])
>>> torch.reshape(b, (-1,))
tensor([ 0,  1,  2,  3])

torch.squeeze(input, dim=None, out=None) → Tensor

返回一个张量,其中所有大小为1的输入的维都已删除。

Example:

>>> x = torch.zeros(2, 1, 2, 1, 2)
>>> x.size()
torch.Size([2, 1, 2, 1, 2])
>>> y = torch.squeeze(x)
>>> y.size()
torch.Size([2, 2, 2])
>>> y = torch.squeeze(x, 0)
>>> y.size()
torch.Size([2, 1, 2, 1, 2])
>>> y = torch.squeeze(x, 1)
>>> y.size()
torch.Size([2, 2, 1, 2])

torch.unsqueeze(input, dim, out=None) → Tensor

Returns a new tensor with a dimension of size one inserted at the specified position.
Example:

>>> x = torch.tensor([1, 2, 3, 4])
>>> torch.unsqueeze(x, 0)
tensor([[ 1,  2,  3,  4]])
>>> torch.unsqueeze(x, 1)
tensor([[ 1],
        [ 2],
        [ 3],
        [ 4]])

torch.t(input) → Tensor

对2维tensor进行转置

torch.transpose(input, dim0, dim1) → Tensor

返回张量,该张量是输入的转置版本。给定的尺寸dim0和dim1被交换。
Example:

>>> x = torch.randn(2, 3)
>>> x
tensor([[ 1.0028, -0.9893,  0.5809],
        [-0.1669,  0.7299,  0.4942]])
>>> torch.transpose(x, 0, 1)
tensor([[ 1.0028, -0.1669],
        [-0.9893,  0.7299],
        [ 0.5809,  0.4942]])

Random sampling

torch.seed()

将用于生成随机数的种子设置为不确定的随机数。返回用于播种RNG的64位数字。即程序自动设置随机种子

torch.manual_seed(seed)

设置CPU用于生成随机数的种子。即手动设置随机种子

torch.cuda.manual_seed(seed)

为当前GPU生成随机数设置种子。如果没有CUDA,则可以安全地调用此函数;在这种情况下,它会被静默忽略。如果使用的是多GPU模型,则此功能不足以获得确定性。要播种所有GPU,请使用torch.cuda.manual_seed_all(seed)

torch.cuda.manual_seed_all(seed)

设置用于在所有GPU上生成随机数的种子。如果没有CUDA,则可以安全地调用此函数;在这种情况下,它会被静默忽略。

torch.initial_seed()

返回用于生成随机数的初始种子。torch.seed()torch.manual_seed(seed)设置的随机种子
Example:

>>> torch.seed()
1989945232164789487
>>> torch.initial_seed()
1989945232164789487
>>> torch.manual_seed(12345)
<torch._C.Generator object at 0x7f869477cf30>
>>> torch.initial_seed()
12345

torch.bernoulli(input, *, generator=None, out=None) → Tensor

伯努利分布,二项分布

torch.multinomial(input, num_samples, replacement=False, *, generator=None, out=None) → LongTensor

多项式分布

torch.normal()

正态分布

torch.randn(*size, out=None, dtype=None, layout=torch.strided, device=None, requires_grad=False) → Tensor

标准正态分布,mean=0 and variance=1 (also called the standard normal distribution).

torch.randn_like(input, dtype=None, layout=None, device=None, requires_grad=False) → Tensor

torch.rand(*size, out=None, dtype=None, layout=torch.strided, device=None, requires_grad=False) → Tensor

间隔[0,1)上的均匀分布

torch.rand_like(input, dtype=None, layout=None, device=None, requires_grad=False) → Tensor

torch.rand_like(input) 等价于 torch.rand(input.size(), dtype=input.dtype, layout=input.layout, device=input.device)

torch.randint(low=0, high, size, *, generator=None, out=None, dtype=None, layout=torch.strided, device=None, requires_grad=False) → Tensor

low(包含)和high(不含)之间均匀生成的随机整数。

torch.randint_like(input, low=0, high, dtype=None, layout=torch.strided, device=None, requires_grad=False) → Tensor

torch.randperm(n, out=None, dtype=torch.int64, layout=torch.strided, device=None, requires_grad=False) → LongTensor

返回0-n-1的随机整数排列
Example:

>>> torch.randperm(4)
tensor([2, 1, 0, 3])

In-place random sampling

image.png

In-place random sampling是指会改变torch.Tensor的值
Example:

>>> a=torch.zeros(3,3)
>>> a
tensor([[0., 0., 0.],
        [0., 0., 0.],
        [0., 0., 0.]])
>>> a.normal_()
tensor([[ 1.4271, -1.8701, -1.1962],
        [-2.0440, -0.4560, -1.4295],
        [-0.7175,  1.3922,  0.0811]])
>>> a
tensor([[ 1.4271, -1.8701, -1.1962],
        [-2.0440, -0.4560, -1.4295],
        [-0.7175,  1.3922,  0.0811]])

Serialization

torch.save(obj, f, pickle_module=<module 'pickle' from '/opt/conda/lib/python3.6/pickle.py'>, pickle_protocol=2, _use_new_zipfile_serialization=False)

Example

>>> # Save to file
>>> x = torch.tensor([0, 1, 2, 3, 4])
>>> torch.save(x, 'tensor.pt')

torch.load(f, map_location=None, pickle_module=<module 'pickle' from '/opt/conda/lib/python3.6/pickle.py'>, **pickle_load_args)

Example

>>> torch.load('tensors.pt')
# Load all tensors onto the CPU
>>> torch.load('tensors.pt', map_location=torch.device('cpu'))
# Load all tensors onto the CPU, using a function
>>> torch.load('tensors.pt', map_location='cpu')
# If the 'tensors.pt' contains GPU tensors, those tensors will be loaded to GPU by default. Therefore, use map_location='cpu' to load tensors to CPU from GPU.

Best practices

# save
torch.save(the_model.state_dict(), PATH)
# load
the_model = TheModelClass(*args, **kwargs)
the_model.load_state_dict(torch.load(PATH))

Locally disabling gradient computation

上下文管理器torch.no_grad()torch.enable_grad()torch.set_grad_enabled()有助于局部禁用和启用梯度计算。
Example:

>>> x = torch.zeros(1, requires_grad=True)
>>> with torch.no_grad():
...     y=x+2
...
>>> y.requires_grad
False
>>> with torch.enable_grad():
...     y=x+2
...
>>> y.requires_grad
True
>>> with torch.set_grad_enabled(True):
...     y=x+2
...
>>> y.requires_grad
True
>>> torch.set_grad_enabled(False)
<torch.autograd.grad_mode.set_grad_enabled object at 0x7f86efe717c0>
>>> y=x+2
>>> y.requires_grad
False

Math operations

Pointwise Ops

torch.abs(input, out=None) → Tensor 绝对值

torch.add() 加
torch.sub() 减
torch.div() 除
torch.mul() 乘
或通过 + - * / 符号计算
c = a+b
c = a-b
c = a*b
c = a/b

torch.fmod(input, other, out=None) → Tensor 余数
torch.remainder(input, other, out=None) → Tensor 余数

torch.trunc(input, out=None) → Tensor 取截断整数部分,带符号
torch.frac(input, out=None) → Tensor 取小数部分,带符号

image.png

torch.ceil(input, out=None) → Tensor


image.png

torch.floor(input, out=None) → Tensor


image.png

torch.round(input, out=None) → Tensor 四舍五入
torch.clamp(input, min, max, out=None) → Tensor
image.png

Example:

>>> a = torch.randn(4)
>>> a
tensor([-1.7120,  0.1734, -0.0478, -0.0922])
>>> torch.clamp(a, min=-0.5, max=0.5)
tensor([-0.5000,  0.1734, -0.0478, -0.0922])

torch.sin(input, out=None) → Tensor
torch.cos(input, out=None) → Tensor
torch.tan(input, out=None) → Tensor

torch.neg(input, out=None) → Tensor 取负数
torch.reciprocal(input, out=None) → Tensor 取倒数

torch.pow() 幂
torch.sqrt(input, out=None) → Tensor 开根号

torch.exp(input, out=None) → Tensor
torch.log(input, out=None) → Tensor

image.png

torch.log10(input, out=None) → Tensor
image.png

torch.log1p(input, out=None) → Tensor
image.png

torch.lerp(input, end, weight, out=None)
线性插值


image.png

torch.sigmoid(input, out=None) → Tensor

torch.sign(input, out=None) → Tensor

Reduction Ops

torch.argmax()
torch.argmin()
torch.dist(input, other, p=2) → Tensor 求两个tensor差的范数,欧式距离
torch.norm(input, p='fro', dim=None, keepdim=False, out=None, dtype=None) 求范数
torch.median() 中位数
torch.mode(input, dim=-1, keepdim=False, values=None, indices=None) -> (Tensor, LongTensor) 众数
torch.sum() 和
torch.prod() 返回所有元素的乘积
torch.mean() 平均数
torch.std() 标准差
torch.std_mean() 标准差和均值
torch.var() 方差
torch.var_mean() 方差和均值
torch.unique(input, sorted=True, return_inverse=False, return_counts=False, dim=None) 消除非连续重复值,返回输入张量的唯一元素,索引,计数
torch.unique_consecutive(input, return_inverse=False, return_counts=False, dim=None) 只消除连续的重复值,从每个连续的等效元素组中除去除第一个元素外的所有元素。

Example:

>>> x = torch.tensor([1, 1, 2, 2, 3, 1, 1, 2])
>>> output = torch.unique(x)
>>> output
tensor([1, 2, 3])
>>> x = torch.tensor([1, 1, 2, 2, 3, 1, 1, 2])
>>> output = torch.unique_consecutive(x)
>>> output
tensor([1, 2, 3, 1, 2])

Comparison Ops

torch.allclose(input, other, rtol=1e-05, atol=1e-08, equal_nan=False) → bool

image.png

torch.sort(input, dim=-1, descending=False, out=None) -> (Tensor, LongTensor)
torch.argsort(input, dim=-1, descending=False, out=None) → LongTensor
返回按值升序对给定维度上的张量排序的索引。ascending order
torch.max()
torch.min()
torch.kthvalue(input, k, dim=None, keepdim=False, out=None) -> (Tensor, LongTensor) 返回第k个最小值和索引
torch.topk(input, k, dim=None, largest=True, sorted=True, out=None) -> (Tensor, LongTensor) 返回k个最大的元素

torch.isfinite() 返回每个元素是否为有限。
torch.isinf(tensor) 每个元素是否为+/- INF。
torch.isnan() 是否每个元素都是NaN
Example:

>>> torch.isfinite(torch.tensor([1, float('inf'), 2, float('-inf'), float('nan')]))
tensor([True,  False,  True,  False,  False])

torch.eq(input, other, out=None) → Tensor 计算每个元素是否相等
torch.equal(input, other) → bool size和value是否相等
torch.ge(input, other, out=None) → Tensor Computes \text{input} \geq \text{other} element-wise.
torch.gt(input, other, out=None) → Tensor Computes \text{input} > \text{other} element-wise.
torch.le(input, other, out=None) → Tensor Computes \text{input} \leq \text{other} element-wise.
torch.lt(input, other, out=None) → Tensor Computes \text{input} < \text{other} element-wise.
torch.ne(input, other, out=None) → Tensor Computes \text{input} \neq \text{other} element-wise.

Other Operations

torch.bincount(input, weights=None, minlength=0) → Tensor
Example:

>>> input = torch.randint(0, 8, (5,), dtype=torch.int64)
>>> weights = torch.linspace(0, 1, steps=5)
>>> input, weights
(tensor([4, 3, 6, 3, 4]),
 tensor([ 0.0000,  0.2500,  0.5000,  0.7500,  1.0000])

>>> torch.bincount(input)
tensor([0, 0, 0, 2, 2, 0, 1])

>>> input.bincount(weights)
tensor([0.0000, 0.0000, 0.0000, 1.0000, 1.0000, 0.0000, 0.5000])

torch.broadcast_tensors(*tensors) → List of Tensors
Example:

>>> x = torch.arange(3).view(1, 3)
>>> y = torch.arange(2).view(2, 1)
>>> a, b = torch.broadcast_tensors(x, y)
>>> a.size()
torch.Size([2, 3])
>>> a
tensor([[0, 1, 2],
        [0, 1, 2]])

torch.cartesian_prod(*tensors) 笛卡儿积
Example:

>>> a = [1, 2, 3]
>>> b = [4, 5]
>>> list(itertools.product(a, b))
[(1, 4), (1, 5), (2, 4), (2, 5), (3, 4), (3, 5)]
>>> tensor_a = torch.tensor(a)
>>> tensor_b = torch.tensor(b)
>>> torch.cartesian_prod(tensor_a, tensor_b)
tensor([[1, 4],
        [1, 5],
        [2, 4],
        [2, 5],
        [3, 4],
        [3, 5]])

torch.cdist(x1, x2, p=2, compute_mode='use_mm_for_euclid_dist_if_necessary') 计算批处理行向量的两个集合的每对之间的p范数距离。欧式距离
Example

>>> a = torch.tensor([[0.9041,  0.0196], [-0.3108, -2.4423], [-0.4821,  1.059]])
>>> a
tensor([[ 0.9041,  0.0196],
        [-0.3108, -2.4423],
        [-0.4821,  1.0590]])
>>> b = torch.tensor([[-2.1763, -0.4713], [-0.6986,  1.3702]])
>>> b
tensor([[-2.1763, -0.4713],
        [-0.6986,  1.3702]])
>>> torch.cdist(a, b, p=2)
tensor([[3.1193, 2.0959],
        [2.7138, 3.8322],
        [2.2830, 0.3791]])

torch.combinations(input, r=2, with_replacement=False) → seq
长度为2的所有可能组合

Example:

>>> a = [1, 2, 3]
>>> list(itertools.combinations(a, r=2))
[(1, 2), (1, 3), (2, 3)]
>>> list(itertools.combinations(a, r=3))
[(1, 2, 3)]
>>> list(itertools.combinations_with_replacement(a, r=2)) # 有放回
[(1, 1), (1, 2), (1, 3), (2, 2), (2, 3), (3, 3)]
>>> tensor_a = torch.tensor(a)
>>> torch.combinations(tensor_a)
tensor([[1, 2],
        [1, 3],
        [2, 3]])
>>> torch.combinations(tensor_a, r=3)
tensor([[1, 2, 3]])
>>> torch.combinations(tensor_a, with_replacement=True)
tensor([[1, 1],
        [1, 2],
        [1, 3],
        [2, 2],
        [2, 3],
        [3, 3]])

torch.cross(input, other, dim=-1, out=None) → Tensor 返回输入和其他维度的矢量的叉积

torch.cumprod(input, dim, out=None, dtype=None) → Tensor 返回维度dim中输入元素的累积积。

image.png

torch.cumsum(input, dim, out=None, dtype=None) → Tensor 返回维度dim中输入元素的累积和。

image.png

torch.diag(input, diagonal=0, out=None) → Tensor
torch.diag_embed(input, offset=0, dim1=-2, dim2=-1) → Tensor
torch.diagflat(input, offset=0) → Tensor
torch.diagonal(input, offset=0, dim1=0, dim2=1) → Tensor

Examples:

Get the square matrix where the input vector is the diagonal:

>>> a = torch.randn(3)
>>> a
tensor([ 0.5950,-0.0872, 2.3298])
>>> torch.diag(a)
tensor([[ 0.5950, 0.0000, 0.0000],
        [ 0.0000,-0.0872, 0.0000],
        [ 0.0000, 0.0000, 2.3298]])
>>> torch.diag(a, 1)
tensor([[ 0.0000, 0.5950, 0.0000, 0.0000],
        [ 0.0000, 0.0000,-0.0872, 0.0000],
        [ 0.0000, 0.0000, 0.0000, 2.3298],
        [ 0.0000, 0.0000, 0.0000, 0.0000]])

torch.flatten(input, start_dim=0, end_dim=-1) → Tensor 展平一个张量中一个连续的dims范围。

Example:

>>> t = torch.tensor([[[1, 2],
                       [3, 4]],
                      [[5, 6],
                       [7, 8]]])
>>> torch.flatten(t)
tensor([1, 2, 3, 4, 5, 6, 7, 8])
>>> torch.flatten(t, start_dim=1)
tensor([[1, 2, 3, 4],
        [5, 6, 7, 8]])

torch.flip(input, dims) → Tensor

Example:

>>> x = torch.arange(8).view(2, 2, 2)
>>> x
tensor([[[ 0,  1],
         [ 2,  3]],

        [[ 4,  5],
         [ 6,  7]]])
>>> torch.flip(x, [0, 1])
tensor([[[ 6,  7],
         [ 4,  5]],

        [[ 2,  3],
         [ 0,  1]]])

torch.rot90(input, k, dims) → Tensor

torch.histc(input, bins=100, min=0, max=0, out=None) → Tensor

计算张量的直方图。

torch.meshgrid(*tensors, **kwargs)
Example:

>>> x = torch.tensor([1, 2, 3])
>>> y = torch.tensor([4, 5, 6])
>>> grid_x, grid_y = torch.meshgrid(x, y)
>>> grid_x
tensor([[1, 1, 1],
        [2, 2, 2],
        [3, 3, 3]])
>>> grid_y
tensor([[4, 5, 6],
        [4, 5, 6],
        [4, 5, 6]])

torch.renorm(input, p, dim, maxnorm, out=None) → Tensor
返回一个张量,其中沿着维度dim的输入的每个子张量均被规范化,从而子张量的p范数小于maxnorm值
Example:

>>> x = torch.ones(3, 3)
>>> x[1].fill_(2)
tensor([ 2.,  2.,  2.])
>>> x[2].fill_(3)
tensor([ 3.,  3.,  3.])
>>> x
tensor([[ 1.,  1.,  1.],
        [ 2.,  2.,  2.],
        [ 3.,  3.,  3.]])
>>> torch.renorm(x, 1, 0, 5)
tensor([[ 1.0000,  1.0000,  1.0000],
        [ 1.6667,  1.6667,  1.6667],
        [ 1.6667,  1.6667,  1.6667]])

torch.repeat_interleave()

重复张量的元素。

Example:

>>> x = torch.tensor([1, 2, 3])
>>> x.repeat_interleave(2)
tensor([1, 1, 2, 2, 3, 3])
>>> y = torch.tensor([[1, 2], [3, 4]])
>>> torch.repeat_interleave(y, 2)
tensor([1, 1, 2, 2, 3, 3, 4, 4])
>>> torch.repeat_interleave(y, 3, dim=1)
tensor([[1, 1, 1, 2, 2, 2],
        [3, 3, 3, 4, 4, 4]])
>>> torch.repeat_interleave(y, torch.tensor([1, 2]), dim=0)
tensor([[1, 2],
        [3, 4],
        [3, 4]])

torch.roll(input, shifts, dims=None) → Tensor
将张量沿给定维数滚动。移动到最后位置之外的元素在第一个位置重新引入。如果不指定维数,张量在滚动之前会被压扁,然后恢复到原来的形状。

Example:

>>> x = torch.tensor([1, 2, 3, 4, 5, 6, 7, 8]).view(4, 2)
>>> x
tensor([[1, 2],
        [3, 4],
        [5, 6],
        [7, 8]])
>>> torch.roll(x, 1, 0)
tensor([[7, 8],
        [1, 2],
        [3, 4],
        [5, 6]])
>>> torch.roll(x, -1, 0)
tensor([[3, 4],
        [5, 6],
        [7, 8],
        [1, 2]])
>>> torch.roll(x, shifts=(2, 1), dims=(0, 1))
tensor([[6, 5],
        [8, 7],
        [2, 1],
        [4, 3]])

torch.trace(input) → Tensor
返回输入二维矩阵对角线元素的总和。

torch.tril(input, diagonal=0, out=None) → Tensor 返回张量的下三角部分

Example:

>>> a = torch.randn(3, 3)
>>> a
tensor([[-1.0813, -0.8619,  0.7105],
        [ 0.0935,  0.1380,  2.2112],
        [-0.3409, -0.9828,  0.0289]])
>>> torch.tril(a)
tensor([[-1.0813,  0.0000,  0.0000],
        [ 0.0935,  0.1380,  0.0000],
        [-0.3409, -0.9828,  0.0289]])

torch.triu(input, diagonal=0, out=None) → Tensor 返回张量的上三角部分
torch.dot(input, tensor) → Tensor 计算两个张量的点积(内积)
torch.eig(input, eigenvectors=False, out=None) -> (Tensor, Tensor) 计算实方矩阵的特征值和特征向量。
torch.inverse(input, out=None) → Tensor 取方阵输入的逆。
torch.det(input) → Tensor 计算平方矩阵或批次平方矩阵的行列式。
torch.matmul(input, other, out=None) → Tensor 两个张量的矩阵乘积。
torch.mm(input, mat2, out=None) → Tensor 矩阵乘积 此函数不广播。有关广播矩阵产品,请参见torch.matmul()
torch.matrix_rank(input, tol=None, symmetric=False) → Tensor 返回二维张量的rank。
torch.qr(input, some=True, out=None) -> (Tensor, Tensor) QR分解
torch.orgqr(input, input2) → Tensor 计算QR分解的正交矩阵Q
torch.pinverse(input, rcond=1e-15) → Tensor 计算二维时态的伪逆(也称为Moore-Penrose逆)
torch.svd(input, some=True, compute_uv=True, out=None) -> (Tensor, Tensor, Tensor) 奇异值分解

image.png

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容

  • Tensor的创建除了构造器,还提供了工厂模式的创建方式:函数,同时提供了基本运算函数的封装。本主题就专门数理这些...
    杨强AT南京阅读 2,088评论 0 1
  • 概述 在新版本中,PyTorch引入了许多令人兴奋的新特性,主要的更新在于 Variable和Tensor的合并 ...
    古de莫宁阅读 6,137评论 0 1
  • 1.安装 https://pytorch.orgpip3 config set global.index-url ...
    dingtom阅读 346评论 0 0
  • 这是我家的猫。 多么和谐的画面,猫在专心致志的喝水,一条小鱼游了过来,朝它吐泡泡,猫咪任不为所动,眯着眼睛,享受...
    淡墨清影阅读 205评论 0 3
  • 它一直立着,还没回头,世间的沧桑与甘甜都无法打动它,皱一皱眉头,动一动手,它用尘封的古镜照入石上的旅者,用湖水的玉...
    青云剑客阅读 327评论 1 3