逻辑回归(Logistic Regression)是机器学习中的一种分类模型,逻辑回归是一种分类算法,虽然名字中带有回归,但是它与回归之间有一定的联系。由于算法的简单和高效,在实际中应用非常广泛。逻辑回归是解决二分类(两个类别之间的判断)问题的利器
逻辑回归的输入就是一个线性回归的结果(输出)。
假设有两个类别A,B,并且假设我们的概率值为属于A(1)这个类别的概率值。现在有一个样本的输入到逻辑回归输出结果0.6,那么这个概率值超过0.5,意味着我们训练或者预测的结果就是A(1)类别。那么反之,如果得出结果为0.3那么,训练或者预测结果就为B(0)类别。
逻辑回归的损失,称之为对数似然损失,公式如下:
同样使用梯度下降优化算法,去减少损失函数的值。这样去更新逻辑回归前面对应算法的权重参数,提升原本属于1类别的概率,降低原本是0类别的概率。
sklearn.linear_model.LogisticRegression(solver=‘liblinear‘, penalty=‘l2’, C = 1.0)
from sklearn.model_selection import train_test_split from sklearn.linear_model import LogisticRegression from sklearn.preprocessing import StandardScaler import pandas as pd import numpy as np def logisticregression(): """ 逻辑回归进行癌症预测 :return: None """ # 1、读取数据,处理缺失值以及标准化 column_name = [‘Sample code number‘, ‘Clump Thickness‘, ‘Uniformity of Cell Size‘, ‘Uniformity of Cell Shape‘, ‘Marginal Adhesion‘, ‘Single Epithelial Cell Size‘, ‘Bare Nuclei‘, ‘Bland Chromatin‘, ‘Normal Nucleoli‘, ‘Mitoses‘, ‘Class‘] data = pd.read_csv("https://archive.ics.uci.edu/ml/machine-learning-databases/breast-cancer-wisconsin/breast-cancer-wisconsin.data", names=column_name) # 删除缺失值 data = data.replace(to_replace=‘?‘, value=np.nan) data = data.dropna() # 取出特征值 x = data[column_name[1:10]] y = data[column_name[10]] # 分割数据集 x_train, x_test, y_train, y_test = train_test_split(x, y, test_size=0.3) # 进行标准化 std = StandardScaler() x_train = std.fit_transform(x_train) x_test = std.transform(x_test) # 使用逻辑回归 lr = LogisticRegression() lr.fit(x_train, y_train) print("得出来的权重:", lr.coef_) # 预测类别 print("预测的类别:", lr.predict(x_test)) # 得出准确率 print("预测的准确率:", lr.score(x_test, y_test)) return None if __name__ == ‘__main__‘: logisticregression()
在分类任务下,预测结果(Predicted Condition)与正确标记(True Condition)之间存在四种不同的组合,构成混淆矩阵(适用于多分类)
sklearn.metrics.classification_report(y_true, y_pred, labels=[], target_names=None )
print("精确率和召回率为:", classification_report(y_test, lr.predict(x_test), labels=[2, 4], target_names=[‘良性‘, ‘恶性‘]))
最终AUC的范围在[0.5, 1]之间,并且越接近1越好
# 0.5~1之间,越接近于1约好 y_test = np.where(y_test > 2.5, 1, 0) print("AUC指标:", roc_auc_score(y_test, lr.predict(x_test)))
原文:https://www.cnblogs.com/MoooJL/p/14322442.html