Graph Might You Choose to Display a Single Variable That Holds Continuous Data
The histogram is a very commonly used chart in machine learning. It is applicable to continuous variables, like sales, age, salary, profits, Number of customers, etc using the built-in function hist() of a pandas data frame.
You can plot the histogram for those columns in your data which are continuous in nature and can take any value between a min and max range.
A very common mistake is that people plot the histogram for those categorical columns which has numbers in it! e.g. Gender(1/0) or Ticket Priority(1/2/3/4/5) etc. The correct graph for categorical columns is a bar chart.
A histogram helps to understand the distribution of values in single continuous column
A histogram helps to understand the distribution of values in one single column. for example, consider the below example, The data contains three continuous columns(Salary, Age, and Cibil) and one categorical column(Approve_Loan). You can visualize the distribution of continuous columns Salary, Age, and Cibil using a histogram.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | # Creating a sample data frame import pandas as pd ColumnNames = [ 'CIBIL' , 'AGE' , 'SALARY' , 'APPROVE_LOAN' ] DataValues = [ [ 480 , 28 , 610000 , 'Yes' ] , [ 480 , 42 , 140000 , 'No' ] , [ 480 , 29 , 420000 , 'No' ] , [ 490 , 30 , 420000 , 'No' ] , [ 500 , 27 , 420000 , 'No' ] , [ 510 , 34 , 190000 , 'No' ] , [ 550 , 24 , 330000 , 'Yes' ] , [ 560 , 34 , 160000 , 'Yes' ] , [ 560 , 25 , 300000 , 'Yes' ] , [ 570 , 34 , 450000 , 'Yes' ] , [ 590 , 30 , 140000 , 'Yes' ] , [ 600 , 33 , 600000 , 'Yes' ] , [ 600 , 22 , 400000 , 'Yes' ] , [ 600 , 25 , 490000 , 'Yes' ] , [ 610 , 32 , 120000 , 'Yes' ] , [ 630 , 29 , 360000 , 'Yes' ] , [ 630 , 30 , 480000 , 'Yes' ] , [ 660 , 29 , 460000 , 'Yes' ] , [ 700 , 32 , 470000 , 'Yes' ] , [ 740 , 28 , 400000 , 'Yes' ] ] #Create the Data Frame LoanData = pd . DataFrame ( data = DataValues , columns = ColumnNames ) print ( LoanData . head ( ) ) ########################################################## # Generating a histogram for one column in data % matplotlib inline # This line is only required in jupyter notebook LoanData . hist ( column = [ 'SALARY' ] , bins = 4 , figsize = ( 8 , 6 ) ) # Generating a histogram for multiple columns in data % matplotlib inline LoanData . hist ( column = [ 'SALARY' , 'AGE' ] , bins = 5 , figsize = ( 15 , 6 ) ) |
Sample Output:
The X-axis in a histogram represents the range of values present in the column. The Y-axis represents the frequency of values. For example, you can observe in the Histogram for the AGE column, that, there are four values between Age 22.5 Years and 25.0 Years, similarly, you can get an idea about how many values are there in each range.
A Histogram gives you below information
- What is the spread of data? The minimum and maximum values in that column?
- What is the central tendency of the data? A rough idea about the median and the mean values.
- Skewness in the data. Whether there are outliers on the left side(negative skewed) or on the right side(positive skewed)
What is the ideal output of the histogram?
The ideal output of a histogram is a shape like a bell curve. It indicates that the data is normally distributed.
For example, if you generate 100 random values of Age distributed around the mean as 30 Years. Plotting the histogram will generate a bell curve.
This is the type of output that is expected from a histogram of any continuous column. Slight deviations from this curve can be accepted, but If there is too much deviation from normal, then either the outlier treatment is required, or that column is rejected.
Slight deviations from this normal curve can be accepted, but If there is too much deviation from normal, then either the outlier treatment is required, or that column is rejected.
# Ideal Histogram # Generating random number import numpy as np MeanAge = 30 stdDev = 4 TotalValues = 100 RandomAge = np . random . normal ( MeanAge , stdDev , TotalValues ) # Plotting histogram for the random Age values pd . Series ( RandomAge ) . hist ( ) |
Sample Output:
Lead Data Scientist
Farukh is an innovator in solving industry problems using Artificial intelligence. His expertise is backed with 10 years of industry experience. Being a senior data scientist he is responsible for designing the AI/ML solution to provide maximum gains for the clients. As a thought leader, his focus is on solving the key business problems of the CPG Industry. He has worked across different domains like Telecom, Insurance, and Logistics. He has worked with global tech leaders including Infosys, IBM, and Persistent systems. His passion to teach inspired him to create this website!
Source: https://thinkingneuron.com/how-to-visualize-data-distribution-of-a-continuous-variable-in-python/
0 Response to "Graph Might You Choose to Display a Single Variable That Holds Continuous Data"
Publicar un comentario