Лучшим способом в вашем конкретном случае было бы просто изменить два ваших критерия на один критерий:
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)
?Мне нравится использовать
np.vectorize
для таких задач. Учтите следующее:Вы также можете использовать
np.argwhere
вместоnp.where
для четкого вывода. Но это ваш звонок :)Надеюсь, поможет.
источник
Пытаться:
источник
Это должно работать:
Самый элегантный способ ~~
источник
Пытаться:
Выход: (массив ([2, 3]),)
Подробнее см. В разделе « Логические функции» .
источник
Я разработал этот простой пример
источник