• <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 鄒敏 閱讀(2106) 評論(0)  編輯 收藏 引用
            一本久久知道综合久久| 亚洲欧美精品一区久久中文字幕| 欧美噜噜久久久XXX| 久久综合狠狠综合久久综合88| 少妇内射兰兰久久| 国产一区二区精品久久岳| 亚洲人AV永久一区二区三区久久| 国色天香久久久久久久小说 | 久久有码中文字幕| 97久久国产综合精品女不卡| 久久夜色tv网站| 国内精品久久久久影院亚洲| 99久久99这里只有免费费精品| 狠狠综合久久综合中文88 | 精品久久久久久无码不卡| 伊人久久大香线蕉亚洲五月天| 日本福利片国产午夜久久| 亚洲国产欧洲综合997久久| 91精品国产高清久久久久久91| 久久久久亚洲AV无码观看| 国内精品久久久久久中文字幕 | 久久99热这里只有精品国产| 久久se这里只有精品| 久久r热这里有精品视频| 9191精品国产免费久久| 亚洲国产成人久久一区WWW| 亚洲国产精品久久66| 国产精品久久久久久影院 | 久久中文字幕精品| 国产精品岛国久久久久| 亚洲精品乱码久久久久久按摩 | 久久se精品一区二区影院| 久久99国产精品久久99| 久久婷婷五月综合国产尤物app| 亚洲午夜精品久久久久久app| 99精品久久久久久久婷婷| 88久久精品无码一区二区毛片 | 香蕉久久av一区二区三区| 国产精品久久久久久久久免费| 久久综合久久综合九色| 韩国三级中文字幕hd久久精品|