原文地址:torch常用基础函数
本笔记引用自PyTorch中文文档
包torch
包含了多维疑是的数据结构及基于其上的多种数学操作。
torch.is_tensor(obj)
:如果obj
是一个pytorch
张量,则返回True
torch.is_storage(obj)
:如果obj
是一个pytorch storage
对象,则返回True
torch.numel(input)
:返回input
张量中的元素个数。
torch.eye(n, m=None, out=None)
:返回一个2维张量,对角线为1,其它位置为0
torch.from_numpy(ndarray)
:将numpy.ndarray
转换为Tensor
,返回的张量tensor和numpy的ndarray共享同一内存空间,修改一个会导致另一个也被修改,返回的张量不能改变大小
torch.linspace(start, end, steps=100, out=None)
:返回一个1维张量,包含在start
和end
上均匀间隔的steps
个点
start
与end
间生成的样本数torch.logspace(start, end, steps=100, out=None)
:返回一个1维张量,包含在区间10exp(start)和10exp(end)上以对数刻度均匀间隔的 steps
个点。
torch.ones(*sizes, out=None)
:返回一个全为1的张量,形状由可变参数sizes
定义
torch.rand(*sizes, out=None)
:返回一个张量,包含了从区间(0, 1)的均匀分布中抽取的一组随机数,形状由可变参数sizes
定义。
torch.randn(*sizes, out=None)
:返回一个张量,包含了从标准正态分布(mean=0, std=1)中抽取一组随机数,形状由可变参数sizes
定义。
torch.randperm(n, out=None)
:给定参数n
,返回一个从0到n-1的随机整数排列
torch.arange(start, end, step=1, out=None)
:返回一个1维张量,长度为floor((end-start)/step),以
step`为步长的一组序列值。
torch.range(start, end, step=1, out=None)
:还是推荐使用torch.arange()
torch.zeros(*sizes, out=None)
:返回一个全为标量0的张量,形状由可变参数sizes
定义
torch.cat(inputs, dimension=0)
:在给定维度上对输入的张量序列seq
进行连接操作。
torch.chunk(tensor, chunks, dim=0)
:在给定维度上将输入张量进行分块
torch.gather(input, dim, index, out=None)
:沿给定轴dim
,将输入索引张量index
指定位置的值进行聚合。
torch.index_select(input, dim, index, out=None)
:沿指定维度对输入进行切片,取index
中指定的相应项,然后返回一个新的张量,返回的张量与原始张量有相同的维度(在指定轴上),返回的张量与原始张量不共享内存空间
torch.masked_select(input, mask, out=None)
:根据掩码张量mask
中的二元值,取输入张量中的指定项,将取值返回到一个新的1D张量。
张量mask
须跟input
张量有相同的元素数目,但形状或维度不需要相同。返回的张量不与原始张量共享内存空间
torch.nonzero(input, out=None)
:返回一个包含输入input
中非零元素索引的张量,输出张量中的每行包含输入中非零元素的索引
若输入input
有n
维,则输出的索引张量output
形状为z * n, 这里z是输入张量input
中所有非零元素的个数
torch.split(tensor, split_size, dim=0)
:将输入张量分割成相等形状的chunks(如果可分)。如果沿指定维的张量形状大小不能被split_size
整分,则最后一个分块会小于其它分块。
torch.squeeze(input, dim=None, out=None)
:将输入张量形状中的1
去除并返回,如果输入是形如(A * 1 * B * 1 * C * 1 *D),那么输出形状就为:(A * B * C * D)。
当给定dim
时,则只在给定维度上进行挤压,如输入形状为(A * 1 * B),squeeze(input, 0)
,将会保持张量不变,只有用squeeze(input, 1)
,形状会变成(A *B)。
输入张量与返回张量共享内存
torch.stack(sequence, dim=0)
:沿着一个新维度对输入张量进行连接,序列中所有张量都应该为相同的形状。
torch.t(input, out=None)
:输入一个矩阵(2维张量),并转置0,1维,可以被视为transpose(input, 0, 1)
的简写函数
torch.transpose(input, dim0, dim1, out=None)
:返回输入矩阵input
的转置,交换维度dim0
和dim1
。输入张量与输出张量共享内存。
torch.unbind(tensor, dim=0)[source]
:移除指定维度后,返回一个元组,包含了沿着指定维切片后的各个切片
torch.unsequeeze(input, dim, out=None)
:返回一个新的张量,对输入的指定位置插入维度1
,返回张量与输入张量共享内存,若dim
为负,则将被转化为dim+input.dim()+1
torch.manual_seed(seed)
:设定生成随机数的种子,并返回一个torch._C.Generator
对象
torch.initial_seed()
:返回生成随机数的原始种子值
torch.rng_state()[source]
返回随机生成器状态(ByteTensor)
torch.set_rng_state(new_state)[source]
:设定随机生成器状态参数:new_state(torch.ByteTensor)
- 期望的状态
torch.default_generator
torch.bernoulli(input, out=None)
:从伯努利分布中抽取二元随机数(0或者1),输入中所有值必须在[0, 1]区间,输出张量的第i
个元素值,将以输入张量的第i
个概率值等于1
。
返回值将会是与输入相同大小的张量,每个值为0或1
torch.multinomial(input, num_samples, replacement=False, out=None)
:返回一个张量,每行包含从input
相应行中定义的多项式分布中抽取的num_samples
个样本。
input
每行的值不需要总和为1,但必须非负且总和不能为0.
torch.normal(means, std, out=None)
:返回一个张量,包含从给定means
, std
的离散正态分布中抽取随机数,均值和标准差的形状不须匹配,但每个张量的元素个数须相同
torch.saves(obj, f, pickle_module, pickle_protocol=2)
:保存一个对象到一个硬盘文件上
torch.load(f, map_location=None, pickle_module=)
:从磁盘文件中读取一个通过torch.save()
保存的对象,可通过参数map_location
动态地进行内存重映射
torch.get_num_threads()
:获得用于并行化CPU操作的OpenMP线程数
torch.set_num_threads(int)
:设定用于并行化CPU操作的OpenMP线程数
torch.abs(input, out=None)
:计算输入张量的每个元素绝对值
torch.acos(input, out=None)
:返回一个新张量,包含输入张量每个元素的反余弦
torch.add(input, value, out=None)
:对输入张量input
逐元素加上标量值value
,并返回结果到一个新的张量。
torch.addcdiv(tensor, value=1, tensor1, tensor2, out=None)
:用tensor2
对tensor1
逐元素相除,然后乘以标量值value
并加到tensor
上。
torch.addcmul(tensor, value=1, tensor1, tensor2, out=None)
:用tensor2
对tensor1
逐元素相乘,并对结果乘以标量值value
然后加到tensor
,张量形状不需要匹配,但元素数量必须一致。
torch.asin(input, out=None)
:返回一个新张量,包含输入input
张量每个元素的反正弦函数
torch.atan(input, out=None)
:返回一个新张量,包含输入input
张量每个元素的反正切函数
torch.atan2(input1, input2, out=None)
:返回一个新张量,包含两个输入张量input1
和input2
的反正切函数
torch.ceil(input, out=None)
:对输入input
张量每个元素向上取整,即取不小于每个元素的最小整数,并返回结果到输出
torch.clamp(input, min, max, out=None)
:将输入input
张量每个元素值约束到区间[min, max],并返回结果到一个新张量
也可以只设定min
或只设定max
torch.cos(input, out=None)
:返回一个新张量,包含输入input
张量每个元素的余弦
torch.cosh(input, out=None)
:torch.div(input, value, out=None)
:将input
逐元素除以标量值value
,并返回结果到输出张量out
torch.exp(tensor, out=None)
:返回一个新张量,包含输入input
张量每个元素的指数
torch.floor(input, out=None)
:返回一个新张量,包含输入input
张量每个元素的floor,即不大于元素的最大整数。
torch.fmod(input, divisor, out=None)
:计算除法余数,余数的正负与被除数相同
torch.frac(tensor, out=None)
:返回每个元素的分数部分
torch.lerp(start, end, weight, out=None)
:对两个张量以start
, end
做线性插值,将结果返回到输出张量
out = start + weight*(end - start)
torch.log(input, out=None)
:计算input
的自然对数
torch.log1p(input, out=None)
:计算input + 1
的自然对数y = log(x + 1)
对值比较小的输入,此函数比torch.log()
更准确
torch.mul(input, value, out=None)
:用标量值value
乘以输入input
的每个元素,并返回一个新的结果张量
torch.mul(input, other, out=None)
:两个张量input
, other
按元素相乘,并返回到输出张量,两个张量形状不须匹配,但总元素数须一致。当形状不匹配时,input
的形状作为输出张量的形状
torch.neg(input, out=None)
:返回一个新张量,包含输入input
张量按元素取负。
torch.pow(input, exponent, out=None)
:对输入input
按元素求exponent
次幂,并返回结果张量。幂可以为float
数或与input
相同元素数的张量
torch.pow(base, input, out=None)
:base
为标量浮点值,input
为张量。
torch.reciprocal(input, out=None)
:返回一个新张量,包含输入input
张量每个元素的倒数,即1.0/x
torch.remainder(input, divisor, out=None)
:返回一个新张量,包含输入input
张量每个元素的除法余数,余数与除数有相同的符号。
torch.round(input, out=None)
:返回一个新张量,将输入input
张量每个元素四舍五入到最近的整数。
torch.rsqrt(input, out=None)
:返回一个新张量,包含输入input
张量每个元素的平方根倒数。
torch.sigmoid(input, out=None)
:返回一个新张量,包含输入input
张量每个元素的sigmoid值
torch.sign(input, out=None)
:符号函数:返回一个新张量,包含输入input
张量每个元素的正负。
torch.sin(input, out=None)
:返回一个新张量,包含输入input
张量每个元素的正弦。
torch.sinh(input, out=None)
:返回一个新张量,包含输入input
张量每个元素的双曲正弦。
torch.sqrt(input, out=None)
:返回一个新张量,包含输入input
张量每个元素的平方根。
torch.tan(input, out=None)
:返回一个新张量,包含输入input
张量每个元素的正切。
torch.tanh(input, out=None)
:返回一个新张量,包含输入input
张量每个元素的双曲正切。
torch.trunc(input, out=None)
:返回一个新张量,包含输入input
张量每个元素的截断值,使更接近零。即有符号数的小数部分被舍弃。
torch.cumprod(input, dim, out=None) -> Tensor
:返回输入沿指定维度的累积积,如输入是一个N元向量,则结果也是一个N元向量,第i
个输出元素值为yi = x1 * x2 * x3 * ...* xi
torch.cumsum(input, dim, out=None) -> Tensor
:返回输入沿指定维度的累积和
torch.dist(input, other, p=2, out=None) -> Tensor
:返回(input - other)
的p
范数
torch.mean(input) -> float
:返回输入张量所有元素的均值
torch.mean(input, dim, out=None)
:返回输入张量给定维度dim
上每行的均值,输出形状与输入相同,除了给定维度上为1。
torch.median(input, dim=-1, values=None, indices=None) -> (Tensor, LongTensor)
:返回输入张量给定维度每行的中位数,同时返回一个包含中位数的索引。dim
默认为输入张量的最后一维
torch.mode(input, dim=-1, values=None, indices=None) - > (Tensor, LongTensor)
:返回给定维度dim
上,每行的众数值,同时返回一个索引张量。dim
值默认为输入张量的最后一维。输出形状与输入相同,除了给定维度上为1。
torch.norm(input, p=2) -> float
:返回输入张量input
的p
范数。
torch.norm(input, p, dim, out=None) -> Tensor
:返回输入张量给定维度dim
上每行的p
范数。
torch.prod(input) -> float
:返回输入张量input
所有元素的积
torch.prod(input, dim, out=None) -> Tensor
:返回输入张量给定维度上每行的积。
torch.std(input) -> float
:返回输入张量input
所有元素的标准差
torch.std(input, dim, out=None)
:返回输入张量给定维度上每行的标准差。
torch.sum(input) -> float
:返回输入张量input
所有元素的各
torch.sum(input, dim, out=None) -> Tensor
:返回输入疑是给定维度上每行的和
torch.var(input) -> float
:返回输入张量所有元素的方差
torch.var(input, dim, out=None) -> Tensor
:返回输入张量给定维度上每行的方差。
torch.eq(input, other, out=None) -> Tensor
:比较元素相等性,第二个参数可为一个数,或与第一个参数同类型形状的张量
input
同类型torch.equal(tensor1, tensor2) -> bool
:若两个张量有相同的形状和元素值,则返回True
, 否则False
。
torch.ge(input, other, out=None) -> Tensor
:逐元素比较input
和other
,即是否input >= other
第二个参数可以为一个数或与第一个参数相同形状和类型的张量。
float
值ByteTensor
或与第一个参数相同类型。torch.gt(input, other, out=None) -> Tensor
:逐元素比较input
和other
,是否input > other
。若两个张量有相同的形状和元素值,则返回True
,否则False
。第二个参数
可以为一个数或与第一个参数相同形状和类型的张量。
torch.kthvalue(input, k, dim=None, out=None) -> (Tensor, LongTensor)
:取输入张量input
指定维度上第k
个最小值,若不指定dim
,则默认为input
的最后一维。返回一个元组,其中indices
是原始输入张量input
中沿dim
维的第k
个最小值下标。
k
个最小值torch.le(input, other, out=None) -> Tensor
:逐元素比较input
和other
,即是否input <= other
,第二个参数可以为一个数或与第一个参数相同形状和类型的张量。
torch.lt(input, other, out=None) -> Tensor
:逐元素比较input
和other
,即是否input < other
torch.max(input, dim, max=None, max_indice=None) -> (Tensor, LongTensor)
:返回输入张量给定维度上每行的最大值,并同时返回每个最大值的位置索引。
torch.min(input, dim, min=None, min_indices=None) -> (Tensor, LongTensor)
:返回输入张量给定维度上每行的最小值,并同时返回每个最小值的位置索引。
torch.min(input, other, out=None) -> Tensor
:input
中逐元素与other
相应位置的元素对比,返回最小值到输出张量。两张量形状不需匹配,但元素数须相同。
torch.ne(input, other, out=Tensor) -> Tensor
:逐元素比较input
和other
, 即是否input != other
。第二个参数可以为一个数或与第一个参数相同形状和类型的张量。
返回值:一个torch.ByteTensor
张量,包含了每个位置的比较结果(如果tensor != other 为True
,返回1
)。
torch.sort(input, dim=None, descending=False, out=None) -> (Tensor, LongTensor)
:对输入张量input
沿着指定维度按升序排序,如果不给定dim
,默认为输入的最后一维。如果指定参数descending
为True
,则按降序排序。
返回两项:重排后的张量,和重排后元素在原张量的索引
torch.topk(input, k, dim=None, largest=True, sorted=True, out=None) -> (Tensor, LongTensor)
:沿给定dim
维度返回输入张量input
中k
个最大值,不指定dim
,则默认为最后一维,如果largest
为False
,则返回最小的k
个值。
torch.cross(input, other, dim=-1, out=None) -> Tensor
:返回沿着维度dim
上,两个张量input
和other
的叉积。input
和other
必须有相同的形状,且指定的dim
维上size必须为3
。如果不指定dim
,则默认为第一个尺度为3
的维。
torch.diag(input, diagonal=0, out=None) -> Tensor
:如果输入是一个向量,则返回一个以input
为对角线元素的2D方阵
如果输入是一个矩阵,则返回一个包含input
为对角元素的1D张量
参数diagonal
指定对角线:
torch.histc(input, bins=100, min=0, max=0, out=None) -> Tensor
:计算输入张量的直方图。如果min
和max
都为0,则利用数据中的最大最小值作为边界。
torch.renorm(input, p, dim, maxnorm, out=None) -> Tensor
:返回一个张量,包含规范化后的各个子张量,使得沿着dim
维划分的各子张量的p范数小于maxnorm
。如果p范数的值小于maxnorm
,则当前子张量不需要修改。
torch.trace(input) -> float
:返回输入2维矩阵对角元素的和(迹)
torch.tril(input, diagonal=0, out=None) -> Tensor
:返回一个张量,包含输入张量(2D张量)的下三角部分,其余部分设为0,参数diagonal
控制对角线。
torch.triu(input, diagonal=0, out=None) -> Tensor
:返回一个张量,包含输入矩阵的上三角部分,其余被置为0
。
torch.dot(tensor1, tensor2) -> float
:计算两个张量的点乘,两个张量都为1-D向量
torch.eig(a, eigenvectors=False, out=None) -> (Tensor, Tensor)
:计算方阵a
的特征值和特征向量。
True
,同时计算特征值和特征微量,否则只计算特征值a
的右特征向量eigenvectors
为True
,则为包含特征向量的张量,否则为空。torch.inverse(input, out=None) -> Tensor
:对方阵input
求逆
torch.mm(mat1, mat2, out=None) -> Tensor
:对矩阵mat1
和mat2
进行相乘。
torch.mv(mat, vec, out=None) -> Tensor
:对矩阵mat
和向量vec
进行相乘。