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

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

?? kozinec.c~

?? 一個工具包
?? C~
字號:
/*-----------------------------------------------------------------------
 Kozinec's algorithm for separable single-class SVM problem.

 int single_kozinec(TKerFun ker,
             long num_data,
             long tmax,
             double tolabs,
             double tolrel,
             double *Alpha,
             double *UB,
             double *LB,
             long *t,
             double *History)

 tmax, tolabs, tolrel ... Define stopping conditions: 

    UB <= tolabs              ->  exit_flag = 1   Abs. tolerance.
    (UB-LB)/(LB+1) <= tolrel  ->  exit_flag = 2   Relative tolerance.
    t >= tmax                 ->  exit_flag = 0   Number of iterations.
 
 Alpha ... Lagrangians defining found decision rule. 
 UB ... Achieved upper bound on the optimal solution.
 LB ... Achieved lower bound on the optimal solution.
 t  ... Number of iterations.
 History ... Value of LB and UB wrt. number of iterations.

 Modifications:
 22-Jan-2004, VF
 14-Oct-2003, VF
-------------------------------------------------------------------- */

#include "mex.h"
#include "matrix.h"
#include <math.h>
#include <stdlib.h>
#include <string.h>
#include <limits.h>

#define HISTORY_BUF 1000000

#define MINUS_INF INT_MIN
#define PLUS_INF  INT_MAX

#define ABS(A) ((A >= 0) ? A : -A)
#define MIN(A,B) ((A < B) ? A : B)
#define INDEX(ROW,COL,DIM) ((COL*DIM)+ROW)

/* ==============================================================
 Kernel Kozinec's algorithm.
============================================================== */

int single_kozinec(const double (*kernel_fce)(long, long),
            long num_data, 
            long tmax,
            double tolabs,
            double tolrel,
            double **out_Alpha,
            double *out_UB,
            double *out_LB,
            long  *out_t,
            double **out_History)
{
  double *Alpha;
  double *History;
  double LB;
  double UB2;
  double tmp;
  double kernel_diag;
  double *ProjX;
  double *K_Diag;
  double lambda;
  double *tmp_ptr;
  long min_inx;
  long new_min_inx;
  long i;
  long t;
  long History_size;
  int exitflag;

  /* allocate memory */
  Alpha = mxCalloc(num_data, sizeof(double));
  if( Alpha == NULL ) mexErrMsgTxt("Not enough memory.");

  ProjX = mxCalloc(num_data, sizeof(double));
  if( ProjX == NULL ) mexErrMsgTxt("Not enough memory.");

  K_Diag = mxCalloc(num_data, sizeof(double));
  if( K_Diag == NULL ) mexErrMsgTxt("Not enough memory.");

  History_size = (tmax < HISTORY_BUF ) ? tmax+1 : HISTORY_BUF;
  History = mxCalloc(History_size*2,sizeof(double));
  if( History == NULL ) mexErrMsgTxt("Not enough memory.");
  
  /* == inicialization == */
  for( LB =  PLUS_INF, i = 0; i < num_data; i++ ) 
  {
    Alpha[i] = 0;

    ProjX[i] = kernel_fce( 0, i );

    K_Diag[i] = kernel_fce( i, i );

    if( ProjX[i] < LB ) {
      LB = ProjX[i];
      min_inx = i;
    }
  }

  UB2 = K_Diag[0];
  LB = LB/sqrt(UB2);
  Alpha[0] = 1;
  t = 0;
  History[INDEX(0,0,2)] = LB;
  History[INDEX(1,0,2)] = sqrt(UB2);

  if( sqrt(UB2) <= tolabs ) exitflag = 1;
  else if((sqrt(UB2)-LB)/(ABS(LB)+1) <= tolrel ) exitflag = 2;
  else exitflag = -1;

  /* == Main cycle == */

  while( exitflag == -1 ) 
  {
    t++;     
    
    /* Adaptation rule and update */
    lambda = (UB2 - ProjX[min_inx])/(UB2 - 2*ProjX[min_inx] + K_Diag[min_inx]);
    lambda = MIN( lambda, 1);

    UB2 = UB2*(1-lambda)*(1-lambda) + 
          2*lambda*(1-lambda)*ProjX[min_inx]+
          lambda*lambda*K_Diag[min_inx];

    LB = PLUS_INF;
    for( i = 0; i < num_data; i++ ) 
    {
       if( Alpha[i] != 0) Alpha[i] = Alpha[i]*(1-lambda);
       ProjX[i] = ProjX[i]*(1-lambda) + lambda*kernel_fce(i,min_inx);

       if( ProjX[i] < LB ) 
       { 
         LB = ProjX[i];
         new_min_inx = i;
       }
    }    
    
    LB = LB/sqrt(UB2);
    Alpha[min_inx] = Alpha[min_inx] + lambda;
    min_inx = new_min_inx;    

    /* Stopping conditions */
    if( sqrt(UB2) <= tolabs ) exitflag = 1; 
    else if( ((sqrt(UB2)-LB)/(ABS(LB)+1)) <= tolrel ) exitflag = 2; 
    else if(t >= tmax) exitflag = 0; 

    /* Store lower and upper bounds */
    if( t < History_size ) {
      History[INDEX(0,t,2)] = LB;
      History[INDEX(1,t,2)] = sqrt(UB2);
    }
    else {
      tmp_ptr = mxCalloc((History_size+HISTORY_BUF)*2,sizeof(double));
      if( tmp_ptr == NULL ) mexErrMsgTxt("Not enough memory.");
      for( i = 0; i < History_size; i++ ) {
        tmp_ptr[INDEX(0,i,2)] = History[INDEX(0,i,2)];
        tmp_ptr[INDEX(1,i,2)] = History[INDEX(1,i,2)];
      }
      tmp_ptr[INDEX(0,t,2)] = LB;
      tmp_ptr[INDEX(1,t,2)] = sqrt(UB2);
      
      History_size += HISTORY_BUF;
      mxFree( History );
      History = tmp_ptr;
    }
  }

  /* transform Alphas to obtain canonical hyperplane representation */
  for( i = 0; i < num_data; i++ ) {
    Alpha[i] = Alpha[i] / (LB*sqrt(UB2));
  }

  /* outputs */
  (*out_Alpha) = Alpha;
  (*out_UB) = sqrt(UB2);
  (*out_LB) = LB;
  (*out_t) = t;
  (*out_History) = History;

  /**/
  mxFree( ProjX );
  mxFree( K_Diag );

  return( exitflag ); 
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲人成网站在线| 麻豆91在线看| 中文字幕在线观看一区二区| 欧美一区二区免费视频| 欧美影院一区二区三区| 色一情一乱一乱一91av| 国产综合久久久久久鬼色| 五月激情综合网| 亚洲综合999| 亚洲精品日韩一| 亚洲精品视频在线观看免费| 1024精品合集| 日韩理论电影院| 亚洲国产成人私人影院tom| 精品日产卡一卡二卡麻豆| 久久草av在线| 美女mm1313爽爽久久久蜜臀| 亚洲va国产va欧美va观看| 亚洲香蕉伊在人在线观| 国产精品久久久久久久久免费樱桃| 久久久综合精品| 欧美精品一区视频| 久久久精品中文字幕麻豆发布| 久久一区二区三区四区| 国产午夜精品一区二区三区嫩草| 日韩欧美色综合| 日韩精品中文字幕一区二区三区 | 国产香蕉久久精品综合网| 欧美一区二区视频在线观看| 欧美一级在线观看| 日韩视频在线一区二区| 日韩精品最新网址| 久久影视一区二区| 中文字幕欧美日韩一区| 中文字幕一区二区三区视频| 亚洲美女免费在线| 亚洲一区二区高清| 视频一区二区不卡| 美国三级日本三级久久99| 天天操天天色综合| 精品一区二区成人精品| 国产精品一二二区| 91在线丨porny丨国产| 欧美在线一二三四区| 日韩视频一区二区三区在线播放| 欧美videossexotv100| 国产欧美一区二区三区在线老狼| 中文字幕在线免费不卡| 午夜影视日本亚洲欧洲精品| 六月丁香婷婷久久| 成人午夜激情影院| 色婷婷国产精品久久包臀| 欧美军同video69gay| 久久欧美中文字幕| 亚洲免费观看高清完整版在线观看 | 欧美高清激情brazzers| 精品日本一线二线三线不卡| 国产精品乱人伦中文| 亚洲妇女屁股眼交7| 精品一区二区三区不卡| 国产精品自产自拍| 91福利在线播放| 精品国产乱码久久久久久影片| 国产视频视频一区| 亚洲综合一区二区| 国产一区激情在线| 日本韩国精品在线| 久久先锋影音av鲁色资源网| 亚洲美女区一区| 日韩av网站在线观看| 成人av在线电影| 欧美精品xxxxbbbb| 中文字幕av资源一区| 日韩经典中文字幕一区| 精品一区二区免费看| 欧美唯美清纯偷拍| 国产日韩亚洲欧美综合| 午夜激情一区二区| 99久久精品久久久久久清纯| 日韩精品一区二区三区视频 | 日韩精品最新网址| 一区二区三区自拍| 国内外精品视频| 欧美在线免费视屏| 国产精品区一区二区三区| 蜜臀99久久精品久久久久久软件| 99久久综合国产精品| 91麻豆精品91久久久久同性| 国产精品久久久久一区二区三区共| 日本伊人色综合网| 日本精品视频一区二区三区| 国产欧美日韩三区| 一区二区视频在线看| 不卡的电影网站| 精品少妇一区二区三区视频免付费 | 亚洲高清免费一级二级三级| 99热精品国产| 国产欧美一二三区| 国产在线精品一区二区不卡了 | 久久99久久精品| 欧美日韩在线电影| 午夜精品久久久久影视| 欧美日韩精品一区二区三区| 一二三四社区欧美黄| 欧美三级视频在线观看| 亚洲一区二区三区爽爽爽爽爽| 色又黄又爽网站www久久| 一区二区三区在线视频免费| 日本道在线观看一区二区| 亚洲午夜私人影院| 欧美精品三级日韩久久| 全部av―极品视觉盛宴亚洲| 欧美大胆一级视频| 国产中文字幕精品| 欧美国产激情一区二区三区蜜月| 国产成人av影院| 日韩理论片在线| 欧美揉bbbbb揉bbbbb| 天天做天天摸天天爽国产一区 | 轻轻草成人在线| 日韩欧美国产三级电影视频| 激情综合亚洲精品| 欧美国产综合色视频| 91影视在线播放| 亚洲成av人片在线观看无码| 欧美一区二区三区在线视频| 国产一区二区三区香蕉| 中文字幕一区二区三区蜜月| 欧美手机在线视频| 麻豆精品一区二区| 国产肉丝袜一区二区| 91老师国产黑色丝袜在线| 亚洲综合偷拍欧美一区色| 日韩一卡二卡三卡国产欧美| 国产一区二区在线免费观看| 亚洲手机成人高清视频| 7777精品伊人久久久大香线蕉经典版下载 | 日韩电影免费在线观看网站| 久久久久久久久蜜桃| 色婷婷亚洲综合| 裸体健美xxxx欧美裸体表演| 国产精品欧美经典| 欧美日韩一区不卡| 国产精品一区二区免费不卡| 亚洲欧美日韩国产一区二区三区| 91精品国产综合久久精品| 成人午夜短视频| 日韩va欧美va亚洲va久久| 国产欧美一区二区在线| 欧美日韩一本到| 国产成人福利片| 三级影片在线观看欧美日韩一区二区| 久久久久久久久久久电影| 一本一本大道香蕉久在线精品| 美女视频黄 久久| 亚洲欧美日韩电影| 久久影音资源网| 欧美日韩高清一区| 国产激情视频一区二区三区欧美| 玉米视频成人免费看| 久久久精品人体av艺术| 欧美主播一区二区三区美女| 风流少妇一区二区| 蜜臀av一区二区在线观看| 亚洲欧美综合网| 精品国精品国产尤物美女| 欧美专区日韩专区| 成人av中文字幕| 国内精品嫩模私拍在线| 五月天国产精品| 亚洲欧美日韩综合aⅴ视频| 久久久久久久综合| 欧美一卡2卡三卡4卡5免费| 91丨porny丨中文| 寂寞少妇一区二区三区| 日韩在线a电影| 亚洲精品中文字幕乱码三区| 国产日产欧美精品一区二区三区| 欧美卡1卡2卡| 欧美视频中文字幕| 91丨九色丨蝌蚪丨老版| 成人丝袜高跟foot| 国模大尺度一区二区三区| 日本aⅴ免费视频一区二区三区| 樱花影视一区二区| 亚洲女与黑人做爰| 国产精品欧美久久久久无广告 | 国产精品久久久久永久免费观看 | 九色综合狠狠综合久久| 亚洲va欧美va人人爽| 亚洲黄色小视频| 亚洲精品视频在线| 综合久久国产九一剧情麻豆| 欧美激情自拍偷拍| 久久久久久久网| 久久亚洲影视婷婷| 欧美成人aa大片| 2020国产精品| 2023国产精华国产精品| 2021中文字幕一区亚洲|