您的当前位置:首页正文

逻辑回归(Logistic Regression)

2024-11-27 来源:个人技术集锦

逻辑回归(Logistic Regression)的详细理论知识推导

逻辑回归(Logistic Regression)是一种广泛用于二分类问题的线性模型。它的目标是找到一个函数,将输入特征映射到(0, 1)之间的概率值,以预测目标变量的分类。

逻辑回归模型

逻辑回归模型的目标是找到线性决策边界。其假设函数形式为:

代价函数(Cost Function)

逻辑回归的代价函数基于对数似然函数,表示为:

梯度下降(Gradient Descent)

使用梯度下降法优化参数:

实施步骤

数据预处理:标准化或归一化数据。

标准化(Standardization)

标准化的目的是将数据转换成均值为0,标准差为1的正态分布数据。标准化的公式为:

推理过程

归一化(Normalization)

归一化的目的是将数据缩放到指定的范围(通常是[0,1])。归一化的常见公式有两种:

推理过程

通过归一化,数据被缩放到指定范围内(例如[0,1]),这使得不同特征的数据具有相同的尺度,适用于基于梯度的优化算法,如神经网络等。

import numpy as np
from sklearn.preprocessing import StandardScaler, MinMaxScaler

# 生成示例数据
data = np.array([[1, 2, 3], [4, 5, 6], [7, 8, 9], [10, 11, 12]])

# 标准化
scaler_standard = StandardScaler()
standardized_data = scaler_standard.fit_transform(data)
print("标准化数据:\n", standardized_data)

# 归一化
scaler_minmax = MinMaxScaler()
normalized_data = scaler_minmax.fit_transform(data)
print("归一化数据:\n", normalized_data)

拆分数据集:将数据集拆分为训练集和测试集。
模型训练:使用逻辑回归模型进行训练。
模型评估:使用测试集评估模型性能。

参数解读

penalty:指定正则化类型('l1', 'l2', 'elasticnet', 'none')。
C:正则化强度的倒数,较小的值表示更强的正则化。
solver:优化算法('newton-cg', 'lbfgs', 'liblinear', 'sag', 'saga')。
max_iter:最大迭代次数。
tol:优化的容差。

未优化模型实例

import numpy as np
import matplotlib.pyplot as plt
from sklearn.linear_model import LogisticRegression
from sklearn.metrics import accuracy_score, confusion_matrix, classification_report
from sklearn.model_selection import train_test_split
from sklearn.preprocessing import StandardScaler

# 生成示例数据
np.random.seed(0)
X = np.random.rand(100, 2)
y = (X[:, 0] + X[:, 1] > 1).astype(int)

# 数据分割为训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)

# 数据标准化
scaler = StandardScaler()
X_train_scaled = scaler.fit_transform(X_train)
X_test_scaled = scaler.transform(X_test)

# 创建逻辑回归模型
log_reg = LogisticRegression()
log_reg.fit(X_train_scaled, y_train)

# 进行预测
y_pred = log_reg.predict(X_test_scaled)

# 模型评估
accuracy = accuracy_score(y_test, y_pred)
conf_matrix = confusion_matrix(y_test, y_pred)
class_report = classification_report(y_test, y_pred)

print(f"Accuracy: {accuracy}")
print("Confusion Matrix:")
print(conf_matrix)
print("Classification Report:")
print(class_report)

# 可视化结果
plt.scatter(X_test_scaled[:, 0], X_test_scaled[:, 1], c=y_pred, cmap='bwr', alpha=0.7)
plt.xlabel("Feature 1")
plt.ylabel("Feature 2")
plt.title("Logistic Regression (Unoptimized)")
plt.show()

结果

可视化展示

结果解释

  • Accuracy: 准确率,表示模型在测试集上的分类正确率。
  • Confusion Matrix: 混淆矩阵,显示分类结果的详细信息。
  • Classification Report: 分类报告,显示精确度、召回率和F1得分。

优化后的模型实例

import numpy as np
import matplotlib.pyplot as plt
from sklearn.linear_model import LogisticRegression
from sklearn.metrics import accuracy_score, confusion_matrix, classification_report
from sklearn.model_selection import train_test_split
from sklearn.preprocessing import StandardScaler
from sklearn.model_selection import GridSearchCV
# 生成示例数据
np.random.seed(0)
X = np.random.rand(100, 2)
y = (X[:, 0] + X[:, 1] > 1).astype(int)

# 数据分割为训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)

# 数据标准化
scaler = StandardScaler()
X_train_scaled = scaler.fit_transform(X_train)
X_test_scaled = scaler.transform(X_test)

# 创建逻辑回归模型
log_reg = LogisticRegression()
log_reg.fit(X_train_scaled, y_train)

# 进行预测
y_pred = log_reg.predict(X_test_scaled)
# 定义参数网格
param_grid = {
    'C': [0.01, 0.1, 1, 10, 100],
    'solver': ['newton-cg', 'lbfgs', 'liblinear']
}

# 创建带网格搜索的逻辑回归模型
log_reg_cv = GridSearchCV(LogisticRegression(), param_grid, cv=5)
log_reg_cv.fit(X_train_scaled, y_train)

# 进行预测
y_pred_cv = log_reg_cv.predict(X_test_scaled)

# 模型评估
accuracy_cv = accuracy_score(y_test, y_pred_cv)
conf_matrix_cv = confusion_matrix(y_test, y_pred_cv)
class_report_cv = classification_report(y_test, y_pred_cv)

print(f"Best Parameters: {log_reg_cv.best_params_}")
print(f"Accuracy (CV): {accuracy_cv}")
print("Confusion Matrix (CV):")
print(conf_matrix_cv)
print("Classification Report (CV):")
print(class_report_cv)

# 可视化结果
plt.scatter(X_test_scaled[:, 0], X_test_scaled[:, 1], c=y_pred_cv, cmap='bwr', alpha=0.7)
plt.xlabel("Feature 1")
plt.ylabel("Feature 2")
plt.title("Logistic Regression (Optimized)")
plt.show()

结果展示

可视化展示

结果解释

  • Best Parameters: 通过网格搜索选择的最佳参数。
  • Accuracy (CV): 交叉验证后的准确率。
  • Confusion Matrix (CV): 交叉验证后的混淆矩阵。
  • Classification Report (CV): 交叉验证后的分类报告。

通过比较两个实例,可以看出优化后的模型通过网格搜索选择了最佳的超参数,从而提高了模型的预测性能和泛化能力。

显示全文