- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
恐怕标题不太具有描述性,但我想不出更好的标题。本质上我的问题如下:
我有一个形状为(n, 1, h, w)
的pytorch张量,用于任意整数n
、h
和 w
(在我的具体情况下,该数组表示一批尺寸为 h x w
的灰度图像)。
我还有另一个形状为 (m, 2)
的张量,它映射第一个数组中的每个可能值(即第一个数组可以包含从 0
到 m - 1
) 到一些值的元组。我想将此映射“应用”到第一个数组,以便获得形状为 (n, 2, h, w)
的数组。
我希望这有点清楚,我发现这很难用语言表达,这是一个代码示例(但请注意,由于涉及四维数组,这也不是 super 直观):
import torch
m = 18
# could also be arbitrary tensor with this shape with values between 0 and m - 1
a = torch.arange(m).reshape(2, 1, 3, 3)
# could also be arbitrary tensor with this shape
b = torch.LongTensor(
[[11, 17, 9, 6, 5, 4, 2, 10, 3, 13, 14, 12, 7, 1, 15, 16, 8, 0],
[11, 8, 4, 14, 13, 12, 16, 1, 5, 17, 0, 10, 7, 15, 9, 6, 2, 3]]).t()
# I probably have to do this and the permute/reshape, but how?
c = b.index_select(0, a.flatten())
# ...
# another approach that I think works (but I'm not really sure why, I found this
# more or less by trial and error). I would ideally like to find a 'nicer' way
# of doing this
c = torch.stack([
b.index_select(0, a_.flatten()).reshape(3, 3, 2).permute(2, 0, 1)
for a_ in a
])
# the end result should be:
#[[[[11, 17, 9],
# [ 6, 5, 4],
# [ 2, 10, 3]],
#
# [[11, 8, 4],
# [14, 13, 12],
# [16, 1, 5]]],
#
#
# [[[13, 14, 12],
# [ 7, 1, 15],
# [16, 8, 0]],
#
# [[17, 0, 10],
# [ 7, 15, 9],
# [ 6, 2, 3]]]]
如何才能有效地执行此转换? (理想情况下不使用任何额外的内存)。在 numpy 中,这可以通过 np.apply_along_axis 轻松实现,但似乎没有与此等效的 pytorch。
最佳答案
这是使用切片、堆叠和基于 View 的 reshape 的一种方法:
In [239]: half_way = b.shape[0]//2
In [240]: upper_half = torch.stack((b[:half_way, :][:, 0], b[:half_way, :][:, 1]), dim=0).view(-1, 3, 3)
In [241]: lower_half = torch.stack((b[half_way:, :][:, 0], b[half_way:, :][:, 1]), dim=0).view(-1, 3, 3)
In [242]: torch.stack((upper_half, lower_half))
Out[242]:
tensor([[[[11, 17, 9],
[ 6, 5, 4],
[ 2, 10, 3]],
[[11, 8, 4],
[14, 13, 12],
[16, 1, 5]]],
[[[13, 14, 12],
[ 7, 1, 15],
[16, 8, 0]],
[[17, 0, 10],
[ 7, 15, 9],
[ 6, 2, 3]]]])
需要注意的是,这仅适用于 n=2
。但是,这比基于循环的方法快 1.7 倍,但涉及更多代码。
这是一种更通用的方法,它可以扩展到任何正整数n
:
In [327]: %%timeit
...: block_size = b.shape[0]//a.shape[0]
...: seq_of_tensors = [b[block_size*idx:block_size*(idx+1), :].permute(1, 0).flatten().reshape(2, 3, 3).unsqueeze(0) for idx in range(a.shape[0])]
...: torch.cat(seq_of_tensors)
...:
23.5 µs ± 460 ns per loop (mean ± std. dev. of 7 runs, 10000 loops each)
您还可以使用 View
来代替 reshape :
block_size = b.shape[0]//a.shape[0]
seq_of_tensors = [b[block_size*idx:block_size*(idx+1), :].permute(1, 0).flatten().view(2, 3, 3).unsqueeze(0) for idx in range(a.shape[0])]
torch.cat(seq_of_tensors)
# outputs
tensor([[[[11, 17, 9],
[ 6, 5, 4],
[ 2, 10, 3]],
[[11, 8, 4],
[14, 13, 12],
[16, 1, 5]]],
[[[13, 14, 12],
[ 7, 1, 15],
[16, 8, 0]],
[[17, 0, 10],
[ 7, 15, 9],
[ 6, 2, 3]]]])
<小时/>
注意:请注意,我仍然使用列表理解,因为我们必须均匀划分张量 b
来排列、展平、 reshape 、解压缩,然后连接/stack 沿维度 0。它仍然比我上面的解决方案快一些。
关于python - PyTorch:在张量的单维上应用映射,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55778000/
我正在处理一组标记为 160 个组的 173k 点。我想通过合并最接近的(到 9 或 10 个组)来减少组/集群的数量。我搜索过 sklearn 或类似的库,但没有成功。 我猜它只是通过 knn 聚类
我有一个扁平数字列表,这些数字逻辑上以 3 为一组,其中每个三元组是 (number, __ignored, flag[0 or 1]),例如: [7,56,1, 8,0,0, 2,0,0, 6,1,
我正在使用 pipenv 来管理我的包。我想编写一个 python 脚本来调用另一个使用不同虚拟环境(VE)的 python 脚本。 如何运行使用 VE1 的 python 脚本 1 并调用另一个 p
假设我有一个文件 script.py 位于 path = "foo/bar/script.py"。我正在寻找一种在 Python 中通过函数 execute_script() 从我的主要 Python
这听起来像是谜语或笑话,但实际上我还没有找到这个问题的答案。 问题到底是什么? 我想运行 2 个脚本。在第一个脚本中,我调用另一个脚本,但我希望它们继续并行,而不是在两个单独的线程中。主要是我不希望第
我有一个带有 python 2.5.5 的软件。我想发送一个命令,该命令将在 python 2.7.5 中启动一个脚本,然后继续执行该脚本。 我试过用 #!python2.7.5 和http://re
我在 python 命令行(使用 python 2.7)中,并尝试运行 Python 脚本。我的操作系统是 Windows 7。我已将我的目录设置为包含我所有脚本的文件夹,使用: os.chdir("
剧透:部分解决(见最后)。 以下是使用 Python 嵌入的代码示例: #include int main(int argc, char** argv) { Py_SetPythonHome
假设我有以下列表,对应于及时的股票价格: prices = [1, 3, 7, 10, 9, 8, 5, 3, 6, 8, 12, 9, 6, 10, 13, 8, 4, 11] 我想确定以下总体上最
所以我试图在选择某个单选按钮时更改此框架的背景。 我的框架位于一个类中,并且单选按钮的功能位于该类之外。 (这样我就可以在所有其他框架上调用它们。) 问题是每当我选择单选按钮时都会出现以下错误: co
我正在尝试将字符串与 python 中的正则表达式进行比较,如下所示, #!/usr/bin/env python3 import re str1 = "Expecting property name
考虑以下原型(prototype) Boost.Python 模块,该模块从单独的 C++ 头文件中引入类“D”。 /* file: a/b.cpp */ BOOST_PYTHON_MODULE(c)
如何编写一个程序来“识别函数调用的行号?” python 检查模块提供了定位行号的选项,但是, def di(): return inspect.currentframe().f_back.f_l
我已经使用 macports 安装了 Python 2.7,并且由于我的 $PATH 变量,这就是我输入 $ python 时得到的变量。然而,virtualenv 默认使用 Python 2.6,除
我只想问如何加快 python 上的 re.search 速度。 我有一个很长的字符串行,长度为 176861(即带有一些符号的字母数字字符),我使用此函数测试了该行以进行研究: def getExe
list1= [u'%app%%General%%Council%', u'%people%', u'%people%%Regional%%Council%%Mandate%', u'%ppp%%Ge
这个问题在这里已经有了答案: Is it Pythonic to use list comprehensions for just side effects? (7 个答案) 关闭 4 个月前。 告
我想用 Python 将两个列表组合成一个列表,方法如下: a = [1,1,1,2,2,2,3,3,3,3] b= ["Sun", "is", "bright", "June","and" ,"Ju
我正在运行带有最新 Boost 发行版 (1.55.0) 的 Mac OS X 10.8.4 (Darwin 12.4.0)。我正在按照说明 here构建包含在我的发行版中的教程 Boost-Pyth
学习 Python,我正在尝试制作一个没有任何第 3 方库的网络抓取工具,这样过程对我来说并没有简化,而且我知道我在做什么。我浏览了一些在线资源,但所有这些都让我对某些事情感到困惑。 html 看起来
我是一名优秀的程序员,十分优秀!