Machine Learning 学习笔记 (4) —— 广义线性模型
本系列文章允许转载,转载请保留全文!
【请先阅读】【说明&总目录】http://www.cnblogs.com/tbcaaa8/p/4415055.html
1. 指数分布族简介
之前的文章分别介绍了因变量服从高斯分布、伯努利分布、泊松分布、多项分布时,与之对应的回归模型,本文章将阐释这些模型的共同点,并加以推广。
首先非正式地给出指数分布族的定义:
定义 如果变量y的分布可以被表示为p(y;η)=b(y)exp(ηTT(y)-a(η))的形式(η为分布的参数),则称y服从指数分布族
萌萌哒博主能力有限,关于指数分布族无法给出过多解释。如果对指数分布族的性质及a(η),b(y),T(y)的含义等内容有兴趣,请参考维基百科。
维基百科指数分布族参考链接:http://en.wikipedia.org/wiki/Exponential_family
2. 从特殊到一般:验证上述四分布属于指数分布族
2.1 高斯分布
以单变量高斯分布为例进行推导。高斯分布的概率密度函数如下:
对比指数分布族定义,可以发现:
从而验证了高斯分布属于指数分布族。
2.2 伯努利分布
伯努利分布的概率密度函数如下:
对比指数分布族定义,可以发现:
从而验证了伯努利分布属于指数分布族。
2.3 泊松分布
泊松分布的概率密度函数如下:
对比指数分布族定义,可以发现:
从而验证了泊松分布属于指数分布族。
2.4 多项分布
注意:在Softmax回归的背景下,对多项分布的自变量n1...nk进行了限制,即假设n1...nk恰有一个取值为1,其余为0。只有这样才能满足k分类的要求。在这种限制下,多项分布的自变量可以由k维向量转换为取值范围在{1...k}的标量,从而简化运算。在这种情况下,多项分布的概率密度如下:
化简至此,可以发现仍然与指数分布族有些许差距。继续将概率密度化为向量形式:
有没有似曾相识的感觉呢?如果取k=2,多项分布将退化为伯努利分布:伯努利分布是多项分布的特例,而多项分布是伯努利分布的推广。对比指数分布族定义,可以发现:
从而验证了多项分布属于指数分布族。
函数1{·}的含义参看本系列上一篇文章,此处不再赘述。参见:http://www.cnblogs.com/tbcaaa8/p/4486297.html
3. 广义线性模型
广义线性模型基于如下三点假设:
假设一 y(i)|x(i)相互独立且满足同一属于指数分布族的分布
假设二 E(T(y(i))|x(i))是y(i)|x(i)所满足的分布的参数
假设三 模型具有线性性,即η=θTx
基于以上假设,广义线性模型中的对数似然函数可以表示为如下形式:
下面求似然函数的极大值:
在线性回归、逻辑回归、泊松回归和Softmax回归中,将相关参数带入上式,即可得到对其损失函数求导后的结果(损失函数自身的意义小于其导函数的意义)。随后可以使用梯度下降(上升)法求解,也可以直接利用牛顿法求解。
注:线性回归由于参数σ2的存在,处理过程稍有不同,但结果是一致的;上式与损失函数求导后的结果相比,可能有符号的差别,这与损失函数的定义有关。
至此,广义线性模型问题基本解决,但仍遗留有一些细节问题。例如,在线性回归、逻辑回归、泊松回归和Softmax回归中提到的假设函数hθ(x)是怎么得出的?
在指数分布族中,未知参数为η,而我们想要求得的参数是一个权重向量θ。hθ(x)的作用,正是将二者关联起来,因此也称之为连接函数。在广义线性模型中,参数η其实是概率分布的某个参数(如高斯分布的参数μ,伯努利分布的参数Φ等)的函数,例如η=η(μ)等等,而连接函数则是其反函数,即μ=η-1(η)。解出反函数后,将η=θTx带入其中,即可得到hθ(x)。
那么,对于一个给定的回归模型,连接函数的选取是否是唯一的呢?
在一般情况下,应选择η-1作为连接函数。但选择形态上与其类似的函数作为连接函数也是可以的,例如在逻辑回归中,可以选择双曲正切函数代替sigmoid函数,只不过此时的回归模型不再是标准的回归模型了。
Machine Learning 学习笔记 (4) —— 广义线性模型的更多相关文章
- [Machine Learning]学习笔记-Logistic Regression
[Machine Learning]学习笔记-Logistic Regression 模型-二分类任务 Logistic regression,亦称logtic regression,翻译为" ...
- Machine Learning 学习笔记
点击标题可转到相关博客. 博客专栏:机器学习 PDF 文档下载地址:Machine Learning 学习笔记 机器学习 scikit-learn 图谱 人脸表情识别常用的几个数据库 机器学习 F1- ...
- [Python & Machine Learning] 学习笔记之scikit-learn机器学习库
1. scikit-learn介绍 scikit-learn是Python的一个开源机器学习模块,它建立在NumPy,SciPy和matplotlib模块之上.值得一提的是,scikit-learn最 ...
- Machine Learning 学习笔记1 - 基本概念以及各分类
What is machine learning? 并没有广泛认可的定义来准确定义机器学习.以下定义均为译文,若以后有时间,将补充原英文...... 定义1.来自Arthur Samuel(上世纪50 ...
- Coursera 机器学习 第6章(上) Advice for Applying Machine Learning 学习笔记
这章的内容对于设计分析假设性能有很大的帮助,如果运用的好,将会节省实验者大量时间. Machine Learning System Design6.1 Evaluating a Learning Al ...
- machine learning学习笔记
看到Max Welling教授主页上有不少学习notes,收藏一下吧,其最近出版了一本书呢还,还没看过. http://www.ics.uci.edu/~welling/classnotes/clas ...
- Machine Learning 学习笔记 01 Typora、配置OSS、导论
Typora 安装与使用. Typora插件. OSS图床配置. 机器学习导论. 机器学习的基本思路. 机器学习实操的7个步骤
- [Machine Learning]学习笔记-线性回归
模型 假定有i组输入输出数据.输入变量可以用\(x^i\)表示,输出变量可以用\(y^i\)表示,一对\(\{x^i,y^i\}\)名为训练样本(training example),它们的集合则名为训 ...
- 吴恩达Machine Learning学习笔记(一)
机器学习的定义 A computer program is said to learn from experience E with respect to some class of tasks T ...
随机推荐
- angular $apply()以及$digest()讲解1
一些知名的批评和缺陷.他们都涉及到$digest loop(更新周期)中一个很常见的问题:如何在Angular之外更新$scope? 在哪调用 $apply? 更佳的做法是确保你是在$digest l ...
- .NET中的字符串你了解多少?
字符串的特性 1.不可变性 由于字符串是不可变的的,每次修改字符串,都是创建了一个单独字符串副本(拷贝了一个字符串副本).之所以发生改变只是因为指向了一块新的地址. ps: ...
- 一个学生分数表,用sql语句查询出各班级的前三名
昨天去一家公司面试,被这道题难住了,哎,又失去一次好的机会. 回来 之后就再想这个问题 表结构及数据如下:
- 创建带sshd服务的docker image
参考:https://docs.docker.com/examples/running_ssh_service/ 1. 创建一个空目录用于存放Dockerfile mkdir -p /home/thm ...
- CentOS学习笔记--JDK安装
JDK安装 大部分的服务都离不开JAVA环境,CentOS里都是OpenJDK,显然我们还是使用JAVA的JDK好.(注:minimal版没有安装OpenJDK,其它版本需要删除这个.) JDK下载 ...
- 计算2的n次方的三种方法(C语言实现)
C代码如下: #include <stdio.h> int func1(int n) { <<n; } int func2(int n) { ) { ; } )*; } int ...
- 遍历List/Map的时候删除成员遇到的奇怪问题
1.for each删除成员 List<String> list = new LinkedList<String>(); list.add("a"); li ...
- 详解Oracle临时表的几种用法及意义
Oracle临时表可以说是提高数据库处理性能的好方法,在没有必要存储时,只存储在Oracle临时表空间中.希望本文能对大家有所帮助. 1 .前言 Oracle Logo 目前所有使用 Oracle 作 ...
- luigi学习8--使用中央调度器
--local-scheduler一般用在开发阶段,这在一个产品中是不建议这样使用的.使用中央调度器有两个目的: 保证两个相同的task不会同时运行两次 提供一个可视化的界面 注意:中央调度器并不会帮 ...
- luigi学习2-在hadoop上运行Top Artists
一.AggregateArtistsHadoop class AggregateArtistsHadoop(luigi.contrib.hadoop.JobTask): date_interval = ...