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.