Numpy (Numerical Python) John R. Woodward
Introduction Numpy Numeric Python Fast computation with n-dimensional arrays
Numpy Based around one data structure ndarray n-dimensional array Import with import numpy as np Usage is np.command(xxx)
ndarrays 1d: 5,67,43,76,2,21 a=np.array([5,67,43,76,2,21]) 2d: 4,5,8,4 6,3,2,1 8,6,4,3 a=np.array([4,5,8,4],[6,3,2,1],[8,6,4,3])
*, + import numpy as np data = randn(2, 3) print data print data * 10 print data + data [[ 0.079 -0.8418 -0.0838] [-1.4497 0.6628 1.1006]] [[ 0.7896 -8.4175 -0.8378] [-14.4973 6.6275 11.0059]] [[ 0.1579 -1.6835 -0.1676] [-2.8995 1.3255 2.2012]]
Shape and dtype OUTPUT (2L, 3L) float64 print data.shape print data.dtype Numpy tries to infer the datatype OUTPUT (2L, 3L) float64
Creating ndarrays data1 = [6, 7.5, 8, 0, 1] arr1 = np.array(data1) print arr1 Output [ 6. 7.5 8. 0. 1. ]
Multidimensional arrays data2 = [[1, 2, 3, 4], [5, 6, 7, 8]] arr2 = np.array(data2) print arr2 print arr2.ndim print arr2.shape OUTPUT [[1 2 3 4] [5 6 7 8]] 2 (2L, 4L)
print arr2 print arr2.ndim print type(arr2.ndim) print arr2.shape print type(arr2.shape) print arr2.shape[0] print arr2.shape[1]
OUTPUT [[1 2 3 4] [5 6 7 8]] 2 <type 'int'> (2L, 4L) <type 'tuple'> 4 print arr2 print arr2.ndim print type(arr2.ndim) print arr2.shape print type(arr2.shape) print arr2.shape[0] print arr2.shape[1]
3d array data2 = [[[1]]] arr2 = np.array(data2) print arr2 print arr2.ndim print arr2.shape
3d array OUTPUT [[[1]]] 3 (1L, 1L, 1L) data2 = [[[1]]] arr2 = np.array(data2) print arr2 print arr2.ndim print arr2.shape OUTPUT [[[1]]] 3 (1L, 1L, 1L)
More making arrays np.zeros(10) np.zeros((3, 6)) np.empty((2, 3, 2)) [ 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.] [[ 0. 0. 0. 0. 0. 0.] [ 0. 0. 0. 0. 0. 0.] [ 0. 0. 0. 0. 0. 0.]] [[[ 0. 0.] [ 0. 0.] [ 0. 0.]] [[ 0. 0.] [ 0. 0.]]] np.zeros(10) np.zeros((3, 6)) np.empty((2, 3, 2))
Operations between arrays and scalars arr = np.array ([1., 2., 3.]) print arr print arr * arr print arr - arr print 1 / arr print arr ** 0.5
Operations between arrays and scalars output [ 1. 2. 3.] [ 1. 4. 9.] [ 0. 0. 0.] [ 1. 0.5 0.3333] [ 1. 1.4142 1.7321] arr = np.array ([1., 2., 3.]) print arr print arr * arr print arr - arr print 1 / arr print arr ** 0.5
Array creation functions
a=np.array([True], dtype=np.int64) print a print a.dtype a=np.array([True], dtype=np.bool)
[1] Int64 [ True] bool a=np.array([True], dtype=np.int64) print a print a.dtype a=np.array([True], dtype=np.bool) [1] Int64 [ True] bool
NumPy data types 1
NumPy data types 2
astype [ 3.7 -1.2 -2.6] [ 3 -1 -2] arr = np.array( [3.7, -1.2, -2.6]) print arr print arr.astype(np.int32) note that the data has been truncated.
astype - string to float numeric_strings = np.array(['1.25', '-9.6', '42'], dtype=np.string_) print numeric_strings print numeric_strings.astype(float) ['1.25' '-9.6' '42'] [ 1.25 -9.6 42. ]
Basic indexing and slicing (broadcasting) arr = np.arange(10) print arr print arr[5] print arr[5:8] arr[5:8] = 12 [0 1 2 3 4 5 6 7 8 9] 5 [5 6 7] [ 0 1 2 3 4 12 12 12 8 9]
The original array has changed arr_slice = arr[5:8] arr_slice[1] = 12345 print arr arr_slice[:] = 64 [ 0 1 2 3 4 12 12345 12 8 9] [ 0 1 2 3 4 64 64 64 8 9]
2d array [7 8 9] 3 arr2d = np.array ([[1, 2, 3], [4, 5, 6], [7, 8, 9]]) print arr2d[2] print arr2d[0][2] print arr2d[0, 2] (last two are same) [7 8 9] 3
3d array [[[ 1 2 3] [ 4 5 6]] [[ 7 8 9] [10 11 12]]] [[1 2 3] [4 5 6]] [[[ 1 2 3] [ 4 5 6]] [[ 7 8 9] [10 11 12]]] [[1 2 3] [4 5 6]] [10 11 12]] arr3d = np.array ([[[1, 2, 3], [4, 5, 6]], [[7, 8, 9], [10, 11, 12]]]) print arr3d print arr3d[0] print arr3d[1]
Indexing with slices – 1D arr = np.arange(10) print arr print arr[1:6] Output [0 1 2 3 4 5 6 7 8 9] [1 2 3 4 5]
Indexing with slices – 2D [[1 2 3] [4 5 6] [7 8 9]] [4 5 6]] [[2 3] [5 6]] arr2d = np.array( [[1, 2, 3], [4, 5, 6], [7, 8, 9]]) print arr2d print arr2d[:2] print arr2d[:2, 1:]
Indexing with slices – 2D arr2d = np.array( [[1, 2, 3], [4, 5, 6], [7, 8, 9]]) print arr2d[1, :2] print arr2d[2, :1] print arr2d[:, :1] [4 5] [7] [[1] [4] [7]]
Fancy indexing indexing using integer arrays arr = np.empty((8, 4)) [[ 0. 0. 0. 0.] [ 1. 1. 1. 1.] [ 2. 2. 2. 2.] [ 3. 3. 3. 3.] [ 4. 4. 4. 4.] [ 5. 5. 5. 5.] [ 6. 6. 6. 6.] [ 7. 7. 7. 7.]] [[ 4. 4. 4. 4.] [ 0. 0. 0. 0.] [ 6. 6. 6. 6.]] [[ 5. 5. 5. 5.] [ 1. 1. 1. 1.]] Fancy indexing indexing using integer arrays arr = np.empty((8, 4)) for i in range(8): arr[i] = i print arr print arr[[4, 3, 0, 6]] print arr[[-3, -5, -7]] Negative index select from the end
Transposing arrays and swapping axes [[ 0 1 2 3 4] [ 5 6 7 8 9] [10 11 12 13 14]] (3L, 5L) [[ 0 5 10] [ 1 6 11] [ 2 7 12] [ 3 8 13] [ 4 9 14]] (5L, 3L) Transposing arrays and swapping axes arr = np.arange(15).reshape((3, 5)) print arr print arr.shape print arr.T print arr.T.shape
Inner Product (dot operator) [[0 1] [2 3]] [[0 2] [1 3]] [[ 4 6] [ 6 10]] [[ 1 3] [ 3 13]] arr = np.arange(4). reshape((2, 2)) print arr print arr.T print np.dot(arr.T, arr) print np.dot(arr, arr.T)
Inner Product (dot operator) arr = np.arange(9).reshape((3, 3)) print arr print np.dot(arr.T, arr) [[0 1 2] [3 4 5] [6 7 8]] [[45 54 63] [54 66 78] [63 78 93]]
arr*arr [[ 0 1 4] [[0 1 2] [ 9 16 25] [3 4 5] [36 49 64]] [6 7 8]] arr = np.arange(9).reshape((3, 3)) print arr print arr*arr [[0 1 2] [3 4 5] [6 7 8]] [[ 0 1 4] [ 9 16 25] [36 49 64]]
Fast element-wise array functions arr = np.arange(5) print arr print np.sqrt(arr) print np.exp(arr) [0 1 2 3 4] [ 0. 1. 1.4142 1.7321 2. ] [ 1. 2.7183 7.3891 20.0855 54.5982]
element-wise maximum x = randn(4) y = randn(4) print x print y print np.maximum(x, y) [-0.9691 -1.4411 1.2614 -0.9615] [-0.0398 -0.0692 -1.6854 -0.3902] [-0.0398 -0.0692 1.2614 -0.3902]
element-wise add x = randn(4) y = randn(4) print x print y print np.add(x, y) [ 0.0987 -1.2579 -1.4827 -1.4299] [-0.2855 -0.7548 -1.0134 0.7546] [-0.1868 -2.0127 -2.4961 -0.6753]