NumPy - funkcje statystyczne
NumPy ma sporo użytecznych funkcji statystycznych do znajdowania minimum, maksimum, percentylowego 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 mieści się 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 0-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 ś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 to średnia 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