码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • [从0开始机器学习]4.线性回归 正规方程


    🐺本博主博客:ζั͡ ั͡雾 ั͡狼 ั͡✾的博客

    🎀专栏:机器学习

    🎀专栏:爬虫

    🎀专栏:OpenCV图像识别处理

    🎀专栏:Unity2D


    ⭐本节课理论视频:P23-P25 正规方程

    ⭐本节课推荐其他人笔记:正规方程(Normal equations)推导过程_momentum_的博客

    🐺机器学习通过文字描述是难以教学学会的,每一节课我会推荐这个理论的网课,一定要看上面的理论视频!一定要看上面的理论视频!一定要看上面的理论视频!所以我只是通过代码实现,并通过注释形式来详细讲述每一步的原因,最后通过画图对比的新式来看结果比较。

    ⭐机器学习推荐博主:GoAI的博客_CSDN博客-深度学习,机器学习,大数据笔记领域博主

    😊如果你什么都不懂机器学习,那我推荐GoAI的入门文章:机器学习知识点全面总结_GoAI的博客-CSDN博客_机器学习笔记

    在线性回归中实际就是求代价函数对系数变量求导,导数为0的时候,即代价函数最小的时候,系数矩阵的值。以多元一次函数为例

     使用前提:1.X特征数量小于样本数量

                        2.X矩阵中不存在线性相关的量

    缺点:n很大时候(n>10000),比起梯度下降法,运行远远慢

    1. import numpy as np
    2. # 全局变量
    3. # 生成数据
    4. # X中每一行代表一条数据i,代表着一个等式,其中列数代表着变量数,每个变量的系数是不知道的
    5. # 每一行数据是y=k0x0+k1x1+k2x2+k3x3+k4x4,
    6. # k是我们要回归的系数向量,x1,x2,x3,x4是每一行数据其中
    7. # k0代表常数,x0恒为1
    8. X = np.array([[5, 100, 58, -3],
    9. [7, 120, 59, -3],
    10. [3, 140, 50, -5],
    11. [10, 80, 45, -1],
    12. [6, 96, 55, -7],
    13. [15, 200, 52, -11],
    14. [11, 125, 65, -5],
    15. [12, 63, 100, -3],
    16. [20, 500, 66, -10]])
    17. # 假设K系数为这个,咱们的算法就是逼近这个结果,当然,如果有自己的数据就更好了
    18. preK = [12, -1, 2, 8] + np.random.random((1, 4))
    19. # Y中的数据量等于X矩阵的行数
    20. Y = (np.dot(preK, X.T) + np.random.random() * 15).ravel() # 加的一项是随机常数项,最后将矩阵转换成数组向量
    21. # X矩阵中第一列加入x0=1参数
    22. X = np.insert(X, 0, np.ones((1, len(X))), axis=1)
    23. # 数据个数
    24. m = len(X)
    25. # 参数个数
    26. n = len(X[0])
    27. # 输出
    28. print(f"有{n}个参数,就是X列数算上常数项所乘的单位1")
    29. print(f"有{m}条数据,就是加常数后X行数")
    30. # 系数变量K矩阵就是多元参数的系数,就是我们要递归的重点变量,先给这个矩阵的每个值都赋予初始值1
    31. K = np.ones(n)
    32. #正规方程,固定公式详细推导见吴恩达P23
    33. def NorEq():
    34. global X,Y,K
    35. m1=np.dot(X.T,X)
    36. m2=np.matrix(m1).I
    37. m3=np.dot(m2,X.T)
    38. K=np.dot(m3,Y.T)
    39. if __name__ == "__main__":
    40. print("X",X)
    41. print("Y",Y)
    42. NorEq()
    43. print("K",K)
    44. print("preK",preK)

    可见结果完全一致

  • 相关阅读:
    游戏“羊了个羊”火爆天际背后的秘密
    AD教程系列 | 5 - 绘制原理图
    智源社区AI周刊No.108:Meta发布玩外交游戏的Cicero,登Science;Neuralink实现猴子意念打字...
    Python从零到一构建项目
    【JQuery】JQuery入门——知识点讲解(三)
    scp -r ./dist root@你的IP:/root/www/website/解释
    vlan,每个接口都配了对应的trunk或hybrid并且放行,但还是ping不通,三个都互相不通
    Linux账户组管理及权限练习
    stm32cubemx hal学习记录:TIMER输入捕获
    重装系统后电脑图片显示不出来怎么办
  • 原文地址:https://blog.csdn.net/qq_54263076/article/details/127458807
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号