NumPy - zaawansowane indeksowanie

Możliwe jest dokonanie wyboru z ndarray, który jest sekwencją inną niż krotka, obiekt ndarray o typie danych typu integer lub Boolean lub krotka z co najmniej jednym elementem będącym obiektem sekwencji. Zaawansowane indeksowanie zawsze zwraca kopię danych. W związku z tym cięcie przedstawia tylko widok.

Istnieją dwa rodzaje zaawansowanego indeksowania - Integer i Boolean.

Indeksowanie liczb całkowitych

Mechanizm ten pomaga w wyborze dowolnego elementu w tablicy na podstawie jego indeksu N-wymiarowego. Każda tablica liczb całkowitych reprezentuje liczbę indeksów w tym wymiarze. Gdy indeks składa się z tylu tablic całkowitych, ile wynosi wymiary docelowej tablicy ndarray, staje się to proste.

W poniższym przykładzie wybrano jeden element określonej kolumny z każdego wiersza obiektu ndarray. W związku z tym indeks wierszy zawiera wszystkie numery wierszy, a indeks kolumny określa element, który ma zostać wybrany.

Przykład 1

import numpy as np 

x = np.array([[1, 2], [3, 4], [5, 6]]) 
y = x[[0,1,2], [0,1,0]] 
print y

Jego wynik byłby następujący -

[1  4  5]

Wybór obejmuje elementy w (0,0), (1,1) i (2,0) z pierwszej tablicy.

W poniższym przykładzie zaznaczono elementy umieszczone w rogach tablicy 4X3. Wskaźniki wierszy to [0, 0] i [3,3], podczas gdy indeksy kolumn to [0,2] i [0,2].

Przykład 2

import numpy as np 
x = np.array([[ 0,  1,  2],[ 3,  4,  5],[ 6,  7,  8],[ 9, 10, 11]]) 
   
print 'Our array is:' 
print x 
print '\n' 

rows = np.array([[0,0],[3,3]])
cols = np.array([[0,2],[0,2]]) 
y = x[rows,cols] 
   
print 'The corner elements of this array are:' 
print y

Wynik tego programu jest następujący -

Our array is:                                                                 
[[ 0  1  2]                                                                   
 [ 3  4  5]                                                                   
 [ 6  7  8]                                                                   
 [ 9 10 11]]
 
The corner elements of this array are:                                        
[[ 0  2]                                                                      
 [ 9 11]]

Wynikowe zaznaczenie to obiekt ndarray zawierający elementy narożne.

Indeksowanie zaawansowane i podstawowe można łączyć za pomocą jednego wycinka (:) lub wielokropka (…) z tablicą indeksów. W poniższym przykładzie zastosowano wycinek dla wiersza i zaawansowany indeks dla kolumny. Rezultat jest taki sam, gdy plasterek jest używany do obu. Ale zaawansowany indeks powoduje kopiowanie i może mieć inny układ pamięci.

Przykład 3

import numpy as np 
x = np.array([[ 0,  1,  2],[ 3,  4,  5],[ 6,  7,  8],[ 9, 10, 11]]) 

print 'Our array is:' 
print x 
print '\n'  

# slicing 
z = x[1:4,1:3] 

print 'After slicing, our array becomes:' 
print z 
print '\n'  

# using advanced index for column 
y = x[1:4,[1,2]] 

print 'Slicing using advanced index for column:' 
print y

Wynik tego programu byłby następujący -

Our array is:
[[ 0  1  2] 
 [ 3  4  5] 
 [ 6  7  8]
 [ 9 10 11]]
 
After slicing, our array becomes:
[[ 4  5]
 [ 7  8]
 [10 11]]

Slicing using advanced index for column:
[[ 4  5]
 [ 7  8]
 [10 11]]

Indeksowanie tablic logicznych

Ten typ zaawansowanego indeksowania jest używany, gdy wynikowy obiekt ma być wynikiem operacji logicznych, takich jak operatory porównania.

Przykład 1

W tym przykładzie elementy większe niż 5 są zwracane w wyniku indeksowania logicznego.

import numpy as np 
x = np.array([[ 0,  1,  2],[ 3,  4,  5],[ 6,  7,  8],[ 9, 10, 11]]) 

print 'Our array is:' 
print x 
print '\n'  

# Now we will print the items greater than 5 
print 'The items greater than 5 are:' 
print x[x > 5]

Wynik tego programu byłby:

Our array is: 
[[ 0  1  2] 
 [ 3  4  5] 
 [ 6  7  8] 
 [ 9 10 11]] 
 
The items greater than 5 are:
[ 6  7  8  9 10 11]

Przykład 2

W tym przykładzie elementy NaN (Not a Number) są pomijane przy użyciu ~ (operator dopełniacza).

import numpy as np 
a = np.array([np.nan, 1,2,np.nan,3,4,5]) 
print a[~np.isnan(a)]

Jego wyjście byłoby -

[ 1.   2.   3.   4.   5.]

Przykład 3

Poniższy przykład pokazuje, jak odfiltrować niezłożone elementy z tablicy.

import numpy as np 
a = np.array([1, 2+6j, 5, 3.5+5j]) 
print a[np.iscomplex(a)]

Tutaj wynik jest następujący -

[2.0+6.j  3.5+5.j]