539
441

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

【入門者向け】機械学習の分類問題評価指標解説(正解率・適合率・再現率など)

Last updated at Posted at 2019-02-28

分類問題の評価指標の言葉の定義に関するメモです。いつも、やるたびにググって思い出しているので、記憶を定着させるために作りました。さすがにそろそろ 「覚えるぞ」という意思を込めて結構、力を入れました:muscle:

混合行列(Confusion Matrix)とTP, FP, FN, TN

まずは基本の基本から。二値分類の正解・不正解の種類です。
TP(True Positive)、FP(False Positive)、FN(False Negative)、TN(True Negative)の4種類です。

  • 1文字目:T(True)は予測正解、F(False)は予測不正解。
  • 2文字目:Pは予測が正(Positive)、Nは予測が負(Negative)

TP、FP、FN、TNのマトリックスを混合行列(Confusion Matrix)と呼びます。下の混合行列で太字部分(TPとTN)は正解です。太字でないFPとFNは不正解で、False Positiveが統計で言う「第1種の誤り」で、False Negativeが「第2種の誤り」で、それぞれ偽陽性と偽陰性と呼ばれることもあります。

実際は正
(Positive)
実際は負
(Negative)
予測が正
(Positive)
TP(真陽性)
True Positive
FP(偽陽性)
False Positive
第1種の誤り
予測が負
(Negative)
FN(偽陰性)
Flase Negative
第2種の誤り
TN(真陰性)
True Negative

実例

例えば、妊娠検査を例にします。女性に対して妊娠検査をして妊娠または非妊娠と診断したかを混合行列で表現します。

実際は妊娠中
(Positive)
実際は非妊娠
(Negative)
予測が妊娠中
(Positive)
TP(True Positive)
妊娠女性に妊娠と診断
FP(False Positive)
非妊娠女性に妊娠と診断
第1種の誤り
予測が非妊娠
(Negative)
FN(Flase Negative)
妊娠女性に非妊娠と診断
第2種の誤り
TN(True Negative)
非妊娠女性に非妊娠と診断

まったく同じことを絵にしました。

実際は妊娠中
(Positive)
実際は非妊娠
(Negative)
予測が妊娠中
(Positive)
10.ExampleTP.jpg 10.ExampleFP.jpg
予測が非妊娠
(Negative)
10.ExampleFN.jpg 10.ExampleTN.jpg

ひらたく言うとこういうことです(医学的な検査ではないですが、わかりやすいかと思い表現を変えています)。

  • TP: 妊婦に妊娠と予測し正解
  • FP: お腹が出ていたので妊娠と予測したら実はただ太っていただけ(第1種の誤り)
  • FN: スリムだったので非妊娠と予測したら妊婦だった(第2種の誤り)
  • TN: 非妊娠な人に非妊娠と予測し正解

評価指標

評価指標一覧

まずは評価指標を一覧化しました。個々の評価指標詳細は一覧の後に書いています。

指標 意味 図解(分母と分子)
正解率(Accuracy) 全予測正答率 $\frac{TP + TN}{TP + FP + FN + TN}$ 分母は図解上になし
20.TPandTN.jpg
適合率(Precision) 正予測の正答率 $\frac{TP}{TP + FP}$ 30.Precision.jpg
再現率(Recall) 正に対する正答率 $\frac{TP}{TP + FN}$ 40.Recall.jpg
特異率(Specificity) 負に対する正答率 $\frac{TN}{FP + TN}$ 50.Specificity.jpg
F値(F-measure) 適合率と再現率の調和平均 $\frac{2 \times Precision \times Recall}{Precision + Recall}$ なし

正解率(Accuracy)

全予測に対する正答率です。

\frac{TP + TN}{TP + FP + FN + TN} 

妊娠検査の例:全検査数に対する妊娠・非妊娠の正答率

正解率(Accuracy):分子の図解(分母は省略)。
20.TPandTN.jpg

適合率(Precision)

正と予測したデータのうち,実際に正であるものの割合。「精度」と呼ぶこともあり。

\frac{TP}{TP + FP} 

妊娠検査の例:妊娠と診断した中で正しかった(本当に妊娠だった)率

適合率(Precision)図解(上下を分子と分母で表しています)
30.Precision.jpg

再現率(Recall)

実際に正であるもののうち,正であると予測されたものの割合。
(2019/7/26追記)機械学習の指標を理解しにくい原因のひとつに「再現率」という呼び方があると考えています。これ、正直翻訳ミスなのではないでしょうか?私は心の中では「回収率」と呼んでいます(車などのリコール(回収)と同じ)。実際に正であるものをどれだけ回収(予測)できたかの割合と理解しています。

\frac{TP}{TP + FN} 

妊娠検査の例:妊娠中の人で検査結果が正しかった(正しく妊娠と診断された)率

再現率(Recall)図解(上下を分子と分母で表しています)
40.Recall.jpg

特異率(Specificity)

実際に負であるもののうち,負であると予測されたものの割合。再現率の逆。

\frac{TN}{FP + TN} 

妊娠検査の例:非妊娠の人で検査結果が正しかった(正しく非妊娠と診断された)率

特異率(Specificity)図解(上下を分子と分母で表しています)
50.Specificity.jpg

F値(F-measure)

適合率と再現率の調和平均。算術平均
でなく調和平均を使う理由は記事「F値に調和平均を使う理由(再)」にわかりやすく書かれています。

\frac{2 \times Precision \times Recall}{Precision + Recall} 

各評価指標と頭の体操

数値を例示して各指標がどうなるかを見てみます。

すべて均等混合行列

全体100のうちTP, FP, FN, TNすべて均等で25としました。すべて半分予測が正解というケースです。

実際は正
(Positive)
実際は負
(Negative)
予測が正
(Positive)
TP
25
FP
25
予測が負
(Negative)
FN
25
TN
25
指標 意味
正解率(Accuracy) 全予測正答率 $50\% = \frac{TP(25) + TN(25)}{TP(25) + FP(25) + FN(25) + TN(25)}$
適合率(Precision) 正予測の正答率 $50\% = \frac{TP(25)}{TP(25) + FP(25)}$
再現率(Recall) 正に対する正答率 $50\% = \frac{TP(25)}{TP(25) + FN(25)}$
特異率(Specificity) 負に対する正答率 $50\% = \frac{TN(25)}{FP + TN(25)}$
F値(F-measure) 適合率と再現率の調和平均 $50\% = \frac{2 \times Precision(50) \times Recall(50)}{Precision(50) + Recall(50)}$

データにPositiveに偏った場合

Positive(正)にデータが偏った場合です。全体の正解率(Accuracy)をあげようとすると、分類器でNegativeが軽視されることがあります。
妊娠の例では、妊婦(正)が多いので全体の正答率を重視して分類器が妊婦(正)ばっかり予測した場合です。非妊娠(負)に対する正答率が低いのですが、正解率(Accuracy)・適合率(Precision)、再現率(Recall)、F値(F-measure)は高い数値を出しています。逆に特異率(Specificity)が低いです。

実際は正
(Positive)
実際は負
(Negative)
予測が正
(Positive)
TP
70
FP
10
予測が負
(Negative)
FN
10
TN
10
指標 意味
正解率(Accuracy) 全予測正答率 $80\% = \frac{TP(70) + TN(10)}{TP + FP(10) + FN(10) + TN(10)}$
適合率(Precision) 正予測の正答率 $88\% = \frac{TP(70)}{TP(70) + FP(10)}$
再現率(Recall) 正に対する正答率 $88\% = \frac{TP(70)}{TP + FN(10)} = 88%$
特異率(Specificity) 負に対する正答率 $50\% = \frac{TN(10)}{FP(10) + TN(10)}$
F値(F-measure) 適合率と再現率の調和平均 $88\% = \frac{2 \times Precision(88) \times Recall(88)}{Precision(88) + Recall(88)}$

データにNegativeに偏った場合

Negative(負)にデータが偏った場合です。全体の正解率(Accuracy)をあげようとすると、今度は逆に分類器でPositiveが軽視されることがあります。
妊娠の例では、非妊娠(負)が多いので全体の正答率を重視して分類器が非妊娠(負)ばっかり予測した場合です。妊娠(正)に対する正答率が低いので、正解率(Accuracy)・特異率(Specificity)は高い数値を出しています。逆に適合率(Precision)、再現率(Recall)、F値(F-measure)が低いです。

実際は正
(Positive)
実際は負
(Negative)
予測が正
(Positive)
TP
10
FP
10
予測が負
(Negative)
FN
10
TN
70
指標 意味
正解率(Accuracy) 全予測正答率 $80\% = \frac{TP(10) + TN(70)}{TP(10) + FP(10) + FN(10) + TN(70)}$
適合率(Precision) 正予測の正答率 $50\% = \frac{TP(10)}{TP(10) + FP(10)}$
再現率(Recall) 正に対する正答率 $50\% = \frac{TP(10)}{TP(10) + FN(10)}$
特異率(Specificity) 負に対する正答率 $88\% = \frac{TN(70)}{FP(10) + TN(70)}$
F値(F-measure) 適合率と再現率の調和平均 $50\% = \frac{2 \times Precision(50) \times Recall(50)}{Precision(50) + Recall(50)}$

適合率重視(FNが多い場合)

FN(False Negative)が多い場合です。これは、分類器にとって、Positive(正)は正しく判断できるが、Negative(負)と判断しやすいPositiveが多い場合です。
適合率と再現率はトレードオフの関係で、問題設定によりどちらを重視するかを決めます。適合率を重視するのは、第2種の誤りが多くても正予測の正答率をあげたい場合です。例えば、スパムメール判定の場合スパムメールがスパムと判定されなくて(FN)もいいので、通常メールをスパム判定(FP)したくないような場合に適合率を重視します。
妊娠の例では、妊婦(正)を比較的正しく診断できるのですが、スリムな人間をどちらか判断できてきない場合です。この場合、Positive予測(TPとFP)を分母にとる適合率(Precision)は高い数値を出します。

実際は正
(Positive)
実際は負
(Negative)
予測が正
(Positive)
TP
40
FP
10
予測が負
(Negative)
FN
40
TN
10
指標 意味
正解率(Accuracy) 全予測正答率 $ 50\% = \frac{TP(40) + TN(10)}{TP(40) + FP(10) + FN(40) + TN(10)}$
適合率(Precision) 正予測の正答率 $ 80\% = \frac{TP(40)}{TP(40) + FP(10)}$
再現率(Recall) 正に対する正答率 $ 50\% = \frac{TP(40)}{TP(40) + FN(40)}$
特異率(Specificity) 負に対する正答率 $50\% = \frac{TN(10)}{FP(10) + TN(10)}$
F値(F-measure) 適合率と再現率の調和平均 $ 62\% = \frac{2 \times Precision(80) \times Recall(50)}{Precision(80) + Recall(50)}$

再現率重視(FPが多い場合)

FP(False Positive)が多い場合です。これは、分類器にとって、Negative(負)は正しく判断できるが、Positive(正)と判断しやすいNegativeが多い場合です。
(適合率を軽視して)再現率を重視するのは、第1種の誤りが多くても負予測の正答率をあげたい場合です。言い換えると、見つけにくいものを機械的に発見して、正予測を人間がチェックするような場合です。例えば、工場の生産プロセスでめったにない不良品候補を機械的に検知して、不良品候補を人間が不良品かを調べるような場合です。この場合は、不良品のすり抜け(FN)をさせたくないので、不良品でないのに不良品と診断した数(FP)が多くてもいいシナリオです。
妊娠の例では、非妊娠(負)を比較的正しく診断できるのですが、お腹が出た人間をどちらか判断できてきない場合です。この場合、実際はPositive(TPとFN)を分母にとる再現率(Recall)は高い数値を出します。逆にが特異率(Specificity)低いです。

実際は正
(Positive)
実際は負
(Negative)
予測が正
(Positive)
TP
40
FP
40
予測が負
(Negative)
FN
10
TN
10
指標 意味
正解率(Accuracy) 全予測正答率 $ 50\% = \frac{TP(40) + TN(10)}{TP(40) + FP(40) + FN(10) + TN(10)}$
適合率(Precision) 正予測の正答率 $ 50\% = \frac{TP(40)}{TP(40) + FP(40)}$
再現率(Recall) 正に対する正答率 $ 80\% = \frac{TP(40)}{TP(40) + FN(10)}$
特異率(Specificity) 負に対する正答率 $20\% = \frac{TN(10)}{FP(40) + TN(10)}$
F値(F-measure) 適合率と再現率の調和平均 $ 62\% = \frac{2 \times Precision(50) \times Recall(80)}{Precision(50) + Recall(80)}$

多クラス分類

多クラス分類の場合は多少複雑になります。
例えばA・B・Cの三値分類の混合行列は以下のようになります。

実際はA 実際はB 実際はC
予測がA True A False A(B) False A(C)
予測がB False B(A) True B False B(C)
予測がC False C(A) False C(B) True C

Aに関する適合率(Precision)、再現率(Recall)、F値(F-measure)は以下の計算式です。BとCも同様です。

指標 意味
Aの適合率 A予測の正答率 $\frac{True A}{True A + False A}$
Aの再現率 Aに対する正答率 $\frac{True A}{True A + False B(A) + False C(A)}$
AのF値 Aの適合率と再現率の調和平均 $\frac{2 \times Precision(A) \times Recall(A)}{Precision(A) + Recall(A)}$

マクロ平均とマイクロ平均

マクロ平均は単純な算術平均(相加平均)です。調和平均ではありません。各クラスごとの正解率、適合率等の値を平均するだけです(なので式も省略)。
マイクロ平均は各クラスごとの計算をせずに、混合行列全体からTP等の値集計をして算出します。他クラス分類の場合に、全体の合計で考えるのでPositiveとNegativeの区別が丸め込まれるためFPとFNは同一です。そのため、適合率・再現率・F値も同じ値です。詳しくは記事「Why are precision, recall and F1 score equal when using micro averaging in a multi-class problem?」を見てください。

種類
TP True A + True B + True C
FP/FN False A + False B + False C
適合率・再現率・F値 $\frac{TP}{TP + FP}$

マクロ平均やマイクロ平均とは別に「重み付け平均」もあります。「機械学習で使う指標総まとめ(教師あり学習編)」などを参考にしてください。

参考リンク

朱鷺の杜Wiki
【python】分類タスクの評価指標の解説とsklearnでの計算方法
機械学習で使う指標総まとめ(教師あり学習編)

PR曲線とROC曲線について別記事で書きました。

539
441
4

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
539
441

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?