filtruj tablicę ND numpy i zachowaj tylko określone elementy
Nov 27 2020
Mam do czynienia z dużą tablicą numpy ND. Chciałbym zachować tylko te elementy obecne w innej tablicy numpy, a pozostałe wartości ustawić na 0.
na przykład, jeśli weźmiemy pod uwagę tę tablicę numpy
array([[[36, 1, 72],
[76, 50, 23],
[28, 68, 17],
[84, 75, 69]],
[[ 5, 15, 93],
[92, 92, 88],
[11, 54, 21],
[87, 76, 81]]])
i chcę ustawić 0
we wszystkich miejscach z wyjątkiem gdzie wartości są 50
, 11
,72
Odpowiedzi
1 DanielLenz Nov 27 2020 at 09:31
Skonfigurować maski przez połączenie reduce
z np.logical_or
i powtórzyć się wartości, które powinny pozostać:
import functools
import numpy as np
arr = np.array([[[36, 1, 72],
[76, 50, 23],
[28, 68, 17],
[84, 75, 69]],
[[ 5, 15, 93],
[92, 92, 88],
[11, 54, 21],
[87, 76, 81]]])
# Set the values that should not
# be set to zero
vals = [11, 50, 72]
# Create a mask by looping over the above values
mask = functools.reduce(np.logical_or, (arr==val for val in vals))
masked = np.where(mask, arr, 0.)
print(masked)
> array([[[ 0., 0., 72.],
[ 0., 50., 0.],
[ 0., 0., 0.],
[ 0., 0., 0.]],
[[ 0., 0., 0.],
[ 0., 0., 0.],
[11., 0., 0.],
[ 0., 0., 0.]]])
2 swag2198 Nov 27 2020 at 09:33
Jeśli chcesz używać tylko numpy
, można to również zrobić za pomocą prostego użycia rozgłaszania, rzutując vals
tablicę tylko o jedną pozycję wyższą niż a
. Osiąga się to bez używania iteracji lub innych funkcji.
import numpy as np
a = np.array([[[36, 1, 72],
[76, 50, 23],
[28, 68, 17],
[84, 75, 69]],
[[ 5, 15, 93],
[92, 92, 88],
[11, 54, 21],
[87, 76, 81]]])
vals = np.array([50, 11, 72])
inds = a == vals[:, None, None, None]
a[~np.any(inds, axis = 0)] = 0
a
Wynik:
array([[[ 0, 0, 72],
[ 0, 50, 0],
[ 0, 0, 0],
[ 0, 0, 0]],
[[ 0, 0, 0],
[ 0, 0, 0],
[11, 0, 0],
[ 0, 0, 0]]])