您好,登錄后才能下訂單哦!
這篇“Python如何用鳶尾花數(shù)據(jù)繪制ROC和AUC曲線”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Python如何用鳶尾花數(shù)據(jù)繪制ROC和AUC曲線”文章吧。
很多學(xué)習(xí)器是為了測(cè)試樣本產(chǎn)生的一個(gè)實(shí)值或概率預(yù)測(cè),然后將這個(gè)預(yù)測(cè)值與一個(gè)分類閾值(threshold)進(jìn)行比較,若大于閾值則分為正類,否則為反類。主要看需要建立的模型側(cè)重于想用在測(cè)試數(shù)據(jù)的泛華性能的好壞。排序本身的質(zhì)量好壞體系了綜合考慮學(xué)習(xí)去在不同任務(wù)下的“期望泛化性能”的好壞。ROC曲線則是從這個(gè)角度出發(fā)來研究學(xué)習(xí)器泛化性能。
ROC的全稱是“受試者工作特征”曲線,與P-R曲線相似。與P-R曲線使用查準(zhǔn)率、查全率為縱、橫坐標(biāo)不同,ROC曲線的縱軸是“真正例率”{簡(jiǎn)稱TPR),橫軸是“假正例率”(簡(jiǎn)稱FPR)二者分別定義為:
ROC曲線圖以真正例率為Y軸,假正例率為X軸。
進(jìn)行檢驗(yàn)判定ROC曲線性能的合理判據(jù)是比較ROC曲線下的面積,即AUC。從定義知AUC可通過對(duì)ROC曲線下各部分的面積求和而得,AUC可估算為:
從形式化看,AUC考慮的是樣本預(yù)測(cè)的排序質(zhì)量,因此它與排序誤差有緊密聯(lián)系。因此存在排序損失。
形式基本和P-R曲線差不多,只是幾個(gè)數(shù)值要改一下。
代碼如下(示例):
from sklearn import svm, datasets from sklearn.model_selection import train_test_split from sklearn.metrics import roc_curve, auc from itertools import cycle from sklearn.preprocessing import label_binarize #標(biāo)簽二值化LabelBinarizer,可以把yes和no轉(zhuǎn)化為0和1,或是把incident和normal轉(zhuǎn)化為0和1。 import numpy as np from sklearn.multiclass import OneVsRestClassifier iris = datasets.load_iris() # 鳶尾花數(shù)據(jù)導(dǎo)入 X = iris.data #每一列代表了萼片或花瓣的長寬,一共4列,每一列代表某個(gè)被測(cè)量的鳶尾植物,iris.shape=(150,4) y = iris.target #target是一個(gè)數(shù)組,存儲(chǔ)了data中每條記錄屬于哪一類鳶尾植物,所以數(shù)組的長度是150,所有不同值只有三個(gè) random_state = np.random.RandomState(0) #給定狀態(tài)為0的隨機(jī)數(shù)組 y = label_binarize(y, classes=[0, 1, 2]) n_classes = y.shape[1] n_samples, n_features = X.shape X = np.c_[X, random_state.randn(n_samples, 200 * n_features)] #添加合并生成特征測(cè)試數(shù)據(jù)集 X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.25, random_state=0) #根據(jù)此模型訓(xùn)練簡(jiǎn)單數(shù)據(jù)分類器 classifier = OneVsRestClassifier(svm.SVC(kernel='linear', probability=True, random_state=random_state))#線性分類支持向量機(jī) y_score = classifier.fit(X_train, y_train).decision_function(X_test) #用一個(gè)分類器對(duì)應(yīng)一個(gè)類別, 每個(gè)分類器都把其他全部的類別作為相反類別看待。 fpr = dict() tpr = dict() roc_auc = dict() for i in range(n_classes): fpr[i], tpr[i], _ = roc_curve(y_test[:, i], y_score[:, i]) #計(jì)算ROC曲線面積 roc_auc[i] = auc(fpr[i], tpr[i]) fpr["micro"], tpr["micro"], _ = roc_curve(y_test.ravel(), y_score.ravel()) roc_auc["micro"] = auc(fpr["micro"], tpr["micro"]) import matplotlib.pyplot as plt plt.figure() lw = 2 plt.plot(fpr[2], tpr[2], color='darkorange', lw=lw, label='ROC curve (area = %0.2f)' % roc_auc[2]) plt.plot([0, 1], [0, 1], color='navy', lw=lw, linestyle='--') plt.xlabel('FPR') plt.ylabel('TPR') plt.ylim([0.0, 1.0]) plt.xlim([0.0, 1.0]) plt.legend(loc="lower right") plt.title("Precision-Recall") plt.show()
以上就是關(guān)于“Python如何用鳶尾花數(shù)據(jù)繪制ROC和AUC曲線”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。