Ponieważ tak naprawdę potrzebujesz innej tablicy, która jest arr
tam arr < 255
, gdzie 255
indziej, można to zrobić po prostu:
result = np.minimum(arr, 255)
Mówiąc bardziej ogólnie, dla dolnej i / lub górnej granicy:
result = np.clip(arr, 0, 255)
Jeśli chcesz uzyskać dostęp do wartości powyżej 255 lub coś bardziej skomplikowanego, odpowiedź @ mtitan8 jest bardziej ogólna, ale np.clip
i np.minimum
(lub np.maximum
) jest ładniejsza i znacznie szybsza w twoim przypadku:
In [292]: timeit np.minimum(a, 255)
100000 loops, best of 3: 19.6 µs per loop
In [293]: %%timeit
.....: c = np.copy(a)
.....: c[a>255] = 255
.....:
10000 loops, best of 3: 86.6 µs per loop
Jeśli chcesz to zrobić w miejscu (tj. Zmodyfikować arr
zamiast tworzyć result
), możesz użyć out
parametru np.minimum
:
np.minimum(arr, 255, out=arr)
lub
np.clip(arr, 0, 255, arr)
( out=
nazwa jest opcjonalna, ponieważ argumenty w tej samej kolejności, co definicja funkcji).
W przypadku modyfikacji na miejscu indeksowanie logiczne znacznie przyspiesza (bez konieczności wykonywania, a następnie modyfikowania kopii osobno), ale nadal nie jest tak szybkie, jak minimum
:
In [328]: %%timeit
.....: a = np.random.randint(0, 300, (100,100))
.....: np.minimum(a, 255, a)
.....:
100000 loops, best of 3: 303 µs per loop
In [329]: %%timeit
.....: a = np.random.randint(0, 300, (100,100))
.....: a[a>255] = 255
.....:
100000 loops, best of 3: 356 µs per loop
Dla porównania, jeśli chcesz ograniczyć swoje wartości z minimum, jak i maksimum, bez clip
konieczności robienia tego dwa razy, z czymś takim jak
np.minimum(a, 255, a)
np.maximum(a, 0, a)
lub,
a[a>255] = 255
a[a<0] = 0