Jump to content

Platt scaling: Difference between revisions

From Wikipedia, the free encyclopedia
Content deleted Content added
m Description: formatting
 
(24 intermediate revisions by 18 users not shown)
Line 1: Line 1:
{{Short description|Machine learning calibration technique}}
{{machine learning bar}}
{{machine learning bar}}


In [[machine learning]], '''Platt scaling''' or '''Platt calibration''' is a way of transforming the outputs of a [[statistical classification|classification model]] into a [[probabilistic classification|probability distribution over classes]]. The method was invented by [[John Platt (computer scientist)|John Platt]] in the context of [[support vector machines]],<ref name="platt99">{{cite journal |last=Platt |first=John |authorlink=John Platt (computer scientist) |title=Probabilistic outputs for support vector machines and comparisons to regularized likelihood methods |journal=Advances in large margin classifiers |volume=10 |issue=3 |year=1999 |pages=61–74 |url=http://www.researchgate.net/publication/2594015_Probabilistic_Outputs_for_Support_Vector_Machines_and_Comparisons_to_Regularized_Likelihood_Methods/file/504635154cff5262d6.pdf}}</ref>
In [[machine learning]], '''Platt scaling''' or '''Platt calibration''' is a way of transforming the outputs of a [[statistical classification|classification model]] into a [[probabilistic classification|probability distribution over classes]]. The method was invented by [[John Platt (computer scientist)|John Platt]] in the context of [[support vector machines]],<ref name="platt99">{{cite journal |last=Platt |first=John |authorlink=John Platt (computer scientist) |title=Probabilistic outputs for support vector machines and comparisons to regularized likelihood methods |journal=Advances in Large Margin Classifiers |volume=10 |issue=3 |year=1999 |pages=61–74 |url=https://www.researchgate.net/publication/2594015}}</ref>
replacing an earlier method by [[Vladimir Vapnik|Vapnik]],
replacing an earlier method by [[Vladimir Vapnik|Vapnik]],
but can be applied to other classification models.<ref name="Niculescu">{{cite doi|10.1145/1102351.1102430}}</ref>
but can be applied to other classification models.<ref name="Niculescu">{{cite conference |last1=Niculescu-Mizil |first1=Alexandru |first2=Rich |last2=Caruana |title=Predicting good probabilities with supervised learning |conference=ICML |year=2005 |url=https://www.cs.cornell.edu/~alexn/papers/calibration.icml05.crc.rev3.pdf | doi = 10.1145/1102351.1102430}}</ref>
Platt scaling works by fitting a [[logistic regression]] model to a classifier's scores.
Platt scaling works by fitting a [[logistic regression]] model to a classifier's scores.


==Description==
==Description==
Consider the problem of [[binary classification]]: for inputs {{mvar|x}}, we want to determine whether they belong to one of two classes, arbitrarily labeled {{math|+1}} and {{math|−1}}. We assume that the classification problem will be solved by a real-valued function {{mvar|f}}, by predicting a class label {{math|''y'' {{=}} sign(''f''(''x''))}} (see [[sign function]]; the label for {{math|''f''(''x'') {{=}} 0}} is irrelevant). For many problems, it is convenient to get a probability {{math|P(''y''{{=}}1{{!}}''x'')}}, i.e. a classification that not only gives an answer, but also a degree of certainty about the answer. Some classification models do not provide such a probability, or give poor probability estimates.
Consider the problem of [[binary classification]]: for inputs {{mvar|x}}, we want to determine whether they belong to one of two classes, arbitrarily labeled {{math|+1}} and {{math|−1}}. We assume that the classification problem will be solved by a real-valued function {{mvar|f}}, by predicting a class label {{math|''y'' {{=}} sign(''f''(''x''))}}.{{efn|See [[sign function]]. The label for {{math|''f''(''x'') {{=}} 0}} is arbitrarily chosen to be either zero, or one.}} For many problems, it is convenient to get a probability <math>P(y=1|x)</math>, i.e. a classification that not only gives an answer, but also a degree of certainty about the answer. Some classification models do not provide such a probability, or give poor probability estimates.
[[File:Logistic-curve.svg|right|thumb|320x320px|Standard logistic function where <math>L=1, k=1, x_0=0</math>]]
<math>L=1, k=1, x_0=0</math>.


Platt scaling is an algorithm to solve the aforementioned problem. It produces probability estimates
Platt scaling is an algorithm to solve the aforementioned problem. It produces probability estimates
Line 13: Line 16:
:<math>\mathrm{P}(y=1 | x) = \frac{1}{1 + \exp(Af(x) + B)}</math>,
:<math>\mathrm{P}(y=1 | x) = \frac{1}{1 + \exp(Af(x) + B)}</math>,


i.e., a [[logistic function|logistic]] transformation of the classifier scores {{math|''f''(''x'')}}, where {{mvar|A}} and {{mvar|B}} are two [[scalar (mathematics)|scalar]] parameters that are learned by the algorithm. Note that predictions can now be made according to {{math|y {{=}} 1}} iff {{math|P(''y''{{=}}1{{!}}''x'') > ½}}; if {{math|''B'' 0}}, the probability estimates contain a correction compared to the old decision function {{math|y {{=}} sign(''f''(''x''))}}.<ref>{{cite journal |author1=Olivier Chapelle |author2=Vladimir Vapnik |author3=Olivier Bousquet |author4=Sayan Mukherjee |title=Choosing multiple parameters for support vector machines |journal=Machine Learning |year=2002 |volume=46 |pages=131–159 |url=http://www.chapelle.cc/olivier/pub/mlj02.pdf | doi = 10.1023/a:1012450327387 }}</ref>
i.e., a [[logistic function|logistic]] transformation of the classifier scores {{math|''f''(''x'')}}, where {{mvar|A}} and {{mvar|B}} are two [[scalar (mathematics)|scalar]] parameters that are learned by the algorithm. Note that predictions can now be made according to <math>y=1 \text{ iff } P(y=1|x) > \frac{1}{2};</math> if <math>B \ne 0,</math> the probability estimates contain a correction compared to the old decision function {{math|''y'' {{=}} sign(''f''(''x''))}}.<ref>{{cite journal |author1=Olivier Chapelle |author2=Vladimir Vapnik |author3=Olivier Bousquet |author4=Sayan Mukherjee |title=Choosing multiple parameters for support vector machines |journal=Machine Learning |year=2002 |volume=46 |pages=131–159 |url=http://www.chapelle.cc/olivier/pub/mlj02.pdf | doi = 10.1023/a:1012450327387 |doi-access=free }}</ref>


The parameters {{mvar|A}} and {{mvar|B}} are estimated using a [[maximum likelihood estimation|maximum likelihood]] method that optimizes on the same training set as that for the original classifier {{mvar|f}}. To avoid [[overfitting]] to this set, a held-out [[validation set|calibration set]] or [[cross-validation (statistics)|cross-validation]] can be used, but Platt additionally suggests transforming the labels {{mvar|y}} to target probabilities
The parameters {{mvar|A}} and {{mvar|B}} are estimated using a [[maximum likelihood estimation|maximum likelihood]] method that optimizes on the same training set as that for the original classifier {{mvar|f}}. To avoid [[overfitting]] to this set, a held-out [[validation set|calibration set]] or [[cross-validation (statistics)|cross-validation]] can be used, but Platt additionally suggests transforming the labels {{mvar|y}} to target probabilities
Line 20: Line 23:
:<math>t_{-} = \frac{1}{N_{-} + 2}</math> for negative samples, {{math|''y'' {{=}} -1}}.
:<math>t_{-} = \frac{1}{N_{-} + 2}</math> for negative samples, {{math|''y'' {{=}} -1}}.


Here, {{math|''N''}} and {{math|''N''}} are the number of positive and negative samples, resp. This transformation follows by applying [[Bayes' rule]] to a model of out-of-sample data that has a uniform prior over the labels.<ref name="platt99"/>
Here, {{math|''N''<sub>+</sub>}} and {{math|''N''<sub>−</sub>}} are the number of positive and negative samples, respectively. This transformation follows by applying [[Bayes' rule]] to a model of out-of-sample data that has a uniform prior over the labels.<ref name="platt99"/> The constants 1 and 2, on the numerator and denominator respectively, are derived from the application of [[additive smoothing|Laplace smoothing]].


Platt himself suggested using the [[Levenberg–Marquardt algorithm]] to optimize the parameters, but a [[Newton's method in optimization|Newton algorithm]] was later proposed that should be more [[numerical stability|numerically stable]].<ref>{{cite journal |last1=Lin |first1=Hsuan-Tien |first2=Chih-Jen |last2=Lin |first3=Ruby C. |last3=Weng |title=A note on Platt’s probabilistic outputs for support vector machines |journal=[[Machine Learning (journal)|Machine Learning]] |volume=68 |issue=3 |year=2007 |pages=267–276 |url=http://stocktrendresearch.googlecode.com/svn-history/r77/trunk/Paper/SVM_ANN/plattprob.pdf |doi=10.1007/s10994-007-5018-6}}</ref>
Platt himself suggested using the [[Levenberg–Marquardt algorithm]] to optimize the parameters, but a [[Newton's method in optimization|Newton algorithm]] was later proposed that should be more [[numerical stability|numerically stable]].<ref>{{cite journal |last1=Lin |first1=Hsuan-Tien |first2=Chih-Jen |last2=Lin |first3=Ruby C. |last3=Weng |title=A note on Platt's probabilistic outputs for support vector machines |journal=[[Machine Learning (journal)|Machine Learning]] |volume=68 |issue=3 |year=2007 |pages=267–276 |url=https://www.csie.ntu.edu.tw/~cjlin/papers/plattprob.pdf |doi=10.1007/s10994-007-5018-6|doi-access=free }}</ref>


==Analysis==
==Analysis==
Platt scaling has been shown to be effective for SVMs as well as other types of classification models, including [[Boosting (machine learning)|boosted]] models and even [[naive Bayes classifier]]s, which produce distorted probability distributions. It is particularly effective for max-margin methods such as SVMs and boosted trees, which show sigmoidal distortions in their predicted probabilities, but has less of an effect with well-calibrated models such as [[logistic regression]], [[multilayer perceptron]]s and [[random forest]]s.<ref name="Niculescu"/>
Platt scaling has been shown to be effective for SVMs as well as other types of classification models, including [[Boosting (machine learning)|boosted]] models and even [[naive Bayes classifier]]s, which produce distorted probability distributions. It is particularly effective for max-margin methods such as SVMs and boosted trees, which show sigmoidal distortions in their predicted probabilities, but has less of an effect with well-[[Calibration (statistics)|calibrated]] models such as [[logistic regression]], [[multilayer perceptron]]s, and [[random forest]]s.<ref name="Niculescu"/>


An alternative approach to probability calibration is to fit an [[isotonic regression]] model to an ill-calibrated probability model. This has been shown to work better than Platt scaling, in particular when enough training data is available.<ref name="Niculescu"/>
An alternative approach to probability calibration is to fit an [[isotonic regression]] model to an ill-calibrated probability model. This has been shown to work better than Platt scaling, in particular when enough training data is available.<ref name="Niculescu"/>

Platt scaling can also be applied to deep neural network classifiers. For image classification, such as CIFAR-100, small networks like [[LeNet|LeNet-5]] have good calibration but low accuracy, and large networks like [[Residual neural network|ResNet]] has high accuracy but is overconfident in predictions. A 2017 paper proposed ''temperature scaling'', which simply multiplies the output logits of a network by a constant <math>1/T</math> before taking the [[Softmax function|softmax]]. During training, <math>T</math> is set to 1. After training, <math>T</math> is optimized on a held-out calibration set to minimize the calibration loss.<ref>{{Cite journal |last=Guo |first=Chuan |last2=Pleiss |first2=Geoff |last3=Sun |first3=Yu |last4=Weinberger |first4=Kilian Q. |date=2017-07-17 |title=On Calibration of Modern Neural Networks |url=https://proceedings.mlr.press/v70/guo17a.html |journal=Proceedings of the 34th International Conference on Machine Learning |language=en |publisher=PMLR |pages=1321–1330}}</ref>


==See also==
==See also==
* [[Relevance vector machine]]: probabilistic alternative to the support vector machine
* [[Relevance vector machine]]: probabilistic alternative to the support vector machine

==Notes==
{{notelist}}


==References==
==References==

Latest revision as of 07:17, 15 September 2024

In machine learning, Platt scaling or Platt calibration is a way of transforming the outputs of a classification model into a probability distribution over classes. The method was invented by John Platt in the context of support vector machines,[1] replacing an earlier method by Vapnik, but can be applied to other classification models.[2] Platt scaling works by fitting a logistic regression model to a classifier's scores.

Description

[edit]

Consider the problem of binary classification: for inputs x, we want to determine whether they belong to one of two classes, arbitrarily labeled +1 and −1. We assume that the classification problem will be solved by a real-valued function f, by predicting a class label y = sign(f(x)).[a] For many problems, it is convenient to get a probability , i.e. a classification that not only gives an answer, but also a degree of certainty about the answer. Some classification models do not provide such a probability, or give poor probability estimates.

Standard logistic function where

.

Platt scaling is an algorithm to solve the aforementioned problem. It produces probability estimates

,

i.e., a logistic transformation of the classifier scores f(x), where A and B are two scalar parameters that are learned by the algorithm. Note that predictions can now be made according to if the probability estimates contain a correction compared to the old decision function y = sign(f(x)).[3]

The parameters A and B are estimated using a maximum likelihood method that optimizes on the same training set as that for the original classifier f. To avoid overfitting to this set, a held-out calibration set or cross-validation can be used, but Platt additionally suggests transforming the labels y to target probabilities

for positive samples (y = 1), and
for negative samples, y = -1.

Here, N+ and N are the number of positive and negative samples, respectively. This transformation follows by applying Bayes' rule to a model of out-of-sample data that has a uniform prior over the labels.[1] The constants 1 and 2, on the numerator and denominator respectively, are derived from the application of Laplace smoothing.

Platt himself suggested using the Levenberg–Marquardt algorithm to optimize the parameters, but a Newton algorithm was later proposed that should be more numerically stable.[4]

Analysis

[edit]

Platt scaling has been shown to be effective for SVMs as well as other types of classification models, including boosted models and even naive Bayes classifiers, which produce distorted probability distributions. It is particularly effective for max-margin methods such as SVMs and boosted trees, which show sigmoidal distortions in their predicted probabilities, but has less of an effect with well-calibrated models such as logistic regression, multilayer perceptrons, and random forests.[2]

An alternative approach to probability calibration is to fit an isotonic regression model to an ill-calibrated probability model. This has been shown to work better than Platt scaling, in particular when enough training data is available.[2]

Platt scaling can also be applied to deep neural network classifiers. For image classification, such as CIFAR-100, small networks like LeNet-5 have good calibration but low accuracy, and large networks like ResNet has high accuracy but is overconfident in predictions. A 2017 paper proposed temperature scaling, which simply multiplies the output logits of a network by a constant before taking the softmax. During training, is set to 1. After training, is optimized on a held-out calibration set to minimize the calibration loss.[5]

See also

[edit]

Notes

[edit]
  1. ^ See sign function. The label for f(x) = 0 is arbitrarily chosen to be either zero, or one.

References

[edit]
  1. ^ a b Platt, John (1999). "Probabilistic outputs for support vector machines and comparisons to regularized likelihood methods". Advances in Large Margin Classifiers. 10 (3): 61–74.
  2. ^ a b c Niculescu-Mizil, Alexandru; Caruana, Rich (2005). Predicting good probabilities with supervised learning (PDF). ICML. doi:10.1145/1102351.1102430.
  3. ^ Olivier Chapelle; Vladimir Vapnik; Olivier Bousquet; Sayan Mukherjee (2002). "Choosing multiple parameters for support vector machines" (PDF). Machine Learning. 46: 131–159. doi:10.1023/a:1012450327387.
  4. ^ Lin, Hsuan-Tien; Lin, Chih-Jen; Weng, Ruby C. (2007). "A note on Platt's probabilistic outputs for support vector machines" (PDF). Machine Learning. 68 (3): 267–276. doi:10.1007/s10994-007-5018-6.
  5. ^ Guo, Chuan; Pleiss, Geoff; Sun, Yu; Weinberger, Kilian Q. (2017-07-17). "On Calibration of Modern Neural Networks". Proceedings of the 34th International Conference on Machine Learning. PMLR: 1321–1330.