Confusion matrix is one of the easiest and most intuitive metrics used for finding the accuracy of a classification model, where the output can be of two or more categories. This is the most popular method used to evaluate logistic regression.
Without much delay, let’s get started.
Confusion matrix is quite simple, but the related terminologies can be a bit confusing. Alright, let us understand the terminologies related to confusion matrix with the help of an example.
Let us say, we have a data set with the data of all patients in a hospital. We built a logistic regression model to predict if a patient has cancer or not. There could be four possible outcomes. Let us look at all four.
True Positive
True positive is nothing but the case where the actual value, as well as the predicted value, are true. The patient has been diagnosed with cancer, and the model also predicted that the patient had cancer.
False Negative
In false negative, the actual value is true, but the predicted value is false, which means that the patient has cancer, but the model predicted that the patient did not have cancer.
Get 100% Hike!
Master Most in Demand Skills Now!
False Positive
This is the case where the predicted value is true, but the actual value is false. Here, the model predicted that the patient had cancer, but in reality, the patient doesn’t have cancer. This is also known as Type 1 Error.
True Negative
This is the case where the actual value is false and the predicted value is also false. In other words, the patient is not diagnosed with cancer and our model predicted that the patient did not have cancer.
If you are looking for Confusion Matrix in R, here’s a video from Intellipaat.
Understanding Various Performance Metrics
We will be taking the help of a confusion matrix given below in order to find various performance metrics.
Alright, let us start with accuracy:
Accuracy or Classification Accuracy:
- What: In classification problems, ‘accuracy’ refers to the number of correct predictions made by the predictive model over the rest of the predictions.
- How:
- When to use: When the target variable classes in the data are nearly balanced
- When not to use: When the target variables in the data are majority of one class
Precision
- What: Here, ‘precision’ means what proportion of all predictions that we made with our predictive model is actually true.
- How:
- It means, when our model predicts that a patient does not have cancer, it is correct 76 percent of the time.
Recall or Sensitivity:
- What: ‘Recall’ is nothing but the measure that tells what proportion of patients that actually had cancer were also predicted of having cancer. It answers the question, “How sensitive the classifier is in detecting positive instances?”
- How:
- It means that 80 percent of all cancer patients are correctly predicted by the model to have cancer.
Specificity:
- What: It answers question, “How specific or selective is the classifier in predicting positive instances?”
- How:
- A specificity of 0.61 means 61 percent of all patients that didn’t have cancer are predicted correctly.
- What: This is nothing but the harmonic mean of precision and recall.
- How:
- F1 score is high, i.e., both precision and recall of the classifier indicate good results.
Prepare yourself for the industry by going through Python technical Interview Questions now!
Implementing Confusion Matrix in Python Sklearn – Breast Cancer
Dataset: In this Confusion Matrix in Python example, the Python data set that we will be using is a subset of famous Breast Cancer Wisconsin (Diagnostic) data set. Some of the key points about this data set are mentioned below:
- Four real-valued measures of each cancer cell nucleus are taken into consideration here.
- Radius_mean represents mean radius of the cell nucleus
- Texture_mean represents mean texture of the cell nucleus
- Perimeter_mean represents mean perimeter of the cell nucleus
- Area_mean represents a mean area of the cell nucleus
- Based on these measures the diagnosed result is divided into two categories, malignant and benign.
- Diagnosis column consists of two categories, malignant (M) and benign (B)
Take a look at the dataset:
Step 1: Load the data set
Step 2: Take a glance at the data set
Step 3: Take a look at the shape of the data set
Step 4: Split the data into features (X) and target (y) label sets
Take a look at the feature set:
Take a look at the target set:
Step 5: Split the data into training and test sets importing scikit learn
Interested to become a Data Scientist? Go through the Data Science course and become a certified professional.
Step 6: Create and train the model
Step 7: Predict the test set results
Step 8: Evaluate the model using a confusion matrix using sklearn
Note: Here,
- True positive is 10.
- True negative is 7.
- False positive is 1.
- False negative is 2.
Step 9: Evaluate the model using other performance metrics
Note: A confusion matrix python gives you complete picture of how the classification is working. It also allows you to compute various classification metrics and these metrics can guide your model selection.
What Did We Learn So Far?
In this tutorial, we have discussed the use of the confusion matrix in Machine Learning and its different terminologies. We talked about different performance metrics such as accuracy, precision, recall, and f1 score. In the end, we have implemented one confusion matrix example using sklearn. In the next module, we will increase the precision rate and the accuracy with the help of the ROC curve and threshold adjustment. See you there.