码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 机器学习 之 python实现正规方程


    Normal Equations (正规方程)

    书接上文,想要计算代价函数中 θ \theta θ的值,可以用正规方程的方法来解。这里推导过程就不展开了,有兴趣的可以移步 正规方程推导。

    这里直接给出公式:

    θ = ( X T X ) − 1 X T y \theta = (X^TX)^{-1}X^Ty θ=(XTX)−1XTy

    从公式可以看出,相较于梯度下降法,正规方程不需要选择学习率,不需要迭代计算 θ \theta θ,甚至不需要特征缩放。

    在给出python代码前,强调一下正规方程的适用范围。

    1. 当模型有冗余特征(特征线性相关)或 特征过多,样本过少时,项 ( X T X ) − 1 (X^TX)^{-1} (XTX)−1会不可逆,既无法计算。(可以用筛选样本,正则化的方法解决这个问题)
    2. 因为需要计算 ( X T X ) − 1 (X^TX)^{-1} (XTX)−1,当特征很多的时候算法会很慢。(根据吴恩达老师的说法,现代的电脑都可以处理1000个特征以下的简单模型没什么压力,除非你的模型非常复杂。如果特征过多或模型过于复杂,可以使用梯度下降法)

    Python 实现代码如下:

    # 正规方程
    
    import matplotlib.pyplot as plt
    import numpy as np
    # P = np.loadtxt("PV.csv", delimiter=",")
    
    
    # y = 3x - 2k + 7z - 3
    # X = np.array([[1,1,1,1],[2,1,2,1],[3,0,1,1],[0,1,2,1]])
    # Y = np.array([[5],[15],[13],[9]])
    
    # y = 2x + 4k + 7
    
    # X = np.array([[1,1,1],[2,3,1],[4,2,1],[3,3,1],[2,2,1]])
    # Y = np.array([[13],[23],[23],[25],[19]])
    
    
    # y = -13 x + 9
    X = np.array([[1,1],[0,1],[-1,1],[2,1]])
    Y = np.array([[-4],[9],[22],[-17]])
    
    
    theta = np.linalg.inv(X.T@X)@X.T@Y
    print (theta)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24

    以上。

  • 相关阅读:
    初识C++ (五)
    C++ 虚函数优化探索简介
    阿尔巴尼亚借助ChatGPT加快欧盟入会进程
    智慧园区:AI边缘计算技术与视频监控汇聚平台打造智慧园区解决方案
    【火灾检测】森林火灾检测系统(带面板)【含GUI Matlab源码 1921期】
    突破编程_C++_设计模式(观察者模式)
    项目实战:中央控制器实现(3)-优化Controller,处理普通的请求参数
    深聊性能测试,从入门到放弃之: Windows系统性能监控(一) 性能监视器介绍及使用。
    【AIGC核心技术剖析】Hotshot-XL 一种 AI 文本转 GIF 模型(论文 + 代码:经过训练可与Stable Diffusion XL一起使用)
    集群外Prometheus 集群 k8s
  • 原文地址:https://blog.csdn.net/qq_41608408/article/details/127798822
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号