
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