आपके विशेष मामले में सबसे अच्छा तरीका यह होगा कि आप अपने दो मानदंडों को एक मानदंड में बदल दें:
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)
?