皮尔逊相关系数 Java工具类

皮尔逊相关系数:计算两条折线的相关性。
1为完全相关,-1为完全负相关,0为完全不相关
计算公式:
在这里插入图片描述

public class PearsonUtil {

    /**
     * 计算2个list的皮尔逊相关系数
     *
     * @param x
     * @param y
     * @return
     */
    public static double getPearsonCorrelationScore(List x, List y) {
        if (x.size() != y.size()) {
            throw new BaseException(CODE_SYSTEM_ERROR, "皮尔逊相关系数计算,相关数组长度不相等");
        }
        double[] xData = new double[x.size()];
        double[] yData = new double[x.size()];
        for (int i = 0; i < x.size(); i++) {
            xData[i] = Double.parseDouble(x.get(i).toString());
            yData[i] = Double.parseDouble(y.get(i).toString());
        }
        return getPearsonCorrelationScore(xData, yData);
    }

    /**
     * 计算2个数组的皮尔逊相关系数
     *
     * @param xData
     * @param yData
     * @return
     */
    public static double getPearsonCorrelationScore(double[] xData, double[] yData) {
        if (xData.length != yData.length) {
            throw new BaseException(CODE_SYSTEM_ERROR, "皮尔逊相关系数计算,相关数组长度不相等");
        }
        double xMeans;
        double yMeans;
        double numerator = 0; // 求解皮尔逊的分子
        double denominator = 0; // 求解皮尔逊系数的分母

        double result = 0;
        // 拿到两个数据的平均值
        xMeans = getMeans(xData);
        yMeans = getMeans(yData);
        // 计算皮尔逊系数的分子
        numerator = generateNumerator(xData, xMeans, yData, yMeans);
        // 计算皮尔逊系数的分母
        denominator = generateDenomiator(xData, xMeans, yData, yMeans);
        // 计算皮尔逊系数
        result = numerator / denominator;
        return result;
    }

    /**
     * 计算分子
     *
     * @param xData
     * @param xMeans
     * @param yData
     * @param yMeans
     * @return
     */
    private static double generateNumerator(double[] xData, double xMeans, double[] yData, double yMeans) {
        double numerator = 0.0;
        for (int i = 0; i < xData.length; i++) {
            numerator += (xData[i] - xMeans) * (yData[i] - yMeans);
        }
        return numerator;
    }

    /**
     * 计算分母
     *
     * @param yMeans
     * @param yData
     * @param xMeans
     * @param xData
     * @return 分母
     */
    private static double generateDenomiator(double[] xData, double xMeans, double[] yData, double yMeans) {
        double xSum = 0.0;
        for (int i = 0; i < xData.length; i++) {
            xSum += (xData[i] - xMeans) * (xData[i] - xMeans);
        }
        double ySum = 0.0;
        for (int i = 0; i < yData.length; i++) {
            ySum += (yData[i] - yMeans) * (yData[i] - yMeans);
        }
        return Math.sqrt(xSum) * Math.sqrt(ySum);
    }

    /**
     * 计算数组平均值
     *
     * @param datas 数据集
     * @return 给定数据集的平均值
     */
    private static double getMeans(double[] datas) {
        double sum = 0.0;
        for (int i = 0; i < datas.length; i++) {
            sum += datas[i];
        }
        return sum / datas.length;
    }

    public static void main(String[] args) {
        double[] x = new double[]{0.98, 0.96, 0.96, 0.94, 0.925, 0.9025, 0.875};
        double[] y = new double[]{1, 1, 1, 1, 0.961483893, 0.490591662, 0.837341784};
        double score = getPearsonCorrelationScore(x, y);
        System.out.println(score); // 0.6350393282549671

        List lx = Arrays.asList(1,2,3);
        List ly = Arrays.asList(1,2,3);
        double score2 = getPearsonCorrelationScore(lx, ly);
        System.out.println(score2); // 0.9999999999999998
    }
}
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值