NumPy-통계 함수

NumPy에는 배열의 주어진 요소에서 최소, 최대, 백분위 수 표준 편차 및 분산 등을 찾는 데 유용한 통계 함수가 많이 있습니다. 기능은 다음과 같이 설명됩니다-

numpy.amin () 및 numpy.amax ()

이 함수는 지정된 축을 따라 지정된 배열의 요소에서 최소값과 최대 값을 반환합니다.

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)

다음과 같은 출력이 생성됩니다.

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 ()

그만큼 numpy.ptp() 함수는 축을 따라 값의 범위 (최대-최소)를 반환합니다.

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)

다음과 같은 출력이 생성됩니다.

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 ()

백분위 수 (또는 백분위 수)는 관측치 그룹에서 주어진 관측치 비율이 아래로 떨어지는 값을 나타내는 통계에 사용되는 측정 값입니다. 함수numpy.percentile() 다음 인수를 사용합니다.

numpy.percentile(a, q, axis)

어디,

Sr. 아니. 인수 및 설명
1

a

입력 배열

2

q

계산할 백분위 수는 0-100 사이 여야합니다.

axis

백분위 수를 계산할 축

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)

다음과 같은 출력이 생성됩니다.

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 ()

Median데이터 샘플의 상위 절반과 하위 절반을 구분하는 값으로 정의됩니다. 그만큼numpy.median() 기능은 다음 프로그램과 같이 사용됩니다.

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)

다음과 같은 출력이 생성됩니다.

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 ()

산술 평균은 축을 따라있는 요소의 합계를 요소 수로 나눈 값입니다. 그만큼numpy.mean()함수는 배열에있는 요소의 산술 평균을 반환합니다. 축이 언급되면 그 축을 따라 계산됩니다.

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)

다음과 같은 출력이 생성됩니다.

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 ()

가중 평균은 각 구성 요소의 중요성을 반영하는 요소를 곱한 결과의 평균입니다. 그만큼numpy.average()함수는 다른 배열에 주어진 각각의 가중치에 따라 배열에있는 요소의 가중치 평균을 계산합니다. 이 함수는 축 매개 변수를 가질 수 있습니다. 축을 지정하지 않으면 배열이 평평 해집니다.

배열 [1,2,3,4] 및 해당 가중치 [4,3,2,1]를 고려할 때 해당 요소의 곱을 더하고 합계를 가중치의 합으로 나누어 가중 평균을 계산합니다.

가중 평균 = (1 * 4 + 2 * 3 + 3 * 2 + 4 * 1) / (4 + 3 + 2 + 1)

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)

다음과 같은 출력이 생성됩니다.

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)

다차원 배열에서는 계산 축을 지정할 수 있습니다.

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)

다음과 같은 출력이 생성됩니다.

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.]))

표준 편차

표준 편차는 평균에서 제곱 된 편차의 평균의 제곱근입니다. 표준 편차의 공식은 다음과 같습니다.

std = sqrt(mean(abs(x - x.mean())**2))

배열이 [1, 2, 3, 4]이면 평균은 2.5입니다. 따라서 제곱 편차는 [2.25, 0.25, 0.25, 2.25]이고 평균의 제곱근을 4로 나눈 값입니다. 즉, sqrt (5/4)는 1.1180339887498949입니다.

import numpy as np 
print np.std([1,2,3,4])

다음과 같은 출력이 생성됩니다.

1.1180339887498949

변화

분산은 제곱 편차의 평균입니다. mean(abs(x - x.mean())**2). 즉, 표준 편차는 분산의 제곱근입니다.

import numpy as np 
print np.var([1,2,3,4])

다음과 같은 출력이 생성됩니다.

1.25