http://blog.csdn.net/ybdesire/article/details/6270328/.net
协方差的定义blog
对于通常的分布,直接代入E(X)之类的就能够计算出来了,但真给你一个具体数值的分布,要计算协方差矩阵,根据这个公式来计算,还真不容易反应过来。网上值得参考的资料也很少,这里用一个例子说明协方差矩阵是怎么计算出来的吧。get
记住,X、Y是一个列向量,它表示了每种状况下每一个样本可能出现的数。好比给定方法
则X表示x轴可能出现的数,Y表示y轴可能出现的。注意这里是关键,给定了4个样本,每一个样本都是二维的,因此只可能有X和Y两种维度。因此matlab
用中文来描述,就是:co
协方差(i,j)=(第i列的全部元素-第i列的均值)*(第j列的全部元素-第j列的均值)源代码
这里只有X,Y两列,因此获得的协方差矩阵是2x2的矩阵,下面分别求出每个元素:中文
因此,按照定义,给定的4个二维样本的协方差矩阵为:ab
用matlab计算这个例子实例
z=[1,2;3,6;4,2;5,2]
cov(z)
ans =
2.9167 -0.3333
-0.3333 4.0000
能够看出,matlab计算协方差过程当中还将元素统一缩小了3倍。因此,协方差的matlab计算公式为:
协方差(i,j)=(第i列全部元素-第i列均值)*(第j列全部元素-第j列均值)/(样本数-1)
下面在给出一个4维3样本的实例,注意4维样本与符号X,Y就没有关系了,X,Y表示两维的,4维就直接套用计算公式,不用X,Y那么具备迷惑性的表达了。
(3)与matlab计算验证
Z=[1 2 3 4;3 4 1 2;2 3 1 4]
cov(Z)
ans =
1.0000 1.0000 -1.0000 -1.0000
1.0000 1.0000 -1.0000 -1.0000
-1.0000 -1.0000 1.3333 0.6667
-1.0000 -1.0000 0.6667 1.3333
可知该计算方法是正确的。咱们还能够看出,协方差矩阵都是方阵,它的维度与样本维度有关(相等)。参考2中还给出了计算协方差矩阵的源代码,很是简洁易懂,在此感谢一下!