import pandas as pd
import lightgbm as lgb
from sklearn.model_selection import train_test_split
# Load the German Credit Data
= "https://archive.ics.uci.edu/ml/machine-learning-databases/statlog/german/german.data"
data_url = ['existing_checking', 'duration', 'credit_history', 'purpose', 'credit_amount', 'savings',
column_names 'employment', 'installment_rate', 'personal_status', 'other_debtors', 'residence_since',
'property', 'age', 'other_installment_plans', 'housing', 'existing_credits', 'job', 'people_liable',
'telephone', 'foreign_worker', 'class']
= pd.read_csv(data_url, delimiter=' ', names=column_names)
data
# Preprocess the data
= data.drop('class', axis=1)
X = data['class']
y = pd.get_dummies(X, drop_first=True)
X = train_test_split(X, y, test_size=0.5, random_state=42, stratify=y)
X_train, X_test, y_train, y_test = train_test_split(X_test, y_test, test_size=0.5, stratify=y_test)
X_cal, X_test, y_cal, y_test == 2] = 0
y_train[y_train == 2] = 0
y_test[y_test == 2] = 0 y_cal[y_cal
Model calibration
Model calibration
Model calibration is a process used in machine learning to ensure that the predicted probabilities from a classification model reflect the true likelihood of the corresponding outcomes. In classification tasks, a well-calibrated model should produce probability estimates that are both reliable and accurate. This is important because many machine learning applications, such as risk assessment, medical diagnosis, and fraud detection, rely on these probability estimates to make decisions.
Calibration involves adjusting the predicted probabilities from a model to align them with the actual outcomes. There are several methods to calibrate models, and the choice of method depends on the specific algorithm and problem. Some common calibration techniques include:
Platt Scaling: This is a simple method that fits a logistic regression model to the output of the original model. It essentially learns a transformation to map the model’s raw scores to calibrated probabilities.
Isotonic Regression: Isotonic regression is a non-parametric approach that fits a piecewise-constant, non-decreasing function to the predicted probabilities. It can be more flexible than Platt scaling in some cases.
Beta Calibration: This method models the predicted probabilities as Beta distributions and estimates the parameters of these distributions to better match the observed outcomes.
Histogram Binning: This technique divides the predicted probabilities into bins and estimates the true class frequencies within each bin. It then uses these frequencies to adjust the predicted probabilities.
Bayesian Calibration: Bayesian methods can be used to update the model’s probability estimates based on prior knowledge or data. This approach can be especially useful when you have a limited amount of data.
The goal of model calibration is to ensure that, for instance, if a model predicts a 70% probability of an event happening, it should be correct approximately 70% of the time in practice. Calibrated models provide more meaningful and reliable probability estimates, making them easier to interpret and use for decision-making. In applications where it’s important to understand the level of confidence associated with predictions, model calibration is a critical step in improving the model’s utility.
History of calibration models
The history of calibration models in the context of machine learning and statistics is closely tied to the need for well-calibrated probability estimates, especially in classification tasks. Here’s a brief overview of the history and development of calibration models:
Early Days of Probability Estimation (Pre-2000s): In the early years of machine learning and statistics, the primary focus was on developing classification models that predict class labels. Probability estimates were often not a central concern.
Rise of Support Vector Machines (SVMs): In the 1990s and early 2000s, Support Vector Machines gained popularity. These models produced decision functions that were not inherently calibrated probability estimates, leading to a need for calibration techniques.
Platt Scaling (1999): John Platt introduced Platt Scaling, a logistic regression-based calibration technique, in his paper “Probabilistic Outputs for Support Vector Machines and Comparisons to Regularized Likelihood Methods.” This method became one of the earliest and widely used approaches for converting SVM scores into well-calibrated probabilities.
Logistic Regression Calibration: Logistic regression, a well-established statistical technique, was used as an early calibration method for various classifiers. It helped map model scores to calibrated probabilities.
Development of Calibration Metrics (2000s): During this period, researchers started to develop calibration metrics, such as the Brier Score and calibration plots, to quantitatively measure the calibration performance of models.
Bayesian Calibration (2000s): Bayesian approaches for calibration started to gain attention. These methods allow for the incorporation of prior knowledge and often provide robust calibration.
Isotonic Regression (2000s): Isotonic regression became a popular non-parametric technique for calibration. It offers flexibility by allowing for monotonic transformations of probability estimates.
Improvements in Machine Learning Models (2010s): The advancement of machine learning models, such as gradient-boosted trees and neural networks, led to the need for more advanced calibration methods. Techniques like Beta Calibration started to emerge.
Software Libraries and Packages: As machine learning and data science gained prominence, software libraries and packages like scikit-learn and TensorFlow included calibration functionalities, making it easier for practitioners to apply calibration techniques.
Ongoing Research and Development: Research in calibration continues, focusing on more complex models, large-scale applications, and novel techniques. The field is evolving to address challenges in deep learning and ensemble methods.
In summary, the history of calibration models reflects the growing awareness of the importance of well-calibrated probability estimates in various machine learning applications. Over the years, a variety of techniques and methods have been developed to address calibration issues, enabling machine learning models to provide more reliable and interpretable probability estimates for informed decision-making. The field continues to evolve as new challenges and opportunities emerge in machine learning and data analysis.
Beta Calibration
Beta Calibration is one of the more recent calibration techniques that has gained attention in the field of machine learning. Its emergence can be attributed to several factors:
Improved Calibration Needs: As machine learning models have become increasingly popular for a wide range of applications, the need for well-calibrated probability estimates has grown. Many machine learning models, including complex ensemble methods and deep learning models, often produce uncalibrated or poorly calibrated probability estimates. This need for improved calibration led to the exploration of novel calibration techniques, including Beta Calibration.
Flexibility in Modeling Probability Distributions: Beta Calibration offers flexibility in modeling probability distributions. It assumes that predicted probabilities can be represented by a Beta distribution, which is a flexible parametric distribution. This flexibility allows it to capture a wide range of probability distribution shapes, making it suitable for a variety of real-world scenarios.
Suitability for Imbalanced Datasets: In many practical applications, datasets are imbalanced, meaning one class significantly outnumbers the other. Traditional calibration techniques may not be effective in such cases. Beta Calibration’s ability to handle imbalanced data by modeling the distribution of predicted probabilities is a valuable feature.
Addressing Overconfidence or Underconfidence: Beta Calibration is effective in addressing issues of model overconfidence or underconfidence. Some models may produce predicted probabilities that are too extreme (close to 0 or 1) and do not accurately reflect the true likelihood of events occurring. Beta Calibration can moderate these extreme probabilities to provide more reliable estimates.
Growing Research and Tools: As researchers and practitioners have recognized the importance of calibration, there has been an increased focus on developing and providing tools and libraries that support calibration techniques. The availability of software packages like the
betacal
package has made it easier for data scientists to apply Beta Calibration.Comparative Studies: Comparative studies and evaluations of different calibration techniques have highlighted the effectiveness of Beta Calibration in certain scenarios. This has contributed to its adoption and prominence.
Versatility in Calibration Challenges: Beta Calibration can be used in a wide range of applications and is not limited to specific types of models or datasets. Its versatility in addressing calibration challenges makes it a valuable addition to the calibration toolbox.
In summary, Beta Calibration emerged as a response to the growing need for more advanced and flexible calibration techniques that can handle a variety of machine learning models and data scenarios. Its ability to model predicted probabilities as Beta distributions and address issues like overconfidence or underconfidence has made it a valuable tool for improving the reliability and utility of machine learning models in practical applications.
y_cal.value_counts()
1 175
0 75
Name: class, dtype: int64
import pandas as pd
import lightgbm as lgb
from sklearn.model_selection import train_test_split
from sklearn.calibration import CalibratedClassifierCV
from sklearn.isotonic import IsotonicRegression
from sklearn.linear_model import LogisticRegression
from sklearn.metrics import brier_score_loss
import matplotlib.pyplot as plt
# Load the German Credit Data
= "https://archive.ics.uci.edu/ml/machine-learning-databases/statlog/german/german.data"
data_url = ['existing_checking', 'duration', 'credit_history', 'purpose', 'credit_amount', 'savings',
column_names 'employment', 'installment_rate', 'personal_status', 'other_debtors', 'residence_since',
'property', 'age', 'other_installment_plans', 'housing', 'existing_credits', 'job', 'people_liable',
'telephone', 'foreign_worker', 'class']
= pd.read_csv(data_url, delimiter=' ', names=column_names)
data
# Preprocess the data
= data.drop('class', axis=1)
X = data['class']
y = pd.get_dummies(X, drop_first=True)
X = train_test_split(X, y, test_size=0.5, random_state=42, stratify=y)
X_train, X_test, y_train, y_test = train_test_split(X_test, y_test, test_size=0.5, stratify=y_test)
X_cal, X_test, y_cal, y_test
# Convert class labels to binary (0 and 1)
= (y_train == 1).astype(int)
y_train = (y_cal == 1).astype(int)
y_cal = (y_test == 1).astype(int) y_test
# Train a classifier (LightGBM in this example)
= lgb.LGBMClassifier(n_estimators=100, random_state=42)
clf
clf.fit(X_train, y_train)
# Predict probabilities on the test set
= clf.predict_proba(X_test)[:, 1]
predicted_probabilities = clf.predict_proba(X_cal)[:, 1]
cal_probas
# Isotonic Calibration
= IsotonicRegression()
iso_calibrator
iso_calibrator.fit(cal_probas, y_cal)= iso_calibrator.predict(cal_probas)
iso_calibrated_probabilities = brier_score_loss(y_cal, iso_calibrated_probabilities)
iso_brier print(f'Brier Score after Isotonic Calibration: {iso_brier:.4f}')
# Logistic Calibration
= LogisticRegression(C=99999999999)
logistic_calibrator -1, 1), y_cal)
logistic_calibrator.fit(cal_probas.reshape(= logistic_calibrator.predict_proba(cal_probas.reshape(-1, 1))[:, 1]
logistic_calibrated_probabilities = brier_score_loss(y_cal, logistic_calibrated_probabilities)
logistic_brier print(f'Brier Score after Logistic Calibration: {logistic_brier:.4f}')
# Beta Calibration
from betacal import BetaCalibration
= BetaCalibration()
beta_calibrator
beta_calibrator.fit(cal_probas, y_cal)= beta_calibrator.predict(cal_probas)
beta_calibrated_probabilities = brier_score_loss(y_cal, beta_calibrated_probabilities)
beta_brier print(f'Brier Score after Beta Calibration: {beta_brier:.4f}')
Brier Score after Isotonic Calibration: 0.1745
Brier Score after Logistic Calibration: 0.1876
Brier Score after Beta Calibration: 0.1827
from sklearn.metrics import roc_auc_score
# Calculate Gini coefficient for Isotonic calibration
= 2 * roc_auc_score(y_cal, iso_calibrated_probabilities) - 1
gini_iso print(f'Gini for Isotonic Calibration: {gini_iso:.4f}')
# Calculate Gini coefficient for Logistic calibration
= 2 * roc_auc_score(y_cal, logistic_calibrated_probabilities) - 1
gini_logistic print(f'Gini for Logistic Calibration: {gini_logistic:.4f}')
# Calculate Gini coefficient for Beta calibration
= 2 * roc_auc_score(y_cal, beta_calibrated_probabilities) - 1
gini_beta print(f'Gini for Beta Calibration: {gini_beta:.4f}')
Gini for Isotonic Calibration: 0.5006
Gini for Logistic Calibration: 0.4539
Gini for Beta Calibration: 0.4539
from sklearn.calibration import calibration_curve
# Generate calibration plots
=(12, 6))
plt.figure(figsize
# Calibration Curve (Isotonic)
131)
plt.subplot(= calibration_curve(y_cal, iso_calibrated_probabilities, n_bins=10)
fraction_of_positives, mean_predicted_value ='o', label='Calibrated Probabilities (Isotonic)')
plt.plot(mean_predicted_value, fraction_of_positives, marker0, 1], [0, 1], 'k--', label='Perfectly Calibrated')
plt.plot(['Mean Predicted Probability')
plt.xlabel('Fraction of Positives')
plt.ylabel('Calibration Curve (Isotonic)')
plt.title(
plt.legend()
# Calibration Curve (Logistic)
132)
plt.subplot(= calibration_curve(y_cal, logistic_calibrated_probabilities, n_bins=10)
fraction_of_positives, mean_predicted_value ='o', label='Calibrated Probabilities (Logistic)')
plt.plot(mean_predicted_value, fraction_of_positives, marker0, 1], [0, 1], 'k--', label='Perfectly Calibrated')
plt.plot(['Mean Predicted Probability')
plt.xlabel('Fraction of Positives')
plt.ylabel('Calibration Curve (Logistic)')
plt.title(
plt.legend()
# Calibration Curve (Beta)
133)
plt.subplot(= calibration_curve(y_cal, beta_calibrated_probabilities, n_bins=10)
fraction_of_positives, mean_predicted_value ='o', label='Calibrated Probabilities (Beta)')
plt.plot(mean_predicted_value, fraction_of_positives, marker0, 1], [0, 1], 'k--', label='Perfectly Calibrated')
plt.plot(['Mean Predicted Probability')
plt.xlabel('Fraction of Positives')
plt.ylabel('Calibration Curve (Beta)')
plt.title(
plt.legend()
plt.tight_layout() plt.show()
Brier Score
The Brier Score, also known as the Brier Loss or Brier’s Probability Score, is a commonly used metric to assess the calibration quality of probabilistic predictions generated by a classification model. The Brier Score quantifies the mean squared difference between predicted probabilities and actual outcomes. The formula for the Brier Score is as follows:
\[ \text{Brier Score} = \frac{1}{N} \sum_{i=1}^{N} (P_i - O_i)^2 \]
Where: - \(N\) is the total number of samples. - \(P_i\) is the predicted probability for the positive class (usually class 1) for sample i. - \(O_i\) is the actual outcome for sample i, which is binary (1 for a positive outcome, 0 for a negative outcome).
The Brier Score ranges from 0 to 1, where lower values indicate better calibration. A Brier Score of 0 means perfect calibration, where the predicted probabilities are identical to the actual outcomes. A Brier Score of 1 indicates the worst calibration, where the predicted probabilities are far from the true outcomes.
The Brier Score is used for calibration purposes for the following reasons:
Measuring Calibration Quality: The Brier Score provides a quantitative measure of how well the predicted probabilities align with the true outcomes. It directly assesses the calibration quality of a model’s probability estimates.
Sensitivity to Miscalibration: It is sensitive to both overconfidence and underconfidence in predicted probabilities. If a model is poorly calibrated, the Brier Score will be high, highlighting the need for calibration.
Comparison of Calibration Techniques: The Brier Score allows for the comparison of different calibration techniques. It can help you evaluate the effectiveness of calibration methods in improving the reliability of probability estimates.
Interpretability: The Brier Score is easy to understand and interpret. Lower Brier Scores indicate better calibration, making it a useful metric for explaining the quality of probability estimates to stakeholders.
Direct Application to Decision Thresholds: In binary classification tasks, the Brier Score can assist in selecting appropriate decision thresholds. By analyzing the Brier Score at different threshold values, you can make decisions that balance precision and recall based on the calibration performance.
Thresholds for Brier Score:
Perfect Calibration (Threshold: 0): Achieving a Brier Score of 0 represents perfect calibration, where the model’s predicted probabilities precisely match the actual outcomes. While this is the ideal calibration, it is rarely attainable in practice.
Good Calibration (Threshold: < 0.25): Brier Scores below 0.25 are often regarded as a benchmark for good calibration. In such cases, the predicted probabilities are reasonably aligned with the true outcomes, indicating reliable probability estimates.
Fair Calibration (Threshold: 0.25 - 0.5): Brier Scores falling between 0.25 and 0.5 suggest moderately calibrated models. While not perfect, these models provide fairly reliable probability estimates, making them suitable for various applications.
Poor Calibration (Threshold: > 0.5): Brier Scores exceeding 0.5 typically indicate poor calibration. Such scores imply that the model’s predicted probabilities are unreliable for decision-making, as they deviate significantly from the actual outcomes.
Decision-Making Threshold (Application-Dependent): The choice of an acceptable Brier Score threshold depends on the specific application’s criticality and requirements. In critical applications where decisions are heavily based on probabilities, a lower threshold (e.g., 0.1) might be necessary for confidence. In less critical scenarios, a threshold closer to 0.5 may be considered acceptable. The chosen threshold should align with the level of risk tolerance and the consequences of incorrect decisions within the application context.
In summary, the Brier Score is a valuable metric for evaluating the calibration of probabilistic predictions, making it an essential tool for assessing the reliability of classification models and the effectiveness of calibration techniques. Its simplicity and direct connection to calibration quality make it a widely used metric in machine learning and statistics.