Найкращим способом у вашому конкретному випадку буде просто змінити два ваші критерії на один критерій:
dists[abs(dists - r - dr/2.) <= dr/2.]
Він створює лише один булевий масив, і на мою думку, це легше читати, оскільки він каже, що знаходиться dist
в межах dr
або r
? (Хоча я б переосмислив, r
щоб бути центром вашої області інтересів замість початку, але r = r + dr/2.
) Але це не відповідає на ваше запитання.
Відповідь на ваше запитання:
насправді вам не потрібно, where
якщо ви просто намагаєтесь відфільтрувати елементи dists
, які не відповідають вашим критеріям:
dists[(dists >= r) & (dists <= r+dr)]
Тому що &
воля дасть вам елементарно and
(круглі дужки необхідні).
Або, якщо ви хочете використовувати where
з якоїсь причини, ви можете зробити:
dists[(np.where((dists >= r) & (dists <= r + dr)))]
Чому:
Причина не працює в тому, що np.where
повертає список індексів, а не булевий масив. Ви намагаєтеся пройти and
між двома списками чисел, які, звичайно, не мають True
/ False
значення, які ви очікуєте. Якщо a
і 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]),)
Наприклад, те, що ви очікували порівняти, було просто булевим масивом
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)
Тепер ви можете зателефонувати np.where
за комбінованим булевим масивом:
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. ])
Або просто індексувати початковий масив булевим масивом, використовуючи фантазійну індексацію
In [241]: dists[(dists >= r) & (dists <= r + dr)]
Out[241]: array([ 5. , 5.5, 6. ])
()
навколо(ar>3)
і(ar>6)
?