Najlepszym sposobem w twoim konkretnym przypadku byłaby po prostu zmiana dwóch kryteriów na jedno kryterium:
dists[abs(dists - r - dr/2.) <= dr/2.]
Tworzy tylko jedną tablicę logiczną i moim zdaniem jest łatwiejszy do odczytania, ponieważ mówi, że znajduje się dist
w obrębie dr
lub r
? (Chociaż przedefiniowałbym to, r
aby być centrum twojego regionu zainteresowania zamiast na początku, więc r = r + dr/2.
) Ale to nie odpowiada na twoje pytanie.
Odpowiedź na twoje pytanie:
tak naprawdę nie potrzebujesz, where
jeśli próbujesz tylko odfiltrować elementy dists
, które nie pasują do twoich kryteriów:
dists[(dists >= r) & (dists <= r+dr)]
Ponieważ &
da ci elementarny and
(nawiasy są konieczne).
Lub, jeśli where
z jakiegoś powodu chcesz użyć , możesz zrobić:
dists[(np.where((dists >= r) & (dists <= r + dr)))]
Dlaczego:
Przyczyną tego nie jest to, że np.where
zwraca listę indeksów, a nie tablicę logiczną. Próbujesz dostać się and
między dwiema listami liczb, które oczywiście nie mają oczekiwanych wartości True
/ False
. Jeśli obie wartości są a
i , to zwraca . Więc powiedzenie czegoś takiego po prostu ci da . Oto akcja:b
True
a and b
b
[0,1,2] and [2,3,4]
[2,3,4]
In [230]: dists = np.arange(0,10,.5)
In [231]: r = 5
In [232]: dr = 1
In [233]: np.where(dists >= r)
Out[233]: (array([10, 11, 12, 13, 14, 15, 16, 17, 18, 19]),)
In [234]: np.where(dists <= r+dr)
Out[234]: (array([ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]),)
In [235]: np.where(dists >= r) and np.where(dists <= r+dr)
Out[235]: (array([ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12]),)
Na przykład to, co spodziewałeś się porównać, to po prostu tablica boolowska
In [236]: dists >= r
Out[236]:
array([False, False, False, False, False, False, False, False, False,
False, True, True, True, True, True, True, True, True,
True, True], dtype=bool)
In [237]: dists <= r + dr
Out[237]:
array([ True, True, True, True, True, True, True, True, True,
True, True, True, True, False, False, False, False, False,
False, False], dtype=bool)
In [238]: (dists >= r) & (dists <= r + dr)
Out[238]:
array([False, False, False, False, False, False, False, False, False,
False, True, True, True, False, False, False, False, False,
False, False], dtype=bool)
Teraz możesz wywołać np.where
połączoną tablicę boolowską:
In [239]: np.where((dists >= r) & (dists <= r + dr))
Out[239]: (array([10, 11, 12]),)
In [240]: dists[np.where((dists >= r) & (dists <= r + dr))]
Out[240]: array([ 5. , 5.5, 6. ])
Lub po prostu zindeksuj oryginalną tablicę tablicą logiczną, używając fantazyjnego indeksowania
In [241]: dists[(dists >= r) & (dists <= r + dr)]
Out[241]: array([ 5. , 5.5, 6. ])
np.logical_and
. Dzięki!