評估機器學習分類模型
概要
- 模型評估的目標是什麼?
- 模型評估的目的是什麼,有哪些 常見的評估程序?
- 分類準確率有什麼用,它的作用是什麼 限制?
- 混淆矩陣如何描述 分類器?
- 可以從混淆矩陣計算哪些指標?
T模型評估的目標是回答問題;
不同型號如何選擇?
評估機器學習的過程有助於確定模型的應用可靠性和有效性。這涉及評估不同的因素,例如其性能、指標以及預測或決策的準確性。
無論您選擇使用什麼模型,您都需要一種在模型之間進行選擇的方法:不同的模型類型、調整參數和功能。此外,您還需要一個模型評估程式來估計模型對未見過的資料的泛化能力。最後,您需要一個評估程序來與其他程序配合,以量化您的模型性能。
在我們繼續之前,讓我們回顧一下一些不同的模型評估程序及其運作方式。
模型評估程序及其運作方式。
-
使用相同資料進行訓練和測試
- 獎勵過於複雜的模型,這些模型「過度擬合」訓練資料且不一定具有泛化能力
-
訓練/測試分開
- 將資料集分成兩部分,以便可以在不同的資料上訓練和測試模型
- 更好地估計樣本外性能,但仍然是「高方差」估計
- 因其速度、簡單性和靈活性而有用
-
K 折交叉驗證
- 系統地建立「K」個訓練/測試分組並將結果一起平均
- 更好地估計樣本外表現
- 運行速度比訓練/測試分開慢「K」倍。
從上面我們可以推論出:
對相同數據進行訓練和測試是過度擬合的一個典型原因,在這種情況下,您建立的模型過於複雜,無法泛化到新數據,而且實際上沒有用。
Train_Test_Split 可以更好地估計樣本外效能。
透過系統性地進行 K 次訓練測試分割並將結果平均在一起,K 折交叉驗證效果更好。
總之,train_tests_split 由於其速度和簡單性,對於交叉驗證來說仍然是有利可圖的,這就是我們將在本教程中使用的內容。
模型評估指標:
您始終需要一個評估指標來配合您選擇的程序,而您選擇的指標取決於您要解決的問題。對於分類問題,可以使用分類精度。但我們將在本指南中重點關注其他重要的分類評估指標。
在我們學習任何新的評估指標之前,讓我們回顧一下分類準確性,並討論它的優點和缺點。
分類準確率
我們為本教學選擇了 Pima Indians 糖尿病資料集,其中包括 768 名患者的健康資料和糖尿病狀況。
讓我們讀取資料並列印前 5 行資料。如果患者患有糖尿病,則標籤欄顯示 1,如果患者沒有糖尿病,則標籤欄顯示 0,我們要回答的問題是:
問題: 我們可以根據患者的健康測量結果預測其糖尿病狀況嗎?
我們定義特徵量測 X 和反應向量 Y。我們使用 train_test_split 將 X 和 Y 分成訓練集和測試集。
接下來,我們在訓練集上訓練邏輯迴歸模型。在擬合步驟中,logreg 模型物件正在學習 X_train 和 Y_train 之間的關係。最後我們對測試集進行類別預測。
現在,我們已經對測試集進行了預測,我們可以計算分類準確率,簡單來說就是正確預測的百分比。
但是,每當您使用分類準確性作為評估指標時,將其與空準確性進行比較非常重要,這是透過始終預測最頻繁的類別可以獲得的準確性。
空準確率回答了問題;如果我的模型能夠 100% 預測主要類別,那麼它正確的機率是多少?在上面的場景中,y_test 的 32% 為 1(個)。換句話說,預測患者患有糖尿病的愚蠢模型68% 的時間是正確的(即零)。這提供了一個基線,我們可能希望根據該基線來衡量邏輯迴歸模型。
當我們比較 68% 的空精度和 69% 的模型精度時,我們的模型看起來不太好。這表明分類準確性作為模型評估指標的一個弱點。分類準確性並不能告訴我們有關測試測試的基本分佈的任何資訊。
總結:
- 分類準確度是最容易理解的分類指標
- 但是,它不會告訴您回應值的底層分佈
- 並且,它不會告訴您分類器正在產生什麼錯誤「類型」。
現在讓我們來看看混淆矩陣。
混淆矩陣
混淆矩陣是描述分類模型表現的表格。
它有助於幫助您了解分類器的性能,但它不是模型評估指標;所以你不能告訴 scikit learn 選擇具有最佳混淆矩陣的模型。然而,有許多指標可以從混淆矩陣中計算出來,並且可以直接用於在模型之間進行選擇。
- 測試集中的每個觀察結果都在恰好一個盒子中表示
- 這是一個 2x2 矩陣,因為有 2 個反應類別
- 此處顯示的格式不通用
讓我們解釋一下它的一些基本術語。
- 真陽性 (TP):我們正確預測他們確實患有糖尿病
- 真陰性 (TN):我們正確預測他們沒有患有糖尿病
- 誤報 (FP):我們錯誤地預測他們確實患有糖尿病(「I 類錯誤」)
- 假陰性 (FN):我們錯誤地預測他們沒有患有糖尿病(「II 型錯誤」)
讓我們來看看如何計算指標
結論:
- 混淆矩陣為您提供更完整的圖片您的分類器的執行情況
- 還允許您計算各種分類指標,這些指標可以指導您的模型選擇
以上是評估機器學習分類模型的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Python适合数据科学、Web开发和自动化任务,而C 适用于系统编程、游戏开发和嵌入式系统。Python以简洁和强大的生态系统著称,C 则以高性能和底层控制能力闻名。

Python在遊戲和GUI開發中表現出色。 1)遊戲開發使用Pygame,提供繪圖、音頻等功能,適合創建2D遊戲。 2)GUI開發可選擇Tkinter或PyQt,Tkinter簡單易用,PyQt功能豐富,適合專業開發。

兩小時內可以學到Python的基礎知識。 1.學習變量和數據類型,2.掌握控制結構如if語句和循環,3.了解函數的定義和使用。這些將幫助你開始編寫簡單的Python程序。

2小時內可以學會Python的基本編程概念和技能。 1.學習變量和數據類型,2.掌握控制流(條件語句和循環),3.理解函數的定義和使用,4.通過簡單示例和代碼片段快速上手Python編程。

Python更易學且易用,C 則更強大但複雜。 1.Python語法簡潔,適合初學者,動態類型和自動內存管理使其易用,但可能導致運行時錯誤。 2.C 提供低級控制和高級特性,適合高性能應用,但學習門檻高,需手動管理內存和類型安全。

Python在web開發、數據科學、機器學習、自動化和腳本編寫等領域有廣泛應用。 1)在web開發中,Django和Flask框架簡化了開發過程。 2)數據科學和機器學習領域,NumPy、Pandas、Scikit-learn和TensorFlow庫提供了強大支持。 3)自動化和腳本編寫方面,Python適用於自動化測試和系統管理等任務。

要在有限的時間內最大化學習Python的效率,可以使用Python的datetime、time和schedule模塊。 1.datetime模塊用於記錄和規劃學習時間。 2.time模塊幫助設置學習和休息時間。 3.schedule模塊自動化安排每週學習任務。

Python在自動化、腳本編寫和任務管理中表現出色。 1)自動化:通過標準庫如os、shutil實現文件備份。 2)腳本編寫:使用psutil庫監控系統資源。 3)任務管理:利用schedule庫調度任務。 Python的易用性和豐富庫支持使其在這些領域中成為首選工具。
