欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于Python實現(xiàn)一個多分類的Logistic回歸模型的代碼示例

 更新時間:2025年01月06日 09:02:31   作者:Tech Synapse  
在機器學習中,Logistic回歸是一種基本但非常有效的分類算法,它不僅可以用于二分類問題,還可以擴展應(yīng)用于多分類問題,本文將詳細介紹如何使用Python實現(xiàn)一個多分類的Logistic回歸模型,并給出詳細的代碼示例,需要的朋友可以參考下

一、Logistic回歸簡介

Logistic回歸是一種線性模型,用于二分類問題。它通過Sigmoid函數(shù)將線性回歸的輸出映射到(0, 1)區(qū)間內(nèi),從而得到樣本屬于某一類的概率。對于多分類問題,可以使用Softmax函數(shù)將輸出映射到多個類別上,使得每個類別的輸出概率之和為1。

Logistic回歸模型的一般形式為:

其中,θ 是模型參數(shù),x 是輸入特征。

對于多分類問題,假設(shè)有 k 個類別,則Softmax函數(shù)的形式為:

其中,θi 是第 i 個類別的參數(shù)向量。

二、數(shù)據(jù)準備

在實現(xiàn)多分類Logistic回歸之前,我們需要準備一些數(shù)據(jù)。這里我們使用經(jīng)典的Iris數(shù)據(jù)集,該數(shù)據(jù)集包含三個類別的鳶尾花,每個類別有50個樣本,每個樣本有4個特征。

以下是數(shù)據(jù)準備的代碼:

import pandas as pd
from sklearn.datasets import load_iris
from sklearn.model_selection import train_test_split
from sklearn.preprocessing import StandardScaler
 
# 加載Iris數(shù)據(jù)集
iris = load_iris()
data = pd.DataFrame(data=iris.data, columns=iris.feature_names)
data['target'] = iris.target
 
# 顯示數(shù)據(jù)的前5行
print(data.head())
 
# 劃分訓練集和測試集
X = data[iris.feature_names]  # 特征
y = data['target']  # 目標變量
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.3, random_state=42)
 
# 特征縮放
scaler = StandardScaler()
X_train = scaler.fit_transform(X_train)
X_test = scaler.transform(X_test)

三、模型訓練

在訓練多分類Logistic回歸模型時,我們需要使用LogisticRegression類,并指定multi_class='multinomial'參數(shù)以使用多項邏輯回歸。此外,我們還需要指定優(yōu)化算法,這里使用solver='lbfgs'。

以下是模型訓練的代碼:

from sklearn.linear_model import LogisticRegression
 
# 創(chuàng)建Logistic回歸模型
model = LogisticRegression(multi_class='multinomial', solver='lbfgs')
 
# 訓練模型
model.fit(X_train, y_train)
 
# 輸出模型的訓練分數(shù)
print(f'Training score: {model.score(X_train, y_train)}')

四、模型評估

訓練完模型后,我們需要對模型進行評估,以了解其在測試集上的表現(xiàn)。常用的評估指標包括準確率、混淆矩陣和分類報告。

以下是模型評估的代碼:

from sklearn.metrics import accuracy_score, confusion_matrix, classification_report
 
# 對測試集進行預(yù)測
y_pred = model.predict(X_test)
 
# 計算和顯示準確率
accuracy = accuracy_score(y_test, y_pred)
print(f'Accuracy: {accuracy}')
 
# 計算和顯示混淆矩陣
conf_matrix = confusion_matrix(y_test, y_pred)
print('Confusion Matrix:\n', conf_matrix)
 
# 計算和顯示分類報告
print(classification_report(y_test, y_pred))

五、代碼整合與運行

以下是完整的代碼示例,可以直接運行:

import pandas as pd
from sklearn.datasets import load_iris
from sklearn.model_selection import train_test_split
from sklearn.preprocessing import StandardScaler
from sklearn.linear_model import LogisticRegression
from sklearn.metrics import accuracy_score, confusion_matrix, classification_report
 
# 加載Iris數(shù)據(jù)集
iris = load_iris()
data = pd.DataFrame(data=iris.data, columns=iris.feature_names)
data['target'] = iris.target
 
# 顯示數(shù)據(jù)的前5行
print(data.head())
 
# 劃分訓練集和測試集
X = data[iris.feature_names]  # 特征
y = data['target']  # 目標變量
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.3, random_state=42)
 
# 特征縮放
scaler = StandardScaler()
X_train = scaler.fit_transform(X_train)
X_test = scaler.transform(X_test)
 
# 創(chuàng)建Logistic回歸模型
model = LogisticRegression(multi_class='multinomial', solver='lbfgs')
 
# 訓練模型
model.fit(X_train, y_train)
 
# 輸出模型的訓練分數(shù)
print(f'Training score: {model.score(X_train, y_train)}')
 
# 對測試集進行預(yù)測
y_pred = model.predict(X_test)
 
# 計算和顯示準確率
accuracy = accuracy_score(y_test, y_pred)
print(f'Accuracy: {accuracy}')
 
# 計算和顯示混淆矩陣
conf_matrix = confusion_matrix(y_test, y_pred)
print('Confusion Matrix:\n', conf_matrix)
 
# 計算和顯示分類報告
print(classification_report(y_test, y_pred))

六、結(jié)果分析

運行上述代碼后,你將得到模型的訓練分數(shù)、準確率、混淆矩陣和分類報告。以下是對這些結(jié)果的分析:

  1. 訓練分數(shù):這是模型在訓練集上的準確率,通常會比測試集上的準確率要高。如果訓練分數(shù)過高而測試分數(shù)過低,可能表明模型出現(xiàn)了過擬合。
  2. 準確率:這是模型在測試集上的準確率,是衡量模型性能的重要指標。準確率越高,說明模型的性能越好。
  3. 混淆矩陣:混淆矩陣是一個表格,用于顯示模型在各個類別上的預(yù)測結(jié)果。通過混淆矩陣,我們可以了解模型在各個類別上的表現(xiàn),以及是否存在類別混淆的情況。
  4. 分類報告:分類報告提供了每個類別的精確率、召回率和F1分數(shù)等指標。精確率表示預(yù)測為正樣本的實例中真正為正樣本的比例;召回率表示所有真正的正樣本中被正確預(yù)測的比例;F1分數(shù)是精確率和召回率的調(diào)和平均數(shù),用于綜合衡量模型的性能。

七、模型優(yōu)化

雖然上述代碼已經(jīng)實現(xiàn)了一個基本的多分類Logistic回歸模型,但在實際應(yīng)用中,我們可能還需要對模型進行優(yōu)化,以提高其性能。以下是一些常用的優(yōu)化方法:

  1. 特征選擇:選擇對模型性能有重要影響的特征進行訓練,可以提高模型的準確性和泛化能力。
  2. 正則化:通過添加正則化項來防止模型過擬合。Logistic回歸中常用的正則化方法包括L1正則化和L2正則化。
  3. 調(diào)整超參數(shù):通過調(diào)整模型的超參數(shù)(如學習率、迭代次數(shù)等)來優(yōu)化模型的性能。
  4. 集成學習:將多個模型的預(yù)測結(jié)果進行組合,以提高模型的準確性和穩(wěn)定性。常用的集成學習方法包括袋裝法(Bagging)和提升法(Boosting)。

八、結(jié)論

本文詳細介紹了如何使用Python實現(xiàn)一個多分類的Logistic回歸模型,并給出了詳細的代碼示例。通過數(shù)據(jù)準備、模型訓練、模型評估和結(jié)果分析等步驟,我們了解了多分類Logistic回歸的基本實現(xiàn)流程。此外,本文還介紹了模型優(yōu)化的一些常用方法,以幫助讀者在實際應(yīng)用中提高模型的性能。希望本文能為初學者提供有價值的參考,并在實踐中不斷提升自己的技能。

以上就是基于Python實現(xiàn)一個多分類的Logistic回歸模型的代碼示例的詳細內(nèi)容,更多關(guān)于Python Logistic回歸模型的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • pandas 如何保存數(shù)據(jù)到excel,csv

    pandas 如何保存數(shù)據(jù)到excel,csv

    這篇文章主要介紹了pandas 如何保存數(shù)據(jù)到excel,csv的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • Python的pytest測試框架使用詳解

    Python的pytest測試框架使用詳解

    這篇文章主要介紹了Python的pytest測試框架使用詳解,說到?pytest,大家總不免要拿來和?unittest?來比一下,但是?unittest?畢竟是標準庫,兼容性方面肯定沒得說,但要論簡潔和方便的話,pytest?也是不落下風的,需要的朋友可以參考下
    2023-07-07
  • Python函數(shù)的參數(shù)常見分類與用法實例詳解

    Python函數(shù)的參數(shù)常見分類與用法實例詳解

    這篇文章主要介紹了Python函數(shù)的參數(shù)常見分類與用法,結(jié)合實例形式較為詳細的分析了Python函數(shù)的形參、實參、默認參數(shù)、可變參數(shù)等概念、使用方法及相關(guān)操作注意事項,需要的朋友可以參考下
    2019-03-03
  • python實現(xiàn)單向鏈表詳解

    python實現(xiàn)單向鏈表詳解

    這篇文章主要介紹了python實現(xiàn)單向鏈表詳解,分享了相關(guān)代碼示例,每一步操作前都有簡單分析,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下
    2018-02-02
  • Python OpenCV實現(xiàn)識別信用卡號教程詳解

    Python OpenCV實現(xiàn)識別信用卡號教程詳解

    本文將介紹如何通過 OpenCV 和 Python 使用模板匹配來執(zhí)行光學字符識別 (OCR),再應(yīng)用我們的模板匹配 OCR 方法來識別信用卡類型以及 16 位信用卡數(shù)字。代碼具有一定價值,感興趣的童鞋可以了解一下
    2021-11-11
  • 1分鐘快速生成用于網(wǎng)頁內(nèi)容提取的xslt

    1分鐘快速生成用于網(wǎng)頁內(nèi)容提取的xslt

    這篇文章主要教大家如何1分鐘快速生成用于網(wǎng)頁內(nèi)容提取的xslt,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-02-02
  • Python裝飾器的應(yīng)用場景代碼總結(jié)

    Python裝飾器的應(yīng)用場景代碼總結(jié)

    這篇文章主要介紹了Python裝飾器的應(yīng)用場景,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-04-04
  • python中os模塊和sys模塊的使用詳解

    python中os模塊和sys模塊的使用詳解

    本文主要介紹了python中os模塊和sys模塊的使用詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-03-03
  • python 數(shù)據(jù)庫查詢返回list或tuple實例

    python 數(shù)據(jù)庫查詢返回list或tuple實例

    這篇文章主要介紹了python 數(shù)據(jù)庫查詢返回list或tuple實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • Numpy數(shù)據(jù)轉(zhuǎn)換成image并保存的實現(xiàn)示例

    Numpy數(shù)據(jù)轉(zhuǎn)換成image并保存的實現(xiàn)示例

    本文主要介紹了Numpy數(shù)據(jù)轉(zhuǎn)換成image并保存的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-12-12

最新評論