码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 线性回归(概念+实例)


    目录

    前言

    一、线性回归基本概念

    1. 简单线性回归与多元线性回归

    2. 线性回归的假设

    3. 参数估计

    4. 模型评估

    5. 使用场景

    6. 局限性

    二、基于线性回归的具体实例


    前言

    线性回归是统计学中用来预测两种或两种以上变量之间关系的一种分析方法。在这种模型中,一个变量的值可以通过其他一个或多个变量的值来预测。这种关系被认为是线性的,即变量间的关系可以用一条直线来表示。

    一、线性回归基本概念

    1. 简单线性回归与多元线性回归

    2. 线性回归的假设

    • 线性关系:自变量和因变量之间存在线性关系。
    • 同方差性:对于所有的观测值,误差项的方差应该是常数。
    • 误差项的独立性:误差项之间相互独立。
    • 误差项的正态分布:误差项通常假设为正态分布。

    3. 参数估计

    线性回归模型的参数通常通过最小化误差的平方和来估计,这种方法被称为最小二乘法。具体计算过程如下:

    4. 模型评估

    5. 使用场景

    线性回归被广泛应用于经济学、生物学、工程学、社会科学等多个领域中,用于预测、趋势分析以及变量间关系的研究。

    6. 局限性

    尽管线性回归是一个强大的工具,但它也有其局限性,特别是当数据关系不是线性时,或者数据中存在多重共线性(自变量之间高度相关)时,线性回归可能不会给出有效的预测结果。

    二、基于线性回归的具体实例

    我们将创建一个虚构的数据集,其中包含一些自变量 𝑥和对应的因变量 𝑦,然后我们将使用这些数据来训练一个线性回归模型,并预测新的数据点。这里是具体的步骤:

    1. 生成数据集
    2. 建立线性回归模型
    3. 训练模型
    4. 预测新数据
    5. 可视化结果

    代码:

    1. import numpy as np
    2. import matplotlib.pyplot as plt
    3. from sklearn.linear_model import LinearRegression
    4. # 1. 生成数据集
    5. np.random.seed(0)
    6. x = 2.5 * np.random.randn(100) + 1.5 # 生成100个点的数组
    7. res = 0.5 * np.random.randn(100) # 生成100个点的残差数组
    8. y = 2 + 0.3 * x + res # 实际的y点
    9. # 2. 建立线性回归模型
    10. model = LinearRegression()
    11. # 3. 训练模型
    12. model.fit(x.reshape(-1, 1), y)
    13. # 4. 预测新数据
    14. x_new = np.linspace(-5, 5, 100)
    15. y_pred = model.predict(x_new.reshape(-1, 1))
    16. # 5. 可视化结果
    17. plt.figure(figsize=(8, 4))
    18. plt.scatter(x, y)
    19. plt.plot(x_new, y_pred, color='red') # 预测的线
    20. plt.title('Linear Regression')
    21. plt.xlabel('X')
    22. plt.ylabel('Y')
    23. plt.grid(True)
    24. plt.show()

    结果:

  • 相关阅读:
    WebDAV之葫芦儿·派盘+言叶
    【机器学习】手写数字识别
    shell脚本
    优美的排列 II
    shiro集成 spring-加密md5配置--权限管理-shiro中的session 等等!!
    【MySQL】的存储引擎 事务 锁机制 日志
    Java并发 JUC工具类:Semaphore详解
    Spring注解@Transactional是什么?具体的使用方法
    OpenCV(一)基础API
    协议定制 + Json序列化反序列化
  • 原文地址:https://blog.csdn.net/weixin_47151388/article/details/138190286
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号