Learning Objectives
- Input variables
- Target variable
- Train and Test data intuition
- Building an ML Model
In this module, we will give a quick recap that will help you solidify the concepts you have learned so far with some intuitive examples. This will be focused more on Model Building.
Building a ML Model (Quick Recap)
Data Science Modelling Process
data:image/s3,"s3://crabby-images/77bda/77bda0fd4985293ec267b378f61e6b9a51dba97b" alt="image.png"
Credits: https://towardsdatascience.com/data-science-modeling-process-fa6e8e45bf02
Problem Solving steps
- Define Objective or understand the problem statement
- Data Requirements
- Data Collection/Preparation
- Exploratory Data Analysis
- Data Pre-processing
- Build a model
- Understand whether it is a regression or classification problem
- Evaluate
- Optimise
- Production
- Monitor
- You keep Optimising it every now and then
Problem Statement
HR department wanted to seek the support of the analytics team to get possible salary predictions given they have information about employees' Career Seniority Levels and years of experience.
In other words, they need a machine learning model that would predict the possible salary that one should be provided if they feed information about their seniority level and years of experience.
data:image/s3,"s3://crabby-images/b4993/b4993ad5a3cd51b5a3ccb91ff67fb8127e0932d9" alt="image.png"
Data Preparation
- Given: we have to predict a person's salary based on years of experience.
- We have a dataset that looks like this:
data:image/s3,"s3://crabby-images/09c1d/09c1d2ee732558be32a443882d95037f210abc9e" alt="image.png"
- What features do we have here?
- We have 3 features: Seniority_Level, Years_of_Experience, and Salary.
- What will our target variable(value to be predicted) be in this case?
- Since Salary needs to be predicted, our model will take that to be the target variable and the rest (Seniority_Level, Years_of_Experience) as input variables.
- In short, we’ll predict the target variable using input variables.
data:image/s3,"s3://crabby-images/a8e57/a8e572c6bbcd1814e83a7f93349fad6df201bd1d" alt="image.png"
Separating input and target variable
- Now how do you actually separate the input and target variables?
- Since there’s only one target variable in the DataFrame, we can simply drop it and choose the rest of the variables. We do this using the drop( ) function by simply providing column name inside it.
data:image/s3,"s3://crabby-images/4813c/4813cf227242959802b68ee7bc0daf7440f7d4b7" alt="image.png"
Train and Test Data
- Another data splitting that we need to do is dividing the data into Train and Test Sets.
- Imagine drawing a horizontal line between the table, let’s say, after the 8th entry. That’s what Train Test Split looks like. The whole table is now divided into 4 parts.
- PLEASE NOTE: The dataset should always be shuffled before splitting. We’ve used an unshuffled version here just for explanation.
data:image/s3,"s3://crabby-images/faa74/faa741e444ac427b24398445c375cf724b1a0e2a" alt="image.png"
- The upper part of the table becomes the Train Set which consists of X_train (The input variables) and y_train (The output variable).
data:image/s3,"s3://crabby-images/f7849/f7849efc95ae7087586f15372b4f2fd3f2a4a11a" alt="image.png"
- The lower part of the table becomes the Test Set which consists of X_test (The input variables) and y_test (The output variable).
data:image/s3,"s3://crabby-images/59f4c/59f4cd920d807961bd1c3dc5f97b2065cdc13c90" alt="image.png"
- The sklearn’s function used for splitting the dataset is known as train_test_split
data:image/s3,"s3://crabby-images/d9c76/d9c76b6fa0c4a294474ff1610f34dabbae6da7ee" alt="image.png"
- The 4 variables that we learned about in the previous slides are assigned values using the above piece of code. Let’s understand what the values inside the brackets mean:
- X = Input variables
- y = Target variable
- test_size = The ratio of the dataset that’ll be used in test set. If there are 100 rows, 70 rows will be used in train set and 30 in test set.
- random_state = It is provided just for the sake of obtaining the same result every time we run the code. It ensures that the rows in train and test set remain same each time.
Model Building
Let’s build the simplest of all regression models using Linear Regression now.
- Import the model from sklearn
- Initialise and store the model in a variable (linear_regressor in this case)
- Train the model on Train Data(X_train and y_train) using the fit method.
data:image/s3,"s3://crabby-images/fb297/fb2977c5fc350968178925b0c02936cebc462000" alt="image.png"
Understanding the type of Problem
- For understanding the type of problem, we need to see the target variable we are dealing with.
- What kind of variable is Salary? Does it have classes? No, right?
- Salary is numerical and different salaries are not divided into classes but are rather continuous values.
- The technique used for determining relationship between the input and target variables where the target variable is numerical (or continuous) is known as Regression.
Model Evaluation
- Our model has been created! But how do we know if it works well? By testing it on the Test Data we created.
- Remember the test data is also split into 2 parts - X_test and y_test?
- We’ll first put the X_test(input variables) in our model and see what Salary predicts for those input values. The actual values of the salaries(y_test) are not shown to the model.
data:image/s3,"s3://crabby-images/447c2/447c28e8d0af79f949562333309f3f20a8d30b89" alt="image.png"
- Let’s say our model predicts the following salaries:
data:image/s3,"s3://crabby-images/abfca/abfcabe40be1baf4f99f61df76557763c97b4e50" alt="image.png"
- This prediction is done using the predict function of sklearn. Inside the predict function, we’ll provide X_test to the model.
data:image/s3,"s3://crabby-images/c2b37/c2b379709f43f1e44c2cc604b1e2c93cb44b1cfc" alt="image.png"
- To know how good these predictions (y_pred) are, we’ll have to compare them to the actual salary values (y_test).
ACTUAL VALUES | PREDICTED VALUES |
---|---|
![]() | ![]() |
- There are a lot of evaluation metrics for regression problems. Let’s use Root Mean Squared Error for this case.
Root Mean Squared Error (RMSE)
- It is just the square root of the mean square error.
- It is preferred more in some cases because the errors are first squared before averaging which poses a high penalty on large errors. This implies that RMSE is useful when large errors are undesired.
data:image/s3,"s3://crabby-images/0e00d/0e00d50173f0cb29f0edd735069b50a3527888b0" alt="image.png"
- For using RMSE, we’ll first import metrics library from sklearn.
1 2
# import metrics library from sklearn import metrics
- RMSE is not present as a function in sklearn. So we’ll just use the mean_squared_error function and take its square root . The main thing to note is what we provide inside the function - y_test (actual value) and y_pred(predictions made by our model).
1 2
# print results of RMSE print(np.sqrt(metrics.mean_squared_error(y_test, y_pred)))
Video Tutorial
Transformations on Train and Test
- Now let’s say we performed some feature selection techniques and found out that Seniority_Level is not an important feature, the model can perform better when only Years_of_Experience is used.
- We’ll then transform our train data to a dataset with only Years_of_Experience as input variable to predict our target variable Salary.
- Now what about test data? Should we remove the Seniority_Level feature from that as well?
- The answer is yes.
- The Train and Test data must undergo the same data preparation steps. Otherwise, the predictive model will not make sense. This means that the number of features for both the training and test set should be the same and represent the same thing.
- Similarly, if normalization is required, then it should be done on both the train and test sets.
Slides Download Link
You can download the slides for this topic from here.