优化算法-BFGS

BGFS是一种准牛顿算法, 所谓的"准"是指牛顿算法会使用Hessian矩阵来进行优化, 但是直接计算Hessian矩阵比较麻烦, 所以很多算法会使用近似的Hessian, 这些算法就称作准牛顿算法(Quasi Newton Algorithm).

1. 牛顿算法(Newton Algorithm)

牛顿算法考虑了函数的二阶单数, 是一种二阶优化方法, 并且是所有其他二阶优化方法的鼻祖. 作为对比, 梯度下降(Gradient Descent)只考虑了函数的一阶导数, 是一阶优化方法.

推导过程:

我们考虑函数的二阶泰勒展开式: fquad(θ)=fk+gTk(θ−θk)+12(θ−θk)THk(θ−θk), 其中θ为需要优化的参数, gk为∇f(θk)

上式可以重写作:

fquad(θ)=θTAθ+bTθ+c

其中

  式子-1

二次函数的最小值取为x=−b2a

所以式子-1在θ取以下值时达到最小

亦即Newton算法每次迭代时只需要对θk加上以下项

牛顿方法的步骤为

2. BFGS算法

Newton算法在计算时需要用到Hessian矩阵H, 计算Hessian矩阵非常费时, 所以研究者提出了很多使用方法来近似Hessian矩阵, 这些方法都称作准牛顿算法, BFGS就是其中的一种, 以其发明者Broyden, Fletcher, Goldfarb和Shanno命名.

BFGS算法使用以下方法来近似Hessian矩阵, Bk≈Hk:

初始时可以取B0=I

因为Hessian矩阵的大小为O(D2), 其中D为参数的个数, 所以有时Hessian矩阵会比较大, 可以使用L-BFGS(Limited-memory BFGS)算法来进行优化.

参考文献:

[1]. Machine Learning: A Probabilistic Perspective. p249-p252.

[2]. Wekipedia: L-BFGS

顺手的Linux发行版及其工具推荐

从Windows切换到Linux已经有半年多的时间了,简单给大家推荐一些个人感觉不错的软件,主要都是和开发相关的通用软件~~~

0.archlinux 

挑一个比较顺手的linux发行版当然是首要任务了,我的开发硬件平台是笔记本,所以我主要看重这几个方面(以我用过的ubuntu/debian/centos/fedora/opensuse/archlinux/gentoo为例):

1.社区支持

  其实,上面列举的几个linx distribution,社区支持都比较好,差别不是特别大,在国内都有一定基数的用户

  ubuntu的中文社区应该是最好的(不过对于programmer或geek来说,英文真的不应该是问题)

  debian,因为ubuntu基于debian,所以问题也很好解决,社区很强大

  centos是rhel的源代码重编译的版本之一(rhel是Red Hat付费提供服务,centos则是纯社区支持),因为很多企业用的是centos,所以有问题很好解决,社区也很强大

  fedora和opensuse用的不是很多,fedora在中国的用户基数也很大,fedora背后是Red Hat。opensuse的kde界面确实不错,suse的背后是Novell,两家都有企业版,都有认证

  archlinux的社区很强大,aur很好用,问题也很好解决,wiki中英文都有,安装文档handbook都很方便

  gentoo,最近一直在做测试,打算下一个可能是gentoo,社区依然很强大,google问题依然很好解决,wiki也很好用,handbook什么的都有

2.更新升级

  分为两种,一种滚动升级,一种是版本升级,没有好坏之分,个人倾向于archlinux,服务器的话还是版本升级

  1.滚动升级,就像是滚雪球,不断更新最新的包,没有固定的版本号。

  (1)archlinux的更新速度超快,快赶上自己去github上clone下源代码自己编译了,我现在的内核已经是3.11.4,现在kernel.org上的stable就是3.11.4。据说不经常滚容易滚挂了,但我貌似还没有滚挂过。

    archlinux的包管理器pacman用起来很方便,国内更新源的速度也很赞,pacman的具体使用就不介绍了,下同。

  (2)gentoo的更新没有这么激进,社区还是很负责的,基本都是测试过才放进去,kernel到了3.10

    gentoo的一个特点就是他的包管理器emerge,默认是down下来源代码在本机编译,再加上通过USE,可以最大化性能和极高的可选择余地。目前我还在测试中,不过要是本机性能不济的话,编译安装确实很慢。

  2.版本升级,好比windows升级方式(xp 7 8)

  (1)ubuntu每4月和10月的中下旬出来,分为两个版本,桌面版和服务器版,最新到13.04,LTS(长期支持版)最新是12.04.3(每半年小版本号更新一下)

   ubuntu和debian都用一个包管理器,就是apt-get,使用起来很方便,源的速度很快,适合新手

  (2)debian一般来说每两年出一个版本,期间有小版本号的更新,最新版本是7.1(内核版本是3.2),ubuntu是debian的unstable分支。

   软件包都比较旧,不过很稳定,源的速度很快

  (3)centos一般来说每三年一个大版本,每六个月一个小版本,最新的是6.4(内核版本是2.6.32)

       yum包管理器也很好用,也很简单,个人感觉不及apt,源的速度很快

  (4)fedora一般来说每半年一个版本,最新是18,用的不是太多,用的没有ubuntu顺手,但是用户也很多很多,源也很快

3.轻量级

  判断轻量级的概念,一般来说就是预装的包的数量、可定制余地以及系统性能占用

  简单一下,排个名,从快到慢,archlinux>gentoo>debian>centos>ubuntu≈fedora>opensuse

  但是换句话说,每个发行版都安装成很轻量级的,因为都可以选择自己所要安装的包。

4.性能

  差距不是很大,通常来说,内核越新,越轻量级,性能越快。

  这里archlinux就比较突出,gentoo也不错,因为可以自定义编译

5.稳定性

  排个名:centos>debian>archlinux>ubuntu

  要检验稳定性,肯定是要有长时间使用过,才有发言权,其他发行版没有长时间的系统的使用过,所以就不列上了

  debian很稳定,目前我的VPS上运行的就是Debian 7.1 x64,uptime最长到了30多天(不过被我手动重启了),不过debian 7在我的电脑上(t420)有个bug,就是gnome3经常假死,有时候死的很彻底,archlinux就没有这个问题(无论3.8  3.10)。

  centos的某些驱动比debian上要稳定,默认debian只安装自由软件。

  ubuntu在我印象中,就是很不稳定~~~

6.其他

  推荐路线ubuntu(fedora)->debian(centos)->archlinux->gentoo->lfs(额~~~)

  再推荐一个很好用的PE盘(姑且这么称呼吧),就是GRML,是一个LIVE版的GRML(就是说可以在U盘或者光盘中运行的Linux),我用他替代了老毛桃(我目前所有的系统全部都是Linux,哪怕是移动硬盘的分区EXT4)~~~

  BTW:FreeBSD作为服务器也是很不错的,正在测试(gentoo的Portal概念就来自freebsd)

7.总结一下

  新手用ubuntu或fedora

  熟练之后,想要稳定用debian或centos(貌似服务器上用更好),要更新速度,用archlinux或gentoo

1.zsh

  首先是Shell,虽然bash很常见,但是这里推荐的是zsh,zsh兼容bash,zsh自动补全真的是太顺手了,无论是目录,pacman,kill,git下的命令都可以补全。

  比如说我输入kill s后,再按tab就可以列出所有s开头的进程,不断按tab就可以直接在这些列出来的进程中直接选择,不用手动输入。

  配置文件可以先用oh-my-zsh(详见github)。

  可以先sudo pacman -S zsh 尝试一下,估计不到30分钟就chsh了

2.guake

  很像tilda,只需要按下快捷键,就可以弹出全屏的Terminal,可以调节大小和透明度,不需要Alt+CTRL+FX了,支持多标签,archlinux的源里自带

  稳定性比tilda要好不少

3.vim

  神一样的编辑器,不多说了,本人采用了一年多,正式使用才俩月,可以先用大神的配置文件和插件,后期再慢慢修改。

4.tmux

  可以将一个屏幕(一个Terminal)分割成几个Panel,在每个Panel中运行一个Terminal,极大的提高了屏幕利用率

  比如说在上半屏幕vim,左下连着ssh,右下git push

  也支持多标签,不过图形界面下,还是用guake的多标签比较顺手

5.virtualbox

  虽然身边所有的设备都换成了Linux,但是有时候却不得不用Windows(双系统不太喜欢),这时候就要用到虚拟机了

  个人比较崇拜VMware公司,但是vmware一是收费、二是有点慢(宿主计算机),但是性能真的很赞,特别是图形性能(虚拟机上的图形性能很赞)

  virtualbox现在属于oracle,有OSE(开源版),优点:

  1.用着还是很方便,界面简洁,配置简单,还有很方便的headless

  2.免费开源

  3.性能不错

  缺点:

  1.图形性能一般,开了2D 3D加速后,不能在虚拟机里面看百度影音~~~

  2.图形界面中缺少某些功能,需要用vboxmanage,比如说压缩vdi文件,需要手动 vboxmanage modifyvdi compact XXX.vdi

  3.oracle会不会把他给停了,就像opensolaris

6.sublime text

  跟着从Windows带过来,很不错的软件,界面很不错,有众多的插件,作为在图形界面下的vim的替代吧(gvim个人感觉不太好用)

7.stardict

  有时候看文档有什么不会的,可以直接取词,很方便,词典可以从网上下载

8.github

  很赞~~~以下省略1000字

9.dropbox

  国内的网盘虽然容量都很大,但是界面很乱,dropbox小清新很喜欢,并且手机/linux下都有客户端,速度也还是不错(10M网上传下载基本满速),只是容量略小(默认2G,最大19G),但是存文档足够了 。

10.总结

  archlinx + zsh + tmux + vim + stardict + github + dropbox + virtualbox,基本满足了在Linux开发的初级要求,vim还是有很大的研究空间的~~~

  这篇文章只是自己的一些使用心得,有什么错误或者不同的看法,欢迎大家交流哈~~~如果有空的话,再介绍一下平时娱乐时候用的软件,或者一篇文章详细介绍上面的某一条。

 
 
分类: archlinux
 

优化算法-BFGS的更多相关文章

  1. 优化算法——拟牛顿法之L-BFGS算法

    一.BFGS算法 在"优化算法--拟牛顿法之BFGS算法"中,我们得到了BFGS算法的校正公式: 利用Sherman-Morrison公式可对上式进行变换,得到 令,则得到: 二. ...

  2. 一小部分机器学习算法小结: 优化算法、逻辑回归、支持向量机、决策树、集成算法、Word2Vec等

    优化算法 先导知识:泰勒公式 \[ f(x)=\sum_{n=0}^{\infty}\frac{f^{(n)}(x_0)}{n!}(x-x_0)^n \] 一阶泰勒展开: \[ f(x)\approx ...

  3. Scipy优化算法--scipy.optimize.fmin_tnc()/minimize()

    scipy中的optimize子包中提供了常用的最优化算法函数实现,我们可以直接调用这些函数完成我们的优化问题. scipy.optimize包提供了几种常用的优化算法. 该模块包含以下几个方面 使用 ...

  4. L-BFGS算法详解(逻辑回归的默认优化算法)

    python信用评分卡建模(附代码,博主录制) https://study.163.com/course/introduction.htm?courseId=1005214003&utm_ca ...

  5. 数值最优化:一阶和二阶优化算法(Pytorch实现)

    1 最优化概论 (1) 最优化的目标 最优化问题指的是找出实数函数的极大值或极小值,该函数称为目标函数.由于定位\(f(x)\)的极大值与找出\(-f(x)\)的极小值等价,在推导计算方式时仅考虑最小 ...

  6. [Algorithm] 群体智能优化算法之粒子群优化算法

    同进化算法(见博客<[Evolutionary Algorithm] 进化算法简介>,进化算法是受生物进化机制启发而产生的一系列算法)和人工神经网络算法(Neural Networks,简 ...

  7. 基于网格的分割线优化算法(Level Set)

    本文介绍一种网格分割线的优化算法,该方法能够找到网格上更精确.更光滑的分割位置,并且分割线能够自由地合并和分裂,下面介绍算法的具体原理和过程. 曲面上的曲线可以由水平集(level set)形式表示, ...

  8. paper 8:支持向量机系列五:Numerical Optimization —— 简要介绍求解求解 SVM 的数值优化算法。

    作为支持向量机系列的基本篇的最后一篇文章,我在这里打算简单地介绍一下用于优化 dual 问题的 Sequential Minimal Optimization (SMO) 方法.确确实实只是简单介绍一 ...

  9. MOPSO 多目标例子群优化算法

    近年来,基于启发式的多目标优化技术得到了很大的发展,研究表明该技术比经典方法更实用和高效.有代表性的多目标优化算法主要有NSGA.NSGA-II.SPEA.SPEA2.PAES和PESA等.粒子群优化 ...

随机推荐

  1. Quartz.Net任务统一调度框架

    山寨版Quartz.Net任务统一调度框架   TaskScheduler 在日常工作中,大家都会经常遇到Win服务,在我工作的这些年中一直在使用Quartz.Net这个任务统一调度框架,也非常好用, ...

  2. SQL Server Log文件对磁盘的写操作大小是多少

    原文:SQL Server Log文件对磁盘的写操作大小是多少 SQL Server 数据库有三种文件类型,分别是数据文件.次要数据文件和日志文件,其中日志文件包含着用于恢复数据库的所有日志信息,SQ ...

  3. Cookie基础

    周末百度笔试,答得题都会,就是不仔细不心细,提前一个小时交卷子,想起来就已经晚了.问了一个cookie的问题,我SB的蒙住了,于是乎,似乎是跪掉了,回来后总结了下Cooke的相关问题.###获取coo ...

  4. 编译 & 预处理

    编译(compilation , compile) 1.利用编译程序从源语言编写的源程序产生目标程序的过程. 2.用编译程序产生目标程序的动作. 编译就是把高级语言变成计算机可以识别的2进制语言,计算 ...

  5. Write the code.Change the world.---WWDC2014

  6. 10个实用的PHP正则表达式汇总

    原文 10个实用的PHP正则表达式汇总 正则表达式是程序开发中一个重要的元素,它提供用来描述或匹配文本的字符串,如特定的字符.词或算式等.但在某些情况下,用正则表达式去验证一个字符串比较复杂和费时.本 ...

  7. openfire修改服务器名称方法

    1.登陆openfire管理页面,在主页面下方选择编辑属性,修改服务器名称为当前主机名称,点击保存属性,按页面提示重启服务器. 2.重启后,主页的服务器属性下的服务器名称出现一个叹号,鼠标放上去显示F ...

  8. CentOs Linux 文件位置标记

    vsFTP默认位置: 匿名:/var/ftp/ 用户:/home/用户名 配置文件:/etc/vsftpd/ (一般安装软件后都会在/etc/下生成一个软件相关的配置文件夹) 防火墙位置: /etc/ ...

  9. 请确保在编译时已将“AjaxControlToolkit.Properties.Resources.NET4.resources”正确嵌入或链接到程序集“AjaxControlToolkit”

    原文:请确保在编译时已将"AjaxControlToolkit.Properties.Resources.NET4.resources"正确嵌入或链接到程序集"AjaxC ...

  10. PHP 12 :字符串的操作

    原文:PHP 12 :字符串的操作 本章介绍字符串的操作.之所以要把字符串单独拿出来讲,是因为字符串在每种语言里都是非常重要的.并且也是大家关心的.我们从以下几个方面介绍字符串: 字符串的表现形式. ...