相关系数——Correlation coefficient

liftword3周前 (12-15)技术文章17

通常指Pearson product-moment correlation coefficient,统计学参数,用来研究变量间的相关性,通常描述变量间的线性相关性。其范围介于-1和1之间,其绝对值越接近1,说明变量间的相关性越大。

  • 当r>0的时候,我们认为两个变量之间是正相关的;
  • 当r<0时,两个变量之间是负相关的。当r=0时,两个变量之间是线性无关的。
  • 当r=-1和1时,两个变量之间的相关性可以用一次函数(直线的形式)来描述。

Pearson相关系数的计算公式如下:

该公式将变量x和y的协方差与变量x和y的方差积的根号值的比值作为新的参数来衡量变量x和y之间相关性。Pearson相关系数的好处在于归一化了系数的范围,不用考虑量纲值对参数评价的影响,但是该系数有一定的局限性,并不能完全描述所有变量的相关性。除此之外描述变量相关性的系数还有Spearman correlation coefficient(斯皮尔曼相关性系数)和Kendall(肯德尔相关性系数)系数。Spearman系数用于描述具有顺序属性的变量序列,而Kendall序列用于描述具有类别属性的变量。

如何计算Pearson等相关系数呢?

明确了这些系数之后,重点在于如何计算这些系数。可以通过一些统计分析软件,去计算这些系数,常用的有Origin和Spss等。此外也可以使用Python和Matlab的库函数很容易求得这些变量之间的相关系数。以Origin为例:

我们首先可以导入需要分析的变量值到一个工作簿中,然后进入Origin统计菜单,然后点击相关系数进入相关系数页面

在相关系数页面,我们可以选择要选取变量的范围,指定需要计算那些相关性系数,同时可以将变量绘制成散点图便于可视化分析。

通过计算可得变量A和变量B之间是高度相关的,其相关系数值高达0.99。

使用Python计算相关性系数

通过使用Python的pandas库我们可以很容易对相应的变量执行相关系数计算,通过计算可以求得变量1和变量2之间的相关系数为0.99461,这和Origin计算得到的结果一致。此外还可以在corr函数内设置相关系数的计算类别,进一步执行Spearman系数和Kendall系数计算。使用Python的好处是可以方便快捷去执行批量化的相关系数计算。

相关文章

「Python算术运算符」计算一个数的平方数和平方根数

功能要求编写一个Python应用程序,从键盘上输入一个整数,计算这个数的平方数(2次方)和平方根数(0.5次方),并将结果在控制台打印输出。实现步骤1.创建一个Python文件,从键盘上读取一个整数,...

一文读懂概率分布 概率分布是啥

概率中通常将试验的结果称为随机变量。随机变量将每一个可能出现的试验结果赋予了一个数值,包含离散型随机变量和连续型随机变量。掷硬币就是一个典型的离散型随机变量,离散随机变量可以取无限个但可数的数值。而连...