机器学习&NLP基础学习笔记

这篇博客详细介绍了机器学习的基础算法,包括KNN、朴素贝叶斯、决策树、感知机和SVM,以及NLP的相关内容,如中文分词、词性标注和命名实体识别。还涵盖了数据挖掘中的聚类算法和关联规则分析。

去年暑假综合老师给的ppt和《统计学习方法》一周内对nlp入门时写的笔记,本来放在github上,放在这里方便自己未来回顾。嘎嘎。

KNN

算法基本步骤

  • 预先准备数据:[features],[label]
  • 无需训练,只需要求数据足够大(同类样本多)
  • 输入样本计算其与所有储存数据的特征距离
    ∑l=1n(xil−xjl)2\sqrt{\sum_{l=1}^n(x_i^l-x_j^l)^2 }l=1n(xilxjl)2
    l为特征,i为样本
  • 根据输入k,排序后从k个样本中选取频率最高类别作为输出

优化方法:KD树

  • KD树建立:
    • 与搜索树及其相似,采用中位数进行划分,每次特征选择由 depth_j%features_num 决定。每个节点可理解为一片区域,其两个分支则为切割划分的一刀结果,每一刀之间互相垂直(和guilintine cutting中树搜索接近,根节点为第一刀全区域,第二层为第二刀上下两部分)
  • KD树搜索:
    • 类似于搜索树的查找过程,但通常不会匹配出相同坐标的节点,故需要在递归返回的过程中对子区域进行判断。

    • 预先保留叶子节点与样本距离,并作为最近样本点

    • 递归向上回退:计算节点距离,若小于,更新最近样本点。

    • 对最近样本点兄弟节点区域查找,若区域与圆形不相交(按节点对应维度比较大小即可)则回退,若相交则继续搜索其区域内子节点。

      每一次递归回退是会计算其父母节点距离的,如果父母更近则无需管兄弟,若兄弟更近则去找其子节点–>到叶子节点,再递归向上回退重复。

朴素贝叶斯法

极大似然估计

  • 训练样本中,频率视为概率,先验概率为:
    P=∑i=1NI(yi=ck)NP=\frac{\sum_{i=1}^NI(y_i=c_k)}{N}P=Ni=1NI(yi=ck)
  • 同样可用指示函数表示条件概率
  • 测试样本直接套用训练样本中计算出的概率代入贝叶斯公式相加计算。选取其中概率最大者即为分类

贝叶斯估计

  • 极大似然估计出现一种情况:条件概率为0/先验概率为0
  • 解决方法: 拉普拉斯平滑
    p(X=al∣Y=ck)=∑i=1NI(xi=al,yi=ck)+λ∑i=1NI(yi=ck)+Sjλ p(X=a_l|Y=c_k)=\frac{\displaystyle \sum_{i=1}^{N}I(x_i=a_l,y_i=c_k)+\lambda}{\displaystyle \sum_{i=1}^{N}I(y_i=c_k)+S_j\lambda}p(X=alY=ck)=i=1NI(yi=ck)+Sjλi=1NI(xi=al,yi=ck)+λ
    先验概率同上,且可通过计算验证得其满足概率定义。

决策树

采用C4.5算法实现基本步骤

  • 若当前集合属于同一类,置其为单节点树,并将当前分类作为类别,返回
  • A=∅A=\emptysetA=,取其中数目最多的类别作为类别返回
  • 计算各特征A的熵:
    HA(X)=−∑i=1n∣Di∣∣D∣log2∣Di∣∣D∣H_A(X)=-\sum_{i=1}^n\frac{|D_i|}{|D|}log_2\frac{|D_i|}{|D|}HA(X)=i=1nDDilog2DDi
    Di表示此特征的样本数D_i表示此特征的样本数Di
  • 统计出各类在各特征下的数目∣Dik∣|D_{ik}|Dik,此时可得出:H(D∣A),信息增益为g(D,A)=H(D)−H(D∣A)H(D|A),信息增益为g(D,A)=H(D)-H(D|A)H(DA),g(D,A)=H(D)H(DA)
  • 计算出信息增益比:
    gR(D,A)=g(DK,A)HA(D)g_R(D,A)=\frac{g(DK,A)}{H_A(D)}gR(D,A)=HA(D)g(DK,A)
  • 如果信息增益比小于设定阈值,设定数目最多的类别作为类别返回
  • 否则将其子集按最大数目类别标记
  • 删除已分类的特征集AgA_gAg后递归调用

剪枝策略

  • 可作预剪枝和后剪枝,预剪枝算法复杂度更小,后剪枝更精确。
  • 引入损失函数:Cα(T)=∑t=1∣T∣NtHt(T)+α∣T∣,∣T∣是叶节点,Nt是t叶节点下的样本点C_\alpha(T)=\sum_{t=1}^{|T|}N_tH_t(T)+\alpha|T|,|T|是叶节点,N_t是t叶节点下的样本点Cα(T)=t=1TNtHt(T)+αT,TNtt
  • 计算每个节点的经验熵后递归计算损失函数值,若父母的损失函数更小,则剪枝

感知机和SVM

感知机对偶形式学习策略

  • α=0,β=0\alpha=0,\beta=0α=0,β=0
  • 选取(xi,yi)(x_i,y_i)(xi,yi)
  • 计算yi(∑j=1Nαyjxj⋅xi+b)y_i(\sum_{j=1}^N\alpha y_jx_j·x_i+b)yi(j=1Nαyjxjxi+b),若小于等于0则为误分类,更新α,β\alpha,\betaα,β(此时为随机梯度下降)
  • 直到无误分类数据

训练数据直接使用Gram矩阵可提速(计算时有个点积)

线性SVM

  • 为了最大化margin(2/∣∣w∣∣)(2/||w||)(2/w) 且不存在误差点(和感知机策略相似)引入如下表达式:

  • minw,b∣∣w∣∣22(除2便于计算)min_{w,b} \frac{||w||^2}{2}(除2便于计算)minw,b2w2(2便)
    s.t.yi((w⋅xi)+b>=1)s.t. y_i((w·x_i)+b>=1)s.t.yi((wxi)+b>=1)

  • 通过lagrange函数转换后:
    minα12∑i=1n∑j=1nyiyjαiαj(xixj)−∑j=1nαjmin_\alpha \frac{1}{2}\sum_{i=1}^n\sum_{j=1}^ny_iy_j\alpha_i\alpha_j(x_ix_j)-\sum_{j=1}^n\alpha_jminα21i=1nj=1nyiyjαiαj(xixj)j=1nαj
    s.t.∑i=1nyiαi=0,αi>=0s.t. \sum_{i=1}^n y_i\alpha_i=0,\alpha_i>=0s.t.i=1nyiαi=0,αi>=0

  • 最终的决策函数:f(x)=sgn()f(x)=sgn()f(x)=sgn(),支持向量即在间隔边界上

非线性

  • 通过核函数将数据升维,升维后再利用SVM分类 (计算将变复杂,神经网络可替代)

  • 可用SMO算法解决最优化计算问题

    本人没有深入研究此处

logistic回归

引入

从线性回归和阶跃函数启发,引入sigmoid函数实现非线性形式:

  • 11+e−(wx+b),其中w为向量形式\frac{1}{1+e^{-(wx+b)}},其中w为向量形式1+e(wx+b)1,w
    即可模拟阶跃函数,实现0/1分类预测
  • 优化策略:对0的概率和1的概率相乘再取对数(实现极大似然估计),最小化损失函数:
  • minL(w,b)=−∑i=1m(yilogyi−+(1−yi)log(1−yi−))mmin L(w,b)=-\frac{\sum_{i=1}^m(y_ilog y_i^-+(1-y_i)log(1-y_i^-))}{m}minL(w,b)=mi=1m(yilogyi+(1yi)log(1yi))
  • 防止过拟合:引入L2范数正则化

学习步骤

  1. init(w,b)
  2. 根据sigmoid(z)计算y_hat
  3. 根据损失函数偏导方向更新w,b.(可用数值方法按相差更新/解析方法直接根据导数计算)
  4. 更新后重新计算损失函数,若cost与上一次迭代相差小于指定参数即可跳出迭代

Adaboost

引入

“三个诸葛亮顶个臭皮匠”,弱学习算法组合起来是否能形成强学习算法?

步骤

  • 初始化训练数据权值分布
  • 计算误差率e,更新此次迭代弱分类器对应权重为:α=12ln(1−ee))\alpha=\frac{1}{2}ln(\frac{1-e}{e}))α=21ln(e1e))
  • 根据α\alphaα更新样本权重:正确样本权重下降,错误样本权重上升

思想主要是:此次错误样本在下一次权重提升,而最终各分类器组合时权重则为正确率越高权重越高

扩展:随机森林

数据重抽样的方法建立多颗决策树,最终按频率决定数据类别

NLP

中文分词方法

基于词典匹配

  • 双向匹配:正反向各匹配一次,计算:

    1. 非字典词:越少越好
    2. 单字字典词:越少越好
    3. 总词数:越少越好

    在两种分词中选择(通常逆向匹配准确率高)

基于统计的分词方法

  • n-gram
    P(w1,...,wm)=∏i=1mP(wi∣w1,...,wi−1)≈∏i=1mP(wi∣wi−(n−1),...,wi−1) P(w1,...,w_m)=\prod_{i=1}^mP(w_i|w1,...,w_{i-1})\approx\prod_{i=1}^mP(w_i|w_{i-(n-1),...,w_{i-1}})P(w1,...,wm)=i=1mP(wiw1,...,wi1)i=1mP(wiwi(n1),...,wi1)

    采用极大似然估计计算:频率代替概率
    设S=wi−(n−1),...,wi−1设S=w_{i-(n-1)},...,w_{i-1}S=wi(n1),...,wi1
    P(wi∣S)=P(S,wi)P(S)P(w_i|S)=\frac{P(S,w_i)}{P(S)}P(wiS)=P(S)P(S,wi)

    • Eg:

      Tri-gram:P(I,saw,red,house)≈P(I∣(s),(s))P(saw∣(s),I)P(the∣I,saw)...P((s)∣red,house)P(I,saw,red,house)\approx P(I|(s),(s))P(saw|(s),I)P(the|I,saw)...P((s)|red,house)P(I,saw,red,house)P(I(s),(s))P(saw(s),I)P(theI,saw)...P((s)red,house)

      P(红色)≈P(红∣(s))P(色∣红)P((s)∣色)P(红色)\approx P(红|(s))P(色|红)P((s)|色)P()P((s))P()P((s))

    概率越大越可能成为词

歧义识别

  • n-gram可用于交集型歧义识别

    • Eg:
      bi-gram:P(化妆/和服/装)≈P(化妆∣(s))P(和服∣化妆)P(装∣和服)P((s)∣装)P(化妆/和服/装)\approx P(化妆|(s))P(和服|化妆)P(装|和服)P((s)|装)P(//)P((s))P()P()P((s))
      和P(化妆/和/服装)概率进行对比计算

    通常n越大消除歧义效果越好

  • 组合型歧义识别

    结合上下文语境判断

  • 新词识别

歧义消解

  • 基于互信息和t测试差(相关性反映)

    相关性越小越适于分词

词性标注

假设前提

  • Markov假设
  • 独立输出假设

即假设满足马尔科夫图(词性标志通常为线性链模型,容易满足)

HMM/CRF

CRF实际上可以替代HMM(特征综合)

  • Veterbi算法适用于词性标志(即状态输出)

    1. initial:
      δ1(i)=πibi(o1)\delta_1(i)=\pi_ib_i(o_1)δ1(i)=πibi(o1)
      i1=0i_1=0i1=0
    2. DP:对每个状态判断只计算从上一时刻到这一时刻此状态max(δt−1(i)∗Pij∗输出观测值概率)\delta_{t-1}(i)* P{ij}*输出观测值概率)δt1(i)Pij,保留上一时刻计算结果最大的δt−1\delta_{t-1}δt1对应节点
    3. 最终回溯可得最优路径,并直接取maxδTmax \delta_TmaxδT得到此路径对应概率

命名实体识别

基于统计的方法:HMM&CRF

  • 从文本中选取特征加入特征向量(特征挖掘)
  • 采用前向-后向算法学习(HMM)/采用最小化损失函数(CRF)学习
  • 预测,可得出命名实体识别结果

向量空间模型

TF-IDF和DF

  • DF直接计算各单词词频作为向量:di=[t1,t2,...,tm]d_i=[t_1,t_2,...,t_m]di=[t1,t2,...,tm]
  • TF-IDF计算各单词对文档的贡献程度:
    wi=tf−idf(xi,S)=tf(xi,di)∗idf(xi,di)w_i=tf-idf(x_i,S)=tf(x_i,d_i)*idf(x_i,d_i)wi=tfidf(xi,S)=tf(xi,di)idf(xi,di)
    词频−log(当前文档出现词频)词频-log(当前文档出现词频)log()

TF-IDF可用于特征选择

文档相似度计算

  • Dot
  • Cosine
  • Dice
  • Jaccard

LDA(无监督)

  • 输入:词语-文档矩阵(词频)
  • 用Gibbs采样
  • α\alphaα分布取样产生文档i的主题分布θi\theta_iθi(多项式分布)
  • 主题分布中取样生成文档i第j个词主题zi,jz_{i,j}zi,j
  • β\betaβ分布取样生成主题zi,jz{i,j}zi,j对应词语分布(多项式分布)
  • 词语分布中取样生成词语
  • 输出:主题-词语矩阵,文档-主题矩阵

词向量

传统:词典对应

Word2Vec:CBOW+Skip-Gram

  • 思想:一个词可由其上下文特征表示

  • CBOW+哈夫曼树

    • 输入:2c个词向量(每一个词多特征)
    • 投影:对向量累加(同特征相加)
    • 构建哈夫曼树,把语料库中出现过的词全部按词频构建
    • 更新:按照logistic回归,梯度下降法更新每一个非叶节点向量,并保存Δ\DeltaΔ值(左负类1右正类0)
    • 最终对叶子节点按累计Δ\DeltaΔ更新词向量
    • 输出:哈夫曼树,按softmax计算只需沿树走

综合词频、词特征及其上下文结合概率,占用空间将远小于按词典表示词向量

聚类

距离

  • Minkowski
  • 马氏距离(协方差+均值标准化):
    DM(x)=(x−μ)T∑−1(x−μ)D_M(x)=\sqrt{(x-\mu)^T\sum-1(x-\mu)}DM(x)=(xμ)T1(xμ)

    x为待识别样本

  • 余弦相似度(常用)
  • 无序属性:
    VDMp(a,b)=∑i=1k∣mu,a,imu,a−mu,b,imu,b∣pVDM_p(a,b)=\sum_{i=1}^k|\frac{m_{u,a,i}}{m_{u,a}}-\frac{m_{u,b,i}}{m_{u,b}}|^pVDMp(a,b)=i=1kmu,amu,a,imu,bmu,b,ip

    mu,am_{u,a}mu,a表示属性u上取值为a的样本数,mu,a,im_{u,a,i}mu,a,i为第i个样本簇中属性u上取值为a的样本数。

k-means聚类

  1. 随意选k个中心
  2. 每个样本计算离各中心距离,选最近点对应类别作为自己类别
  3. 计算结束,每个类别更新中心为其均值,重新迭代直到稳定

层次聚类

  1. 两两计算样本距离,选最近两点作为一簇
  2. 向上层按簇间距离计算:可用最小距离/最大距离/平均距离
  3. 直到只剩k类停止

密度聚类

  • DBSCAN算法

    • 输入:邻域值(半径),MinPTs(定义核心对象的邻域数目值))

    第一阶段:确定核心节点集合

      1. initial:空集
      2. 遍历各节点确定其邻域节点(存储)
      3. 判断数目是否大于MinPTs->是:加入核心对象集合
    

    第二阶段:聚类

    1. initial:簇数->0,未访问集合->全集
    2. 随机选取核心对象o,初始化队列
    3. 未访问集合-o
    4. 队列中依次访问并判断邻域是否大于MinPTs,是则取其邻域中未访问点加入队列,未访问集合-n
    5. k递增,簇可用上一次迭代未访问集合-这一次迭代未访问集合,数据集删除掉已分类集合
    

高斯模型聚类

高斯混合模型(GMM)

pM(x)=∑i=1kαi⋅p(x∣μi,∑i)p_M(x)=\sum_{i=1}^k \alpha_i·p(x|\mu_i,\sum_i)pM(x)=i=1kαip(xμi,i)

k个高斯分布

步骤

EM算法典型应用

  1. E:遍历样本点,计算属于j分布的概率
    wj(i)=p(x(i)∣z(i)=j)w_j^{(i)}=p(x^{(i)}|z^{(i)}=j)wj(i)=p(x(i)z(i)=j)
  2. M:根据计算结果更新各分布均值和协方差
  3. 收敛即停止
  4. 用学习所得混合模型遍历所有样本,样本归于计算出概率最大的一类

优劣势

O(tkn)
局部最优

关联规则分析

概念

  • 置信度:在数据集中已经出现A时,B发生的概率.条件概率P(B|A)
  • 支持度:联合概率

Aprior算法

  1. 扫描item,按最小支持度除去item
  2. 两两组合(过程中可通过分析其子集是否存在于上一次迭代,否则剪枝)
  3. 重新扫描

FP-tree算法

提速

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值