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));
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值