検索

Python の混同行列のトリック

Jun 11, 2023 am 10:43 AM
スキルPythonプログラミング混同行列

機械学習とデータ マイニングの人気に伴い、ますます多くのデータ サイエンティストや研究者が高級プログラミング言語である Python を使用してデータを処理および分析し始めています。Python の直観性と使いやすさにより、Python は広く使用されています。深さ 学習や人工知能の分野で広く使用されています。ただし、多くの初心者は Python を使用するときにいくつかの問題に遭遇します。その 1 つは混同行列の難しさです。この記事では、Python での混同行列の使用方法と、混同行列を扱うときに役立ついくつかのテクニックを紹介します。

1.混同行列とは

ディープラーニングとデータマイニングにおいて、混同行列とは、予測結果と実際の結果の差異を比較するために使用される長方形のテーブルです。このマトリックスは、分類アルゴリズムの精度、エラー率、精度、再現率などの重要な指標を含む、分類アルゴリズムのパフォーマンスを示します。混同行列は通常、分類器のパフォーマンスを視覚化し、分類器の改善と最適化のための予測結果の主な参照を提供します。

通常、混同行列は 4 つのパラメーターで構成されます。

  • 真陽性 (TP): 分類アルゴリズムは、陽性クラスを陽性クラスとして正確に予測します。
  • 偽陰性 (FN): 分類アルゴリズムは、陽性クラスを陰性クラスとして誤って予測します。
  • 偽陽性 (FP): 分類アルゴリズムは、陰性クラスを陽性クラスとして誤って予測します。
  • 真陰性 (TN): 分類アルゴリズムは、陰性クラスを陰性クラスとして正確に予測します。

2. 混同行列の計算方法

Python の scikit-learn ライブラリには、混同行列を計算する便利な関数が用意されています。この関数はconfusion_matrix()と呼ばれ、分類子とテストセットの実際の結果の間の入力として使用でき、混同行列のパラメータ値を返します。この関数の構文は次のとおりです。

from sklearn.metrics import confusion_matrix
confusion_matrix(y_true, y_pred, labels=None, sample_weight=None)

このうち、y_true は分類子の正しい結果を表し、y_pred は分類子の予測結果を表し、ラベルはクラス ラベルの名前を表します (指定されていない場合)。 、デフォルトは y_true および y_pred から抽出された値です)、sample_weight は各サンプルの重みを表します (必要ない場合は、このパラメーターを設定しないでください)。

たとえば、次のデータの混同行列を計算する必要があるとします。

y_true = [1, 0, 1, 2, 0, 1]
y_pred = [1, 0, 2, 1, 0, 2]

混同行列を計算するには、次のコードを使用できます。

from sklearn.metrics import confusion_matrix
cm = confusion_matrix(y_true, y_pred)
print(cm)

The出力結果は次のとおりです:

array([[2, 0, 0],
       [0, 1, 2],
       [0, 1, 0]])

つまり、混同行列は、「1」が「1」として 2 回正しく分類され、「0」が「0」として 1 回正しく分類され、「2」が正しく分類されていることを示しています。 as "2" 「「1」が「2」と誤分類されるケースが 0 件あり、「2」が「1」と誤分類されるケースが 2 件あり、「0」が「2」と誤分類されるケースが 1 回発生しました。

3. 混同行列を表示する

混同行列をより適切に視覚化する必要がある状況は数多くあります。 Python の matplotlib ライブラリは、混同行列を視覚化できます。以下は、matplotlib ライブラリと sklearn.metrics を使用して混同行列を視覚化する Python コードです。

import itertools
import numpy as np
import matplotlib.pyplot as plt
from sklearn.metrics import confusion_matrix

def plot_confusion_matrix(cm, classes,
                          normalize=False,
                          title='Confusion matrix',
                          cmap=plt.cm.Blues):
    """
    This function prints and plots the confusion matrix.
    Normalization can be applied by setting `normalize=True`.
    """
    if normalize:
        cm = cm.astype('float') / cm.sum(axis=1)[:, np.newaxis]
        print("Normalized confusion matrix")
    else:
        print('Confusion matrix, without normalization')

    print(cm)

    plt.imshow(cm, interpolation='nearest', cmap=cmap)
    plt.title(title)
    plt.colorbar()
    tick_marks = np.arange(len(classes))
    plt.xticks(tick_marks, classes, rotation=45)
    plt.yticks(tick_marks, classes)

    fmt = '.2f' if normalize else 'd'
    thresh = cm.max() / 2.
    for i, j in itertools.product(range(cm.shape[0]), range(cm.shape[1])):
        plt.text(j, i, format(cm[i, j], fmt),
                 horizontalalignment="center",
                 color="white" if cm[i, j] > thresh else "black")

    plt.tight_layout()
    plt.ylabel('True label')
    plt.xlabel('Predicted label')

# Compute confusion matrix
cnf_matrix = confusion_matrix(y_test, y_pred)
np.set_printoptions(precision=2)

# Plot non-normalized confusion matrix
plt.figure()
plot_confusion_matrix(cnf_matrix, classes=class_names,
                      title='Confusion matrix, without normalization')

# Plot normalized confusion matrix
plt.figure()
plot_confusion_matrix(cnf_matrix, classes=class_names, normalize=True,
                      title='Normalized confusion matrix')

plt.show()

上記のコードでは、plot_confusion_matrix() という名前のカスタム関数を定義します。この関数は、混同行列のパラメータ、カテゴリ名のテキスト文字列をパラメータとして受け取り、混同行列をカラー イメージとして出力します。混同行列の各セルの色は、その値のサイズを表します。次に、それぞれの真のカテゴリと予測されたカテゴリを使用して混同行列を計算し、上で定義した Lot_confusion_matrix() 関数を使用して混同行列を表す必要があります。

4. 概要

Python 言語は、データ サイエンティストや研究者がディープ ラーニングや人工知能のデータ分析をより迅速に実行できるようにする、多数の視覚化およびデータ分析ライブラリを提供します。この記事では、混同行列とそのアプリケーション、Python で混同行列を計算する方法、および matplotlib ライブラリを使用して混同行列のグラフィックを生成する方法を紹介します。混同行列技術は、ディープラーニングや人工知能の分野で重要な応用分野があるため、混同行列技術を習得することが非常に必要です。

以上がPython の混同行列のトリックの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Python vs. C:比較されたアプリケーションとユースケースPython vs. C:比較されたアプリケーションとユースケースApr 12, 2025 am 12:01 AM

Pythonは、データサイエンス、Web開発、自動化タスクに適していますが、Cはシステムプログラミング、ゲーム開発、組み込みシステムに適しています。 Pythonは、そのシンプルさと強力なエコシステムで知られていますが、Cは高性能および基礎となる制御機能で知られています。

2時間のPython計画:現実的なアプローチ2時間のPython計画:現実的なアプローチApr 11, 2025 am 12:04 AM

2時間以内にPythonの基本的なプログラミングの概念とスキルを学ぶことができます。 1.変数とデータ型、2。マスターコントロールフロー(条件付きステートメントとループ)、3。機能の定義と使用を理解する4。

Python:主要なアプリケーションの調査Python:主要なアプリケーションの調査Apr 10, 2025 am 09:41 AM

Pythonは、Web開発、データサイエンス、機械学習、自動化、スクリプトの分野で広く使用されています。 1)Web開発では、DjangoおよびFlask Frameworksが開発プロセスを簡素化します。 2)データサイエンスと機械学習の分野では、Numpy、Pandas、Scikit-Learn、Tensorflowライブラリが強力なサポートを提供します。 3)自動化とスクリプトの観点から、Pythonは自動テストやシステム管理などのタスクに適しています。

2時間でどのくらいのPythonを学ぶことができますか?2時間でどのくらいのPythonを学ぶことができますか?Apr 09, 2025 pm 04:33 PM

2時間以内にPythonの基本を学ぶことができます。 1。変数とデータ型を学習します。2。ステートメントやループの場合などのマスター制御構造、3。関数の定義と使用を理解します。これらは、簡単なPythonプログラムの作成を開始するのに役立ちます。

プロジェクトの基本と問題駆動型の方法で10時間以内にコンピューター初心者プログラミングの基本を教える方法は?プロジェクトの基本と問題駆動型の方法で10時間以内にコンピューター初心者プログラミングの基本を教える方法は?Apr 02, 2025 am 07:18 AM

10時間以内にコンピューター初心者プログラミングの基本を教える方法は?コンピューター初心者にプログラミングの知識を教えるのに10時間しかない場合、何を教えることを選びますか...

中間の読書にどこでもfiddlerを使用するときにブラウザによって検出されないようにするにはどうすればよいですか?中間の読書にどこでもfiddlerを使用するときにブラウザによって検出されないようにするにはどうすればよいですか?Apr 02, 2025 am 07:15 AM

fiddlereveryversings for the-middleの測定値を使用するときに検出されないようにする方法

Python 3.6にピクルスファイルをロードするときに「__Builtin__」モジュールが見つからない場合はどうすればよいですか?Python 3.6にピクルスファイルをロードするときに「__Builtin__」モジュールが見つからない場合はどうすればよいですか?Apr 02, 2025 am 07:12 AM

Python 3.6のピクルスファイルのロードレポートエラー:modulenotFounderror:nomodulenamed ...

風光明媚なスポットコメント分析におけるJieba Wordセグメンテーションの精度を改善する方法は?風光明媚なスポットコメント分析におけるJieba Wordセグメンテーションの精度を改善する方法は?Apr 02, 2025 am 07:09 AM

風光明媚なスポットコメント分析におけるJieba Wordセグメンテーションの問題を解決する方法は?風光明媚なスポットコメントと分析を行っているとき、私たちはしばしばJieba Wordセグメンテーションツールを使用してテキストを処理します...

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません