机器学习 从矩阵和概率的角度解释最小均方误差函数

2023-12-05 12:08

本文主要是介绍机器学习 从矩阵和概率的角度解释最小均方误差函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最小均方误差函数

之前的讲义里, 我们提到了最小均方误差函数,给出一组有 m 个样本的训练集,我们希望找到合适的参数 θ, 使得预测值 hθ(x) 与目标值尽可能接近。为了估计参数 θ , 我们定义如下的 cost function:

J(θ)=12i=1m(hθ(xi)yi)2

这个 cost function 就是最小均方误差函数,第一讲里面,我们用梯度下降算法估计参数 θ , 而第二讲里面我们提到了矩阵的基本运算及矩阵的求导,现在就从矩阵的角度求参数 θ 的解析解。

矩阵的解析解

给定一组训练样本, D={(xi,yi)|xiRn,yiR}mi=1 , xi 是维数为 n 的输入特征(默认为列向量),yi 是连续的实数值, m 表示样本数,则输入特征可以用矩阵表示为:

X=[x1,x2,,xm]T

输出变量可以用一个向量表示为:

y=[y1,y2,,ym]T

而我们从第一讲已经知道, hθ(xi)=xTiθ , 则我们可以得到如下的表达式:
Xθy=xT1θxTmθy1ym=hθ(x1)y1hθ(xm)ym

则最小均方误差函数可以表示为:
J(θ)=12i=1m(hθ(xi)yi)2=12(Xθy)T(Xθy)

利用第二讲的矩阵基本运算将上式展开,可以得到:
J(θ)=12θTXTXθθTXTyyTXθ+yTy

利用第二讲的矩阵求导,可以得到 J(θ) θ 的偏导数为:
J(θ)θ=12(XTXθ+XTXθ2XTy)=XTXθXTy

令该偏导数为0,则可以得到:
XTXθ=XTy

最终可以得到参数 θ 的解析解为:
θ=(XTX)1XTy

如果矩阵 (XTX)1 可逆,则该解就是全局最优解,有的时候,该矩阵不一定可逆,就是我们常常遇到的样本数远远大于参数的个数即 mn ,那么参数 θ 就只能得到近似解。

从最大似然估计到最小均方误差

有的时候我们会考虑,在做回归问题的时候,为什么用最小均方误差函数作为 \textbf{cost function}, 为什么不用其它的函数。接下来,我们从概率分布的角度去考虑这个问题,随后我们会发现,最小均方误差函数从某种意义上来说,
是从最大似然估计中演化出来的。
我们先假设目标值与输入变量之间存在以下关系:

yi=θTxi+ϵi

其中, ϵi 是一个误差项,表示由于一些我们没有考虑到的因素导致估计值域目标值之间出现得偏差,我们进一步假设这些误差项是
独立同分布的(independently and identically distributed), 并且是均值为0,方差为 σ2 的高斯分布(这是自然界非常常见的一种分布)。我们可以表示为
ϵiN(0,σ2) , 其概率密度函数为:
p(ϵi)=12πσexp(ϵ2i2σ2)

将式代入,可以得到:
p(yi|xi;θ)=12πσexp((yiθTxi)22σ2)

这里需要注意, p(yi|xi;θ) 表示的是 yi xi 的条件概率, θ 是参数, xi 是随机变量,两者之间用 ";" 隔开,不能用
"," 隔开。当我们考虑所有的样本时,则所有的输出变量的分布表示为: p(y|X;θ) , 我们可以建立一个关于参数 θ 的似然函数:
L(θ)=L(θ;X,y)=p(y|X;θ)

因为 ϵi 是独立同分布的,我们可以得到:
L(θ)=i=1mp(yi|xi;θ)=i=1m12πσexp((yiθTxi)22σ2)

最大似然估计原则告诉我们,要选择参数 θ 使得概率要尽可能地高。所以我们可以建立如下的优化函数:
maxθ[i=1m12πσexp((yiθTxi)22σ2)]

上式是一个单调函数,根据单调函数的传递性原则,我们可以对上式取对数,则可以得到:
l(θ)=log(L(θ))=logi=1m12πσexp((yiθTxi)22σ2)=i=1mlog12πσexp((yiθTxi)22σ2)=mlog12πσ1σ212i=1m(yiθTxi)2

因此,要使上式最大化,则只要使其中的二次项最小化,即
minθ12i=1m(hθ(xi)yi)2

我们可以看到,从概率出发,最小均方误差是最大似然估计非常自然的一种延伸,两者最后可以完美的统一起来。

参考文献

Andrew Ng, “Machine Learning”, Stanford University.

这篇关于机器学习 从矩阵和概率的角度解释最小均方误差函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/457509

相关文章

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

Java function函数式接口的使用方法与实例

《Javafunction函数式接口的使用方法与实例》:本文主要介绍Javafunction函数式接口的使用方法与实例,函数式接口如一支未完成的诗篇,用Lambda表达式作韵脚,将代码的机械美感... 目录引言-当代码遇见诗性一、函数式接口的生物学解构1.1 函数式接口的基因密码1.2 六大核心接口的形态学

Oracle的to_date()函数详解

《Oracle的to_date()函数详解》Oracle的to_date()函数用于日期格式转换,需要注意Oracle中不区分大小写的MM和mm格式代码,应使用mi代替分钟,此外,Oracle还支持毫... 目录oracle的to_date()函数一.在使用Oracle的to_date函数来做日期转换二.日

C++11的函数包装器std::function使用示例

《C++11的函数包装器std::function使用示例》C++11引入的std::function是最常用的函数包装器,它可以存储任何可调用对象并提供统一的调用接口,以下是关于函数包装器的详细讲解... 目录一、std::function 的基本用法1. 基本语法二、如何使用 std::function

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06