私は本当に大きな数字の配列(145000行* 550 cols)を持っています。そして、私はサブアレイ内にローリングスライスを作りたいと思っていました。私はそれを関数で実装しようとしました。期待通りに機能lagged_vals
振る舞うだけに、私はそれを望むようにnp.lib.stride_tricks
動作しません - どのように私はnp.lib.stride_tricks
実装では、その特定の行を削除するにはnumpyのストライドはサブアレイ内でのみストライドできますか?
def lagged_vals(series,l):
# Garbage implementation but still right
return np.concatenate([[x[i:i+l] for i in range(x.shape[0]) if i+l <= x.shape[0]] for x in series]
,axis = 0)
# Sample 2D numpy array
something = np.array([[1,2,2,3],[2,2,3,3]])
lagged_vals(something,2) # Works as expected
# array([[1, 2],
# [2, 2],
# [2, 3],
# [2, 2],
# [2, 3],
# [3, 3]])
np.lib.stride_tricks.as_strided(something,
(something.shape[0]*something.shape[1],2),
(8,8))
# array([[1, 2],
# [2, 2],
# [2, 3],
# [3, 2], <--- across subarray stride, which I do not want
# [2, 2],
# [2, 3],
# [3, 3])
?そして、どのように私は大きな配列のためにこのクロス配列のストライド除去をスケールすることができますか?
、あなたはそれらの進歩の3D出力で大丈夫だろうか、あなたがする必要がありますか2D出力ですか? – Divakar