news 2026/6/10 16:59:13

线性回归是机器学习中最基础的算法之一,用于建立输入变量(特征)与输出变量

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
线性回归是机器学习中最基础的算法之一,用于建立输入变量(特征)与输出变量

线性回归原理与代码实现

线性回归是机器学习中最基础的算法之一,用于建立输入变量(特征)与输出变量(目标)之间的线性关系。以下是其核心原理及Python实现。

数学原理

线性回归模型表示为:
$y = wX + b$
其中:

  • $y$ 是预测值
  • $X$ 是输入特征矩阵
  • $w$ 是权重(斜率)
  • $b$ 是偏置项(截距)

目标是最小化损失函数(均方误差):
$L = \frac{1}{N}\sum_{i=1}^N (y_i - (wX_i + b))^2$

代码实现
import numpy as np class LinearRegression: def __init__(self): self.w = None # 权重 self.b = None # 偏置 def fit(self, X, y, learning_rate=0.01, epochs=1000): # 初始化参数 n_samples, n_features = X.shape self.w = np.zeros(n_features) self.b = 0 # 梯度下降 for _ in range(epochs): y_pred = np.dot(X, self.w) + self.b # 计算梯度 dw = (1/n_samples) * np.dot(X.T, (y_pred - y)) db = (1/n_samples) * np.sum(y_pred - y) # 更新参数 self.w -= learning_rate * dw self.b -= learning_rate * db def predict(self, X): return np.dot(X, self.w) + self.b
使用示例
# 生成示例数据 X = np.array([[1], [2], [3], [4]]) y = np.array([2, 4, 6, 8]) # 训练模型 model = LinearRegression() model.fit(X, y) # 预测 print(model.predict(np.array([[5]]))) # 输出接近10
关键点说明
  • 梯度下降:通过迭代调整参数使损失函数最小化
  • 学习率:控制参数更新步长,过大可能无法收敛,过小收敛慢
  • 特征缩放:在实际应用中建议对特征做标准化处理
扩展建议
  • 添加正则化(L1/L2)防止过拟合
  • 实现批量梯度下降/随机梯度下降变体
  • 添加模型评估指标(如R²分数)

这段代码完整实现了线性回归的核心逻辑,包含训练和预测功能,适合初学者理解算法本质。实际应用时可结合Scikit-learn等库进行优化。

公式解析

该公式表示均方误差损失函数(Mean Squared Error, MSE),常用于回归问题的模型训练中,用于衡量模型预测值与真实值之间的差异。

  • 符号说明
    • $N$:样本数量。
    • $y_i$:第 $i$ 个样本的真实值。
    • $X_i$:第 $i$ 个样本的特征向量。
    • $w$:模型权重参数(可能是标量或向量,取决于 $X_i$ 的维度)。
    • $b$:偏置项(截距)。
    • $wX_i + b$:模型的线性预测值。

数学意义

公式计算所有样本的预测误差平方的平均值:

  1. 对每个样本,计算预测值 $wX_i + b$ 与真实值 $y_i$ 的差值。
  2. 对差值取平方,消除正负影响并放大较大误差。
  3. 对所有样本的平方误差求和并除以样本数 $N$,得到平均误差。

代码实现(Python)

import numpy as np def mean_squared_error(y_true, y_pred): """ 计算均方误差损失 :param y_true: 真实值数组,形状 (N,) :param y_pred: 预测值数组,形状 (N,) :return: MSE 标量值 """ return np.mean((y_true - y_pred) ** 2) # 示例用法 y_true = np.array([3, 5, 7]) y_pred = np.array([2.5, 5.1, 7.8]) mse = mean_squared_error(y_true, y_pred) print(f"MSE: {mse:.4f}")


优化目标

在训练中,通过调整 $w$ 和 $b$ 最小化 $L$:

  • 使用梯度下降等优化算法,计算 $L$ 对 $w$ 和 $b$ 的偏导数:
    • $\frac{\partial L}{\partial w} = -\frac{2}{N}\sum_{i=1}^N X_i(y_i - (wX_i + b))$
    • $\frac{\partial L}{\partial b} = -\frac{2}{N}\sum_{i=1}^N (y_i - (wX_i + b))$
  • 迭代更新参数直至收敛。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 14:10:08

Keil MDK下载安装过程中路径设置注意事项

Keil MDK 安装路径设置:一个被严重低估的嵌入式开发“地基工程”你有没有遇到过这样的情况?明明代码写得没问题,点击“Build”却弹出“Cannot find compiler ‘ARMCC’”;自动化脚本在同事电脑上跑得好好的,到了你的机…

作者头像 李华
网站建设 2026/6/6 15:39:31

STM32CubeMX下载后的第一个LED闪烁项目从零实现

从零开始点亮第一盏LED:STM32CubeMX实战入门全记录 你有没有过这样的经历?下载完STM32CubeMX,打开软件却不知道下一步该点哪里;好不容易生成了代码,编译烧录后LED却不亮……别担心,这几乎是每个嵌入式新手…

作者头像 李华
网站建设 2026/6/10 12:48:52

AD导出Gerber文件时层设置的系统学习

Altium Designer导出Gerber文件:从层设置到生产交付的实战指南在电子硬件开发中,完成PCB布局布线只是走完了“万里长征第一步”。真正决定产品能否顺利投产的关键一步——把设计准确无误地交给工厂制造,往往被许多工程师轻视甚至忽视。而这个…

作者头像 李华
网站建设 2026/5/30 18:19:34

基于STM32的工业控制ISR配置手把手教程

手把手教你打造工业级实时响应系统:STM32中断配置实战全解析在工厂的自动化产线上,一个电机突然过流,控制系统必须在几毫秒内切断电源;一台机器人手臂接近障碍物,安全光栅信号必须被立即捕获并处理;PLC需要…

作者头像 李华
网站建设 2026/6/10 9:17:53

STM32开发入门:Keil5安装与配置手把手教程

从零开始搭建STM32开发环境:Keil5安装与配置实战指南 你是不是也曾在准备动手写第一行代码时,被一堆工具链、驱动和配置项搞得晕头转向?明明只是想点亮一个LED,却卡在“无法连接目标”或者“找不到芯片”这种问题上。别急——这几…

作者头像 李华
网站建设 2026/6/10 14:32:18

Multisim汉化实战:软件层修改完整指南

Multisim汉化实战:从资源修改到自动化部署的完整技术路径你有没有遇到过这样的场景?打开Multisim准备做电路仿真,刚点开“Place”菜单就卡住了——Ground是接地还是电源?Probe到底该译成“探针”还是“探测器”?对于初…

作者头像 李华