• <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 鄒敏 閱讀(2129) 評論(0)  編輯 收藏 引用
            久久久久高潮综合影院| 亚洲国产精品无码久久久不卡| 狠狠色婷婷综合天天久久丁香| 99久久免费国产特黄| 大美女久久久久久j久久| 香蕉99久久国产综合精品宅男自| 波多野结衣久久| 国产免费久久精品丫丫| 国产成人久久精品一区二区三区| 久久亚洲国产欧洲精品一| 日本精品久久久久久久久免费| 婷婷伊人久久大香线蕉AV| 久久精品国产一区二区三区不卡| 欧美一区二区三区久久综| 国产成人99久久亚洲综合精品| 久久丫忘忧草产品| 久久精品国产色蜜蜜麻豆| 精品人妻久久久久久888| 亚洲国产精品狼友中文久久久| 四虎国产精品免费久久5151| 久久天天躁狠狠躁夜夜躁2O2O| 亚洲一区精品伊人久久伊人| 精品一久久香蕉国产线看播放| 国产精品久久波多野结衣| 欧洲精品久久久av无码电影 | 久久精品国产清高在天天线| 国产亚州精品女人久久久久久 | 色综合合久久天天综合绕视看| 人人狠狠综合久久88成人| 狠狠色丁香婷婷久久综合| 亚洲精品99久久久久中文字幕| 国产福利电影一区二区三区久久老子无码午夜伦不 | 激情五月综合综合久久69| 久久精品国产99国产精品澳门| 日韩人妻无码精品久久久不卡| 久久这里只有精品首页| 无码8090精品久久一区| 国产免费久久精品99re丫y| 日韩欧美亚洲综合久久| 无码专区久久综合久中文字幕 | 色婷婷久久久SWAG精品|