本文源码基于版本1.0,交互界面基于0.4.1
import torch
按照指定轴上的坐标进行过滤
index_select()
沿着某tensor的一个轴dim筛选若干个坐标
>>> 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, dim=0, indices) # 指定筛选对象、轴、筛选坐标 tensor([[ 0.1427, 0.0231, -0.5414, -1.0009], [-1.1734, -0.6571, 0.7230, -0.6004]]) >>> torch.index_select(x, dim=1, indices) tensor([[ 0.1427, -0.5414], [-0.4664, -0.1228], [-1.1734, 0.7230]])
where()
用于将两个broadcastable的tensor组合成新的tensor,类似于c++++中的三元操作符“?:”
>>> x = torch.randn(3, 2) >>> y = torch.ones(3, 2) >>> torch.where(x > 0, x, y) tensor([[1.4013, 1.0000], [1.0000, 0.9267], [1.0000, 0.4302]]) >>> x tensor([[ 1.4013, -0.9960], [-0.3715, 0.9267], [-0.7163, 0.4302]])
指定条件返回01-tensor
>>> x = torch.arange(5) >>> x tensor([0, 1, 2, 3, 4]) >>> torch.gt(x,1) # 大于 tensor([0, 0, 1, 1, 1], dtype=torch.uint8) >>> x>1 # 大于 tensor([0, 0, 1, 1, 1], dtype=torch.uint8) >>> torch.ne(x,1) # 不等于 tensor([1, 0, 1, 1, 1], dtype=torch.uint8) >>> x!=1 # 不等于 tensor([1, 0, 1, 1, 1], dtype=torch.uint8) >>> torch.lt(x,3) # 小于 tensor([1, 1, 1, 0, 0], dtype=torch.uint8) >>> x<3 # 小于 tensor([1, 1, 1, 0, 0], dtype=torch.uint8) >>> torch.eq(x,3) # 等于 tensor([0, 0, 0, 1, 0], dtype=torch.uint8) >>> x==3 # 等于 tensor([0, 0, 0, 1, 0], dtype=torch.uint8)
返回索引
>>> x = torch.arange(5) >>> x # 1维 tensor([0, 1, 2, 3, 4]) >>> torch.nonzero(x) tensor([[1], [2], [3], [4]]) >>> x = 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]]) >>> x # 2维 tensor([[ 0.6000, 0.0000, 0.0000, 0.0000], [ 0.0000, 0.4000, 0.0000, 0.0000], [ 0.0000, 0.0000, 1.2000, 0.0000], [ 0.0000, 0.0000, 0.0000, -0.4000]]) >>> torch.nonzero(x) tensor([[0, 0], [1, 1], [2, 2], [3, 3]])
借助nonzero()我们可以返回符合某一条件的index(https://stackoverflow.com/questions/47863001/how-pytorch-tensor-get-the-index-of-specific-value)
>>> x=torch.arange(12).view(3,4) >>> x tensor([[ 0, 1, 2, 3], [ 4, 5, 6, 7], [ 8, 9, 10, 11]]) >>> (x>4).nonzero() tensor([[1, 1], [1, 2], [1, 3], [2, 0], [2, 1], [2, 2], [2, 3]])
以上这篇在PyTorch中Tensor的查找和筛选例子就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
本文向大家介绍PyTorch之图像和Tensor填充的实例,包括了PyTorch之图像和Tensor填充的实例的使用技巧和注意事项,需要的朋友参考一下 在PyTorch中可以对图像和Tensor进行填充,如常量值填充,镜像填充和复制填充等。在图像预处理阶段设置图像边界填充的方式如下: 对Tensor进行填充的方式如下: 这里需要注意一点的是,transforms.Pad只能对PIL图像格式进行填充
本文向大家介绍Pytorch Tensor的索引与切片例子,包括了Pytorch Tensor的索引与切片例子的使用技巧和注意事项,需要的朋友参考一下 1. Pytorch风格的索引 根据Tensor的shape,从前往后索引,依次在每个维度上做索引。 示例代码: 上述代码创建了一个shape=[4, 3, 28, 28]的Tensor,我们可以理解为4张图片,每张图片有3个通道,每个通道是28x
本文向大家介绍pytorch索引查找 index_select的例子,包括了pytorch索引查找 index_select的例子的使用技巧和注意事项,需要的朋友参考一下 index_select anchor_w = self.FloatTensor(self.scaled_anchors).index_select(1, self.LongTensor([0])) 参数说明:index_sel
本文向大家介绍pytorch 获取tensor维度信息示例,包括了pytorch 获取tensor维度信息示例的使用技巧和注意事项,需要的朋友参考一下 我就废话不多说了,直接上代码吧! 参考https://stackoverflow.com/questions/46826218/pytorch-how-to-get-the-shape-of-a-tensor-as-a-list-of-int 以上
本文向大家介绍PyTorch中Tensor的维度变换实现,包括了PyTorch中Tensor的维度变换实现的使用技巧和注意事项,需要的朋友参考一下 对于 PyTorch 的基本数据对象 Tensor (张量),在处理问题时,需要经常改变数据的维度,以便于后期的计算和进一步处理,本文旨在列举一些维度变换的方法并举例,方便大家查看。 维度查看:torch.Tensor.size() 查看当前 tens
本文向大家介绍详解PyTorch中Tensor的高阶操作,包括了详解PyTorch中Tensor的高阶操作的使用技巧和注意事项,需要的朋友参考一下 条件选取:torch.where(condition, x, y) → Tensor 返回从 x 或 y 中选择元素的张量,取决于 condition 操作定义: 举个例子: 把张量中的每个数据都代入条件中,如果其大于 0 就得出 a,其它情况就得出