<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
AUC(Area under curve)是機器學習常用的二分類評測手段,直接含義是ROC曲線下的面積,如下圖:
要理解這張圖的含義,得先理解下面這個表:
表中列代表預測分類,行代表實際分類:
在第一張圖中,
橫座標false positive rate 代表假正類率,由fp/n計算得到,
意為 在實際負樣本中出現預測正樣本的概率。
縱座標true positive rate 代表真正類率,由tp/p計算得到,
意為 在實際正樣本中出現預測正樣本的概率。
先來看看如何得到這條曲線:
1. 通過分類器得到每個樣本的預測概率,對其從高到低進行排序
2. 從高到低,分別以每一個預測概率作為閾值,大於該閾值的認定其為1,小於的為0,計算fp rate和tp rate。
對於一個有分類效果(效果比隨機要好)的分類器,剛開始將高概率作為閾值時,閾值以上的真正樣本佔全部正樣本的比例(tp rate)>閾值以上的假正樣本佔全部負樣本的比例(fp rate)。
auc就是:隨機抽出一對樣本(一個正樣本,一個負樣本),然後用訓練得到的分類器來對這兩個樣本進行預測,預測得到正樣本的概率大於負樣本概率的概率。
在有M個正樣本,N個負樣本的資料集裡。一共有M*N對樣本(一對樣本即,一個正樣本與一個負樣本)。統計這M*N對樣本里,正樣本的預測概率大於負樣本的預測概率的個數。
舉個例子:
假設有4條樣本。2個正樣本,2個負樣本,那麼M*N=4。
即總共有4個樣本對。分別是:
(D,B),(D,A),(C,B),(C,A)。
在(D,B)樣本對中,正樣本D預測的概率大於負樣本B預測的概率(也就是D的得分比B高),記為1
同理,對於(C,B)。正樣本C預測的概率小於負樣本C預測的概率,記為0.
那麼auc如下:
假如出現得分一致的時候:
同樣本是4個樣本對,對於樣本對(C,B)其I值為0.5。
利公式:
● 對預測概率從高到低排序
● 對每一個概率值設一個rank值(最高的概率的rank為n,第二高的為n-1)
● rank實際上代表了該score(預測概率)超過的樣本的數目
為了求的組合中正樣本的score值大於負樣本,如果所有的正樣本score值都是大於負樣本的,那麼第一位與任意的進行組合score值都要大,我們取它的rank值為n,但是n-1中有M-1是正樣例和正樣例的組合這種是不在統計範圍內的(為計算方便我們取n組,相應的不符合的有M個),所以要減掉,那麼同理排在第二位的n-1,會有M-1個是不滿足的,依次類推,故得到後面的公式M*(M+1)/2,我們可以驗證在正樣本score都大於負樣本的假設下,AUC的值為1
● 除以M*N
舉例說明:
排序。按概率排序後得到:
按照上面的公式,只把正樣本的序號加起來也就是隻把樣本C,D的rank值加起來後減去一個常數項:
得到:
如果出現得分一樣的情況:
假如有4個取值概率為0.5,而且既有正樣本也有負樣本的情況。計算的時候,其實原則就是相等得分的rank取平均值。具體來說如下:
先排序:
這裡需要注意的是:相等概率得分的樣本,無論正負,誰在前,誰在後無所謂。
由於只考慮正樣本的rank值:
對於正樣本A,其rank值為7
對於正樣本B,其rank值為6
對於正樣本E,其rank值為(5+4+3+2)/4
對於正樣本F,其rank值為(5+4+3+2)/4
採用sklearn中的庫函數驗證:
import numpy as np from sklearn.metrics import roc_curve from sklearn.metrics import auc #---自己按照公式實現 def auc_calculate(labels,preds,n_bins=100): postive_len = sum(labels) negative_len = len(labels) - postive_len total_case = postive_len * negative_len pos_histogram = [0 for _ in range(n_bins)] neg_histogram = [0 for _ in range(n_bins)] bin_width = 1.0 / n_bins for i in range(len(labels)): nth_bin = int(preds[i]/bin_width) if labels[i]==1: pos_histogram[nth_bin] += 1 else: neg_histogram[nth_bin] += 1 accumulated_neg = 0 satisfied_pair = 0 for i in range(n_bins): satisfied_pair += (pos_histogram[i]*accumulated_neg + pos_histogram[i]*neg_histogram[i]*0.5) accumulated_neg += neg_histogram[i] return satisfied_pair / float(total_case) if __name__ == '__main__': y = np.array([1,0,0,0,1,0,1,0,]) pred = np.array([0.9, 0.8, 0.3, 0.1,0.4,0.9,0.66,0.7]) fpr, tpr, thresholds = roc_curve(y, pred, pos_label=1) print("-----sklearn:",auc(fpr, tpr)) print("-----py指令碼:",auc_calculate(y,pred))
AUC的優點:
它不受類別不平衡問題的影響,不同的樣本比例不會影響AUC的評測結果。在訓練時,可以直接使用AUC作為損失函數。
到此這篇關於Python實現計算AUC的範例程式碼的文章就介紹到這了,更多相關Python計算AUC內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45