Introduction to Numpy in Python
Last Updated on October 29, 2021 by Editorial Team
Author(s): sonia jessica
Programming
What isΒ NumPy?
NumPy stands for numeric python, a Python module that allows you to compute and manipulate multi-dimensional and single-dimensional array items. It comes with a high-performance multidimensional array object as well as utilities for working withΒ them.
In 2005, Travis Oliphant created the NumPy package by combining the features of the ancestral module Numeric with the characteristics of another module Numarray. NumPy implements multidimensional arrays and matrices as well as other complex data structures. These data structures help to compute arrays and matrices in the most efficient way possible. NumPy allows you to conduct mathematical and logical operations on arrays. Many other prominent Python packages, like pandas and matplotlib, are compatible with Numpy and useΒ it.
Need to use NumPy inΒ Python?
NumPy is a valuable and efficient tool for dealing with large amounts of data. NumPy is quick; thus, itβs easy to work with a vast amount of data. Data analysis libraries like NumPy, SciPy, Pandas, and others have exploded in popularity due to the data science revolution. Python is the most simple language in terms of syntax, and is the priority for many data scientists; therefore, NumPy is getting popular day by day.
Many mathematical procedures commonly used in scientific computing are made quick and simple with Numpy, including:
- Multiplication of Vector or Matrix to Vector orΒ Matrix.
- Operations on vectors and matrices at the element level (i.e., adding, subtracting, multiplying, and dividing by a numberΒ )
- Applying functions to a vector/matrix element by element ( like power, log, and exponential).
- NumPy has functions for linear algebra and random number generation built-in.
- NumPy also makes matrix multiplication and data reshaping simple.
- Multidimensional arrays are implemented efficiently usingΒ NumPy.
- NumPy arrays in Python give capabilities for integrating C, C++, and other languages. Itβs also useful in linear algebra and random number generation, among other things. NumPy arrays can also be used to store generic data in a multi-dimensional container.
- Itβs faster than standard Python arrays, which donβt have NumPyβs pre-compiled C code(Precompiled code is a header file that is compiled into an intermediate form that is faster to process for the compiler).
Installation ofΒ NumPy
Go to your command prompt and run βpip install numpyβ to install Python NumPy. Once the installation is complete, simply go to your IDE (for example, VS Code, Jupyter Notebook, PyCharm) and type βimport numpy as npβ to import it; now you are ready to useΒ NumPy.
What is a NumPyΒ Array?
The Numpy array object is a strong N-dimensional array object with rows and columns. NumPy arrays can be created from nested Python lists, and their elements can be accessed. It refers to a group of items that are all of the same types and can be accessed using zero-based indexing. Every item in a ndarray is the same size as the memory block. Each entry in ndarray is a data-type object (calledΒ dtype).
Types of NumpyΒ Array:
- One-Dimensional NumPy array
A one-dimensional array has only one dimension of elements. In other words, the one-dimensional NumPy array should only contain one tuple value.
Example:
# One-Dimensional Array
import numpy as np
val=np.array([1, 5, 2, 6])
print(val)
Implementation:-
Explanation: print() function is used to print the whole array provided.
- Multi-Dimensional NumPy Array
A multi-dimensional array can have n dimensions of elements. In other words, the multi-dimensional NumPy array can contain a number of tuple values.
Example:
# Multi-Dimensional Array
import numpy as np
val=np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val)
Implementation:
Explanation: print() function is used to print the whole array provided.
Accessing Element in theΒ Array
Indexing or accessing the array index in a NumPy array can be done in a variety of ways.
1. Slicing is used to print a range of an array. The built-in slice function is used to create a Python slice object by passing start, stop, and step parameters to it. Slicing an array involves establishing a range in a new array used to print a subset of the original arrayβs elements. Because a sliced array holds a subset of the original arrayβs elements, editing content alters the original arrayβs content.
ExampleΒ 1:
# Accessing Array Element
import numpy as np
val=np.array([1, 5, 2, 6])
# Zero based indexing
print(val[1])
val_mul=np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val_mul[1][1])
Implementation:
Explanation: Here we are accessing the 1st index value of the 1-D array via writing val[1] and accessing the value in the 2nd row and 2nd column of the 2-D array as the arrays have zero-based indexing.
Example 2:
#Accessing Range of Elements
#in array using slicing
val_mul=np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
slice_val = val_mul[:2, :2]
print (βFirst 2 rows and columns of the array\nβ, slice_val)
Implementation:
Implementation:
Explanation: Here we are trying to access the values in rows and columns starting from 1st row to 2nd row by writing βΒ :2 β as the first argument and similarly accessing all the values corresponding to those rows and having columns from starting to theΒ 2nd.
Example 3:
val_mul1=np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6),(1, 5, 0, 1),(7, 3, 3, 0)])
slice_step_row = val_mul1[::2, :2]
print (βAll rows and 2 columns of the array with step size of 2 along the row\nβ, slice_step_row)
Implementation:
Explanation: Here we are trying to access the values in rows and columns starting from 1st row to end row with a step size of 2 which means the difference between consecutive rows to be 2 by writing β::2 β as the first argument and similarly accessing all the values corresponding to those rows and having columns from starting to theΒ 2nd.
Example 4:
# Accessing multiple elements at one go
val_mul1=np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6),(1, 5, 0, 1),(7, 3, 3, 0)])
mul_idx_arr = val_mul1[
[1, 2, 2, 3],
[1, 2, 3, 3]
]
print (β\nAccessing Elements at multiple indices (1, 1),(2, 2), (2, 3), (3, 3) ββ, mul_idx_arr)
Implementation:
Explanation: Here we are trying to access the values from the array which are present at the indexes (1,1),(2,2),(2,3), andΒ (3,3).
2. Another type of accessing technique is the boolean array indexing where we can give the condition where elements that follow the condition areΒ printed.
Example:
# Boolean array indexing
val_mul=np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6),(1, 5, 0, 1),(7, 3, 3, 0)])
condition = val_mul > 3
res = val_mul[condition]
print (res)
Implementation:
Explanation: Here we are accessing the values which follow the given conditions i.e. the value of the element should be greater thanΒ 3.
Frequently used Operations on NumpyΒ Array
- ndim– This operation is used to compute the dimension of theΒ array.
Example:
# Dimension of the array
val1 = np.array([1, 5, 2, 6])
print(val1.ndim)
# 2-D array
val2 = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val2.ndim)
Implementation:
Explanation: Here val1 is a 1-D array having values 1,5,2 and 6 therefore we are getting value 1 for val1.ndim and val2 is a 2-D array
3 4 2 5
3 6 2 4
1 5 2 6
Therefore we are getting value 2 corresponding to val2.ndim
- SizeβββThis operation is used to calculate the number of elements in theΒ array.
Example:
# Calculate Array Size
val2 = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val2.size)
Implementation:
Explanation: Here val2 contains 12 values 3, 4, 2, 5, 3, 6, 2, 4, 1, 5, 2, 6 therefore we are getting the size of the val2 array asΒ 12.
- ShapeβββThis operation is used to calculate the shape of theΒ array.
Example:
# Calculate Array Shape
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val.shape)
Implementation:
Explanation: Here Val array is a 2-D array
3 4 2 5
3 6 2 4
1 5 2 6
It has 3 rows and 4 columns and val.shape is used to get the size corresponding to each dimension.
- ReshapeβββReshape is used to reshape the array according to the given parameters
Example:
# Reshape the Array
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val)
val=val.reshape(2,6)
print(val)
Implementation:
Explanation: reshape function helps us to reshape the array and fill the values of the array correspondingly. Here we have 12 values and we want to reshape the array from (3,4) to (2,6) so now there would be only 2 rows and 6Β columns.
- TransposeβββT operator is used in getting the transpose of an array.
Example:
# Transpose of an array
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val.T)
Implementation:
Explanation: When we need to replace all the rows of an array with the columns and columns with rows then we need to call the val.T to get the transpose of the array. In transpose, the shape of the array changes as now number of rows becomes a number of columns and vice versa. As here 3, 4, 2, 5 was the first row initially but after transpose, it becomes the 1stΒ column.
- Ravelβββravel is used to convert the array into a single column
Example:
# Convert Array to Single Column
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val.ravel())
Implementation:
Explanation: When we want to convert the array to a 1-D array we use the ravel function as it combines all the values of the array as in the above example we had initially a 2-D array of 3 rows and 4 columns but after applying the ravel function we gets the 1-D array of 12Β values.
- Itemsize: Itemsize is used to compute the size of each element in bytes.
Example:
# Calculate Array Itemsize
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
# size of each element in bytes
print(val.itemsize)
Implementation:
Explanation: When we want to get the size of each element in bytes we use (array_name.itemsize) as in the above example the data type is int32 which means integer of 32 bits and as we know that 1 byte is equal to 8 bits and hence it is 4 bytes inΒ size.
- Dtype– Dtype is used to get the data type of the elements in the array.
Example:
# Calculate Data type of each element
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val.dtype)
Implementation:
Explanation: When we want to compute the data type of the elements present in the array we use val.dtype which gives us the data type here in the above example the values of the array are integer so the data type given is int32 which means it represents an integer of 32Β bits.
- np.zeros()/np.ones()βββones() and zeros() functions of numpy are used to generate arrays having all 1βs and 0βs respectively.
Example:
# Generating array having all 1's
val = np.ones(3)
print(val)
# Generating array having all 0's
val0 = np.zeros(3)
print(val0)
Implementation:
Explanation: When we want to generate an array having all 1βs or 0βs we use the above-given functions which helped us generate an array of size n. Here we gave the size of the array as 3 so an array of size 3 having all 1βs and 0βs is generated.
– linspaceβββThe linspace function is used to generate an array containing elements distributed equally in a given range. It takes 3 parameters to start and end of the range and the number of elements to be present in theΒ array.
Example:
# Linspce generate 8 numbers present in range 2β5
val = np.linspace(2,5,8)
print(val)
Implementation:
Explanation: When we want to generate an array having specific order like in range x to y and size of the array to be n then we use linspace function as here we wanted to generate an array of size 8 having values equally spaced between range 2 toΒ 5.
- MaxβββMax is used in getting the maximum element across the wholeΒ array.
Example:
# Find maximum element in whole array
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val.max())
Implementation:
Explanation: When we want to calculate the maximum of all elements of the array we can simply write array_name.max() and get the maximum element as here we get 6 which is the maximum of all the elements.
- MinβββMin function is used in getting the minimum element across the wholeΒ array.
Example:
# Find minimum element in whole array
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val.min())
Implementation:
Explanation: When we want to calculate the minimum of all elements of the array we can simply write array_name.min() and get the minimum element as here we get 1 which is the minimum of all the elements.
- SumβββSum function is used to get the total of all the elements of theΒ array.
Example:
# Sum of all elements in whole array
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val.sum())
Implementation:
Explanation: When we want to calculate the sum of all elements of the array we can simply write array_name.sum().
- np.sqrt()βββThis function is used to get the square root of all the elements of the array.
Example:
# Used to calculate square root of each element
val=np.array([1, 4, 9])
print(np.sqrt(val))
Implementation:
Explanation: When we want to calculate the square root of each value of an array we can simply write np.sqrt(array_name) and we get the corresponding square roots to each and every value e.g. 2 corresponding to 4 and 3 corresponding toΒ 9.
- np.std(): This function is used to calculate the standard deviation of all the elements of theΒ array.
Example:
# Used to calculate standard deviation of all elements
val=np.array([1, 4, 9])
print(np.std(val))
Implementation:
Explanation: When we want to find the standard deviation of all the values of the array we do not need to do the hectic math calculation for calculating the standard deviation, we can simply write (np.std(array_name)).
- Summation operation on the arrayβββWhen we need to add some particular number n to all the elements of the array or one array to anotherΒ array.
Example1:
# Add number 3 to all elements of array val
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val+3)
Implementation:
Explanation: When we want to add value n from each value of array we can simply write (array_name+n).
Example 2:
# Add array val to another array val1
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
val1 = np.array([(4, 4, 8, 2),(9, 0, 3, 5),(6, 8, 3, 3)])
print(val+val1)
Implementation:
Explanation: When we want to find the addition of 2 arrays we can simply write (array1+array2) to get the addition of arrays but just keep in mind that the dimensions of both the arrays must be theΒ same.
- Subtraction operation on the arrayβββWhen we need to subtract some particular number n to all the elements of the array or one array from anotherΒ array.
Example1:
# Subtract number 3 from all elements of array val
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val-3)
Implementation:
Explanation: When we want to subtract value n from each value of array we can simply write (array_name-n).
Example 2:
# Subtract array val from another array val1
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
val1 = np.array([(4, 4, 8, 2),(9, 0, 3, 5),(6, 8, 3, 3)])
print(val1-val)
Implementation:
Explanation: When we want to find the difference between 2 arrays we can simply write (array1-array2) to get the difference of arrays but just keep in mind that the dimensions of both the arrays must be theΒ same.
- Power of each element of the array raised to numberΒ n:
Example:
# Power of each element of the array raise to 3
# Cube of each element
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val**(3))
# Power of each element of the array raise to 0.5
# Square root of each element
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val**(0.5))
Implementation:
Explanation: Here we are raising to the power of 3 each and every value of the array and printing it.When we want to raise to the power of n each value of array we simply write (array_name)**n to raise to the power of each and every value of the array by valueΒ n.
- Modify eachΒ element:
Example:
# Multiply each element of the array by 3
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val*(3))
# Divide each element of the array by 3
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(val/3)
Implementation:
Explanation: Here we are multiplying each and every value of the array by 3 and printing it. Similarly, when we want to divide each value of array we simply write (array_name)/n to divide the array by valueΒ n.
- np.sort()βββThis function is used to sort the array and takes the argument axis which allows sorting the array row-wise and column-wise when initialized with values 1 and 0 respectively.
Example1:
# Sort the array row-wise
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
print(np.sort(val,axis=1))
Implementation:
Explanation: Here we are sorting the values of the array row-wise as we have provided the value of the axis asΒ 1.
Example2:
# Sort the array column-wise
val = np.array([(3, 4, 2, 5),(3, 6, 2, 4),(1, 5, 2, 6)])
np.sort(val,axis=0)
Implementation:
Explanation: Here we are sorting the values of the array column-wise as we have provided the value of the axis asΒ 0.
What to doΒ next?
The NumPy library in Python is one of the most widely used libraries for numerical computation. We looked at the NumPy library in-depth with the help of various examples in this article. We also demonstrated how to utilize the NumPy library to do several linear algebra operations. I recommend that you practice the examples provided in this post. If you want to work as a data scientist, the NumPy library is one of the tools youβll need to master to be a successful and productive member of the profession. LearnΒ More.
Introduction to Numpy in Python was originally published in Towards AI on Medium, where people are continuing the conversation by highlighting and responding to this story.
Published via Towards AI