Main Content

cov

协方差

说明

示例

C = cov(A) 返回协方差

  • 如果 A 是由观测值组成的向量,则 C 为标量值方差

  • 如果 A 是其列表示随机变量或行表示观测值的矩阵,则 C 为对应的列方差沿着对角线排列的协方差矩阵。

  • 如果 A 是标量,则 cov(A) 返回 0。如果 A 是空数组,则 cov(A) 返回 NaN

C 按观测值数量 -1 实现归一化。如果仅有一个观测值,应按 1 进行归一化。

示例

C = cov(A,B) 返回两个随机变量 AB 之间的协方差。

  • 如果 AB 是长度相同的观测值向量,则 cov(A,B)2×2 协方差矩阵。

  • 如果 AB 是观测值矩阵,则 cov(A,B)AB 视为向量,并等价于 cov(A(:),B(:))AB 的大小必须相同。

  • 如果 AB 为标量,则 cov(A,B) 返回零的 2×2 块。如果 AB 为空数组,则 cov(A,B) 返回 NaN2×2 块。

示例

C = cov(___,w) 为之前的任何语法指定归一化权重。如果 w = 0(默认值),则 C 按观测值数量 -1 实现归一化。w = 1 时,按观测值数量对它实现归一化。

示例

C = cov(___,nanflag) 指定处理输入数组中 NaN 值的条件。例如,cov(A,"omitrows") 在计算协方差时会忽略 A 中包含一个或多个 NaN 值的任何行。默认情况下,cov 包括 NaN 值。

示例

全部折叠

创建一个 3×4 矩阵并计算它的协方差。

A = [5 0 3 7; 1 -5 7 3; 4 9 8 10];
C = cov(A)
C = 4×4

    4.3333    8.8333   -3.0000    5.6667
    8.8333   50.3333    6.5000   24.1667
   -3.0000    6.5000    7.0000    1.0000
    5.6667   24.1667    1.0000   12.3333

由于 A 的列数是 4,结果为 4×4 矩阵。

创建两个向量并计算它们的 2×2 协方差矩阵。

A = [3 6 4];
B = [7 12 -9];
cov(A,B)
ans = 2×2

    2.3333    6.8333
    6.8333  120.3333

创建两个大小相同的矩阵并计算它们的 2×2 协方差。

A = [2 0 -9; 3 4 1];
B = [5 2 6; -4 4 9];
cov(A,B)
ans = 2×2

   22.1667   -6.9333
   -6.9333   19.4667

创建一个矩阵并计算按行数归一化的协方差。

A = [1 3 -7; 3 9 2; -5 4 6];
C = cov(A,1)
C = 3×3

   11.5556    5.1111  -10.2222
    5.1111    6.8889    5.2222
  -10.2222    5.2222   29.5556

创建一个包含 NaN 值的矩阵。

A = [1.77 -0.005 3.98; NaN -2.95 NaN; 2.54 0.19 1.01];

计算矩阵的协方差,排除包含任一 NaN 值的行。

C = cov(A,"omitrows")
C = 3×3

    0.2964    0.0751   -1.1435
    0.0751    0.0190   -0.2896
   -1.1435   -0.2896    4.4104

输入参数

全部折叠

输入数组,指定为向量或矩阵。

数据类型: single | double

附加的输入矩阵,指定为向量或矩阵。B 的大小必须与 A 相同。

数据类型: single | double

归一化权重,指定为下列值之一:

  • 0 - 输出按观测值数量 -1 实现归一化。如果仅有一个观测值,应按 1 进行归一化。

  • 1 - 输出按观测值数量实现归一化。

数据类型: single | double

缺失值条件,指定为下列值之一:

  • "includemissing""includenan" - 计算协方差时,包含输入数组中的 NaN 值。"includemissing""includenan" 具有相同的行为。

  • "omitrows" - 计算协方差时,忽略输入数组中包含一个或多个 NaN 值的任何行。

  • "partialrows" - 对于每个双列协方差计算,仅忽略输入数组中那些成对的包含 NaN 值的行。

输出参数

全部折叠

协方差,以标量或矩阵形式返回。

  • 对于单矩阵输入,C 基于用 A 表示的随机变量数(列数)提供大小 [size(A,2) size(A,2)]。列的方差沿着对角线排列。如果 A 是行或列向量,则 C 为标量值方差。

  • 对于二向量或二矩阵输入,C 是介于两个随机变量之间的 2×2 协方差矩阵。方差沿着 C 的对角线排列。

详细信息

全部折叠

协方差

对于两个随机可变向量 A 和 B,协方差定义为

cov(A,B)=1N1i=1N(AiμA)*(BiμB)

,其中,μA 是 A 的均值,μB 是 B 的均值,* 表示复共轭。

两个随机变量的协方差矩阵是每个变量间成对的协方差计算结果的矩阵,

C=(cov(A,A)cov(A,B)cov(B,A)cov(B,B)).

对于矩阵 A,它的列是由观测值组成的随机变量,其协方差矩阵就是每个列组合之间的成对协方差计算结果。换言之,C(i,j)=cov(A(:,i),A(:,j))

方差

对于由 N 个标量观测值组成的有限长向量 A,方差被定义为

V=1N1i=1N|Aiμ|2

,其中,μ 是 A 的均值,

μ=1Ni=1NAi.

某些方差定义使用 N(而不是 N-1)的归一化因子,您可以通过将 w 设置为 1 来指定该因子。在任一情况下,都假定均值包含常见的归一化因子 N。

扩展功能

版本历史记录

在 R2006a 之前推出

全部展开

另请参阅

| | | | | |