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

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

?? nca.c

?? 功能為neighborhood components analysis
?? C
字號:
/*
 * simple code for computing the KL-divergence objective function and gradient
 * from "Neighbourhood Components Analysis" Goldberger et al, NIPS04
 *
 * charless fowlkes
 * fowlkes@cs.berkeley.edu
 * 2005-02-23
 *
 */

#include <mex.h>
#include <string.h>
#include <math.h>

void mexFunction (int nlhs, mxArray* plhs[], int nrhs, const mxArray* prhs[])
{
    double *A,*X,*Y,*AXT,*F,*M,*P,*ED2,*pi;
    int ID,OD,N,K,ci,i,j,k,m,n;
    // check number of arguments
    if (nlhs < 2) {
        mexErrMsgTxt("Too few output arguments.");
    }
    if (nlhs >= 3) {
        mexErrMsgTxt("Too many output arguments.");
    }
    if (nrhs < 4) {
        mexErrMsgTxt("Too few input arguments.");
    }
    if (nrhs >= 5) {
        mexErrMsgTxt("Too many input arguments.");
    }

    // get arguments
    
    A = mxGetPr(prhs[0]);
    ID = mxGetN(prhs[0]);
    OD = mxGetM(prhs[0]);
    X = mxGetPr(prhs[1]);
    if (mxGetN(prhs[1]) != ID) { mexErrMsgTxt("data (X) dimension  does not match (A) input dimension"); }
    N = mxGetM(prhs[1]);

    Y = mxGetPr(prhs[2]);
    K = mxGetN(prhs[2]);
    if (mxGetM(prhs[2]) != N) { mexErrMsgTxt("different #of class labels (Y) and point coordinates (X)"); } 

    AXT = mxGetPr(prhs[3]);
    if (mxGetN(prhs[3]) != N) { mexErrMsgTxt("AX has wrong # colums"); } 
    if (mxGetM(prhs[3]) != OD) { mexErrMsgTxt("AX has wrong # rows"); } 

    printf("pts=%d ",N);
    printf("classes=%d ",K);
    printf("indim=%d ",ID);
    printf("outdim=%d \n",OD);

    ////// set up output arguments
    plhs[0] = mxCreateDoubleMatrix(1,1,mxREAL); 
    //plhs[1] = mxCreateDoubleMatrix(1,ID*OD,mxREAL); 
    plhs[1] = mxCreateDoubleMatrix(ID,ID,mxREAL); 
    F = mxGetPr(plhs[0]);
    M = mxGetPr(plhs[1]);

    //compute exp(-D2)
    //ED2 = new double[N*N];
    ED2 = mxCalloc(N*N,sizeof(double));
    for (i = 0; i < N; i++)
    {
      for (j = 0; j < N; j++)
      {
        double d2 = 0;
        for (k = 0; k < OD; k++)
        {
          d2 = d2 + (AXT[i*OD+k] - AXT[j*OD+k])*(AXT[i*OD+k] - AXT[j*OD+k]) ;
        }
        ED2[i*N+j] = exp(-d2);
      }
    }

    //compute softmax function P 
    //P = new double[N*N];
    P = mxCalloc(N*N,sizeof(double));
    for (j = 0; j < N; j++)
    {
      for (i = 0; i < N; i++)
      {
        if (i == j)
        {
          P[j*N+i] = 0;
        }
        else
        {
          double den = 0;
          for (k = 0; k < N; k++)
          {
            if (k != i)
            {
              den = den + ED2[i*N+k];
            }
          }
          P[j*N+i] = ED2[j*N+i] / den;
        }
      }
    }

    //compute classification probability pi and total objective F
    //pi = new double[N];
    pi = mxCalloc(N,sizeof(double));
    F[0] = 0;
    for (i = 0; i < N; i++)
    {
      int ci = -1;
      for (k = 0; k < K; k++)
      {
        if (Y[k*N+i] != 0)
        {
          ci = k; 
        }
      }
      pi[i] = 0; //probability of drawing a neighbor in our same class
      for (j = 0; j < N; j++)
      {
        if (Y[ci*N+j] != 0)
        {
          pi[i] = pi[i] + P[j*N+i];
        }
      }
      F[0] = F[0] + log(pi[i]);
    }

    //now compute the gradient
    //double* M = new double[ID*ID];
    memset(M,0,ID*ID*sizeof(double));
    for (i = 0; i < N; i++)
    {
      //add in first sum
      for (k = 0; k < N; k++)
      {
        for (m = 0; m < ID; m++)
        {
          for (n = 0; n < ID; n++)
          {
            M[m*ID+n] = M[m*ID+n] + P[k*N+i]*(X[m*N+i] - X[m*N+k])*(X[n*N+i] - X[n*N+k]);
          }
        }
      }

      //subtract off second sum (only over class of point i)
      ci = -1;
      for (k = 0; k < K; k++)
      {
        if (Y[k*N+i] != 0)
        {
          ci = k; 
        }
      }
      for (j = 0; j < N; j++)
      {
        if (Y[ci*N+j] != 0)
        {
          for (m = 0; m < ID; m++)
          {
            for (n = 0; n < ID; n++)
            {
              M[m*ID+n] = M[m*ID+n] - (1/pi[i])*P[j*N+i]*(X[m*N+i] - X[m*N+j])*(X[n*N+i] - X[n*N+j]);
            }
          }
        }
      }
    }
      
    free(ED2);
    free(P);
    free(pi);
}



?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩在线免费视频| 成人精品鲁一区一区二区| 亚洲精品欧美激情| 亚洲视频在线一区二区| 国产精品三级久久久久三级| ww亚洲ww在线观看国产| www亚洲一区| 久久亚洲捆绑美女| 国产精品嫩草99a| 国产精品国产馆在线真实露脸| 国产精品久久99| 亚洲精品老司机| 日韩精彩视频在线观看| 激情综合色播激情啊| 国产成人自拍高清视频在线免费播放| 国内外成人在线| av欧美精品.com| 欧美少妇bbb| 精品国产91亚洲一区二区三区婷婷| 欧美大片顶级少妇| 国产精品视频免费看| 一区二区三区精品视频| 日韩va欧美va亚洲va久久| 国产伦精品一区二区三区在线观看| 国产精品亚洲一区二区三区在线 | 91浏览器在线视频| 色天天综合久久久久综合片| 欧美日韩国产经典色站一区二区三区 | 国产91精品一区二区麻豆亚洲| 国产精品一线二线三线| 91影视在线播放| 日韩一区二区三区三四区视频在线观看 | 精品国精品国产尤物美女| 国产精品久久综合| 午夜亚洲福利老司机| 国产成人亚洲精品青草天美| 欧洲精品一区二区| 国产亚洲精品福利| 亚洲福利国产精品| bt欧美亚洲午夜电影天堂| 欧美一区二区三区免费| 国产精品毛片高清在线完整版| 亚洲第一av色| 成人毛片老司机大片| 欧美一区二区三区的| 亚洲欧美另类小说| 国产精品亚洲午夜一区二区三区 | 福利一区福利二区| 在线成人av网站| 自拍偷拍亚洲激情| 国产成人免费在线视频| 日韩午夜av一区| 天天色综合成人网| 欧美在线视频日韩| 亚洲欧洲在线观看av| 国产一区二区影院| 欧美顶级少妇做爰| 一区二区三区欧美视频| 成人激情午夜影院| 欧美激情中文字幕一区二区| 久久99精品久久久久久久久久久久| 欧洲在线/亚洲| 亚洲综合成人在线视频| 色综合久久综合| 国产精品电影一区二区三区| 国产另类ts人妖一区二区| 精品剧情在线观看| 麻豆freexxxx性91精品| 91精品在线麻豆| 亚洲国产欧美在线| 欧美系列日韩一区| 亚洲一级二级三级| 欧美日韩免费在线视频| 亚洲午夜精品在线| 欧美久久久影院| 日韩不卡一区二区三区 | 国产福利91精品| 久久久久久久久久美女| 国产一区在线精品| 国产亚洲一区二区三区在线观看| 免费在线观看一区二区三区| 7777精品伊人久久久大香线蕉完整版| 亚洲一二三区不卡| 欧美一级欧美三级在线观看 | 久久久久88色偷偷免费| 国产剧情一区二区三区| 欧美极品少妇xxxxⅹ高跟鞋| 国产一区二区伦理片| 中文字幕av资源一区| 91影视在线播放| 午夜免费久久看| 精品99一区二区| 白白色 亚洲乱淫| 亚洲国产毛片aaaaa无费看| 3d成人h动漫网站入口| 国产伦精品一区二区三区免费迷 | 制服丝袜亚洲播放| 国内精品第一页| 中文字幕亚洲一区二区av在线| 色偷偷88欧美精品久久久| 亚洲成人免费视| 久久久亚洲精品石原莉奈| 91影院在线观看| 捆绑紧缚一区二区三区视频| 亚洲欧洲美洲综合色网| 欧美一级黄色大片| 99久久婷婷国产精品综合| 蜜臀久久久久久久| 国产精品久久久久7777按摩| 6080午夜不卡| 色综合网站在线| 韩国在线一区二区| 一区二区三区四区国产精品| 欧美一区二区福利视频| 99国产精品国产精品久久| 秋霞国产午夜精品免费视频| 中文字幕制服丝袜成人av| 日韩亚洲欧美在线| 91国产免费看| 国产乱色国产精品免费视频| 亚洲网友自拍偷拍| 欧美国产激情二区三区| 日韩精品专区在线影院观看| 色婷婷精品久久二区二区蜜臀av | 亚洲一区二区五区| 精品国产免费一区二区三区四区| 一本大道久久a久久综合| 国产精品白丝jk黑袜喷水| 午夜精品一区二区三区免费视频| 国产精品毛片大码女人| 久久精品视频一区二区三区| 欧美老年两性高潮| 色老汉一区二区三区| 不卡一卡二卡三乱码免费网站 | 久久免费的精品国产v∧| 欧美三级三级三级| 色狠狠av一区二区三区| a美女胸又www黄视频久久| 黄色资源网久久资源365| 婷婷综合另类小说色区| 亚洲欧美一区二区三区孕妇| 中文字幕精品—区二区四季| 精品国产sm最大网站免费看| 8x8x8国产精品| 日韩一区二区三区在线观看| 欧美日本不卡视频| 欧美日韩一级黄| 欧美精品在线观看一区二区| 欧美美女bb生活片| 欧美日本国产一区| 7777精品伊人久久久大香线蕉完整版 | 成人黄色777网| 高清国产午夜精品久久久久久| 国产一区欧美二区| 国产一区二区三区四| 麻豆国产精品一区二区三区| 免费高清在线一区| 黑人巨大精品欧美黑白配亚洲| 久久国产尿小便嘘嘘尿| 久88久久88久久久| 韩国女主播一区二区三区| 精品一区二区三区在线观看| 国模无码大尺度一区二区三区| 国产乱子轮精品视频| 国产91色综合久久免费分享| 99精品国产91久久久久久| 91麻豆成人久久精品二区三区| 91美女片黄在线观看91美女| 欧美中文字幕不卡| 日韩欧美亚洲一区二区| 久久蜜桃av一区精品变态类天堂| 日本一区二区动态图| 一区二区三区四区国产精品| 日韩中文字幕麻豆| 国产成人啪午夜精品网站男同| 99久久精品免费精品国产| 日本久久一区二区三区| 欧美一区二区在线不卡| 久久久久亚洲蜜桃| 中文字幕制服丝袜成人av| 亚洲成人免费视| 国产精品69毛片高清亚洲| 在线观看免费一区| 精品少妇一区二区三区免费观看 | 成+人+亚洲+综合天堂| 欧美三级日韩三级| 国产午夜精品一区二区三区嫩草| 亚洲激情在线激情| 国内精品自线一区二区三区视频| a在线欧美一区| 精品对白一区国产伦| 亚洲精品乱码久久久久久久久| 天堂成人免费av电影一区| 成人黄色软件下载| 欧美va亚洲va香蕉在线| 一区二区三区国产精品| 国产91精品久久久久久久网曝门| 欧美日韩精品电影| 亚洲欧美中日韩| 国产美女久久久久|