A melhor maneira no seu caso específico seria apenas alterar seus dois critérios para um critério:
dists[abs(dists - r - dr/2.) <= dr/2.]
Ele cria apenas uma matriz booleana e, na minha opinião, é mais fácil de ler porque diz: está dist
dentro de um dr
ou r
? (Embora eu redefinisse r
para ser o centro da sua região de interesse e não o começo, então r = r + dr/2.
) Mas isso não responde à sua pergunta.
A resposta para sua pergunta:
você realmente não precisa where
se estiver apenas tentando filtrar os elementos dists
que não atendem aos seus critérios:
dists[(dists >= r) & (dists <= r+dr)]
Porque o &
mostrará um elemento and
(os parênteses são necessários).
Ou, se você deseja usar where
por algum motivo, pode:
dists[(np.where((dists >= r) & (dists <= r + dr)))]
Motivo:
o motivo pelo qual não funciona é porque np.where
retorna uma lista de índices, não uma matriz booleana. Você está tentando obter and
entre duas listas de números, que obviamente não têm os valores True
/ False
esperados. Se a
e b
são os dois True
valores, então a and b
retorna b
. Então, dizer algo como [0,1,2] and [2,3,4]
apenas lhe dará [2,3,4]
. Aqui está em ação:
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]),)
O que você esperava comparar era simplesmente a matriz booleana, por exemplo
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)
Agora você pode chamar np.where
a matriz booleana combinada:
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. ])
Ou simplesmente indexe a matriz original com a matriz booleana usando indexação sofisticada
In [241]: dists[(dists >= r) & (dists <= r + dr)]
Out[241]: array([ 5. , 5.5, 6. ])
()
volta(ar>3)
e(ar>6)
?Eu gosto de usar
np.vectorize
para essas tarefas. Considere o seguinte:Você também pode usar em
np.argwhere
vez denp.where
obter uma saída clara. Mas essa é a sua decisão :)Espero que ajude.
fonte
Experimentar:
fonte
Isso deve funcionar:
A maneira mais elegante ~~
fonte
Experimentar:
Saída: (matriz ([2, 3]))
Você pode ver as funções lógicas para mais detalhes.
fonte
Eu elaborei este exemplo simples
fonte