人工智能直通车系列14【机器学习基础】(逻辑回归原理逻辑回归模型实现)

目录

逻辑回归原理

基本概念

线性组合

[逻辑函数(Sigmoid 函数)](#逻辑函数(Sigmoid 函数))

决策规则

损失函数与参数优化

[逻辑回归模型实现(scikit - learn)](#逻辑回归模型实现(scikit - learn))

代码实现步骤

代码解释

场景示例

邮件分类

疾病诊断


逻辑回归原理

基本概念

逻辑回归(Logistic Regression)是一种广泛用于二分类问题的机器学习算法,虽然名字中带有 "回归",但实际上是分类算法。它通过对输入特征进行线性组合,然后使用逻辑函数(也称为 Sigmoid 函数)将线性组合的结果映射到 0 到 1 之间的概率值,以此来进行分类决策。

线性组合

假设我们有一个包含 个特征的输入向量 ,逻辑回归首先对这些特征进行线性组合,得到一个线性得分

其中 是模型需要学习的参数,​ 是截距项, 的转置。

逻辑函数(Sigmoid 函数)

为了将线性得分 转换为概率值,逻辑回归使用 Sigmoid 函数

Sigmoid 函数的图像呈 S 形,其值域在 之间。当 趋近于正无穷时, 趋近于 1;当 趋近于负无穷时, 趋近于 0。通过 Sigmoid 函数,我们可以将线性得分 映射为一个概率值,表示样本属于正类的概率

而样本属于负类的概率则为

决策规则

通常,我们会设定一个阈值(一般为 0.5),当 时,将样本预测为正类;当 时,将样本预测为负类。

损失函数与参数优化

逻辑回归使用对数损失函数(也称为交叉熵损失函数)来衡量模型预测的概率与真实标签之间的差异。对于单个样本 ,其对数损失函数为:

对于包含 个样本的数据集,总的损失函数为所有样本损失的平均值:

模型的目标是找到一组参数 使得损失函数 最小化,常用的优化算法有梯度下降法等。

逻辑回归模型实现(scikit - learn)

代码实现步骤

以下是使用 scikit - learn 实现逻辑回归模型的详细步骤和示例代码:

python 复制代码
import numpy as np
from sklearn.datasets import make_classification
from sklearn.model_selection import train_test_split
from sklearn.linear_model import LogisticRegression
from sklearn.metrics import accuracy_score, confusion_matrix

# 1. 生成示例数据集
# 使用 make_classification 函数生成一个二分类数据集
X, y = make_classification(n_samples=1000, n_features=10, n_informative=5, n_redundant=0, random_state=42)

# 2. 划分训练集和测试集
# 将数据集按照 80:20 的比例划分为训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)

# 3. 创建逻辑回归模型对象
# 创建 LogisticRegression 类的实例,使用默认参数
model = LogisticRegression()

# 4. 训练模型
# 使用训练集数据对模型进行训练
model.fit(X_train, y_train)

# 5. 进行预测
# 使用训练好的模型对测试集数据进行预测
y_pred = model.predict(X_test)

# 6. 评估模型性能
# 计算模型的准确率
accuracy = accuracy_score(y_test, y_pred)
# 计算混淆矩阵
conf_matrix = confusion_matrix(y_test, y_pred)

print(f"模型准确率: {accuracy}")
print(f"混淆矩阵:\n{conf_matrix}")
代码解释
  1. 数据生成 :使用 make_classification 函数生成一个包含 1000 个样本、10 个特征的二分类数据集,其中 5 个特征是有信息的。
  2. 数据划分 :使用 train_test_split 函数将数据集划分为训练集和测试集,测试集占比 20%。
  3. 模型创建 :创建 LogisticRegression 类的实例 model,使用默认的参数设置。
  4. 模型训练 :调用 fit 方法,使用训练集数据 X_train 和对应的标签 y_train 对模型进行训练。
  5. 模型预测 :使用训练好的模型对测试集数据 X_test 进行预测,得到预测结果 y_pred
  6. 模型评估 :使用 accuracy_score 函数计算模型的准确率,使用 confusion_matrix 函数计算混淆矩阵,以评估模型的性能。

场景示例

邮件分类

假设你要构建一个邮件分类系统,将邮件分为垃圾邮件和正常邮件。你可以收集大量的邮件数据,提取邮件的各种特征,如邮件主题中的关键词、发件人信息、邮件内容中的词汇等,将这些特征作为输入向量 x。邮件的标签(垃圾邮件或正常邮件)作为目标变量 y。使用逻辑回归模型进行训练和预测,根据模型预测的概率值判断邮件是否为垃圾邮件。

疾病诊断

在医学领域,医生可以收集患者的各种生理指标(如年龄、血压、血糖等)作为特征,患者是否患有某种疾病作为目标变量。通过逻辑回归模型,医生可以根据患者的生理指标预测患者患病的概率,辅助进行疾病诊断。

相关推荐
墨染天姬9 分钟前
【AI】端侧AIBOX可以部署哪些智能体
人工智能
AI成长日志13 分钟前
【Agentic RL】1.1 什么是Agentic RL:从传统RL到智能体学习
人工智能·学习·算法
2501_9481142425 分钟前
2026年大模型API聚合平台技术评测:企业级接入层的治理演进与星链4SAPI架构观察
大数据·人工智能·gpt·架构·claude
小小工匠27 分钟前
LLM - awesome-design-md 从 DESIGN.md 到“可对话的设计系统”:用纯文本驱动 AI 生成一致 UI 的新范式
人工智能·ui
黎阳之光43 分钟前
黎阳之光:视频孪生领跑者,铸就中国数字科技全球竞争力
大数据·人工智能·算法·安全·数字孪生
小超同学你好1 小时前
面向 LLM 的程序设计 6:Tool Calling 的完整生命周期——从定义、决策、执行到观测回注
人工智能·语言模型
智星云算力1 小时前
本地GPU与租用GPU混合部署:混合算力架构搭建指南
人工智能·架构·gpu算力·智星云·gpu租用
jinanwuhuaguo1 小时前
截止到4月8日,OpenClaw 2026年4月更新深度解读剖析:从“能力回归”到“信任内建”的范式跃迁
android·开发语言·人工智能·深度学习·kotlin
xiaozhazha_1 小时前
效率提升80%:2026年AI CRM与ERP深度集成的架构设计与实现
人工智能
枫叶林FYL1 小时前
【自然语言处理 NLP】7.2.2 安全性评估与Constitutional AI
人工智能·自然语言处理