亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? mexccacollectdata.c

?? 一個很好的Matlab編制的數據降維處理軟件
?? C
字號:
/* * * mexCCACollectdata.c *      prepare data for cca.m to form SDP * * by feisha@cis.upenn.edu */  #include "mex.h" #include "matrix.h"#include <stdlib.h>#include <float.h>#include <string.h> #include <math.h> /* the computation engine */void collectdata(double *x, double *y, int* edgerow, int *edgecol, int *relative, int *nv, int *vidx, int D, int d, int n, int ks, double *a, double *b, double *g);/* auxiliary functions */void sanity_check(int nlhs, mxArray *plhs[], int nrhs, const mxArray *prhs[]);/* the gateway */ void mexFunction(int nlhs, mxArray *plhs[], int nrhs, const mxArray *prhs[]){    int n, ks=1, D, d;    double *x, *y, *a, *b, *g;    int *neighbors;        /* sanity_check(nlhs, plhs, nrhs, prhs); */        n = mxGetN(prhs[0]);    D = mxGetM(prhs[0]);    d = mxGetM(prhs[1]);    /*printf("%d data points, reducing from dimension %d ---> dimension %d, using \%d nearest neighbors\n", n, D, d, ks); */        plhs[0] = mxCreateDoubleMatrix(d*d, d*d, mxREAL);    plhs[1] = mxCreateDoubleMatrix(d*d, n, mxREAL);    plhs[2] = mxCreateDoubleMatrix(n,1, mxREAL);        collectdata( (double*)mxGetData(prhs[0]),                 (double*)mxGetData(prhs[1]),                 (int*)mxGetData(prhs[2]),                 (int*)mxGetData(prhs[3]),                 (int*)mxGetData(prhs[4]),                 (int*)mxGetData(prhs[5]),                 (int*)mxGetData(prhs[6]),                 D, d, n, ks,                  (double*)mxGetData(plhs[0]),                 (double*)mxGetData(plhs[1]),                 (double*)mxGetData(plhs[2]));    return;}/* check input arguments */void sanity_check(int nlhs, mxArray *plhs[], int nrhs, const mxArray *prhs[]) {    int n1, n2, n3;    /* Check for proper number of input and output arguments. */        if (nrhs != 4) {        mexErrMsgTxt("Four input argument required.");    }     if (nlhs != 3) {        mexErrMsgTxt("Three output arguments required.");    }    /* Check data type of input argument. */    /*if (!(mxIsDouble(prhs[0])) || !(mxIsDouble(prhs[1])) || !(mxIsDouble(prhs[2]))) {        mexErrMsgTxt("Input array must be of type double.");    }*/        /* Check dimensions */    if(mxGetNumberOfDimensions(prhs[0])!=2 || mxGetNumberOfDimensions(prhs[1])!=2 || mxGetNumberOfDimensions(prhs[2])!=2) {        mexErrMsgTxt("Input arrays must be two-dimension arrays");    }    /* matching dimensions */    n1 = mxGetN(prhs[0]);    n2 = mxGetN(prhs[1]);    n3 = mxGetN(prhs[2]);    if (n1 != n2 || n1 !=n3) {        mexErrMsgTxt("Input arrays must have same number of columns!");    }    return;}/* computing */double vecdot(double* v1, int n) {  /* v1'*v2 */    double x = 0;    int i;    for(i = 0; i < n; i++) {        x += v1[i]*v1[i];    }    return x;}void vecsub(double* v1,double* v2, double* v3, int n) { /* v3=v1-v2 */    int incx=1;    double none = -1;    /*       dcopy_(&n, v1, &incx,v3, &incx);	     daxpy_(&n, &none, v2, &incx, v3, &incx);*/    int i;     for(i=0;i<n;i++) v3[i]=v1[i]-v2[i];     }void vecout(double* v1, double* v3, int d) { /* v3 = v1*v2' */  double temp,one = 1.0;    int inca = 1;    int i,j,c;     /*   dger_(&d , &d, &one, v1, &inca,v1, &inca, v3, &d); */    c=0;    for(i=0;i<d;i++){       temp=v1[i];      for(j=0;j<d;j++){   	v3[c]=temp*v1[j];      c++;	}        }}void makevecsym(double *v, int d) { /* assume V is a dxd matrix, return (V+V')/2 */    int row, col, i;    double temp;    for(col=0; col < d; col++) {        for(row=col; row < d; row++) {            temp = (v[row*d+col] + v[col*d+row])/2;            v[row*d+col] = v[col*d+row] = temp;        }    }}void updateA(double *a, double *v, double alpha, int d) {  /* update A */    int inca = 1;    char *uplo= "U";    double temp;    int i,j,c;    /*            dspr_(uplo, &d , &alpha, v, &inca, a);*/     if(alpha==1.0){ /*optimize the common case */     c=0;     for(i=0;i<d;i++){      temp=v[i];      for(j=0;j<=i;j++)  {	a[c]+=temp*v[j];       c++;      }      }    } else{     c=0;     for(i=0;i<d;i++){      temp=v[i]*alpha;      for(j=0;j<=i;j++)  {	a[c]+=temp*v[j];       c++;      }      }    }}void updateB(double * b, double alpha, double *v, int d) { /* update B(:,i) */    int i;    int incx = 1;    /*   daxpy_(&d, &alpha, v, &incx, b, &incx);*/    for(i=0;i<d;i++) b[i]+=alpha*v[i];}/* transform upper triangular matrix stored in A as full matrix */void recoverA(int D, double *A, double *tempA){  int l = 0, idx, jdx,s, incx=1, incy=1;  int n = D*(D+1)/2;  for(jdx=0; jdx <D; jdx++) {     for(idx=0; idx <=jdx; idx++) {    	A[jdx*D+idx] = tempA[l];        l++;          }  }  for(jdx=0; jdx <D; jdx++)     for(idx=jdx; idx <D; idx++) {        A[jdx*D+idx] = A[idx*D+jdx];    } }void collectdata(double *x, double *y, int* edgesrow, int *edgescol, int *relative, int *nv, int *vidx, int D, int d, int n, int ks, double *a, double *b, double *g) {    double *diffx, *diffy, *yij, *nid;    double gij;    int i, j, k, iEdge, iVertex,itemp, ii;    int nn_start, nn_end, nn;    double *diffxjk, *diffyjk;    double gjk, *yjk, *tempA;    int relflg = *relative;    /* clear data area */    memset(a, 0, sizeof(double)*d*d*d*d);    memset(b, 0, sizeof(double)*d*d*n);    memset(g, 0, sizeof(double)*n);    /* temporary working space */    diffx = (double*)calloc(D, sizeof(double));    diffy = (double*)calloc(d, sizeof(double));    yij = (double*)calloc(d*d, sizeof(double));            tempA = (double*)calloc((d*d)*(d*d+1)/2, sizeof(double));        if(!diffx || !diffy || !yij || !tempA) {        mexErrMsgTxt("Out of memory..cannot allocate working space..");        return;    }    iEdge = 0;    iVertex = 0;    if(relflg==0) {            for(i=0; i <n ; i++) {             /* figure out the nearest neighbors */            nn_start = edgescol[i]; nn_end = edgescol[i+1]-1;            if (nn_end >= nn_start) {                for(nn=nn_start; nn<=nn_end; nn++) {                    j = edgesrow[nn];                                        /* compute diffx and diffy */                    vecsub(x+i*D, x+j*D, diffx, D);                    gij = vecdot(diffx, D);                                    vecsub(y+i*d, y+j*d, diffy, d);                    vecout(diffy,  yij, d);                                /* update A, b */                    updateA(tempA, yij, 1.0*nv[iEdge],d*d);                    for(itemp=0; itemp < nv[iEdge]; itemp++) {                        ii = vidx[iVertex]-1;                        updateB(b+ii*d*d, gij, yij, d*d);                        g[ii] = g[ii]+gij*gij;                        iVertex++;                    }                                        iEdge++;                }               }        }        printf("Iedge :%d, ivertex: %d\n", iEdge, iVertex);    } else {        /* reproducing the code above to some degree so that we don't have to          do if statement inside cache-intensive loop */        for(i=0; i <n ; i++) {             /* figure out the nearest neighbors */            nn_start = edgescol[i]; nn_end = edgescol[i+1]-1;            if (nn_end >= nn_start) {                for(nn=nn_start; nn<=nn_end; nn++) {                    j = edgesrow[nn];                                /* compute diffx and diffy */                    vecsub(x+i*D, x+j*D, diffx, D);                    gij = vecdot(diffx, D);                                    vecsub(y+i*d, y+j*d, diffy, d);                    vecout(diffy,  yij, d);                                /* update A, b */                    updateA(tempA, yij, 1*nv[iEdge]/(gij*gij), d*d);                    for(itemp=0; itemp < nv[iEdge]; itemp++) {                        ii = vidx[iVertex]-1;                        updateB(b+ii*d*d, 1/gij, yij, d*d);                        g[ii] = g[ii]+1;                        iVertex++;                    }                    iEdge++;                }               }        }    }    /* make A symmetric */    recoverA(d*d, a, tempA); }     

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品入口麻豆九色| 日韩午夜激情免费电影| 国产精品麻豆视频| 99久久国产免费看| 亚洲综合网站在线观看| 欧美系列亚洲系列| 亚洲国产成人精品视频| 91精品国产综合久久久蜜臀图片 | 亚洲成人黄色小说| 欧美性色黄大片| 日本最新不卡在线| 久久奇米777| 99久久精品99国产精品| 亚洲成a人片在线观看中文| 制服丝袜在线91| 国产精品99精品久久免费| 亚洲国产高清不卡| 色欧美片视频在线观看| 天天av天天翘天天综合网色鬼国产 | 欧美mv日韩mv亚洲| 国产成人三级在线观看| 一区二区三区小说| 日韩欧美成人午夜| hitomi一区二区三区精品| 曰韩精品一区二区| 日韩精品中文字幕在线一区| 懂色av一区二区三区免费观看| 亚洲视频小说图片| 日韩一级免费观看| 成人av片在线观看| 性做久久久久久| 国产肉丝袜一区二区| 欧美性感一区二区三区| 国产一区二区三区四区五区入口 | 亚洲免费观看高清完整版在线| 欧美羞羞免费网站| 国产一区啦啦啦在线观看| 亚洲精品高清在线| 久久久久久久久久久久久夜| 欧美在线你懂得| 成人av网站在线观看免费| 老司机免费视频一区二区三区| 亚洲同性同志一二三专区| 欧美xxxx在线观看| 欧美亚洲国产一区二区三区| 国产精品一区二区x88av| 亚洲妇熟xx妇色黄| 国产精品视频一二三区| 欧美白人最猛性xxxxx69交| 91国产丝袜在线播放| 黑人精品欧美一区二区蜜桃| 亚洲一区在线电影| 中文字幕一区二区三| 精品捆绑美女sm三区| 欧美三区免费完整视频在线观看| 成人久久18免费网站麻豆 | 久久99热狠狠色一区二区| 亚洲人成影院在线观看| 久久精品一区蜜桃臀影院| 7777精品伊人久久久大香线蕉的| 91免费在线播放| 国产91精品入口| 国产在线视频一区二区| 日韩av在线免费观看不卡| 亚洲激情自拍视频| 一区二区中文字幕在线| 国产午夜精品久久久久久久| 欧美电影免费观看完整版| 在线播放91灌醉迷j高跟美女| 在线观看日韩电影| 日本高清不卡视频| 99久久精品国产一区| 99久久综合精品| 成人永久免费视频| 国产麻豆精品theporn| 蜜臀av一区二区在线免费观看 | 国产一区免费电影| 麻豆成人久久精品二区三区红| 午夜久久久影院| 婷婷夜色潮精品综合在线| 日精品一区二区| 日韩va亚洲va欧美va久久| 日本不卡在线视频| 美日韩黄色大片| 久久成人18免费观看| 精品夜夜嗨av一区二区三区| 国产一区久久久| 成人激情小说乱人伦| 97久久精品人人做人人爽50路| caoporn国产一区二区| 91美女在线观看| 欧美在线观看视频在线| 欧美日韩亚洲国产综合| 欧美精选午夜久久久乱码6080| 欧美一区二区久久久| 精品国产凹凸成av人导航| 久久精品在线观看| 1024成人网| 亚洲超碰97人人做人人爱| 美女一区二区三区在线观看| 国产成人免费在线观看不卡| 92国产精品观看| 欧美精品电影在线播放| 日韩视频在线观看一区二区| 久久久精品黄色| 亚洲欧洲日产国码二区| 亚瑟在线精品视频| 国产乱国产乱300精品| 成人精品在线视频观看| 日本伦理一区二区| 欧美一区二区美女| 国产精品超碰97尤物18| 亚洲图片欧美一区| 狠狠色丁香久久婷婷综合丁香| 菠萝蜜视频在线观看一区| 欧美日韩成人综合在线一区二区| 精品成人佐山爱一区二区| 日韩美女视频一区| 男女激情视频一区| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 亚洲欧美日韩在线| 日韩专区在线视频| 成人免费视频免费观看| 欧美裸体bbwbbwbbw| 欧美激情一区二区三区蜜桃视频| 亚洲一区二区影院| 国产成人综合精品三级| 欧美性生活大片视频| 国产欧美综合在线观看第十页| 一区二区三区av电影| 精品写真视频在线观看| 欧美亚州韩日在线看免费版国语版| 久久久久久久久久久久久女国产乱| 一区二区三区色| 国产成a人亚洲精品| 91精品在线观看入口| 亚洲视频免费在线观看| 精品一区二区三区在线播放视频| 91亚洲精品乱码久久久久久蜜桃 | 91精品国产黑色紧身裤美女| 亚洲欧美在线另类| 韩日欧美一区二区三区| 欧美日韩精品一二三区| 中文字幕一区日韩精品欧美| 精品一区二区在线免费观看| 欧美肥大bbwbbw高潮| 一区二区三区四区亚洲| 成人激情开心网| 亚洲精品在线免费观看视频| 日韩和的一区二区| 欧美偷拍一区二区| 亚洲欧美日韩精品久久久久| 国产很黄免费观看久久| 欧美第一区第二区| 日本不卡在线视频| 欧美男同性恋视频网站| 亚洲香肠在线观看| 91国偷自产一区二区开放时间 | 99久久99久久综合| 欧美激情一区二区三区不卡| 国产一区激情在线| 久久只精品国产| 久久99精品国产.久久久久久| 欧美精品1区2区| 天堂成人国产精品一区| 欧美三级日韩三级国产三级| 亚洲国产欧美另类丝袜| 在线观看日韩av先锋影音电影院| 中文字幕在线不卡一区二区三区| 成人污污视频在线观看| 欧美高清在线一区| a级精品国产片在线观看| 国产精品女同互慰在线看| 成人午夜电影久久影院| 中文字幕日韩av资源站| 91污在线观看| 亚洲一级在线观看| 欧美男人的天堂一二区| 美女任你摸久久 | 欧美精品少妇一区二区三区| 五月婷婷久久丁香| 日韩美女在线视频| 国产一区二区调教| 国产精品麻豆一区二区| 一本色道久久综合精品竹菊| 亚洲自拍与偷拍| 制服丝袜亚洲网站| 激情国产一区二区| 国产欧美日韩卡一| 91电影在线观看| 日韩av不卡在线观看| 久久婷婷国产综合国色天香| 成人小视频免费在线观看| 一区二区三区日韩| 91精品国产色综合久久久蜜香臀| 国内精品自线一区二区三区视频| 久久久久亚洲综合| 色哟哟一区二区| 毛片av中文字幕一区二区| 国产精品久久毛片a|