NumPy - szybki przewodnik
NumPy to pakiet Pythona. Skrót od „Numerical Python”. Jest to biblioteka składająca się z wielowymiarowych obiektów tablicowych i zbioru procedur do przetwarzania tablic.
Numeric, przodek NumPy, został opracowany przez Jima Hugunina. Powstał również inny pakiet Numarray, posiadający dodatkowe funkcjonalności. W 2005 roku Travis Oliphant stworzył pakiet NumPy, włączając funkcje Numarray do pakietu Numeric. Jest wielu współtwórców tego projektu open source.
Operacje przy użyciu NumPy
Korzystając z NumPy, programista może wykonać następujące operacje -
Operacje matematyczne i logiczne na tablicach.
Transformacje Fouriera i procedury manipulowania kształtami.
Działania związane z algebrą liniową. NumPy ma wbudowane funkcje do algebry liniowej i generowania liczb losowych.
NumPy - zamiennik dla MatLab
NumPy jest często używany wraz z pakietami takimi jak SciPy (Scientific Python) i Mat−plotlib(biblioteka wykresów). Ta kombinacja jest szeroko stosowana jako zamiennik MatLab, popularnej platformy do obliczeń technicznych. Jednak Python alternatywa dla MatLab jest teraz postrzegana jako bardziej nowoczesny i kompletny język programowania.
Jest open source, co jest dodatkową zaletą NumPy.
Standardowa dystrybucja Pythona nie jest dostarczana w pakiecie z modułem NumPy. Lekką alternatywą jest instalacja NumPy za pomocą popularnego instalatora pakietów Pythona,pip.
pip install numpy
Najlepszym sposobem na włączenie NumPy jest użycie instalowalnego pakietu binarnego odpowiedniego dla twojego systemu operacyjnego. Te pliki binarne zawierają pełny stos SciPy (w tym pakiety NumPy, SciPy, matplotlib, IPython, SymPy i nos wraz z podstawowym językiem Python).
Windows
Anaconda (z https://www.continuum.io) to darmowa dystrybucja Pythona dla stosu SciPy. Jest również dostępny dla systemów Linux i Mac.
Zadaszenie (https://www.enthought.com/products/canopy/) jest dostępny zarówno jako bezpłatna, jak i komercyjna dystrybucja z pełnym stosem SciPy dla systemów Windows, Linux i Mac.
Python (x, y): Jest to darmowa dystrybucja Pythona ze stosem SciPy i Spyder IDE dla systemu operacyjnego Windows. (Do pobrania zhttps://www.python-xy.github.io/)
Linux
Menedżery pakietów odpowiednich dystrybucji Linuksa są używane do instalowania jednego lub więcej pakietów na stosie SciPy.
W przypadku Ubuntu
sudo apt-get install python-numpy
python-scipy python-matplotlibipythonipythonnotebook python-pandas
python-sympy python-nose
W przypadku Fedory
sudo yum install numpyscipy python-matplotlibipython
python-pandas sympy python-nose atlas-devel
Budynek ze źródła
Core Python (od wersji 2.6.x, 2.7.x i 3.2.x) musi być zainstalowany z distutils, a moduł zlib powinien być włączony.
Musi być dostępny kompilator GNU gcc (4.2 i nowsze) C.
Aby zainstalować NumPy, uruchom następujące polecenie.
Python setup.py install
Aby sprawdzić, czy moduł NumPy jest poprawnie zainstalowany, spróbuj zaimportować go z podpowiedzi Pythona.
import numpy
Jeśli nie jest zainstalowany, zostanie wyświetlony następujący komunikat o błędzie.
Traceback (most recent call last):
File "<pyshell#0>", line 1, in <module>
import numpy
ImportError: No module named 'numpy'
Alternatywnie pakiet NumPy jest importowany przy użyciu następującej składni -
import numpy as np
Najważniejszym obiektem zdefiniowanym w NumPy jest N-wymiarowa tablica o nazwie ndarray. Opisuje zbiór przedmiotów tego samego typu. Dostęp do elementów w kolekcji można uzyskać przy użyciu indeksu liczonego od zera.
Każda pozycja w tablicy ndarray zajmuje ten sam rozmiar bloku w pamięci. Każdy element w ndarray jest obiektem typu danych (tzwdtype).
Każdy element wyodrębniony z obiektu ndarray (przez cięcie) jest reprezentowany przez obiekt Pythona jednego z tablicowych typów skalarnych. Poniższy diagram przedstawia relację między ndarray, obiektem typu danych (dtype) i typem skalarnym tablicy -
Instancja klasy ndarray może zostać skonstruowana przy użyciu różnych procedur tworzenia tablic opisanych w dalszej części kursu. Podstawowy ndarray jest tworzony za pomocą funkcji tablicowej w NumPy w następujący sposób -
numpy.array
Tworzy ndarray z dowolnego obiektu ujawniającego interfejs tablicy lub z dowolnej metody, która zwraca tablicę.
numpy.array(object, dtype = None, copy = True, order = None, subok = False, ndmin = 0)
Powyższy konstruktor przyjmuje następujące parametry -
Sr.No. | Parametr i opis |
---|---|
1 | object Każdy obiekt udostępniający metodę interfejsu tablicy zwraca tablicę lub dowolną (zagnieżdżoną) sekwencję. |
2 | dtype Żądany typ danych tablicy, opcjonalny |
3 | copy Opcjonalny. Domyślnie (prawda) obiekt jest kopiowany |
4 | order C (główny wiersz) lub F (główny kolumna) lub A (dowolny) (domyślnie) |
5 | subok Domyślnie zwracana tablica wymuszona jest tablicą klasy bazowej. Jeśli tak, przechodzą przez podklasy |
6 | ndmin Określa minimalne wymiary wynikowej tablicy |
Spójrz na poniższe przykłady, aby lepiej zrozumieć.
Przykład 1
import numpy as np
a = np.array([1,2,3])
print a
Dane wyjściowe są następujące -
[1, 2, 3]
Przykład 2
# more than one dimensions
import numpy as np
a = np.array([[1, 2], [3, 4]])
print a
Dane wyjściowe są następujące -
[[1, 2]
[3, 4]]
Przykład 3
# minimum dimensions
import numpy as np
a = np.array([1, 2, 3,4,5], ndmin = 2)
print a
Dane wyjściowe są następujące -
[[1, 2, 3, 4, 5]]
Przykład 4
# dtype parameter
import numpy as np
a = np.array([1, 2, 3], dtype = complex)
print a
Dane wyjściowe są następujące -
[ 1.+0.j, 2.+0.j, 3.+0.j]
Plik ndarrayobiekt składa się z ciągłego jednowymiarowego segmentu pamięci komputera, połączonego ze schematem indeksowania, który odwzorowuje każdy element na lokalizację w bloku pamięci. Blok pamięci przechowuje elementy w kolejności wiersz-główny (styl C) lub kolumna-główny porządek (styl FORTRAN lub MatLab).
NumPy obsługuje znacznie większą różnorodność typów liczbowych niż Python. W poniższej tabeli przedstawiono różne skalarne typy danych zdefiniowane w NumPy.
Sr.No. | Typy danych i opis |
---|---|
1 | bool_ Wartość logiczna (prawda lub fałsz) przechowywana jako bajt |
2 | int_ Domyślny typ liczby całkowitej (taki sam jak C long; zwykle int64 lub int32) |
3 | intc Identyczne z C int (zwykle int32 lub int64) |
4 | intp Liczba całkowita używana do indeksowania (taka sama jak C ssize_t; zwykle int32 lub int64) |
5 | int8 Bajty (od -128 do 127) |
6 | int16 Liczba całkowita (od -32768 do 32767) |
7 | int32 Liczba całkowita (od -2147483648 do 2147483647) |
8 | int64 Liczba całkowita (od -9223372036854775808 do 9223372036854775807) |
9 | uint8 Liczba całkowita bez znaku (od 0 do 255) |
10 | uint16 Liczba całkowita bez znaku (od 0 do 65535) |
11 | uint32 Liczba całkowita bez znaku (od 0 do 4294967295) |
12 | uint64 Liczba całkowita bez znaku (od 0 do 18446744073709551615) |
13 | float_ Skrót dla float64 |
14 | float16 Pół-precyzyjny float: bit znaku, wykładnik 5-bitowy, mantysa 10-bitowa |
15 | float32 Liczba zmiennoprzecinkowa pojedynczej precyzji: bit znaku, wykładnik 8-bitowy, mantysa 23-bitowa |
16 | float64 Pływak podwójnej precyzji: bit znaku, 11-bitowy wykładnik, 52-bitowa mantysa |
17 | complex_ Skrót dla kompleksu 128 |
18 | complex64 Liczba zespolona reprezentowana przez dwie 32-bitowe liczby zmiennoprzecinkowe (składniki rzeczywiste i urojone) |
19 | complex128 Liczba zespolona reprezentowana przez dwa 64-bitowe liczby zmiennoprzecinkowe (składniki rzeczywiste i urojone) |
Typy liczbowe NumPy to instancje obiektów dtype (typ danych), z których każdy ma unikalne cechy. Typy są dostępne jako np.bool_, np.float32 itp.
Obiekty typu danych (dtype)
Obiekt typu danych opisuje interpretację stałego bloku pamięci odpowiadającego tablicy, w zależności od następujących aspektów -
Typ danych (liczba całkowita, zmiennoprzecinkowa lub obiekt Python)
Rozmiar danych
Kolejność bajtów (little-endian lub big-endian)
W przypadku typu strukturalnego, nazwy pól, typ danych każdego pola i część bloku pamięci zajmowana przez każde pole.
Jeśli typ danych to podtablica, jej kształt i typ danych
O kolejności bajtów decyduje przedrostek „<” lub „>” do typu danych. „<” oznacza, że kodowanie jest little-endian (najmniej znaczące jest przechowywane w najmniejszym adresie). „>” oznacza, że kodowanie jest typu big-endian (najbardziej znaczący bajt jest przechowywany w najmniejszym adresie).
Obiekt dtype jest konstruowany przy użyciu następującej składni -
numpy.dtype(object, align, copy)
Parametry to -
Object - Do konwersji na obiekt typu danych
Align - Jeśli prawda, dodaje wypełnienie do pola, aby uczynić je podobnym do struktury C
Copy- Tworzy nową kopię obiektu dtype. Jeśli false, wynik jest odniesieniem do wbudowanego obiektu typu danych
Przykład 1
# using array-scalar type
import numpy as np
dt = np.dtype(np.int32)
print dt
Dane wyjściowe są następujące -
int32
Przykład 2
#int8, int16, int32, int64 can be replaced by equivalent string 'i1', 'i2','i4', etc.
import numpy as np
dt = np.dtype('i4')
print dt
Dane wyjściowe są następujące -
int32
Przykład 3
# using endian notation
import numpy as np
dt = np.dtype('>i4')
print dt
Dane wyjściowe są następujące -
>i4
Poniższe przykłady pokazują użycie typu danych strukturalnych. W tym miejscu należy zadeklarować nazwę pola i odpowiedni skalarny typ danych.
Przykład 4
# first create structured data type
import numpy as np
dt = np.dtype([('age',np.int8)])
print dt
Dane wyjściowe są następujące -
[('age', 'i1')]
Przykład 5
# now apply it to ndarray object
import numpy as np
dt = np.dtype([('age',np.int8)])
a = np.array([(10,),(20,),(30,)], dtype = dt)
print a
Dane wyjściowe są następujące -
[(10,) (20,) (30,)]
Przykład 6
# file name can be used to access content of age column
import numpy as np
dt = np.dtype([('age',np.int8)])
a = np.array([(10,),(20,),(30,)], dtype = dt)
print a['age']
Dane wyjściowe są następujące -
[10 20 30]
Przykład 7
W poniższych przykładach zdefiniowano uporządkowany typ danych o nazwie student z polem tekstowym „name”, an integer field „wiek” i a float field'znaki'. Ten typ dtype jest stosowany do obiektu ndarray.
import numpy as np
student = np.dtype([('name','S20'), ('age', 'i1'), ('marks', 'f4')])
print student
Dane wyjściowe są następujące -
[('name', 'S20'), ('age', 'i1'), ('marks', '<f4')])
Przykład 8
import numpy as np
student = np.dtype([('name','S20'), ('age', 'i1'), ('marks', 'f4')])
a = np.array([('abc', 21, 50),('xyz', 18, 75)], dtype = student)
print a
Dane wyjściowe są następujące -
[('abc', 21, 50.0), ('xyz', 18, 75.0)]
Każdy wbudowany typ danych ma kod znaku, który go jednoznacznie identyfikuje.
'b' - boolean
'i' - (ze znakiem) liczba całkowita
'u' - liczba całkowita bez znaku
'f' - zmiennoprzecinkowe
'c' - złożone zmiennoprzecinkowe
'm' - timedelta
'M' - data i godzina
'O' - obiekty (Python)
'S', 'a' - (bajt-) ciąg
'U' - Unicode
'V' - surowe dane (nieważne)
W tym rozdziale omówimy różne atrybuty tablicowe NumPy.
ndarray.shape
Ten atrybut tablicy zwraca krotkę składającą się z wymiarów tablicy. Można go również użyć do zmiany rozmiaru tablicy.
Przykład 1
import numpy as np
a = np.array([[1,2,3],[4,5,6]])
print a.shape
Dane wyjściowe są następujące -
(2, 3)
Przykład 2
# this resizes the ndarray
import numpy as np
a = np.array([[1,2,3],[4,5,6]])
a.shape = (3,2)
print a
Dane wyjściowe są następujące -
[[1, 2]
[3, 4]
[5, 6]]
Przykład 3
NumPy zapewnia również funkcję zmiany kształtu do zmiany rozmiaru tablicy.
import numpy as np
a = np.array([[1,2,3],[4,5,6]])
b = a.reshape(3,2)
print b
Dane wyjściowe są następujące -
[[1, 2]
[3, 4]
[5, 6]]
ndarray.ndim
Ten atrybut tablicy zwraca liczbę wymiarów tablicy.
Przykład 1
# an array of evenly spaced numbers
import numpy as np
a = np.arange(24)
print a
Dane wyjściowe są następujące -
[0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23]
Przykład 2
# this is one dimensional array
import numpy as np
a = np.arange(24)
a.ndim
# now reshape it
b = a.reshape(2,4,3)
print b
# b is having three dimensions
Dane wyjściowe są następujące -
[[[ 0, 1, 2]
[ 3, 4, 5]
[ 6, 7, 8]
[ 9, 10, 11]]
[[12, 13, 14]
[15, 16, 17]
[18, 19, 20]
[21, 22, 23]]]
numpy.itemsize
Ten atrybut tablicy zwraca długość każdego elementu tablicy w bajtach.
Przykład 1
# dtype of array is int8 (1 byte)
import numpy as np
x = np.array([1,2,3,4,5], dtype = np.int8)
print x.itemsize
Dane wyjściowe są następujące -
1
Przykład 2
# dtype of array is now float32 (4 bytes)
import numpy as np
x = np.array([1,2,3,4,5], dtype = np.float32)
print x.itemsize
Dane wyjściowe są następujące -
4
numpy.flags
Obiekt ndarray ma następujące atrybuty. Ta funkcja zwraca jego bieżące wartości.
Sr.No. | Atrybut i opis |
---|---|
1 | C_CONTIGUOUS (C) Dane są w jednym, ciągłym segmencie w stylu C. |
2 | F_CONTIGUOUS (F) Dane są w jednym, ciągłym segmencie w stylu Fortran |
3 | OWNDATA (O) Tablica posiada pamięć, której używa lub pożycza ją z innego obiektu |
4 | WRITEABLE (W) Obszar danych może być zapisywany. Ustawienie tego na False blokuje dane, czyniąc je tylko do odczytu |
5 | ALIGNED (A) Dane i wszystkie elementy są odpowiednio dopasowane do sprzętu |
6 | UPDATEIFCOPY (U) Ta tablica jest kopią innej tablicy. Kiedy ta tablica zostanie zwolniona, podstawowa tablica zostanie zaktualizowana o zawartość tej tablicy |
Przykład
Poniższy przykład przedstawia bieżące wartości flag.
import numpy as np
x = np.array([1,2,3,4,5])
print x.flags
Dane wyjściowe są następujące -
C_CONTIGUOUS : True
F_CONTIGUOUS : True
OWNDATA : True
WRITEABLE : True
ALIGNED : True
UPDATEIFCOPY : False
Nowy ndarray obiekt można skonstruować za pomocą dowolnej z poniższych procedur tworzenia tablicy lub przy użyciu konstruktora niskiego poziomu ndarray.
numpy.empty
Tworzy niezainicjowaną tablicę o określonym kształcie i typie. Używa następującego konstruktora -
numpy.empty(shape, dtype = float, order = 'C')
Konstruktor przyjmuje następujące parametry.
Sr.No. | Parametr i opis |
---|---|
1 | Shape Kształt pustej tablicy w int lub krotce int |
2 | Dtype Żądany typ danych wyjściowych. Opcjonalny |
3 | Order „C” dla głównej tablicy wierszowej w stylu C, „F” dla głównej tablicy kolumnowej w stylu FORTRAN |
Przykład
Poniższy kod przedstawia przykład pustej tablicy.
import numpy as np
x = np.empty([3,2], dtype = int)
print x
Dane wyjściowe są następujące -
[[22649312 1701344351]
[1818321759 1885959276]
[16779776 156368896]]
Note - Elementy tablicy pokazują wartości losowe, ponieważ nie zostały zainicjowane.
numpy.zeros
Zwraca nową tablicę o określonym rozmiarze, wypełnioną zerami.
numpy.zeros(shape, dtype = float, order = 'C')
Konstruktor przyjmuje następujące parametry.
Sr.No. | Parametr i opis |
---|---|
1 | Shape Kształt pustej tablicy w int lub sekwencji int |
2 | Dtype Żądany typ danych wyjściowych. Opcjonalny |
3 | Order „C” dla głównej tablicy wierszowej w stylu C, „F” dla głównej tablicy kolumnowej w stylu FORTRAN |
Przykład 1
# array of five zeros. Default dtype is float
import numpy as np
x = np.zeros(5)
print x
Dane wyjściowe są następujące -
[ 0. 0. 0. 0. 0.]
Przykład 2
import numpy as np
x = np.zeros((5,), dtype = np.int)
print x
Teraz wynik byłby następujący -
[0 0 0 0 0]
Przykład 3
# custom type
import numpy as np
x = np.zeros((2,2), dtype = [('x', 'i4'), ('y', 'i4')])
print x
Powinien dać następujący wynik -
[[(0,0)(0,0)]
[(0,0)(0,0)]]
numpy.ones
Zwraca nową tablicę o określonym rozmiarze i typie, wypełnioną jedynkami.
numpy.ones(shape, dtype = None, order = 'C')
Konstruktor przyjmuje następujące parametry.
Sr.No. | Parametr i opis |
---|---|
1 | Shape Kształt pustej tablicy w int lub krotce int |
2 | Dtype Żądany typ danych wyjściowych. Opcjonalny |
3 | Order „C” dla głównej tablicy wierszowej w stylu C, „F” dla głównej tablicy kolumnowej w stylu FORTRAN |
Przykład 1
# array of five ones. Default dtype is float
import numpy as np
x = np.ones(5)
print x
Dane wyjściowe są następujące -
[ 1. 1. 1. 1. 1.]
Przykład 2
import numpy as np
x = np.ones([2,2], dtype = int)
print x
Teraz wynik byłby następujący -
[[1 1]
[1 1]]
W tym rozdziale omówimy, jak utworzyć tablicę z istniejących danych.
numpy.asarray
Ta funkcja jest podobna do numpy.array z tym wyjątkiem, że ma mniej parametrów. Ta procedura jest przydatna do konwersji sekwencji Pythona na ndarray.
numpy.asarray(a, dtype = None, order = None)
Konstruktor przyjmuje następujące parametry.
Sr.No. | Parametr i opis |
---|---|
1 | a Dane wejściowe w dowolnej formie, takiej jak lista, lista krotek, krotka, krotka krotek lub krotka list |
2 | dtype Domyślnie typ danych wejściowych jest stosowany do wynikowej tablicy ndarray |
3 | order C (główny wiersz) lub F (główny kolumna). C jest wartością domyślną |
Poniższe przykłady pokazują, jak możesz używać asarray funkcjonować.
Przykład 1
# convert list to ndarray
import numpy as np
x = [1,2,3]
a = np.asarray(x)
print a
Jego wynik byłby następujący -
[1 2 3]
Przykład 2
# dtype is set
import numpy as np
x = [1,2,3]
a = np.asarray(x, dtype = float)
print a
Teraz wynik byłby następujący -
[ 1. 2. 3.]
Przykład 3
# ndarray from tuple
import numpy as np
x = (1,2,3)
a = np.asarray(x)
print a
Jego wyjście byłoby -
[1 2 3]
Przykład 4
# ndarray from list of tuples
import numpy as np
x = [(1,2,3),(4,5)]
a = np.asarray(x)
print a
Tutaj wynik wyglądałby następująco -
[(1, 2, 3) (4, 5)]
numpy.frombuffer
Ta funkcja interpretuje bufor jako jednowymiarową tablicę. Każdy obiekt, który uwidacznia interfejs bufora, jest używany jako parametr do zwracania plikundarray.
numpy.frombuffer(buffer, dtype = float, count = -1, offset = 0)
Konstruktor przyjmuje następujące parametry.
Sr.No. | Parametr i opis |
---|---|
1 | buffer Dowolny obiekt, który uwidacznia interfejs bufora |
2 | dtype Typ danych zwrócony ndarray. Domyślnie pływające |
3 | count Liczba elementów do odczytania, domyślnie -1 oznacza wszystkie dane |
4 | offset Pozycja początkowa do czytania. Wartość domyślna to 0 |
Przykład
Poniższe przykłady ilustrują użycie frombuffer funkcjonować.
import numpy as np
s = 'Hello World'
a = np.frombuffer(s, dtype = 'S1')
print a
Oto jego wynik -
['H' 'e' 'l' 'l' 'o' ' ' 'W' 'o' 'r' 'l' 'd']
numpy.fromiter
Ta funkcja buduje plik ndarrayobiekt z dowolnego iterowalnego obiektu. Ta funkcja zwraca nową jednowymiarową tablicę.
numpy.fromiter(iterable, dtype, count = -1)
Tutaj konstruktor przyjmuje następujące parametry.
Sr.No. | Parametr i opis |
---|---|
1 | iterable Dowolny iterowalny obiekt |
2 | dtype Typ danych wynikowej tablicy |
3 | count Liczba elementów do odczytania z iteratora. Wartość domyślna to -1, co oznacza wszystkie dane do odczytania |
Poniższe przykłady pokazują, jak używać wbudowanego range()funkcja, aby zwrócić obiekt listy. Iterator tej listy służy do tworzenia plikundarray obiekt.
Przykład 1
# create list object using range function
import numpy as np
list = range(5)
print list
Jego wynik jest następujący -
[0, 1, 2, 3, 4]
Przykład 2
# obtain iterator object from list
import numpy as np
list = range(5)
it = iter(list)
# use iterator to create ndarray
x = np.fromiter(it, dtype = float)
print x
Teraz wynik byłby następujący -
[0. 1. 2. 3. 4.]
W tym rozdziale zobaczymy, jak utworzyć tablicę z zakresów liczbowych.
numpy.arange
Ta funkcja zwraca plik ndarrayobiekt zawierający równomiernie rozmieszczone wartości w podanym zakresie. Format funkcji jest następujący -
numpy.arange(start, stop, step, dtype)
Konstruktor przyjmuje następujące parametry.
Sr.No. | Parametr i opis |
---|---|
1 | start Początek interwału. Jeśli pominięty, wartość domyślna to 0 |
2 | stop Koniec interwału (bez tego numeru) |
3 | step Odstępy między wartościami, domyślnie 1 |
4 | dtype Typ danych wynikowego ndarray. Jeśli nie jest podany, używany jest typ danych wejściowych |
Poniższe przykłady pokazują, jak możesz użyć tej funkcji.
Przykład 1
import numpy as np
x = np.arange(5)
print x
Jego wynik byłby następujący -
[0 1 2 3 4]
Przykład 2
import numpy as np
# dtype set
x = np.arange(5, dtype = float)
print x
Tutaj wynik wyniósłby -
[0. 1. 2. 3. 4.]
Przykład 3
# start and stop parameters set
import numpy as np
x = np.arange(10,20,2)
print x
Jego wynik jest następujący -
[10 12 14 16 18]
numpy.linspace
Ta funkcja jest podobna do arange()funkcjonować. W tej funkcji zamiast wielkości kroku określa się liczbę równomiernie rozmieszczonych wartości między interwałem. Korzystanie z tej funkcji jest następujące -
numpy.linspace(start, stop, num, endpoint, retstep, dtype)
Konstruktor przyjmuje następujące parametry.
Sr.No. | Parametr i opis |
---|---|
1 | start Wartość początkowa sekwencji |
2 | stop Wartość końcowa sekwencji zawarta w sekwencji, jeśli punkt końcowy ma wartość true |
3 | num Liczba równomiernie rozmieszczonych próbek do wygenerowania. Wartość domyślna to 50 |
4 | endpoint Domyślnie prawda, dlatego wartość zatrzymania jest uwzględniona w sekwencji. Jeśli fałsz, nie jest uwzględniany |
5 | retstep Jeśli prawda, zwraca próbki i przechodzi między kolejnymi liczbami |
6 | dtype Typ danych wyjściowych ndarray |
Poniższe przykłady demonstrują użycie linspace funkcjonować.
Przykład 1
import numpy as np
x = np.linspace(10,20,5)
print x
Jego wyjście byłoby -
[10. 12.5 15. 17.5 20.]
Przykład 2
# endpoint set to false
import numpy as np
x = np.linspace(10,20, 5, endpoint = False)
print x
Wynik byłby -
[10. 12. 14. 16. 18.]
Przykład 3
# find retstep value
import numpy as np
x = np.linspace(1,2,5, retstep = True)
print x
# retstep here is 0.25
Teraz wynik byłby -
(array([ 1. , 1.25, 1.5 , 1.75, 2. ]), 0.25)
numpy.logspace
Ta funkcja zwraca plik ndarrayobiekt zawierający liczby rozmieszczone w równych odstępach na skali logarytmicznej. Punktami początkowymi i końcowymi skali są wskaźniki podstawy, zwykle 10.
numpy.logspace(start, stop, num, endpoint, base, dtype)
Poniższe parametry określają wydajność logspace funkcjonować.
Sr.No. | Parametr i opis |
---|---|
1 | start Punktem początkowym sekwencji jest początek podstawowy |
2 | stop Ostateczna wartość sekwencji to stop bazowy |
3 | num Liczba wartości w zakresie. Wartość domyślna to 50 |
4 | endpoint Jeśli prawda, stop jest ostatnią wartością w zakresie |
5 | base Podstawa obszaru dziennika, domyślnie 10 |
6 | dtype Typ danych tablicy wyjściowej. Jeśli nie jest podany, zależy to od innych argumentów wejściowych |
Poniższe przykłady pomogą ci zrozumieć logspace funkcjonować.
Przykład 1
import numpy as np
# default base is 10
a = np.logspace(1.0, 2.0, num = 10)
print a
Jego wynik byłby następujący -
[ 10. 12.91549665 16.68100537 21.5443469 27.82559402
35.93813664 46.41588834 59.94842503 77.42636827 100. ]
Przykład 2
# set base of log space to 2
import numpy as np
a = np.logspace(1,10,num = 10, base = 2)
print a
Teraz wynik byłby -
[ 2. 4. 8. 16. 32. 64. 128. 256. 512. 1024.]
Zawartość obiektu ndarray może być dostępna i modyfikowana przez indeksowanie lub wycinanie, tak jak wbudowane obiekty kontenera Pythona.
Jak wspomniano wcześniej, elementy w obiekcie ndarray mają indeks zaczynający się od zera. Dostępne są trzy rodzaje metod indeksowania -field access, basic slicing i advanced indexing.
Podstawowe krojenie jest rozszerzeniem podstawowej koncepcji Pythona o krojeniu na n wymiarów. Obiekt plastra Pythona jest konstruowany przez dawaniestart, stop, i step parametry do wbudowanego slicefunkcjonować. Ten obiekt wycinka jest przekazywany do tablicy w celu wyodrębnienia części tablicy.
Przykład 1
import numpy as np
a = np.arange(10)
s = slice(2,7,2)
print a[s]
Jego wynik jest następujący -
[2 4 6]
W powyższym przykładzie plik ndarray obiekt przygotowany wg arange()funkcjonować. Następnie obiekt plastra jest definiowany z wartościami startu, stopu i kroku odpowiednio 2, 7 i 2. Kiedy ten obiekt wycinka jest przekazywany do tablicy ndarray, jego część zaczynająca się od indeksu 2 do 7 z krokiem 2 jest cięta.
Ten sam wynik można również uzyskać, podając parametry krojenia oddzielone dwukropkiem: (start: stop: step) bezpośrednio do ndarray obiekt.
Przykład 2
import numpy as np
a = np.arange(10)
b = a[2:7:2]
print b
Tutaj otrzymamy ten sam wynik -
[2 4 6]
Jeśli zostanie wstawiony tylko jeden parametr, zostanie zwrócony pojedynczy element odpowiadający indeksowi. Jeśli przed nim zostanie wstawiony:, wszystkie elementy począwszy od tego indeksu zostaną wyodrębnione. Jeśli używane są dwa parametry (z: między nimi), elementy między dwoma indeksami (bez indeksu stop) z domyślnym krokiem pierwszym są dzielone.
Przykład 3
# slice single item
import numpy as np
a = np.arange(10)
b = a[5]
print b
Jego wynik jest następujący -
5
Przykład 4
# slice items starting from index
import numpy as np
a = np.arange(10)
print a[2:]
Teraz wynik byłby -
[2 3 4 5 6 7 8 9]
Przykład 5
# slice items between indexes
import numpy as np
a = np.arange(10)
print a[2:5]
Tutaj wynik wyniósłby -
[2 3 4]
Powyższy opis dotyczy wielowymiarowości ndarray także.
Przykład 6
import numpy as np
a = np.array([[1,2,3],[3,4,5],[4,5,6]])
print a
# slice items starting from index
print 'Now we will slice the array from the index a[1:]'
print a[1:]
Dane wyjściowe są następujące -
[[1 2 3]
[3 4 5]
[4 5 6]]
Now we will slice the array from the index a[1:]
[[3 4 5]
[4 5 6]]
Cięcie na plasterki może również obejmować wielokropek (…), aby utworzyć krotkę zaznaczenia o tej samej długości, co wymiar tablicy. Jeśli wielokropek jest używany w pozycji wiersza, zwróci on tablicę ndarray składającą się z elementów w wierszach.
Przykład 7
# array to begin with
import numpy as np
a = np.array([[1,2,3],[3,4,5],[4,5,6]])
print 'Our array is:'
print a
print '\n'
# this returns array of items in the second column
print 'The items in the second column are:'
print a[...,1]
print '\n'
# Now we will slice all items from the second row
print 'The items in the second row are:'
print a[1,...]
print '\n'
# Now we will slice all items from column 1 onwards
print 'The items column 1 onwards are:'
print a[...,1:]
Wynik tego programu jest następujący -
Our array is:
[[1 2 3]
[3 4 5]
[4 5 6]]
The items in the second column are:
[2 4 5]
The items in the second row are:
[3 4 5]
The items column 1 onwards are:
[[2 3]
[4 5]
[5 6]]
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 typy zaawansowanego indeksowania - Integer i Boolean.
Indeksowanie liczb całkowitych
Mechanizm ten pomaga w wyborze dowolnego elementu w tablicy na podstawie jego N-wymiarowego indeksu. Każda tablica liczb całkowitych reprezentuje liczbę indeksów w tym wymiarze. Gdy indeks składa się z tylu tablic całkowitych, ile jest wymiarów 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.
Zaawansowane i podstawowe indeksowanie 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 plaster 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]
Termin broadcastingodnosi się do zdolności NumPy do traktowania tablic o różnych kształtach podczas operacji arytmetycznych. Operacje arytmetyczne na tablicach są zwykle wykonywane na odpowiednich elementach. Jeśli dwie tablice mają dokładnie ten sam kształt, operacje te są wykonywane płynnie.
Przykład 1
import numpy as np
a = np.array([1,2,3,4])
b = np.array([10,20,30,40])
c = a * b
print c
Jego wynik jest następujący -
[10 40 90 160]
Jeśli wymiary dwóch tablic są różne, operacje element-element nie są możliwe. Jednak operacje na tablicach o różnych kształtach są nadal możliwe w NumPy ze względu na możliwości nadawania. Mniejsza tablica tobroadcast do rozmiaru większej tablicy, aby miały zgodne kształty.
Nadawanie jest możliwe, jeśli spełnione są następujące zasady -
Tablica z mniejszymi ndim niż drugi jest poprzedzony „1” w jego kształcie.
Rozmiar w każdym wymiarze kształtu wyjściowego jest maksymalnym z rozmiarów wejściowych w tym wymiarze.
Dane wejściowe mogą być używane w obliczeniach, jeśli ich rozmiar w określonym wymiarze jest zgodny z rozmiarem wyjściowym lub jego wartość wynosi dokładnie 1.
Jeśli dane wejściowe mają rozmiar wymiaru 1, pierwszy wpis danych w tym wymiarze jest używany do wszystkich obliczeń wzdłuż tego wymiaru.
Mówi się, że jest to zestaw tablic broadcastable jeśli powyższe reguły dają prawidłowy wynik i jedno z poniższych jest prawdziwe -
Tablice mają dokładnie ten sam kształt.
Tablice mają tę samą liczbę wymiarów, a długość każdego wymiaru jest albo wspólną długością, albo 1.
Tablica mająca zbyt mało wymiarów może mieć swój kształt poprzedzony wymiarem długości 1, tak aby powyższa właściwość była prawdziwa.
Poniższy program przedstawia przykład nadawania.
Przykład 2
import numpy as np
a = np.array([[0.0,0.0,0.0],[10.0,10.0,10.0],[20.0,20.0,20.0],[30.0,30.0,30.0]])
b = np.array([1.0,2.0,3.0])
print 'First array:'
print a
print '\n'
print 'Second array:'
print b
print '\n'
print 'First Array + Second Array'
print a + b
Wynik tego programu byłby następujący -
First array:
[[ 0. 0. 0.]
[ 10. 10. 10.]
[ 20. 20. 20.]
[ 30. 30. 30.]]
Second array:
[ 1. 2. 3.]
First Array + Second Array
[[ 1. 2. 3.]
[ 11. 12. 13.]
[ 21. 22. 23.]
[ 31. 32. 33.]]
Poniższy rysunek pokazuje, jak array b jest nadawany, aby był kompatybilny z a.
Pakiet NumPy zawiera obiekt iteratora numpy.nditer. Jest to wydajny, wielowymiarowy obiekt iteratora, za pomocą którego można iterować po tablicy. Każdy element tablicy jest odwiedzany przy użyciu standardowego interfejsu Iteratora Pythona.
Utwórzmy tablicę 3X4 za pomocą funkcji arange () i powtórzmy ją za pomocą nditer.
Przykład 1
import numpy as np
a = np.arange(0,60,5)
a = a.reshape(3,4)
print 'Original array is:'
print a
print '\n'
print 'Modified array is:'
for x in np.nditer(a):
print x,
Wynik tego programu jest następujący -
Original array is:
[[ 0 5 10 15]
[20 25 30 35]
[40 45 50 55]]
Modified array is:
0 5 10 15 20 25 30 35 40 45 50 55
Przykład 2
Kolejność iteracji jest wybierana tak, aby pasowała do układu pamięci tablicy, bez uwzględnienia określonej kolejności. Można to zobaczyć, wykonując iterację po transpozycji powyższej tablicy.
import numpy as np
a = np.arange(0,60,5)
a = a.reshape(3,4)
print 'Original array is:'
print a
print '\n'
print 'Transpose of the original array is:'
b = a.T
print b
print '\n'
print 'Modified array is:'
for x in np.nditer(b):
print x,
Wynik powyższego programu jest następujący -
Original array is:
[[ 0 5 10 15]
[20 25 30 35]
[40 45 50 55]]
Transpose of the original array is:
[[ 0 20 40]
[ 5 25 45]
[10 30 50]
[15 35 55]]
Modified array is:
0 5 10 15 20 25 30 35 40 45 50 55
Kolejność iteracji
Jeśli te same elementy są przechowywane przy użyciu kolejności w stylu F, iterator wybiera bardziej wydajny sposób iteracji po tablicy.
Przykład 1
import numpy as np
a = np.arange(0,60,5)
a = a.reshape(3,4)
print 'Original array is:'
print a
print '\n'
print 'Transpose of the original array is:'
b = a.T
print b
print '\n'
print 'Sorted in C-style order:'
c = b.copy(order='C')
print c
for x in np.nditer(c):
print x,
print '\n'
print 'Sorted in F-style order:'
c = b.copy(order='F')
print c
for x in np.nditer(c):
print x,
Jego wynik byłby następujący -
Original array is:
[[ 0 5 10 15]
[20 25 30 35]
[40 45 50 55]]
Transpose of the original array is:
[[ 0 20 40]
[ 5 25 45]
[10 30 50]
[15 35 55]]
Sorted in C-style order:
[[ 0 20 40]
[ 5 25 45]
[10 30 50]
[15 35 55]]
0 20 40 5 25 45 10 30 50 15 35 55
Sorted in F-style order:
[[ 0 20 40]
[ 5 25 45]
[10 30 50]
[15 35 55]]
0 5 10 15 20 25 30 35 40 45 50 55
Przykład 2
Możliwe jest wymuszenie nditer sprzeciwić się użyciu określonej kolejności, wyraźnie o niej wspominając.
import numpy as np
a = np.arange(0,60,5)
a = a.reshape(3,4)
print 'Original array is:'
print a
print '\n'
print 'Sorted in C-style order:'
for x in np.nditer(a, order = 'C'):
print x,
print '\n'
print 'Sorted in F-style order:'
for x in np.nditer(a, order = 'F'):
print x,
Jego wyjście byłoby -
Original array is:
[[ 0 5 10 15]
[20 25 30 35]
[40 45 50 55]]
Sorted in C-style order:
0 5 10 15 20 25 30 35 40 45 50 55
Sorted in F-style order:
0 20 40 5 25 45 10 30 50 15 35 55
Modyfikowanie wartości tablicy
Plik nditer obiekt ma inny opcjonalny parametr o nazwie op_flags. Jego wartość domyślna to tylko do odczytu, ale można ją ustawić w tryb tylko do odczytu i zapisu lub tylko do zapisu. Umożliwi to modyfikowanie elementów tablicy przy użyciu tego iteratora.
Przykład
import numpy as np
a = np.arange(0,60,5)
a = a.reshape(3,4)
print 'Original array is:'
print a
print '\n'
for x in np.nditer(a, op_flags = ['readwrite']):
x[...] = 2*x
print 'Modified array is:'
print a
Jego wynik jest następujący -
Original array is:
[[ 0 5 10 15]
[20 25 30 35]
[40 45 50 55]]
Modified array is:
[[ 0 10 20 30]
[ 40 50 60 70]
[ 80 90 100 110]]
Pętla zewnętrzna
Konstruktor klasy nditer ma rozszerzenie ‘flags’ parametr, który może przyjmować następujące wartości -
Sr.No. | Parametr i opis |
---|---|
1 | c_index Indeks C_order można śledzić |
2 | f_index Śledzony jest indeks Fortran_order |
3 | multi-index Można śledzić typy indeksów z jednym na iterację |
4 | external_loop Powoduje, że podane wartości są jednowymiarowymi tablicami z wieloma wartościami zamiast tablicami zerowymiarowymi |
Przykład
W poniższym przykładzie iterator przechodzi przez jednowymiarowe tablice odpowiadające każdej kolumnie.
import numpy as np
a = np.arange(0,60,5)
a = a.reshape(3,4)
print 'Original array is:'
print a
print '\n'
print 'Modified array is:'
for x in np.nditer(a, flags = ['external_loop'], order = 'F'):
print x,
Dane wyjściowe są następujące -
Original array is:
[[ 0 5 10 15]
[20 25 30 35]
[40 45 50 55]]
Modified array is:
[ 0 20 40] [ 5 25 45] [10 30 50] [15 35 55]
Iteracja nadawania
Jeśli dwie tablice są broadcastable, połączone nditerobiekt jest w stanie je jednocześnie iterować. Zakładając, że tablicaa ma wymiar 3X4 i jest inna tablica b wymiaru 1X4 używany jest iterator następującego typu (tablica b jest nadawany do rozmiaru a).
Przykład
import numpy as np
a = np.arange(0,60,5)
a = a.reshape(3,4)
print 'First array is:'
print a
print '\n'
print 'Second array is:'
b = np.array([1, 2, 3, 4], dtype = int)
print b
print '\n'
print 'Modified array is:'
for x,y in np.nditer([a,b]):
print "%d:%d" % (x,y),
Jego wynik byłby następujący -
First array is:
[[ 0 5 10 15]
[20 25 30 35]
[40 45 50 55]]
Second array is:
[1 2 3 4]
Modified array is:
0:1 5:2 10:3 15:4 20:1 25:2 30:3 35:4 40:1 45:2 50:3 55:4
W pakiecie NumPy dostępnych jest kilka procedur do manipulacji elementami w obiekcie ndarray. Można je podzielić na następujące typy -
Zmienny kształt
Sr.No. | Kształt i opis |
---|---|
1 | przefasonować Nadaje tablicy nowy kształt bez zmiany jej danych |
2 | mieszkanie Iterator 1-D po tablicy |
3 | spłaszczyć Zwraca kopię tablicy zwiniętej do jednego wymiaru |
4 | węzeł Zwraca ciągłą spłaszczoną tablicę |
Operacje transpozycji
Sr.No. | Opis operacji |
---|---|
1 | transponować Przechowuje wymiary tablicy |
2 | ndarray.T To samo co self.transpose () |
3 | rollaxis Odwraca określoną oś do tyłu |
4 | swapaxes Zamienia dwie osie tablicy |
Zmiana wymiarów
Sr.No. | Wymiar i opis |
---|---|
1 | nadawanie Tworzy obiekt, który naśladuje nadawanie |
2 | broadcast_to Rozgłasza tablicę do nowego kształtu |
3 | expand_dims Rozwija kształt tablicy |
4 | ściskać Usuwa jednowymiarowe wpisy z kształtu tablicy |
Łączenie tablic
Sr.No. | Tablica i opis |
---|---|
1 | powiązać Łączy sekwencję tablic wzdłuż istniejącej osi |
2 | stos Łączy sekwencję tablic wzdłuż nowej osi |
3 | hstack Układa tablice w kolejności w poziomie (według kolumn) |
4 | vstack Układa tablice w kolejności w pionie (według wierszy) |
Dzielenie tablic
Sr.No. | Tablica i opis |
---|---|
1 | rozdzielać Dzieli tablicę na wiele tablic podrzędnych |
2 | hsplit Dzieli tablicę na wiele tablic podrzędnych w poziomie (według kolumn) |
3 | vsplit Dzieli tablicę na wiele tablic podrzędnych pionowo (według wierszy) |
Dodawanie / usuwanie elementów
Sr.No. | Element i opis |
---|---|
1 | Zmień rozmiar Zwraca nową tablicę o określonym kształcie |
2 | dodać Dołącza wartości na koniec tablicy |
3 | wstawić Wstawia wartości wzdłuż podanej osi przed podanymi indeksami |
4 | usunąć Zwraca nową tablicę z usuniętymi podrzędnymi tablicami wzdłuż osi |
5 | wyjątkowy Znajduje unikalne elementy tablicy |
Poniżej przedstawiono funkcje operacji bitowych dostępne w pakiecie NumPy.
Sr.No. | Opis operacji |
---|---|
1 | bitwise_and Oblicza operację bitową AND elementów tablicy |
2 | bitwise_or Oblicza operację bitową OR elementów tablicy |
3 | odwracać Oblicza bitowo NIE |
4 | left_shift Przesuwa bity reprezentacji binarnej w lewo |
5 | right_shift Przesuwa bity reprezentacji binarnej w prawo |
Następujące funkcje są używane do wykonywania wektoryzowanych operacji na łańcuchach dla tablic typu dtype numpy.string_ lub numpy.unicode_. Opierają się one na standardowych funkcjach ciągów znaków we wbudowanej bibliotece Pythona.
Sr.No. | Opis funkcji |
---|---|
1 | Dodaj() Zwraca konkatenację ciągów według elementów dla dwóch tablic str lub Unicode |
2 | zwielokrotniać() Zwraca ciąg z wielokrotnymi konkatenacjami, według elementów |
3 | środek() Zwraca kopię podanego ciągu z elementami wyśrodkowanymi w ciągu o określonej długości |
4 | skapitalizować() Zwraca kopię ciągu z tylko pierwszym znakiem pisanym wielką literą |
5 | tytuł() Zwraca tytułową wersję ciągu znaków lub Unicode w postaci wielkości liter |
6 | niższy() Zwraca tablicę z elementami przekonwertowanymi na małe litery |
7 | górny() Zwraca tablicę z elementami zamienionymi na wielkie litery |
8 | rozdzielać() Zwraca listę słów w ciągu, używając separatordelimiter |
9 | linie podziału () Zwraca listę linii w elemencie, zrywając na granicach linii |
10 | rozebrać się() Zwraca kopię z usuniętymi znakami wiodącymi i końcowymi |
11 | Przystąp() Zwraca ciąg będący połączeniem ciągów w sekwencji |
12 | zastąpić() Zwraca kopię ciągu ze wszystkimi wystąpieniami podłańcucha zamienionymi na nowy ciąg |
13 | rozszyfrować() Wywołuje str.decode element-wise |
14 | kodować() Wywołuje str.encode element-wise |
Funkcje te są zdefiniowane w klasie tablicy znaków (numpy.char). Starszy pakiet Numarray zawierał klasę chararray. Powyższe funkcje w klasie numpy.char są przydatne przy wykonywaniu wektoryzowanych operacji na łańcuchach.
Całkiem zrozumiałe, że NumPy zawiera wiele różnych operacji matematycznych. NumPy zapewnia standardowe funkcje trygonometryczne, funkcje do operacji arytmetycznych, obsługi liczb zespolonych itp.
Funkcje trygonometryczne
NumPy ma standardowe funkcje trygonometryczne, które zwracają stosunki trygonometryczne dla danego kąta w radianach.
Example
import numpy as np
a = np.array([0,30,45,60,90])
print 'Sine of different angles:'
# Convert to radians by multiplying with pi/180
print np.sin(a*np.pi/180)
print '\n'
print 'Cosine values for angles in array:'
print np.cos(a*np.pi/180)
print '\n'
print 'Tangent values for given angles:'
print np.tan(a*np.pi/180)
Oto jego wynik -
Sine of different angles:
[ 0. 0.5 0.70710678 0.8660254 1. ]
Cosine values for angles in array:
[ 1.00000000e+00 8.66025404e-01 7.07106781e-01 5.00000000e-01
6.12323400e-17]
Tangent values for given angles:
[ 0.00000000e+00 5.77350269e-01 1.00000000e+00 1.73205081e+00
1.63312394e+16]
arcsin, arcos, i arctanfunkcje zwracają trygonometryczną odwrotność sin, cos i tan dla danego kąta. Wynik tych funkcji można zweryfikować za pomocąnumpy.degrees() function poprzez zamianę radianów na stopnie.
Example
import numpy as np
a = np.array([0,30,45,60,90])
print 'Array containing sine values:'
sin = np.sin(a*np.pi/180)
print sin
print '\n'
print 'Compute sine inverse of angles. Returned values are in radians.'
inv = np.arcsin(sin)
print inv
print '\n'
print 'Check result by converting to degrees:'
print np.degrees(inv)
print '\n'
print 'arccos and arctan functions behave similarly:'
cos = np.cos(a*np.pi/180)
print cos
print '\n'
print 'Inverse of cos:'
inv = np.arccos(cos)
print inv
print '\n'
print 'In degrees:'
print np.degrees(inv)
print '\n'
print 'Tan function:'
tan = np.tan(a*np.pi/180)
print tan
print '\n'
print 'Inverse of tan:'
inv = np.arctan(tan)
print inv
print '\n'
print 'In degrees:'
print np.degrees(inv)
Jego wynik jest następujący -
Array containing sine values:
[ 0. 0.5 0.70710678 0.8660254 1. ]
Compute sine inverse of angles. Returned values are in radians.
[ 0. 0.52359878 0.78539816 1.04719755 1.57079633]
Check result by converting to degrees:
[ 0. 30. 45. 60. 90.]
arccos and arctan functions behave similarly:
[ 1.00000000e+00 8.66025404e-01 7.07106781e-01 5.00000000e-01
6.12323400e-17]
Inverse of cos:
[ 0. 0.52359878 0.78539816 1.04719755 1.57079633]
In degrees:
[ 0. 30. 45. 60. 90.]
Tan function:
[ 0.00000000e+00 5.77350269e-01 1.00000000e+00 1.73205081e+00
1.63312394e+16]
Inverse of tan:
[ 0. 0.52359878 0.78539816 1.04719755 1.57079633]
In degrees:
[ 0. 30. 45. 60. 90.]
Funkcje zaokrąglania
numpy.around ()
Jest to funkcja zwracająca wartość zaokrągloną z żądaną dokładnością. Funkcja przyjmuje następujące parametry.
numpy.around(a,decimals)
Gdzie,
Sr.No. | Parametr i opis |
---|---|
1 | a Dane wejściowe |
2 | decimals Liczba miejsc dziesiętnych do zaokrąglenia. Wartość domyślna to 0. Jeśli jest ujemna, liczba całkowita jest zaokrąglana do pozycji po lewej stronie przecinka dziesiętnego |
Example
import numpy as np
a = np.array([1.0,5.55, 123, 0.567, 25.532])
print 'Original array:'
print a
print '\n'
print 'After rounding:'
print np.around(a)
print np.around(a, decimals = 1)
print np.around(a, decimals = -1)
Generuje następujący wynik -
Original array:
[ 1. 5.55 123. 0.567 25.532]
After rounding:
[ 1. 6. 123. 1. 26. ]
[ 1. 5.6 123. 0.6 25.5]
[ 0. 10. 120. 0. 30. ]
numpy.floor ()
Ta funkcja zwraca największą liczbę całkowitą nie większą niż parametr wejściowy. Podłogascalar x jest największy integer i, takie że i <= x. Zauważ, że w Pythonie podłoga jest zawsze zaokrąglana od 0.
Example
import numpy as np
a = np.array([-1.7, 1.5, -0.2, 0.6, 10])
print 'The given array:'
print a
print '\n'
print 'The modified array:'
print np.floor(a)
Generuje następujący wynik -
The given array:
[ -1.7 1.5 -0.2 0.6 10. ]
The modified array:
[ -2. 1. -1. 0. 10.]
numpy.ceil ()
Funkcja ceil () zwraca górną granicę wartości wejściowej, tj. Pułap wartości scalar x jest najmniejszy integer i, takie że i >= x.
Example
import numpy as np
a = np.array([-1.7, 1.5, -0.2, 0.6, 10])
print 'The given array:'
print a
print '\n'
print 'The modified array:'
print np.ceil(a)
Wytworzy następujący wynik -
The given array:
[ -1.7 1.5 -0.2 0.6 10. ]
The modified array:
[ -1. 2. -0. 1. 10.]
Tablice wejściowe do wykonywania operacji arytmetycznych, takich jak add (), subtract (), multiply () i divide (), muszą mieć ten sam kształt lub być zgodne z regułami rozgłaszania tablic.
Przykład
import numpy as np
a = np.arange(9, dtype = np.float_).reshape(3,3)
print 'First array:'
print a
print '\n'
print 'Second array:'
b = np.array([10,10,10])
print b
print '\n'
print 'Add the two arrays:'
print np.add(a,b)
print '\n'
print 'Subtract the two arrays:'
print np.subtract(a,b)
print '\n'
print 'Multiply the two arrays:'
print np.multiply(a,b)
print '\n'
print 'Divide the two arrays:'
print np.divide(a,b)
Wytworzy następujący wynik -
First array:
[[ 0. 1. 2.]
[ 3. 4. 5.]
[ 6. 7. 8.]]
Second array:
[10 10 10]
Add the two arrays:
[[ 10. 11. 12.]
[ 13. 14. 15.]
[ 16. 17. 18.]]
Subtract the two arrays:
[[-10. -9. -8.]
[ -7. -6. -5.]
[ -4. -3. -2.]]
Multiply the two arrays:
[[ 0. 10. 20.]
[ 30. 40. 50.]
[ 60. 70. 80.]]
Divide the two arrays:
[[ 0. 0.1 0.2]
[ 0.3 0.4 0.5]
[ 0.6 0.7 0.8]]
Omówmy teraz niektóre inne ważne funkcje arytmetyczne dostępne w NumPy.
numpy.reciprocal ()
Ta funkcja zwraca odwrotność argumentu według elementów. W przypadku elementów o wartościach bezwzględnych większych niż 1 wynik zawsze wynosi 0 ze względu na sposób, w jaki Python obsługuje dzielenie liczb całkowitych. W przypadku liczby całkowitej 0 generowane jest ostrzeżenie o przepełnieniu.
Przykład
import numpy as np
a = np.array([0.25, 1.33, 1, 0, 100])
print 'Our array is:'
print a
print '\n'
print 'After applying reciprocal function:'
print np.reciprocal(a)
print '\n'
b = np.array([100], dtype = int)
print 'The second array is:'
print b
print '\n'
print 'After applying reciprocal function:'
print np.reciprocal(b)
Wytworzy następujący wynik -
Our array is:
[ 0.25 1.33 1. 0. 100. ]
After applying reciprocal function:
main.py:9: RuntimeWarning: divide by zero encountered in reciprocal
print np.reciprocal(a)
[ 4. 0.7518797 1. inf 0.01 ]
The second array is:
[100]
After applying reciprocal function:
[0]
numpy.power ()
Ta funkcja traktuje elementy w pierwszej tablicy wejściowej jako podstawę i zwraca ją podniesioną do potęgi odpowiedniego elementu w drugiej tablicy wejściowej.
import numpy as np
a = np.array([10,100,1000])
print 'Our array is:'
print a
print '\n'
print 'Applying power function:'
print np.power(a,2)
print '\n'
print 'Second array:'
b = np.array([1,2,3])
print b
print '\n'
print 'Applying power function again:'
print np.power(a,b)
Wytworzy następujący wynik -
Our array is:
[ 10 100 1000]
Applying power function:
[ 100 10000 1000000]
Second array:
[1 2 3]
Applying power function again:
[ 10 10000 1000000000]
numpy.mod ()
Ta funkcja zwraca pozostałą część podziału odpowiednich elementów w tablicy wejściowej. Funkcjanumpy.remainder() również daje ten sam wynik.
import numpy as np
a = np.array([10,20,30])
b = np.array([3,5,7])
print 'First array:'
print a
print '\n'
print 'Second array:'
print b
print '\n'
print 'Applying mod() function:'
print np.mod(a,b)
print '\n'
print 'Applying remainder() function:'
print np.remainder(a,b)
Wytworzy następujący wynik -
First array:
[10 20 30]
Second array:
[3 5 7]
Applying mod() function:
[1 0 2]
Applying remainder() function:
[1 0 2]
Następujące funkcje służą do wykonywania operacji na tablicach z liczbami zespolonymi.
numpy.real() - zwraca rzeczywistą część argumentu złożonego typu danych.
numpy.imag() - zwraca urojoną część argumentu złożonego typu danych.
numpy.conj() - zwraca sprzężony koniugat, który uzyskuje się poprzez zmianę znaku części urojonej.
numpy.angle()- zwraca kąt złożonego argumentu. Funkcja ma parametr stopnia. Jeśli prawda, zwracany jest kąt w stopniach, w przeciwnym razie kąt jest podawany w radianach.
import numpy as np
a = np.array([-5.6j, 0.2j, 11. , 1+1j])
print 'Our array is:'
print a
print '\n'
print 'Applying real() function:'
print np.real(a)
print '\n'
print 'Applying imag() function:'
print np.imag(a)
print '\n'
print 'Applying conj() function:'
print np.conj(a)
print '\n'
print 'Applying angle() function:'
print np.angle(a)
print '\n'
print 'Applying angle() function again (result in degrees)'
print np.angle(a, deg = True)
Wytworzy następujący wynik -
Our array is:
[ 0.-5.6j 0.+0.2j 11.+0.j 1.+1.j ]
Applying real() function:
[ 0. 0. 11. 1.]
Applying imag() function:
[-5.6 0.2 0. 1. ]
Applying conj() function:
[ 0.+5.6j 0.-0.2j 11.-0.j 1.-1.j ]
Applying angle() function:
[-1.57079633 1.57079633 0. 0.78539816]
Applying angle() function again (result in degrees)
[-90. 90. 0. 45.]
NumPy ma sporo użytecznych funkcji statystycznych do znajdowania minimum, maksimum, percentyla odchylenia standardowego i wariancji itp. Z podanych elementów tablicy. Funkcje są wyjaśnione w następujący sposób -
numpy.amin () i numpy.amax ()
Te funkcje zwracają minimum i maksimum z elementów w danej tablicy wzdłuż określonej osi.
Przykład
import numpy as np
a = np.array([[3,7,5],[8,4,3],[2,4,9]])
print 'Our array is:'
print a
print '\n'
print 'Applying amin() function:'
print np.amin(a,1)
print '\n'
print 'Applying amin() function again:'
print np.amin(a,0)
print '\n'
print 'Applying amax() function:'
print np.amax(a)
print '\n'
print 'Applying amax() function again:'
print np.amax(a, axis = 0)
Wytworzy następujący wynik -
Our array is:
[[3 7 5]
[8 4 3]
[2 4 9]]
Applying amin() function:
[3 3 2]
Applying amin() function again:
[2 4 3]
Applying amax() function:
9
Applying amax() function again:
[8 7 9]
numpy.ptp ()
Plik numpy.ptp() funkcja zwraca zakres (maksimum-minimum) wartości wzdłuż osi.
import numpy as np
a = np.array([[3,7,5],[8,4,3],[2,4,9]])
print 'Our array is:'
print a
print '\n'
print 'Applying ptp() function:'
print np.ptp(a)
print '\n'
print 'Applying ptp() function along axis 1:'
print np.ptp(a, axis = 1)
print '\n'
print 'Applying ptp() function along axis 0:'
print np.ptp(a, axis = 0)
Wytworzy następujący wynik -
Our array is:
[[3 7 5]
[8 4 3]
[2 4 9]]
Applying ptp() function:
7
Applying ptp() function along axis 1:
[4 5 7]
Applying ptp() function along axis 0:
[6 3 6]
numpy.percentile ()
Percentyl (lub centyl) jest miarą używaną w statystykach, wskazującą wartość, poniżej której przypada dany procent obserwacji w grupie obserwacji. Funkcjanumpy.percentile() przyjmuje następujące argumenty.
numpy.percentile(a, q, axis)
Gdzie,
Sr.No. | Argument i opis |
---|---|
1 | a Tablica wejściowa |
2 | q Percentyl do obliczenia musi mieścić się w przedziale od 0 do 100 |
3 | axis Oś, wzdłuż której ma być obliczany percentyl |
Przykład
import numpy as np
a = np.array([[30,40,70],[80,20,10],[50,90,60]])
print 'Our array is:'
print a
print '\n'
print 'Applying percentile() function:'
print np.percentile(a,50)
print '\n'
print 'Applying percentile() function along axis 1:'
print np.percentile(a,50, axis = 1)
print '\n'
print 'Applying percentile() function along axis 0:'
print np.percentile(a,50, axis = 0)
Wytworzy następujący wynik -
Our array is:
[[30 40 70]
[80 20 10]
[50 90 60]]
Applying percentile() function:
50.0
Applying percentile() function along axis 1:
[ 40. 20. 60.]
Applying percentile() function along axis 0:
[ 50. 40. 60.]
numpy.median ()
Medianjest definiowana jako wartość oddzielająca wyższą połowę próbki danych od dolnej połowy. Pliknumpy.median() funkcja jest używana, jak pokazano w poniższym programie.
Przykład
import numpy as np
a = np.array([[30,65,70],[80,95,10],[50,90,60]])
print 'Our array is:'
print a
print '\n'
print 'Applying median() function:'
print np.median(a)
print '\n'
print 'Applying median() function along axis 0:'
print np.median(a, axis = 0)
print '\n'
print 'Applying median() function along axis 1:'
print np.median(a, axis = 1)
Wytworzy następujący wynik -
Our array is:
[[30 65 70]
[80 95 10]
[50 90 60]]
Applying median() function:
65.0
Applying median() function along axis 0:
[ 50. 90. 60.]
Applying median() function along axis 1:
[ 65. 80. 60.]
numpy.mean ()
Średnia arytmetyczna to suma elementów wzdłuż osi podzielona przez liczbę elementów. Pliknumpy.mean()funkcja zwraca średnią arytmetyczną elementów w tablicy. Jeśli wspomniano o osi, jest ona obliczana wzdłuż niej.
Przykład
import numpy as np
a = np.array([[1,2,3],[3,4,5],[4,5,6]])
print 'Our array is:'
print a
print '\n'
print 'Applying mean() function:'
print np.mean(a)
print '\n'
print 'Applying mean() function along axis 0:'
print np.mean(a, axis = 0)
print '\n'
print 'Applying mean() function along axis 1:'
print np.mean(a, axis = 1)
Wytworzy następujący wynik -
Our array is:
[[1 2 3]
[3 4 5]
[4 5 6]]
Applying mean() function:
3.66666666667
Applying mean() function along axis 0:
[ 2.66666667 3.66666667 4.66666667]
Applying mean() function along axis 1:
[ 2. 4. 5.]
numpy.average ()
Średnia ważona to średnia wynikająca z pomnożenia każdego składnika przez czynnik odzwierciedlający jego znaczenie. Pliknumpy.average()funkcja oblicza średnią ważoną elementów w tablicy zgodnie z ich odpowiednią wagą podaną w innej tablicy. Funkcja może mieć parametr osi. Jeśli oś nie jest określona, szyk jest spłaszczany.
Biorąc pod uwagę tablicę [1, 2, 3, 4] i odpowiadające jej wagi [4,3,2,1], średnią ważoną oblicza się poprzez dodanie iloczynu odpowiednich elementów i podzielenie sumy przez sumę wag.
Średnia ważona = (1 * 4 + 2 * 3 + 3 * 2 + 4 * 1) / (4 + 3 + 2 + 1)
Przykład
import numpy as np
a = np.array([1,2,3,4])
print 'Our array is:'
print a
print '\n'
print 'Applying average() function:'
print np.average(a)
print '\n'
# this is same as mean when weight is not specified
wts = np.array([4,3,2,1])
print 'Applying average() function again:'
print np.average(a,weights = wts)
print '\n'
# Returns the sum of weights, if the returned parameter is set to True.
print 'Sum of weights'
print np.average([1,2,3, 4],weights = [4,3,2,1], returned = True)
Wytworzy następujący wynik -
Our array is:
[1 2 3 4]
Applying average() function:
2.5
Applying average() function again:
2.0
Sum of weights
(2.0, 10.0)
W tablicy wielowymiarowej można określić oś do obliczeń.
Przykład
import numpy as np
a = np.arange(6).reshape(3,2)
print 'Our array is:'
print a
print '\n'
print 'Modified array:'
wt = np.array([3,5])
print np.average(a, axis = 1, weights = wt)
print '\n'
print 'Modified array:'
print np.average(a, axis = 1, weights = wt, returned = True)
Wytworzy następujący wynik -
Our array is:
[[0 1]
[2 3]
[4 5]]
Modified array:
[ 0.625 2.625 4.625]
Modified array:
(array([ 0.625, 2.625, 4.625]), array([ 8., 8., 8.]))
Odchylenie standardowe
Odchylenie standardowe to pierwiastek kwadratowy średniej kwadratowych odchyleń od średniej. Wzór na odchylenie standardowe jest następujący -
std = sqrt(mean(abs(x - x.mean())**2))
Jeśli tablica to [1, 2, 3, 4], to jej średnia wynosi 2,5. Stąd odchylenia kwadratowe wynoszą [2,25, 0,25, 0,25, 2,25], a pierwiastek kwadratowy jego średniej podzielony przez 4, tj. Sqrt (5/4) to 1,1180339887498949.
Przykład
import numpy as np
print np.std([1,2,3,4])
Wytworzy następujący wynik -
1.1180339887498949
Zmienność
Wariancja jest średnią kwadratów odchyleń, tj. mean(abs(x - x.mean())**2). Innymi słowy, odchylenie standardowe to pierwiastek kwadratowy z wariancji.
Przykład
import numpy as np
print np.var([1,2,3,4])
Wytworzy następujący wynik -
1.25
W NumPy dostępne są różne funkcje związane z sortowaniem. Te funkcje sortowania implementują różne algorytmy sortowania, każdy z nich charakteryzuje się szybkością wykonywania, wydajnością w najgorszym przypadku, wymaganą przestrzenią roboczą i stabilnością algorytmów. Poniższa tabela przedstawia porównanie trzech algorytmów sortowania.
uprzejmy | prędkość | najgorszy przypadek | miejsce do pracy | stabilny |
---|---|---|---|---|
'szybkie sortowanie' | 1 | O (n ^ 2) | 0 | Nie |
„łączenie” | 2 | O (n * log (n)) | ~ n / 2 | tak |
„heapsort” | 3 | O (n * log (n)) | 0 | Nie |
numpy.sort ()
Funkcja sort () zwraca posortowaną kopię tablicy wejściowej. Ma następujące parametry -
numpy.sort(a, axis, kind, order)
Gdzie,
Sr.No. | Parametr i opis |
---|---|
1 | a Tablica do posortowania |
2 | axis Oś, wzdłuż której tablica ma być sortowana. Jeśli nie ma, tablica jest spłaszczana i sortowana według ostatniej osi |
3 | kind Domyślnie jest to szybkie sortowanie |
4 | order Jeśli tablica zawiera pola - kolejność sortowanych pól |
Przykład
import numpy as np
a = np.array([[3,7],[9,1]])
print 'Our array is:'
print a
print '\n'
print 'Applying sort() function:'
print np.sort(a)
print '\n'
print 'Sort along axis 0:'
print np.sort(a, axis = 0)
print '\n'
# Order parameter in sort function
dt = np.dtype([('name', 'S10'),('age', int)])
a = np.array([("raju",21),("anil",25),("ravi", 17), ("amar",27)], dtype = dt)
print 'Our array is:'
print a
print '\n'
print 'Order by name:'
print np.sort(a, order = 'name')
Wytworzy następujący wynik -
Our array is:
[[3 7]
[9 1]]
Applying sort() function:
[[3 7]
[1 9]]
Sort along axis 0:
[[3 1]
[9 7]]
Our array is:
[('raju', 21) ('anil', 25) ('ravi', 17) ('amar', 27)]
Order by name:
[('amar', 27) ('anil', 25) ('raju', 21) ('ravi', 17)]
numpy.argsort ()
Plik numpy.argsort()funkcja wykonuje pośrednie sortowanie na tablicy wejściowej, wzdłuż danej osi i używając określonego rodzaju sortowania, aby zwrócić tablicę indeksów danych. Ta tablica indeksów służy do konstruowania posortowanej tablicy.
Przykład
import numpy as np
x = np.array([3, 1, 2])
print 'Our array is:'
print x
print '\n'
print 'Applying argsort() to x:'
y = np.argsort(x)
print y
print '\n'
print 'Reconstruct original array in sorted order:'
print x[y]
print '\n'
print 'Reconstruct the original array using loop:'
for i in y:
print x[i],
Wytworzy następujący wynik -
Our array is:
[3 1 2]
Applying argsort() to x:
[1 2 0]
Reconstruct original array in sorted order:
[1 2 3]
Reconstruct the original array using loop:
1 2 3
numpy.lexsort ()
funkcja wykonuje pośrednie sortowanie przy użyciu sekwencji klawiszy. Klucze można zobaczyć jako kolumny w arkuszu kalkulacyjnym. Funkcja zwraca tablicę indeksów, za pomocą których można uzyskać posortowane dane. Zauważ, że ostatni klucz jest rodzajem klucza podstawowego.
Przykład
import numpy as np
nm = ('raju','anil','ravi','amar')
dv = ('f.y.', 's.y.', 's.y.', 'f.y.')
ind = np.lexsort((dv,nm))
print 'Applying lexsort() function:'
print ind
print '\n'
print 'Use this index to get sorted data:'
print [nm[i] + ", " + dv[i] for i in ind]
Wytworzy następujący wynik -
Applying lexsort() function:
[3 1 0 2]
Use this index to get sorted data:
['amar, f.y.', 'anil, s.y.', 'raju, f.y.', 'ravi, s.y.']
Moduł NumPy posiada szereg funkcji do wyszukiwania wewnątrz tablicy. Dostępne są funkcje wyszukujące maksimum, minimum oraz elementy spełniające zadany warunek.
numpy.argmax () i numpy.argmin ()
Te dwie funkcje zwracają odpowiednio wskaźniki maksimum i minimum elementów wzdłuż danej osi.
Przykład
import numpy as np
a = np.array([[30,40,70],[80,20,10],[50,90,60]])
print 'Our array is:'
print a
print '\n'
print 'Applying argmax() function:'
print np.argmax(a)
print '\n'
print 'Index of maximum number in flattened array'
print a.flatten()
print '\n'
print 'Array containing indices of maximum along axis 0:'
maxindex = np.argmax(a, axis = 0)
print maxindex
print '\n'
print 'Array containing indices of maximum along axis 1:'
maxindex = np.argmax(a, axis = 1)
print maxindex
print '\n'
print 'Applying argmin() function:'
minindex = np.argmin(a)
print minindex
print '\n'
print 'Flattened array:'
print a.flatten()[minindex]
print '\n'
print 'Flattened array along axis 0:'
minindex = np.argmin(a, axis = 0)
print minindex
print '\n'
print 'Flattened array along axis 1:'
minindex = np.argmin(a, axis = 1)
print minindex
Wytworzy następujący wynik -
Our array is:
[[30 40 70]
[80 20 10]
[50 90 60]]
Applying argmax() function:
7
Index of maximum number in flattened array
[30 40 70 80 20 10 50 90 60]
Array containing indices of maximum along axis 0:
[1 2 0]
Array containing indices of maximum along axis 1:
[2 0 1]
Applying argmin() function:
5
Flattened array:
10
Flattened array along axis 0:
[0 1 1]
Flattened array along axis 1:
[0 2 0]
numpy.nonzero ()
Plik numpy.nonzero() funkcja zwraca indeksy niezerowych elementów w tablicy wejściowej.
Przykład
import numpy as np
a = np.array([[30,40,0],[0,20,10],[50,0,60]])
print 'Our array is:'
print a
print '\n'
print 'Applying nonzero() function:'
print np.nonzero (a)
Wytworzy następujący wynik -
Our array is:
[[30 40 0]
[ 0 20 10]
[50 0 60]]
Applying nonzero() function:
(array([0, 0, 1, 1, 2, 2]), array([0, 1, 1, 2, 0, 2]))
numpy.where ()
Funkcja where () zwraca indeksy elementów w tablicy wejściowej, w przypadku których dany warunek jest spełniony.
Przykład
import numpy as np
x = np.arange(9.).reshape(3, 3)
print 'Our array is:'
print x
print 'Indices of elements > 3'
y = np.where(x > 3)
print y
print 'Use these indices to get elements satisfying the condition'
print x[y]
Wytworzy następujący wynik -
Our array is:
[[ 0. 1. 2.]
[ 3. 4. 5.]
[ 6. 7. 8.]]
Indices of elements > 3
(array([1, 1, 2, 2, 2]), array([1, 2, 0, 1, 2]))
Use these indices to get elements satisfying the condition
[ 4. 5. 6. 7. 8.]
numpy.extract ()
Plik extract() funkcja zwraca elementy spełniające dowolny warunek.
import numpy as np
x = np.arange(9.).reshape(3, 3)
print 'Our array is:'
print x
# define a condition
condition = np.mod(x,2) == 0
print 'Element-wise value of condition'
print condition
print 'Extract elements using condition'
print np.extract(condition, x)
Wytworzy następujący wynik -
Our array is:
[[ 0. 1. 2.]
[ 3. 4. 5.]
[ 6. 7. 8.]]
Element-wise value of condition
[[ True False True]
[False True False]
[ True False True]]
Extract elements using condition
[ 0. 2. 4. 6. 8.]
Widzieliśmy, że dane przechowywane w pamięci komputera zależą od architektury używanej przez procesor. Może to być little-endian (najmniej znaczący jest przechowywany w najmniejszym adresie) lub big-endian (najbardziej znaczący bajt w najmniejszym adresie).
numpy.ndarray.byteswap ()
Plik numpy.ndarray.byteswap() funkcja przełącza między dwiema reprezentacjami: bigendian i little-endian.
import numpy as np
a = np.array([1, 256, 8755], dtype = np.int16)
print 'Our array is:'
print a
print 'Representation of data in memory in hexadecimal form:'
print map(hex,a)
# byteswap() function swaps in place by passing True parameter
print 'Applying byteswap() function:'
print a.byteswap(True)
print 'In hexadecimal form:'
print map(hex,a)
# We can see the bytes being swapped
Wytworzy następujący wynik -
Our array is:
[1 256 8755]
Representation of data in memory in hexadecimal form:
['0x1', '0x100', '0x2233']
Applying byteswap() function:
[256 1 13090]
In hexadecimal form:
['0x100', '0x1', '0x3322']
Podczas wykonywania funkcji część z nich zwraca kopię tablicy wejściowej, a część zwraca widok. Gdy zawartość jest fizycznie przechowywana w innej lokalizacji, nazywa sięCopy. Jeśli z drugiej strony zostanie przedstawiony inny widok tej samej zawartości pamięci, nazywamy toView.
Brak kopii
Proste przypisania nie tworzą kopii obiektu tablicy. Zamiast tego używa tego samego identyfikatora () oryginalnej tablicy, aby uzyskać do niej dostęp. Plikid() zwraca uniwersalny identyfikator obiektu Pythona, podobny do wskaźnika w C.
Co więcej, wszelkie zmiany w jednym z nich są odzwierciedlane w drugim. Na przykład zmiana kształtu jednego z nich zmieni również kształt drugiego.
Przykład
import numpy as np
a = np.arange(6)
print 'Our array is:'
print a
print 'Applying id() function:'
print id(a)
print 'a is assigned to b:'
b = a
print b
print 'b has same id():'
print id(b)
print 'Change shape of b:'
b.shape = 3,2
print b
print 'Shape of a also gets changed:'
print a
Wytworzy następujący wynik -
Our array is:
[0 1 2 3 4 5]
Applying id() function:
139747815479536
a is assigned to b:
[0 1 2 3 4 5]
b has same id():
139747815479536
Change shape of b:
[[0 1]
[2 3]
[4 5]]
Shape of a also gets changed:
[[0 1]
[2 3]
[4 5]]
Wyświetl lub płytka kopia
NumPy ma ndarray.view()metoda, która jest nowym obiektem tablicy, który sprawdza te same dane, co oryginalna tablica. W przeciwieństwie do poprzedniego przypadku, zmiana wymiarów nowej tablicy nie zmienia wymiarów oryginału.
Przykład
import numpy as np
# To begin with, a is 3X2 array
a = np.arange(6).reshape(3,2)
print 'Array a:'
print a
print 'Create view of a:'
b = a.view()
print b
print 'id() for both the arrays are different:'
print 'id() of a:'
print id(a)
print 'id() of b:'
print id(b)
# Change the shape of b. It does not change the shape of a
b.shape = 2,3
print 'Shape of b:'
print b
print 'Shape of a:'
print a
Wytworzy następujący wynik -
Array a:
[[0 1]
[2 3]
[4 5]]
Create view of a:
[[0 1]
[2 3]
[4 5]]
id() for both the arrays are different:
id() of a:
140424307227264
id() of b:
140424151696288
Shape of b:
[[0 1 2]
[3 4 5]]
Shape of a:
[[0 1]
[2 3]
[4 5]]
Wycinek tablicy tworzy widok.
Przykład
import numpy as np
a = np.array([[10,10], [2,3], [4,5]])
print 'Our array is:'
print a
print 'Create a slice:'
s = a[:, :2]
print s
Wytworzy następujący wynik -
Our array is:
[[10 10]
[ 2 3]
[ 4 5]]
Create a slice:
[[10 10]
[ 2 3]
[ 4 5]]
Głęboka kopia
Plik ndarray.copy()funkcja tworzy głęboką kopię. Jest to pełna kopia tablicy i jej danych, która nie jest współdzielona z oryginalną tablicą.
Przykład
import numpy as np
a = np.array([[10,10], [2,3], [4,5]])
print 'Array a is:'
print a
print 'Create a deep copy of a:'
b = a.copy()
print 'Array b is:'
print b
#b does not share any memory of a
print 'Can we write b is a'
print b is a
print 'Change the contents of b:'
b[0,0] = 100
print 'Modified array b:'
print b
print 'a remains unchanged:'
print a
Wytworzy następujący wynik -
Array a is:
[[10 10]
[ 2 3]
[ 4 5]]
Create a deep copy of a:
Array b is:
[[10 10]
[ 2 3]
[ 4 5]]
Can we write b is a
False
Change the contents of b:
Modified array b:
[[100 10]
[ 2 3]
[ 4 5]]
a remains unchanged:
[[10 10]
[ 2 3]
[ 4 5]]
Pakiet NumPy zawiera bibliotekę Matrix numpy.matlib. Ten moduł zawiera funkcje, które zwracają macierze zamiast obiektów ndarray.
matlib.empty ()
Plik matlib.empty()funkcja zwraca nową macierz bez inicjalizacji wpisów. Funkcja przyjmuje następujące parametry.
numpy.matlib.empty(shape, dtype, order)
Gdzie,
Sr.No. | Parametr i opis |
---|---|
1 | shape int lub krotka z int definiowanie kształtu nowej matrycy |
2 | Dtype Opcjonalny. Typ danych wyjścia |
3 | order C lub F |
Przykład
import numpy.matlib
import numpy as np
print np.matlib.empty((2,2))
# filled with random data
Wytworzy następujący wynik -
[[ 2.12199579e-314, 4.24399158e-314]
[ 4.24399158e-314, 2.12199579e-314]]
numpy.matlib.zeros ()
Ta funkcja zwraca macierz wypełnioną zerami.
import numpy.matlib
import numpy as np
print np.matlib.zeros((2,2))
Wytworzy następujący wynik -
[[ 0. 0.]
[ 0. 0.]]
numpy.matlib.ones ()
Ta funkcja zwraca macierz wypełnioną jedynkami.
import numpy.matlib
import numpy as np
print np.matlib.ones((2,2))
Wytworzy następujący wynik -
[[ 1. 1.]
[ 1. 1.]]
numpy.matlib.eye ()
Ta funkcja zwraca macierz z 1 wzdłuż elementów przekątnych i zerami w innych miejscach. Funkcja przyjmuje następujące parametry.
numpy.matlib.eye(n, M,k, dtype)
Gdzie,
Sr.No. | Parametr i opis |
---|---|
1 | n Liczba wierszy w wynikowej macierzy |
2 | M Liczba kolumn, domyślnie n |
3 | k Indeks przekątnej |
4 | dtype Typ danych wyjścia |
Przykład
import numpy.matlib
import numpy as np
print np.matlib.eye(n = 3, M = 4, k = 0, dtype = float)
Wytworzy następujący wynik -
[[ 1. 0. 0. 0.]
[ 0. 1. 0. 0.]
[ 0. 0. 1. 0.]]
numpy.matlib.identity ()
Plik numpy.matlib.identity()funkcja zwraca macierz tożsamości o podanym rozmiarze. Macierz tożsamości to macierz kwadratowa z wszystkimi elementami przekątnymi równymi 1.
import numpy.matlib
import numpy as np
print np.matlib.identity(5, dtype = float)
Wytworzy następujący wynik -
[[ 1. 0. 0. 0. 0.]
[ 0. 1. 0. 0. 0.]
[ 0. 0. 1. 0. 0.]
[ 0. 0. 0. 1. 0.]
[ 0. 0. 0. 0. 1.]]
numpy.matlib.rand ()
Plik numpy.matlib.rand() funkcja zwraca macierz o podanym rozmiarze wypełnioną losowymi wartościami.
Przykład
import numpy.matlib
import numpy as np
print np.matlib.rand(3,3)
Wytworzy następujący wynik -
[[ 0.82674464 0.57206837 0.15497519]
[ 0.33857374 0.35742401 0.90895076]
[ 0.03968467 0.13962089 0.39665201]]
Noteże macierz jest zawsze dwuwymiarowa, podczas gdy ndarray jest tablicą n-wymiarową. Oba obiekty są wymienialne.
Przykład
import numpy.matlib
import numpy as np
i = np.matrix('1,2;3,4')
print i
Wytworzy następujący wynik -
[[1 2]
[3 4]]
Przykład
import numpy.matlib
import numpy as np
j = np.asarray(i)
print j
Wytworzy następujący wynik -
[[1 2]
[3 4]]
Przykład
import numpy.matlib
import numpy as np
k = np.asmatrix (j)
print k
Wytworzy następujący wynik -
[[1 2]
[3 4]]
Pakiet NumPy zawiera numpy.linalgmoduł, który zapewnia wszystkie funkcje wymagane dla algebry liniowej. Niektóre z ważnych funkcji tego modułu opisano w poniższej tabeli.
Sr.No. | Opis funkcji |
---|---|
1 | kropka Iloczyn skalarny dwóch tablic |
2 | vdot Iloczyn skalarny dwóch wektorów |
3 | wewnętrzny Iloczyn wewnętrzny dwóch tablic |
4 | matmul Iloczyn macierzowy dwóch tablic |
5 | wyznacznik Oblicza wyznacznik tablicy |
6 | rozwiązać Rozwiązuje liniowe równanie macierzowe |
7 | inw Znajduje multiplikatywną odwrotność macierzy |
Matplotlib to biblioteka kreśląca dla Pythona. Jest używany wraz z NumPy, aby zapewnić środowisko, które jest skuteczną alternatywą open source dla MatLab. Może być również używany z zestawami narzędzi graficznych, takimi jak PyQt i wxPython.
Moduł Matplotlib został po raz pierwszy napisany przez Johna D. Huntera. Od 2012 roku głównym deweloperem jest Michael Droettboom. Obecnie Matplotlib ver. 1.5.1 to stabilna dostępna wersja. Pakiet jest dostępny w dystrybucji binarnej, a także w postaci kodu źródłowego na www.matplotlib.org .
Tradycyjnie pakiet jest importowany do skryptu Pythona przez dodanie następującej instrukcji -
from matplotlib import pyplot as plt
Tutaj pyplot()jest najważniejszą funkcją w bibliotece matplotlib, która służy do rysowania danych 2D. Poniższy skrypt przedstawia równaniey = 2x + 5
Przykład
import numpy as np
from matplotlib import pyplot as plt
x = np.arange(1,11)
y = 2 * x + 5
plt.title("Matplotlib demo")
plt.xlabel("x axis caption")
plt.ylabel("y axis caption")
plt.plot(x,y)
plt.show()
Obiekt ndarray x jest tworzony z np.arange() function jako wartości na x axis. Odpowiednie wartości w plikuy axis są przechowywane w innym ndarray object y. Te wartości są wykreślane przy użyciuplot() funkcja podmodułu pyplot pakietu matplotlib.
Graficzna reprezentacja jest wyświetlana przez show() funkcjonować.
Powyższy kod powinien dać następujący wynik -
Zamiast wykresu liniowego wartości można wyświetlać dyskretnie, dodając ciąg formatu do pliku plot()funkcjonować. Można użyć następujących znaków formatujących.
Sr.No. | Opis postaci |
---|---|
1 | '-' Styl linii ciągłej |
2 | '--' Styl linii przerywanej |
3 | '-.' Styl linii przerywanej |
4 | ':' Styl linii kropkowanej |
5 | '.' Znacznik punktu |
6 | ',' Znacznik pikseli |
7 | 'o' Znacznik okręgu |
8 | 'v' Znacznik trójkąta w dół |
9 | '^' Znacznik Triangle_up |
10 | '<' Znacznik Triangle_left |
11 | '>' Znacznik Triangle_right |
12 | '1' Znacznik Tri_down |
13 | '2' Znacznik Tri_up |
14 | '3' Znacznik Tri_left |
15 | '4' Znacznik Tri_right |
16 | 's' Znacznik kwadratowy |
17 | 'p' Marker Pentagon |
18 | '*' Znacznik gwiazdy |
19 | 'h' Marker Hexagon1 |
20 | 'H' Marker Hexagon2 |
21 | '+' Znacznik plus |
22 | 'x' Znacznik X |
23 | 'D' Marker diamentowy |
24 | 'd' Marker Cienki Diament |
25 | '|' Marker Vline |
26 | '_' Znacznik linii |
Zdefiniowano również następujące skróty kolorów.
Postać | Kolor |
---|---|
'b' | niebieski |
'sol' | Zielony |
„r” | Czerwony |
'do' | Cyjan |
'm' | Magenta |
'y' | Żółty |
„k” | czarny |
„w” | Biały |
Aby wyświetlić okręgi reprezentujące punkty, zamiast linii w powyższym przykładzie, użyj “ob” jako ciąg formatu w funkcji plot ().
Przykład
import numpy as np
from matplotlib import pyplot as plt
x = np.arange(1,11)
y = 2 * x + 5
plt.title("Matplotlib demo")
plt.xlabel("x axis caption")
plt.ylabel("y axis caption")
plt.plot(x,y,"ob")
plt.show()
Powyższy kod powinien dać następujący wynik -
Wykres sinusoidalny
Poniższy skrypt tworzy plik sine wave plot przy użyciu matplotlib.
Przykład
import numpy as np
import matplotlib.pyplot as plt
# Compute the x and y coordinates for points on a sine curve
x = np.arange(0, 3 * np.pi, 0.1)
y = np.sin(x)
plt.title("sine wave form")
# Plot the points using matplotlib
plt.plot(x, y)
plt.show()
wątek poboczny()
Funkcja subplot () umożliwia wykreślenie różnych rzeczy na tej samej figurze. W poniższym skrypciesine i cosine values są kreślone.
Przykład
import numpy as np
import matplotlib.pyplot as plt
# Compute the x and y coordinates for points on sine and cosine curves
x = np.arange(0, 3 * np.pi, 0.1)
y_sin = np.sin(x)
y_cos = np.cos(x)
# Set up a subplot grid that has height 2 and width 1,
# and set the first such subplot as active.
plt.subplot(2, 1, 1)
# Make the first plot
plt.plot(x, y_sin)
plt.title('Sine')
# Set the second subplot as active, and make the second plot.
plt.subplot(2, 1, 2)
plt.plot(x, y_cos)
plt.title('Cosine')
# Show the figure.
plt.show()
Powyższy kod powinien dać następujący wynik -
bar()
Plik pyplot submodule zapewnia bar()funkcja do generowania wykresów słupkowych. Poniższy przykład tworzy wykres słupkowy dwóch zestawówx i y tablice.
Przykład
from matplotlib import pyplot as plt
x = [5,8,10]
y = [12,16,6]
x2 = [6,9,11]
y2 = [6,15,7]
plt.bar(x, y, align = 'center')
plt.bar(x2, y2, color = 'g', align = 'center')
plt.title('Bar graph')
plt.ylabel('Y axis')
plt.xlabel('X axis')
plt.show()
Ten kod powinien dawać następujące dane wyjściowe -
NumPy ma numpy.histogram()funkcja, która jest graficzną reprezentacją rozkładu częstotliwości danych. Prostokąty o równej wielkości poziomej odpowiadające przedziałowi klasy tzwbin i variable height odpowiadające częstotliwości.
numpy.histogram ()
Funkcja numpy.histogram () przyjmuje tablicę wejściową i elementy bins jako dwa parametry. Kolejne elementy w tablicy bin działają jako granica każdego bin.
import numpy as np
a = np.array([22,87,5,43,56,73,55,54,11,20,51,5,79,31,27])
np.histogram(a,bins = [0,20,40,60,80,100])
hist,bins = np.histogram(a,bins = [0,20,40,60,80,100])
print hist
print bins
Wytworzy następujący wynik -
[3 4 5 2 1]
[0 20 40 60 80 100]
plt ()
Matplotlib może przekształcić tę numeryczną reprezentację histogramu w wykres. Plikplt() function of pyplot submodule pobiera tablicę zawierającą dane i tablicę bin jako parametry i konwertuje na histogram.
from matplotlib import pyplot as plt
import numpy as np
a = np.array([22,87,5,43,56,73,55,54,11,20,51,5,79,31,27])
plt.hist(a, bins = [0,20,40,60,80,100])
plt.title("histogram")
plt.show()
Powinien dać następujący wynik -
Obiekty ndarray można zapisywać i ładować z plików dyskowych. Dostępne funkcje we / wy to -
load() i save() funkcje obsługują pliki binarne / numPy (z plikami npy rozbudowa)
loadtxt() i savetxt() funkcje obsługują zwykłe pliki tekstowe
NumPy wprowadza prosty format plików dla obiektów ndarray. To.npy file przechowuje dane, kształt, typ i inne informacje wymagane do zrekonstruowania tablicy ndarray w pliku dyskowym, tak że tablica jest poprawnie pobierana, nawet jeśli plik znajduje się na innym komputerze o innej architekturze.
numpy.save ()
Plik numpy.save() file przechowuje tablicę wejściową w pliku dyskowym z rozszerzeniem npy rozbudowa.
import numpy as np
a = np.array([1,2,3,4,5])
np.save('outfile',a)
Aby zrekonstruować tablicę z outfile.npy, posługiwać się load() funkcjonować.
import numpy as np
b = np.load('outfile.npy')
print b
Wytworzy następujący wynik -
array([1, 2, 3, 4, 5])
Funkcje save () i load () akceptują dodatkowy parametr logiczny allow_pickles. Pickle w Pythonie służy do serializacji i deserializacji obiektów przed zapisaniem lub odczytem z pliku dyskowego.
savetxt ()
Przechowywanie i pobieranie danych tablicowych w prostym formacie pliku tekstowego odbywa się za pomocą savetxt() i loadtxt() Funkcje.
Przykład
import numpy as np
a = np.array([1,2,3,4,5])
np.savetxt('out.txt',a)
b = np.loadtxt('out.txt')
print b
Wytworzy następujący wynik -
[ 1. 2. 3. 4. 5.]
Funkcje savetxt () i loadtxt () akceptują dodatkowe opcjonalne parametry, takie jak nagłówek, stopka i separator.