Chcę wyciąć tablicę NumPy nxn. Chcę wyodrębnić plik dowolny wybór m wierszy i kolumn tej tablicy (tj. Bez żadnego wzorca w liczbie wierszy / kolumn), tworząc nową tablicę mxm. W tym przykładzie powiedzmy, że tablica to 4x4 i chcę wyodrębnić z niej tablicę 2x2.
Oto nasza tablica:
from numpy import *
x = range(16)
x = reshape(x,(4,4))
print x
[[ 0 1 2 3]
[ 4 5 6 7]
[ 8 9 10 11]
[12 13 14 15]]
Linia i kolumny do usunięcia są takie same. Najłatwiej jest wtedy, gdy chcę wyodrębnić podmacierz 2x2, która jest na początku lub na końcu, czyli:
In [33]: x[0:2,0:2]
Out[33]:
array([[0, 1],
[4, 5]])
In [34]: x[2:,2:]
Out[34]:
array([[10, 11],
[14, 15]])
Ale co, jeśli muszę usunąć inną kombinację wierszy / kolumn? Co się stanie, jeśli muszę usunąć pierwszą i trzecią linię / wiersz, wyodrębniając w ten sposób podmacierz [[5,7],[13,15]]
? Może istnieć dowolna kompozycja wierszy / linii. Czytałem gdzieś, że muszę po prostu zindeksować moją tablicę za pomocą tablic / list indeksów zarówno dla wierszy, jak i kolumn, ale to nie działa:
In [35]: x[[1,3],[1,3]]
Out[35]: array([ 5, 15])
Znalazłem jeden sposób, czyli:
In [61]: x[[1,3]][:,[1,3]]
Out[61]:
array([[ 5, 7],
[13, 15]])
Po pierwsze, jest to trudne do odczytania, chociaż mogę z tym żyć. Jeśli ktoś ma lepsze rozwiązanie, z pewnością bym to usłyszał.
Inną rzeczą, którą przeczytałem na forum, jest to, że indeksowanie tablic za pomocą tablic zmusza NumPy do wykonania kopii żądanej tablicy, więc podczas traktowania z dużymi tablicami może to stać się problemem. Dlaczego tak jest / jak działa ten mechanizm?