这里回溯到此文章,这篇文章得作者是之前那篇文章的第三作者,里头提到的算法也及其相似,所以算是前者的基础吧。

Problem

这篇文章同样是关于PCA(在线或者说随机),试图寻找一个合适的\(k-\)维的子空间去压缩数据。
普通的PCA,是下面的这种形式:
但是因为这是一个非凸的问题,所以并不容易求解(特征分解然后去前k个主向量忽略,因为这时在线的或者说随机的)。
论文将这个问题进行了第一步放缩:

但是\(rankM=k\)这个条件依然不是凸的。
第二次放缩:

这一次问题和条件都是凸的了,所以这就是一个凸优化问题了。不过,作者刻意提及(3.1)的原因是,可以证明,(3.2)的最优解可以分解为(3.1)的解的凸线性组合[Warmuth, Kuzmin 2008]。

Matrix Stochastic Gradient

每一次迭代,都将进行下面的步骤:

算法(MSG)


步骤二和步骤四会在下面讲到,问题是步骤三上,我不明白为什么需要取个平均值,我感觉直接取最后一个矩阵M就可以了。

步骤二(单次迭代)

算法


每一次迭代,都会先对\(M'+U'diag(\sigma')(U')^{\top}\)进行特征分解,但是并不是直接分解,而是使用了一个技巧,姑且称之为单步SVD,这个分解方法会利用之前\(M'\)的\(U'\)的结果。

单步SVD

为了方便,我们令\(\eta = 1\)且:


上面的算法就是先进行了单步SVD,然后再进行\(project()\)。为什么要进行这个\(project()\)呢,因为新的\(M\)并不满足(3.2)的\(tr(M)=k\)的条件,所以通过\(project()\),映射到一个新的矩阵。
这个矩阵是唯一的,且满足下面的性质:

  1. 迹为k,同时矩阵的特征向量和原来一样
  2. 最大特征值不会超过1
    唯一性由下面这个引理给出

\(project()\)算法

这个算法看起来复杂,但目的很单纯。

\(\sigma_1 \quad \sigma_2 \: \mathop{\uparrow}\limits^{i}\: \sigma_3\ldots\sigma_m \:\mathop{\uparrow}\limits^{j} \: \sigma_{m+1} \quad \sigma_{m+2} \quad\)

注意上面的\(m+2\)个奇异值(从小到大排列),每个\(\sigma\)对应一个代表其个数\(\kappa\)。
\(i,j\)满足(i=0,1或者j=m+2为特殊情况):
\(\sigma_{i-1} + S<0\) \(\quad \sigma_{j+1} + S\geq 1\)
\(S\)根据上面算法的式子算的,且可验证,这样的S是一定存在的。
则,进行下面操作:
小于\(\sigma_i\)的奇异值截为0,大于等于\(\sigma_{j+1}\)的奇异值截为1,
其余的保持为\(\sigma+S\)

就这么经过\(T\)步的岁月,\(M\)来到了生命的尽头,站在悬崖上,朝远处眺望,夕阳、红霞分外美丽:
“啊!我的迹是\(k\),可我的秩呢?”说罢,老泪纵横。
没错,辛苦了这么久,我们得到(3.2)的解,接下来,就需要\(Rounding(M)\)使得迹为\(k\)的\(M\)的秩变为\(k\),这个问题,在之前的论文也提到了,当时不清楚,现在,其实也不怎么清楚,但好歹有个了解,不过我保证我讲不清楚,如果真的想知道,还是看论文吧——这是一种分解方法。

\(rounding()\)

来到:Here
Randomized Online PCA Algorithms with Regret Bounds that are Logarithmic in the Dimension
由Manfred K. Warmuth 和 Dima Kuzmi在08年发表的文章。

这篇论文挑个时间再好好看看吧,先把其中一部分在这里讲一下,但可能不对。

这里就只摆上三个算法吧。大概是这个意思,有个概率向量\(\mathsf{w}\),每个分量表示舍弃该主成分的概率,但我们都知道,舍弃了一部分,就会产生误差,\(\mathbb{l}\)就表示这个损失,每个分量表示舍弃该成分的一个损失(貌似单位化了)。
每次\(\mathsf{w}\)都会更新,根据损失。
论文稍微改进了一下,就是将\(\mathsf{w}\)分解为\(\mathop{\sum}\limits_{i}p_ir_i\),每个\(r_i\)都有\(n-k\)个非零项\(\frac{1}{n-k}\),这样,算法3就是先根据\(p_i\)采样到一个分解项\(r_j\),\(r_j\)中的非零项,表示对应成分是要被舍弃的,根据损失,对\(\mathsf{w}\)进行更新,循环往复。
当然这个算法如何应用到矩阵的选择上,根据后面的描述,应该是利用SVD,然后将其中的对角序列,看成\(\mathsf{w}\)进行选择,不过具体的还没怎么看,到时候再说吧。

Stochastic Optimization of PCA with Capped MSG的更多相关文章

  1. TensorFlow 深度学习笔记 Stochastic Optimization

    Stochastic Optimization 转载请注明作者:梦里风林 Github工程地址:https://github.com/ahangchen/GDLnotes 欢迎star,有问题可以到I ...

  2. Stochastic Optimization Techniques

    Stochastic Optimization Techniques Neural networks are often trained stochastically, i.e. using a me ...

  3. ADAM : A METHOD FOR STOCHASTIC OPTIMIZATION

    目录 概 主要内容 算法 选择合适的参数 一些别的优化算法 AdaMax 理论 代码 Kingma D P, Ba J. Adam: A Method for Stochastic Optimizat ...

  4. (转) An overview of gradient descent optimization algorithms

    An overview of gradient descent optimization algorithms Table of contents: Gradient descent variants ...

  5. First release of mlrMBO - the toolbox for (Bayesian) Black-Box Optimization

    We are happy to finally announce the first release of mlrMBO on cran after a quite long development ...

  6. An overview of gradient descent optimization algorithms

    原文地址:An overview of gradient descent optimization algorithms An overview of gradient descent optimiz ...

  7. 论文翻译:2021_Decoupling magnitude and phase optimization with a two-stage deep network

    论文地址:两阶段深度网络的解耦幅度和相位优化 论文代码: 引用格式:Li A, Liu W, Luo X, et al. ICASSP 2021 deep noise suppression chal ...

  8. 【机器学习Machine Learning】资料大全

    昨天总结了深度学习的资料,今天把机器学习的资料也总结一下(友情提示:有些网站需要"科学上网"^_^) 推荐几本好书: 1.Pattern Recognition and Machi ...

  9. FAQ: Machine Learning: What and How

    What: 就是将统计学算法作为理论,计算机作为工具,解决问题.statistic Algorithm. How: 如何成为菜鸟一枚? http://www.quora.com/How-can-a-b ...

随机推荐

  1. WebClient图片下载

    使用WebClient下载文件非常方便,针对有部分网站通过请求头的Referer,做了图片防盗链,可以在webClient加上Referer 来模拟请求 string basePath = Path. ...

  2. 深入学习SpringMVC以及学习总结

    一.优点: 1.SpringMVC简化web程序开发; 2.SpringMVC效率很好(单例模式): 3.SpringMVC提供了大量扩展点,方便程序员自定义功能: ①.DispatcherServl ...

  3. 4.12Python数据处理篇之Matplotlib系列(十二)---绘图风格的介绍

    目录 目录 前言 (一)不同风格 1.说明: 2.使用: 3.代码使用: (二)例子演示 1.dark_background 2.bmh 3.fivethirtyeight 4.ggplot 5.gr ...

  4. LeetCode算法题-Best Time to Buy and Sell Stock

    这是悦乐书的第172次更新,第174篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第31题(顺位题号是121).假设有一个数组,其中第i个元素是第i天给定股票的价格.如果 ...

  5. June 5. 2018 Week 23rd Tuesday

    Learn to let go and be clear of where you really want to head for. 学会放手,同时也要弄清楚自己的真正所爱. From Kissing ...

  6. keepalived 安装篇-个人实践-编译安装

    官网地址:http://www.keepalived.org/官网文档:http://www.keepalived.org/documentation.html Keepalived的作用是检测服务器 ...

  7. ubuntu集群下ssh配置总结

    最重要的前提就是:集群中的所有机器的用户名和用户组必须一样 一般做法都是在每台机器上新建用户组和用户名. 比如:sudo addgroup sparks 新建用户组sparks: sudo addus ...

  8. 手把手丨我们在UCL找到了一个糖尿病数据集,用机器学习预测糖尿病(三)

    梯度提升: from sklearn.ensemble import GradientBoostingClassifier gb=GradientBoostingClassifier(random_s ...

  9. hive并行执行作业; 强化在脑海的印象

    如果集群资源充足可以设置:set hive.exec.parallel=true; (默认是false) 这样相互独立的job可以并行执行!!!! count(distinct) 最好改写为group ...

  10. 【转】java将excel文件转换成txt格式文件

    在实际应用中,我们难免会遇到解析excel文件入库事情,有时候为了方便,需要将excel文件转成txt格式文件.下面代码里面提供对xls.xlsx两种格式的excel文件解析,并写入到一个新的txt文 ...