numpy python 选择_python – 从numpy中的(n)D数组中选择(n-1)D数组

得到一张脸:

def get_face(M,dim,front_side):

if front_side:

side = 0

else:

side = -1

index = tuple(side if i == dim else slice(None) for i in range(M.ndim))

return M[index]

要添加面部(未经测试):

def add_face(M,new_face,front_side):

#assume sizes match up correctly

if front_side:

return np.concatenate((new_face,M),dim)

else:

return np.concatenate((M,new_face),dim)

要删除一张脸:

def remove_face(M,front_side):

if front_side:

dim_slice = slice(1,None)

else:

dim_slice = slice(None,-1)

index = tuple(dim_slice if i == dim else slice(None) for i in range(M.ndim))

return M[index]

迭代所有面孔:

def iter_faces(M):

for dim in range(M.ndim):

for front_side in (True,False):

yield get_face(M,front_side)

一些快速测试:

In [18]: M = np.arange(27).reshape((3,3,3))

In [19]: for face in iter_faces(M): print face

[[0 1 2]

[3 4 5]

[6 7 8]]

[[18 19 20]

[21 22 23]

[24 25 26]]

[[ 0 1 2]

[ 9 10 11]

[18 19 20]]

[[ 6 7 8]

[15 16 17]

[24 25 26]]

[[ 0 3 6]

[ 9 12 15]

[18 21 24]]

[[ 2 5 8]

[11 14 17]

[20 23 26]]

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值