SciPy - podstawowa funkcjonalność
Domyślnie wszystkie funkcje NumPy są dostępne za pośrednictwem przestrzeni nazw SciPy. Nie ma potrzeby jawnego importowania funkcji NumPy podczas importowania SciPy. Głównym celem NumPy jest jednorodna wielowymiarowa tablica. Jest to tabela elementów (zwykle liczb) tego samego typu, indeksowanych przez krotkę dodatnich liczb całkowitych. W NumPy wymiary nazywane są osiami. Liczbaaxes nazywa się jako rank.
Teraz przejrzyjmy podstawową funkcjonalność wektorów i macierzy w NumPy. Ponieważ SciPy jest zbudowany na podstawie tablic NumPy, zrozumienie podstaw NumPy jest konieczne. Ponieważ większość części algebry liniowej zajmuje się tylko macierzami.
NumPy wektor
Wektor można utworzyć na wiele sposobów. Niektóre z nich opisano poniżej.
Konwersja obiektów typu tablicowego Pythona na NumPy
Rozważmy następujący przykład.
import numpy as np
list = [1,2,3,4]
arr = np.array(list)
print arr
Wynik powyższego programu będzie następujący.
[1 2 3 4]
Tworzenie wewnętrznej tablicy NumPy
NumPy ma wbudowane funkcje do tworzenia tablic od podstaw. Niektóre z tych funkcji opisano poniżej.
Korzystanie z zer ()
Funkcja zer (kształt) utworzy tablicę wypełnioną wartościami 0 o określonym kształcie. Domyślny typ dtype to float64. Rozważmy następujący przykład.
import numpy as np
print np.zeros((2, 3))
Wynik powyższego programu będzie następujący.
array([[ 0., 0., 0.],
[ 0., 0., 0.]])
Korzystanie z jedynek ()
Funkcja jedynki (kształt) utworzy tablicę wypełnioną 1 wartościami. Pod wszystkimi innymi względami jest identyczny z zerami. Rozważmy następujący przykład.
import numpy as np
print np.ones((2, 3))
Wynik powyższego programu będzie następujący.
array([[ 1., 1., 1.],
[ 1., 1., 1.]])
Używanie arange ()
Funkcja arange () utworzy tablice z regularnie rosnącymi wartościami. Rozważmy następujący przykład.
import numpy as np
print np.arange(7)
Powyższy program wygeneruje następujące dane wyjściowe.
array([0, 1, 2, 3, 4, 5, 6])
Definiowanie typu danych wartości
Rozważmy następujący przykład.
import numpy as np
arr = np.arange(2, 10, dtype = np.float)
print arr
print "Array Data Type :",arr.dtype
Powyższy program wygeneruje następujące dane wyjściowe.
[ 2. 3. 4. 5. 6. 7. 8. 9.]
Array Data Type : float64
Korzystanie z linspace ()
Funkcja linspace () utworzy tablice z określoną liczbą elementów, które zostaną równo rozmieszczone między określonymi wartościami początkowymi i końcowymi. Rozważmy następujący przykład.
import numpy as np
print np.linspace(1., 4., 6)
Powyższy program wygeneruje następujące dane wyjściowe.
array([ 1. , 1.6, 2.2, 2.8, 3.4, 4. ])
Matryca
Macierz to wyspecjalizowana tablica dwuwymiarowa, która zachowuje swój dwuwymiarowy charakter poprzez operacje. Ma pewne specjalne operatory, takie jak * (mnożenie macierzy) i ** (moc macierzy). Rozważmy następujący przykład.
import numpy as np
print np.matrix('1 2; 3 4')
Powyższy program wygeneruje następujące dane wyjściowe.
matrix([[1, 2],
[3, 4]])
Koniugat transpozycji macierzy
Ta funkcja zwraca (złożoną) transpozycję koniugatu self. Rozważmy następujący przykład.
import numpy as np
mat = np.matrix('1 2; 3 4')
print mat.H
Powyższy program wygeneruje następujące dane wyjściowe.
matrix([[1, 3],
[2, 4]])
Transpozycja macierzy
Ta funkcja zwraca transpozycję siebie. Rozważmy następujący przykład.
import numpy as np
mat = np.matrix('1 2; 3 4')
mat.T
Powyższy program wygeneruje następujące dane wyjściowe.
matrix([[1, 3],
[2, 4]])
Kiedy transponujemy macierz, tworzymy nową macierz, której wiersze są kolumnami oryginału. Z drugiej strony transpozycja sprzężona zamienia wiersz i indeks kolumny dla każdego elementu macierzy. Odwrotnością macierzy jest macierz, która po pomnożeniu przez macierz oryginalną daje w wyniku macierz tożsamości.