python中偏度和峰度的计算公式

  • Post author:
  • Post category:python


最近由于工作中需要用到c++编写计算偏度和峰度,因此在网上找了很多文章,但最后发现得出的峰度和偏度的计算结果和python直接调用pandas计算的结果不一致,最后在excel的计算中找到公式后发现最终结果需要做一些小小的处理,得到的结果与python一致,这里记录下:

偏度:

在这里插入图片描述

峰度:

在这里插入图片描述

附上c++代码:

double mean(const deque<double>& data){
    if(data.size() > 0){
        double ans = 0.0;
        for (int i = 0; i < data.size(); i++) {
            ans += data[i];
        }
        ans = ans / data.size();
        return ans;
    }else{
        return 0.0;
    }
}

double stddev(const deque<double>& data ){
    if(data.size()>0){
        double a1 = mean(data);
        double a2 = 0.0;
        for(int i=0;i<data.size();++i){
            a2 += (a1 - data[i]) * (a1 - data[i]);
        }
        a2 = sqrt(a2 / (data.size()-1));
        return a2;
    }else{
        return 0.0;
    }
}

double get_deque_skew(const deque<double> &que){
    double que_mean = vec_mean(que);
    double que_std = stddev(que);
    double sum = 0.0;
    if(que_std == 0){
        return 0.0;
    }
    for(auto it=que.begin();it!=que.end();++it){
        sum += pow((*it-que_mean)/que_std,3);
    }
    return sum*que.size()/((que.size()-1)*(que.size()-2));
}

double get_deque_kurt(const deque<double> &que){
    double que_mean = vec_mean(que);
    double que_std = stddev(que);
    double sum = 0.0;
    if(que_std == 0){
        return 0.0;
    }
    for(auto it=que.begin();it!=que.end();++it){
        sum += pow((*it-que_mean)/que_std,4);
    }
    double n = que.size();
    return sum*((n*(n+1))/((n-1)*(n-2)*(n-3))) - 3*(n-1)*(n-1)/((n-2)*(n-3));
}



版权声明:本文为zhouqi1991i原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。