目录

1.线性回归

2.最小均方误差(Least Mean squares)

3.梯度下降

4.批梯度下降算法(BGD)

5.随机梯度下降算法(SGD)


1.线性回归

首先要明白什么是回归。回归的目的是通过几个已知数据来预测另一个数值型数据的目标值。假设特征和结果满足线性关系,即满足一个计算公式h(x),这个公式的自变量就是已知的数据x,函数值h(x)就是要预测的目标值。这一计算公式称为回归方程,得到这个方程的过程就称为回归

假设房子的房屋面积和卧室数量为自变量x,用x1表示房屋面积,x2表示卧室数量;房屋的交易价格为因变量y,我们用h(x)来表示y。假设房屋面积、卧室数量与房屋的交易价格是线性关系。

他们满足公式

上述公式中的θ为参数,也称为权重,可以理解为x1和x2对h(x)的影响度。对这个公式稍作变化就是

公式中θ和x都可以看成是向量,n是特征数量。假如我们依据这个公式来预测h(x),公式中的x是我们已知的(样本中的特征值),然而θ的取值却不知道,只要我们把θ的取值求解出来,我们就可以依据这个公式来做预测了。


2.最小均方误差(Least Mean squares)

在介绍LMS之前先了解一下什么损失函数的概念。我们要做的是依据我们的训练集,选取最优的θ,在我们的训练集中让h(x)尽可能接近真实的值。h(x)和真实的值之间的差距,我们定义了一个函数来描述这个差距,这个函数称为损失函数,表达式如下:

这里的这个损失函数就是著名的最小二乘损失函数,这里还涉及一个概念叫最小二乘法,这里不再展开了。我们要选择最优的θ,使得h(x)最近进真实值。这个问题就转化为求解最优的θ,使损失函数J(θ)取最小值。(损失函数还有其它很多种类型)

那么如何解决这个转化后的问题呢?这又牵扯到一个概念:LMS 和 梯度下降(Radient Descent)。

LMS是求取h(x)回归函数的理论依据,通过最小化均方误差来求最佳参数的方法。


3.梯度下降

我们要求解使得J(θ)最小的θ值,梯度下降算法大概的思路是:我们首先随便给θ一个初始化的值,然后改变θ值让J(θ)的取值变小,不断重复改变θ使J(θ)变小的过程直至J(θ)约等于最小值

首先我们给θ一个初始值,然后向着让J(θ)变化最大的方向更新θ的取值,如此迭代。公式如下:

公式中α称为步长(learning rate),它控制θ每次向J(θ)变小的方向迭代时的变化幅度。J(θ)对θ的偏导表示J(θ)变化最大的方向。由于求的是极小值,因此梯度方向是偏导数的反方向。

  • α取值太小收敛速度太慢,太大则可能会Overshoot the minimum。
  • 越接近最小值时,下降速度越慢
  • 收敛: 当前后两次迭代的差值小于某一值时,迭代结束

求解一下这个偏导,过程如下:

那么θ的迭代公式就变为:

上述表达式只针对样本数量只有一个的时候适用,那么当有m个样本值时该如何计算预测函数?批梯度下降算法和随机梯度下降算法


4.批梯度下降算法(BGD)

有上一节中单个样本的参数计算公式转化为处理多个样本就是如下表达:

这种新的表达式每一步计算都需要全部训练集数据,所以称之为批梯度下降(batch gradient descent)。注意,梯度下降可能得到局部最优,但在优化问题里我们已经证明线性回归只有一个最优点,因为损失函数J(θ)是一个二次的凸函数,不会产生局部最优的情况。(假设学习步长α不是特别大)

批梯度下降的算法执行过程如下图:

大家仔细看批梯度下降的数学表达式,每次迭代的时候都要对所有数据集样本计算求和,计算量就会很大,尤其是训练数据集特别大的情况。那有没有计算量较小,而且效果也不错的方法呢?有!这就是:随机梯度下降(Stochastic Gradient Descent, SGD)


5.随机梯度下降算法(SGD)

随机梯度下降在计算下降最快的方向时时随机选一个数据进行计算,而不是扫描全部训练数据集,这样就加快了迭代速度。随机梯度下降并不是沿着J(θ)下降最快的方向收敛,而是震荡的方式趋向极小点。

随机梯度下降表达式如下:

执行过程如下图:

批梯度下降和随机梯度下降在三维图上对比如下:

reference:监督学习——随机梯度下降算法(sgd)和批梯度下降算法(bgd) - NeilZhang - 博客园

线性回归->最小均方误差->梯度下降相关推荐

  1. 13_线性回归分析、线性模型、损失函数、最小二乘法之梯度下降、回归性能评估、sklearn回归评估API、线性回归正规方程,梯度下降API、梯度下降 和 正规方程对比

    1.线性回归 1.1 线性模型 试图学得一个通过属性的线性组合来进行预测的函数: 1.2 定义 定义:线性回归通过一个或者多个自变量与因变量之间进行建模的回归分析.其中特点为一个或多个称为回归系数的模 ...

  2. sklearn - 线性回归(正规方程与梯度下降)

    一: 线性回归方程 ​ 线性回归(英语:linear regression)是利用称为线性回归方程的最小二乘函数对一个或多个自变量和因变量 之间关系进行建模的一种回归分析.这种函数是一个或多个称为回归 ...

  3. 【MATLAB】机器学习: 线性回归实验(梯度下降+闭式解)

    实验内容 1.根据梯度下降法完成一元线性回归实验. 2.根据闭式解完成一元线性回归实验. 3.比较两种解下的实验结果. 实验代码 clear;clc; %% 数据导入:划分训练集和测试集 % 数据导入 ...

  4. 梯度下降python编程实现_【机器学习】线性回归——单变量梯度下降的实现(Python版)...

    [线性回归] 如果要用一句话来解释线性回归是什么的话,那么我的理解是这样子的:**线性回归,是从大量的数据中找出最优的线性(y=ax+b)拟合函数,通过数据确定函数中的未知参数,进而进行后续操作(预测 ...

  5. 【机器学习】拟合优度度量和梯度下降(红酒数据集的线性回归模型sklearnRidge)

    文章目录 一.拟合优度度量(可决系数) 1.1总离差平方和的分解 1.2 TSS=ESS+RSS 1.3 红酒数据集实例R2_score实现代码 二. 梯度下降 2.1 损失函数直观图(单特征/变量举 ...

  6. 机器学习(机器学习+线性回归+代价函数+梯度下降)

    一.什么是机器学习 一个计算机程序据说从经验 E 学习关于 一些任务 T 和一些性能措施 P,如果它在 T 上的性能, 由 P 测量,随着经验 E 的提高, 体验 E 将是 让程序玩成千上万的游戏本身 ...

  7. 回归算法-线性回归分析-正规方程和梯度下降

    1.分类和回归最本质的区别 定量输出称为回归,或者说是连续变量预测:     定性输出称为分类,或者说是离散变量预测. 举个特别好理解的例子: 预测明天的气温是多少度,这是一个回归任务: 预测明天是阴 ...

  8. 03机器学习--梯度下降及python实现

    目录 ①概述 ②梯度下降法简单模拟 ③多元线性回归中使用梯度下降 ④优化(梯度下降法的向量化) ⑤数据的归一化 ⑥随机梯度下降法 ⑦scikit-learn中的随机梯度下降 ⑧关于梯度的调试 ⑨总结 ...

  9. 监督学习应用与梯度下降

     监督学习应用与梯度下降 (2013-12-01 21:37:37) 转载▼ 标签: 梯度下降算法 回归 机器学习 分类: 机器学习与数据挖掘 (斯坦福大学公开课--监督学习应用与梯度下降笔记) ...

  10. 梯度下降法_梯度下降

    梯度下降法 介绍 (Introduction) Gradient Descent is a first order iterative optimization algorithm where opt ...

最新文章

  1. the day of python learning(考试解释)
  2. 简谈造成循环引用的原因以及处理办法
  3. python3调用adb命令_如何使用Python执行adb命令?
  4. HTML5-画布(canvas)效果之-渐变色
  5. IAR使用技巧 之 快捷键批量更换指定字符(以及Keil的全局替换功能)
  6. Motorola(摩托罗拉)比较不错的机子,直接秒杀诺基亚N8,不看看你会后悔的哦。。。...
  7. JavaScript和TypeScript学习总结
  8. DDoS攻击--CC攻击防护详解(HTTP)
  9. 美团2018校园招聘内推笔试代码分享
  10. VSU(虚拟交换单元)组网提升网络可用性
  11. 新手安装arch安装界面wifi-menu连接不了wifi
  12. maya arnold渲染器产品快速灯光渲染模板文件下载
  13. 大学生职业规划8000字_大一职业规划书8000字
  14. 全球PM25实时可视化
  15. VSCode这13款插件也太好用了
  16. 标准日本语初级 语法整理
  17. 微软输入法 ——当前时间 快捷键
  18. laradock一些坑(长期维护)
  19. 使用字典统计不同班级的成绩(d.get()函数的灵活应用)
  20. @Configuration和@Component

热门文章

  1. 寻找多数元素(主元素)
  2. 网络入侵检测--Snort软件安装
  3. 逐浪CMSv8.2发布-集成Node与Vue脚手架和PowerShell支持的新一代网站管理系统
  4. 终于20年后真正听完了Beyond的《大地》
  5. python矩阵乘法菜鸟_Python中的几种矩阵乘法(转)
  6. Android Studio Genymotion模拟器
  7. 关于网购二手电脑防骗经验分享
  8. 四川电信烽火HG680-KAS_ca高安版_HI3798MV310_免拆刷机固件包
  9. 秽土重生之我要学C++(一)
  10. 打造“家庭第三空间”,亲子餐厅「Twinkle耀童」获华映资本千万级天使轮融资...