统计学习(李航)笔记(编辑中)

2023-11-07 20:40

本文主要是介绍统计学习(李航)笔记(编辑中),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

统计学习笔记

  • 1 工具
    • 1.1 EM算法
    • 1.2 KKT条件
    • 1.3 奇异矩阵SVD
    • 1.4 马尔科夫链MCMC
  • 2 有监督学习
    • 2.1 感知机(二分类)
    • 2.2 KNN近邻(分类)
    • 2.3 朴素贝叶斯
    • 2.4 决策树
    • 2.5 提升Boosting
    • 2.6 逻辑回归
    • 2.7 支持向量机
    • 2.8 HMM蒙特卡洛马尔可夫
  • 3 无监督学习
    • 3.1 聚类
    • 3.2 主成分PCA
    • 3.3 潜在语义分析
    • 3.4 PageRank

1 工具

1.1 EM算法

em算法是通过求期望最大的算法。通过样本来推测参数(迭代直至收敛),k-means是em的一种特殊情况。
输入:观测变量数据Y,隐变量数据Z,联合分布P(Y,Z| θ \theta θ),条件分布P(Z|Y, θ \theta θ)
输出 θ \theta θ 参数

  1. 选择 θ ( 0 ) \theta^{(0)} θ(0) 初值。
  2. E步(求期望Z|Y): Q ( θ , θ ( i ) ) = E Z [ l o g P ( Y , Z ; θ ) ∣ Y ; , θ ( i ) ] = ∑ z P ( Z ∣ Y ; , θ ( i ) ) l o g P ( Y , Z ; θ ) Q(\theta,\theta^{(i)})=E_Z[logP(Y,Z;\theta)|Y;,\theta^{(i)}]=\sum_zP(Z|Y;,\theta^{(i)})logP(Y,Z;\theta) Q(θ,θ(i))=EZ[logP(Y,Z;θ)Y;,θ(i)]=zP(ZY;,θ(i))logP(Y,Z;θ)
  3. M步(求最大期望时的 θ \theta θ): θ ( i + 1 ) = a r g m a x Q ( θ , θ ( i ) ) \theta^{(i+1)}=argmaxQ(\theta,\theta^{(i)}) θ(i+1)=argmaxQ(θ,θ(i))
  4. 重复23直至收敛

EM算法具有单调性和收敛性。

1.2 KKT条件

KKT是最优化求解的一个工具。

  1. min f(x)只需要求导可解。
  2. min f(x), st. h(x)=0, 使用拉格朗日乘子法可解。
  3. min f(x), st. C i ( x ) ⩽ 0 , h j ( x ) = 0 C_i(x)\leqslant 0,h_j(x)=0 Ci(x)0,hj(x)=0,KKT可解。

KKT条件使用广义拉格朗日求解如下:
在这里插入图片描述
此时若要求解上述优化问题,必须满足下述条件(也是我们的求解条件):
在这里插入图片描述
这些求解条件就是KKT条件。(1)是对拉格朗日函数取极值时候带来的一个必要条件,(2)是拉格朗日系数约束(同等式情况),(3)是不等式约束情况,(4)是互补松弛条件,(5)、(6)是原约束条件。

1.3 奇异矩阵SVD

A = U ∑ V T A = U \sum V^T A=UVT

1.4 马尔科夫链MCMC

已知分布(复杂),生成相应的随机样本序列。
输入:目标分布密度函数
输出:符合分布的随机样本x…

2 有监督学习

2.1 感知机(二分类)

f ( x ) = s i g n ( w T x + b ) f(x)=sign(w^Tx+b) f(x)=sign(wTx+b)
损失函数为 − ∑ i ∈ M y i ( w T x + b ) -\sum_{i\in M} y_i(w^Tx+b) iMyi(wTx+b) 分类错误的点到超平面的距离。
优化策略为求损失函数最小时候的w和b,分别求导梯度下降:
在这里插入图片描述
算法:

  • 输入: ( x 1 , y 1 ) , ( x 2 , y 2 ) . . . . . . . {(x_1,y_1),(x_2,y_2).......} (x1,y1),(x2,y2).......,x是n维向量,y为分类变量
  • 输出:w,b
    1.初始选择w,b
    2.加入训练数据
    3.梯度下降
    4.重复23步骤,直至分类正确。

2.2 KNN近邻(分类)

2.3 朴素贝叶斯

2.4 决策树

2.5 提升Boosting

2.6 逻辑回归

2.7 支持向量机

2.8 HMM蒙特卡洛马尔可夫

3 无监督学习

3.1 聚类

  • 度量距离的方法:闵氏距离( ( ∑ ( x i − x j ) p ) 1 / p (\sum(x_i-x_j)^p)^{1/p} (xixjp)1/p)、欧氏距离(p=2)、相关系数、余弦相似度
  • 类别G、距离T: x i , x j ∈ G → d x i x j < T x_i,x_j \in G \rightarrow d_{x_ix_j}<T xi,xjGdxixj<T
  • 层次聚类:聚合(n个类聚)、分裂(1个类分)
    例:1、首先计算距离矩阵。2、合并距离最小的两个类组成新的类。3、重新计算距离矩阵。4、重复23步骤。
  • k-means聚类
    例:1、随机选取k个质心。2、计算距离,归类。3、重新计算质心。4、重复23直至收敛。

3.2 主成分PCA

奇异值分解

3.3 潜在语义分析

给定一个文本,用向量空间内积度量文本之间的’语义相似度‘。
矩阵乘法X=T*Y

  • X单词文本矩阵(m单词*n文本):无法处理一词多义
  • T话题矩阵(m单词*k话题)
  • Y话题文本矩阵(k话题*n文本):文本在话题向量空间的权重

3.4 PageRank

定义:网页经济和的函数表示网页的重要程度。值越高,网页越重要,从质和量两方面衡量。
质:被越重要的网站链接引用。
量:被引用的多。

这篇关于统计学习(李航)笔记(编辑中)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Pandas中统计汇总可视化函数plot()的使用

《Pandas中统计汇总可视化函数plot()的使用》Pandas提供了许多强大的数据处理和分析功能,其中plot()函数就是其可视化功能的一个重要组成部分,本文主要介绍了Pandas中统计汇总可视化... 目录一、plot()函数简介二、plot()函数的基本用法三、plot()函数的参数详解四、使用pl

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Pandas统计每行数据中的空值的方法示例

《Pandas统计每行数据中的空值的方法示例》处理缺失数据(NaN值)是一个非常常见的问题,本文主要介绍了Pandas统计每行数据中的空值的方法示例,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是空值?为什么要统计空值?准备工作创建示例数据统计每行空值数量进一步分析www.chinasem.cn处

Mysql如何将数据按照年月分组的统计

《Mysql如何将数据按照年月分组的统计》:本文主要介绍Mysql如何将数据按照年月分组的统计方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql将数据按照年月分组的统计要的效果方案总结Mysql将数据按照年月分组的统计要的效果方案① 使用 DA

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

一文详解SQL Server如何跟踪自动统计信息更新

《一文详解SQLServer如何跟踪自动统计信息更新》SQLServer数据库中,我们都清楚统计信息对于优化器来说非常重要,所以本文就来和大家简单聊一聊SQLServer如何跟踪自动统计信息更新吧... SQL Server数据库中,我们都清楚统计信息对于优化器来说非常重要。一般情况下,我们会开启"自动更新

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

如何解决Pycharm编辑内容时有光标的问题

《如何解决Pycharm编辑内容时有光标的问题》文章介绍了如何在PyCharm中配置VimEmulator插件,包括检查插件是否已安装、下载插件以及安装IdeaVim插件的步骤... 目录Pycharm编辑内容时有光标1.如果Vim Emulator前面有对勾2.www.chinasem.cn如果tools工

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

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

opencv实现像素统计的示例代码

《opencv实现像素统计的示例代码》本文介绍了OpenCV中统计图像像素信息的常用方法和函数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 统计像素值的基本信息2. 统计像素值的直方图3. 统计像素值的总和4. 统计非零像素的数量