皮尔逊相关系数(Pearson Correlation Coefficient)
皮尔逊相关系数(Pearson Correlation Coefficient)是用于度量两个变量之间线性关系强度和方向的统计量。其值域在-1到1之间,其中:
- 当皮尔逊相关系数为1时,表示两个变量完全正相关。
- 当皮尔逊相关系数为-1时,表示两个变量完全负相关。
- 当皮尔逊相关系数为0时,表示两个变量没有线性关系。
皮尔逊相关系数的计算公式
皮尔逊相关系数的计算公式如下:
公式解读
- 分子部分是两个变量之间协方差的计算公式,它衡量了两个变量共同变化的趋势。
- 分母部分是两个变量各自标准差的乘积,用于对协方差进行标准化处理,使得相关系数的取值范围在-1到1之间。
相关性强度解释
- 一般来说,相关系数的绝对值越接近1,表示两个变量之间的线性关系越强。
- ( |r| > 0.8 ) 表示极强相关。
- ( 0.6 ≤|r| < 0.8 ) 表示强相关。
- ( 0.4 ≤ |r| < 0.6 ) 表示中度相关。
- ( 0.2 ≤|r| < 0.4 ) 表示弱相关。
- ( |r| < 0.2 ) 表示极弱相关或无相关。
Java示例代码
在Java中实现皮尔逊相关系数的计算,你需要首先确保你有两个等长的数值数组或列表,然后按照以下步骤进行:
- 计算两个数组的均值。
- 计算两个数组的偏差(即每个元素与均值的差)。
- 计算偏差的乘积之和。
- 计算偏差的平方和。
- 使用上述结果计算皮尔逊相关系数。
以下是一个简单的Java方法,用于计算两个double数组之间的皮尔逊相关系数:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 | public class PearsonCorrelation { /** * 计算两个数组的皮尔逊相关系数 * * @param x 第一个数组 * @param y 第二个数组 * @return 皮尔逊相关系数 * @throws IllegalArgumentException 如果数组长度不等 */ public static double calculatePearsonCorrelation( double [] x, double [] y) { if (x.length != y.length) { throw new IllegalArgumentException( "数组长度必须相等" ); } int n = x.length; // 计算x和y的均值 double meanX = 0.0 , meanY = 0.0 ; for ( int i = 0 ; i < n; i++) { meanX += x[i]; meanY += y[i]; } meanX /= n; meanY /= n; // 计算偏差的乘积之和以及偏差的平方和 double sumXY = 0.0 , sumX2 = 0.0 , sumY2 = 0.0 ; for ( int i = 0 ; i < n; i++) { double diffX = x[i] - meanX; double diffY = y[i] - meanY; sumXY += diffX * diffY; sumX2 += diffX * diffX; sumY2 += diffY * diffY; } // 计算皮尔逊相关系数 double denom = Math.sqrt(sumX2 * sumY2); if (denom == 0 ) { return 0 ; // 如果分母为0,则没有相关性 } return sumXY / denom; } public static void main(String[] args) { double [] x = { 1 , 2 , 3 , 4 , 5 }; double [] y = { 2 , 3 , 4 , 5 , 6 }; double correlation = calculatePearsonCorrelation(x, y); System.out.println( "皮尔逊相关系数: " + correlation); } } |
在上面的示例中,我们定义了一个名为PearsonCorrelation
的类,并在其中实现了一个名为calculatePearsonCorrelation
的静态方法,用于计算两个double数组之间的皮尔逊相关系数。在main
方法中,我们创建了两个示例数组并调用了该方法来计算并打印皮尔逊相关系数。
注意事项
- 皮尔逊相关系数只能衡量线性关系,不能衡量非线性关系。
- 在计算皮尔逊相关系数时,需要确保两个变量都是连续型变量,并且符合正态分布假设(在样本量较大时,这个假设可能不那么重要)。
- 皮尔逊相关系数对极端值敏感,因此在进行计算之前,需要对数据进行适当的清洗和处理。
- 相关性并不等于因果性,即使两个变量高度相关,也不能说明其中一个变量是另一个变量的原因。
常见的相似度计算方法
余弦相似度(Cosine Similarity)
皮尔逊相关系数
曼哈顿距离(Manhattan Distance)
欧氏距离(Euclidean Distance)
Jaccard相似度
修正余弦相似度(Adjusted Cosine Similarity)
皮尔逊χ²检验(Pearson's Chi-squared Test)
互信息(Mutual Information, MI)
Tanimoto系数(Tanimoto Coefficient)
切比雪夫距离(Chebyshev Distance)
汉明距离(Hamming Distance)
分类:
架构设计类与算法
标签:
常用算法快速入门
, 个性化推荐之理论与实践
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 一文读懂知识蒸馏
· 终于写完轮子一部分:tcp代理 了,记录一下