我有一个小的NXN阵列"块",我想插入一个大阵列"墙"的指定区域(即"开始"的对角线区域).有一种有效的方法来存档吗?
wall[start:start+N][start:start+N] = block[:][:]
Run Code Online (Sandbox Code Playgroud)
目前我正在做的只是:
for i in xrange(N):
wall[start+i][start:start+N] = block[i][:]
Run Code Online (Sandbox Code Playgroud)
HYR*_*YRY 39
你可以使用多维索引:
import numpy as np
wall = np.zeros((10,10),dtype=np.int)
block = np.arange(1,7).reshape(2,3)
x = 2
y = 3
wall[x:x+block.shape[0], y:y+block.shape[1]] = block
Run Code Online (Sandbox Code Playgroud)
输出是:
>>> wall
array([[0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 1, 2, 3, 0, 0, 0, 0],
[0, 0, 0, 4, 5, 6, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0]])
Run Code Online (Sandbox Code Playgroud)
即使给出的位置不在wallnumpy数组的边缘,并且对于您wall和的任何尺寸的尺寸,这都是一种解决方案block(请注意:loc即使在一维情况下,提供的位置也必须是元组)。
def paste_slices(tup):
pos, w, max_w = tup
wall_min = max(pos, 0)
wall_max = min(pos+w, max_w)
block_min = -min(pos, 0)
block_max = max_w-max(pos+w, max_w)
block_max = block_max if block_max != 0 else None
return slice(wall_min, wall_max), slice(block_min, block_max)
def paste(wall, block, loc):
loc_zip = zip(loc, block.shape, wall.shape)
wall_slices, block_slices = zip(*map(paste_slices, loc_zip))
wall[wall_slices] = block[block_slices]
Run Code Online (Sandbox Code Playgroud)
测试:
一维
>>> b = np.zeros([10])
>>> a = np.arange(1, 5)
>>> b
array([ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.])
>>> a
array([1, 2, 3, 4])
>>> paste(b, a, (8,))
>>> b
array([ 0., 0., 0., 0., 0., 0., 0., 0., 1., 2.])
Run Code Online (Sandbox Code Playgroud)
2D
>>> b = np.zeros([10, 10])
>>> a = np.arange(1,33).reshape(4,8)
>>> b
array([[ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.]])
>>> a
array([[ 1, 2, 3, 4, 5, 6, 7, 8],
[ 9, 10, 11, 12, 13, 14, 15, 16],
[17, 18, 19, 20, 21, 22, 23, 24],
[25, 26, 27, 28, 29, 30, 31, 32]])
>>> paste(b, a, (-1, -3))
>>> b
array([[ 12., 13., 14., 15., 16., 0., 0., 0., 0., 0.],
[ 20., 21., 22., 23., 24., 0., 0., 0., 0., 0.],
[ 28., 29., 30., 31., 32., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., 0., 0.]])
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
14526 次 |
| 最近记录: |