• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            一般在計算相關系數時都要遍歷4次數據,這在數據比較多,需要讀寫文件時,顯然是費時的。這里給出Single Pass版本的計算方法,但是其中的變化依據還沒有搞懂,希望各位指教:
            偽代碼:

             1 sum_sq_x = 0
             2 sum_sq_y = 0
             3 sum_coproduct = 0
             4 mean_x = x[1]
             5 mean_y = y[1]
             6 for i in 2 to N:
             7     sweep = (i - 1.0/ i
             8     delta_x = x[i] - mean_x
             9     delta_y = y[i] - mean_y
            10     sum_sq_x += delta_x * delta_x * sweep
            11     sum_sq_y += delta_y * delta_y * sweep
            12     sum_coproduct += delta_x * delta_y * sweep
            13     mean_x += delta_x / i
            14     mean_y += delta_y / i 
            15 pop_sd_x = sqrt( sum_sq_x / N )
            16 pop_sd_y = sqrt( sum_sq_y / N )
            17 cov_x_y = sum_coproduct / N
            18 correlation = cov_x_y / (pop_sd_x * pop_sd_y)
            19

            下面是我用C改寫的,這份改寫同時放在了Wiki上面:
             1#include "stdlib.h"
             2#include "math.h"
             3void SinglePassCorrelation(FILE *file,int N)
             4{
             5    double *x=new double[N+1];
             6    double *y=new double[N+1];
             7    int i;
             8    for(i=1;i<=N;i++)
             9    {
            10        fscanf(file,"%lf %lf",&x[i],&y[i]);
            11        printf("%10.6f %10.6f\n",x[i],y[i]);
            12    }

            13    double sum_sq_x=0;
            14    double sum_sq_y=0;
            15    double sum_coproduct=0;
            16    double mean_x=x[1];
            17    double mean_y=y[1];
            18    double sweep=0;
            19    double delta_x;
            20    double delta_y;
            21    double pop_sd_x;
            22    double pop_sd_y;
            23    double cov_x_y;
            24    double correlation;
            25    for(i=2;i<=N;i++)
            26    {
            27        sweep=(i-1.0)/i;
            28        delta_x=x[i]-mean_x;
            29        delta_y=y[i]-mean_y;
            30        sum_sq_x+=delta_x*delta_y*sweep;
            31        sum_sq_y+=delta_y*delta_y*sweep;
            32        sum_coproduct+=delta_x*delta_y*sweep;
            33        mean_x+=delta_x/i;
            34        mean_y+=delta_y/i;
            35    }
            //end for i
            36    pop_sd_x=sqrt(sum_sq_x/N);
            37    pop_sd_y=sqrt(sum_sq_y/N);
            38    cov_x_y=sum_coproduct/N;
            39    correlation=cov_x_y/(pop_sd_x*pop_sd_y);
            40}

            41
            Posted on 2008-11-28 20:13 鄒敏 閱讀(2114) 評論(0)  編輯 收藏 引用
            狠狠狠色丁香婷婷综合久久俺| 久久最近最新中文字幕大全| 久久综合鬼色88久久精品综合自在自线噜噜| 曰曰摸天天摸人人看久久久| 亚洲国产高清精品线久久| 久久天天躁狠狠躁夜夜不卡| 国内精品久久久久久99| 久久久久亚洲AV无码专区桃色 | 国产精品久久久亚洲| 久久黄色视频| 99久久精品午夜一区二区| 理论片午午伦夜理片久久| 精品无码久久久久久午夜| 伊人久久精品影院| 国产精品99久久不卡| 久久久无码人妻精品无码| 色天使久久综合网天天| www.久久99| 久久久久久亚洲Av无码精品专口| 人妻无码久久精品| 狠狠久久综合伊人不卡| 久久精品国产半推半就| 人妻久久久一区二区三区| 久久午夜福利无码1000合集| 国产69精品久久久久99| 久久久久久综合一区中文字幕| 久久精品aⅴ无码中文字字幕不卡| 久久久久亚洲AV成人网| 国产高清国内精品福利99久久 | 国产精品美女久久久免费| 精品九九久久国内精品| 亚洲午夜久久久久久久久电影网| 伊人色综合久久天天人守人婷 | 久久综合精品国产二区无码| 新狼窝色AV性久久久久久| 免费无码国产欧美久久18| 久久精品国产清自在天天线| 无码人妻久久一区二区三区蜜桃| 欧美久久久久久精选9999| 伊人久久精品影院| 国内高清久久久久久|