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

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

?? kernel.cpp

?? cvm的c語言版
?? CPP
?? 第 1 頁 / 共 4 頁
字號:
      result += mylambda*att_x[pos_x++].att*att_y[pos_y++].att;    }    else if(att_x[pos_x].index < att_y[pos_y].index){      pos_x++;    }    else{      pos_y++;    };  };  return result;};void kernel_exponential_c::input(istream& data_stream){  // read comments and parameters until next @  char next = data_stream.peek();  if(next == EOF){     // set stream to eof    next = data_stream.get();   };  int ok_lambda=0;  char* s = new char[MAXCHAR];  while((! data_stream.eof()) && (next != '@')){    if('#' == next){      // ignore comment      data_stream.getline(s,MAXCHAR);    }    else if('\n' == next){      // ignore line-end      next = data_stream.get();    }    else{      // trying to read in parameter      data_stream >> s;      if(0 == strcmp("lambda",s)){	data_stream >> lambda;	ok_lambda = 1;      }      else{	cout<<"Ignoring unknown parameter: "<<s<<endl;      };      data_stream.getline(s,MAXCHAR);    };    next = data_stream.peek();    if(next == EOF){       // set stream to eof      next = data_stream.get();     };  };  if(!ok_lambda){    throw read_exception("The parameters did not contain a valid description of an exponential kernel.");  };  delete []s;};void kernel_exponential_c::output(ostream& data_stream) const{  data_stream<<"type exponential"<<endl;  data_stream<<"lambda "<<lambda<<endl;};/* * * * kernel_aggregation_c : kernels, that consist of some other kernels * */kernel_aggregation_c::kernel_aggregation_c(){  number_elements = 0;  elements = 0;  from = 0;  to = 0;  new_x.example = 0;  new_y.example = 0;};kernel_aggregation_c::~kernel_aggregation_c(){  if(number_elements > 0){    delete []elements;    elements = 0;    delete []from;    from = 0;    delete[] to;    to = 0;    number_elements = 0;  };  if(new_x.example){ delete []new_x.example; };  if(new_y.example){ delete []new_y.example; };};void kernel_aggregation_c::init(SVMINT new_cache_MB,example_set_c* new_examples){  kernel_c::init(new_cache_MB,new_examples);  SVMINT i;  for(i=0;i<number_elements;i++){    (elements[i])->init(0,new_examples);    (elements[i])->dim = to[i]-from[i];  };  new_x.example = new svm_attrib[dim];  new_y.example = new svm_attrib[dim];};void kernel_aggregation_c::input(istream& data_stream){  // read comments and parameters until next @  // WARNING: no checks of the input values are performed  char next = data_stream.peek();  if(next == EOF){     // set stream to eof    next = data_stream.get();   };  char* s = new char[MAXCHAR];  SVMINT parts_read=0;  while((! data_stream.eof()) && (next != '@')){    if('#' == next){      // ignore comment      data_stream.getline(s,MAXCHAR);    }    else if(('\n' == next) ||	    (' ' == next) ||	    ('\r' == next) ||	    ('\f' == next) ||	    ('\t' == next)){      // ignore line-end      next = data_stream.get();    }    else{      // trying to read in parameter      data_stream >> s;      if(0 == strcmp("number_parts",s)){	if(number_elements>0){	  throw read_exception("Parameter 'number_parts' cannot be defined twice.");	};	data_stream >> number_elements;	if(number_elements<=0){	  throw read_exception("Invalid value for parameter 'number_parts'.");	};	elements = new kernel_c*[number_elements];	from = new SVMINT[number_elements];	to = new SVMINT[number_elements];      }      else if(0==strcmp("range",s)){	if(parts_read<number_elements){	  data_stream >> from[parts_read];	  from[parts_read]--;	  data_stream >> to[parts_read];	  parts_read++;	}	else{	  throw read_exception("too much ranges defined in aggregation kernel or 'number_parts' not given.");	};      }      else{	throw read_exception("Unknown parameter in aggregation kernel.");      };      data_stream.getline(s,MAXCHAR); // ignore rest of line    };    next = data_stream.peek();    if(next == EOF){       // set stream to eof      next = data_stream.get();     };  };  if(!data_stream.eof()){    kernel_container_c cont;    SVMINT i;    for(i=0;i<number_elements;i++){      // next line should be "@kernel"      data_stream >> s;      if(0==strcmp("@kernel",s)){	data_stream.getline(s,MAXCHAR); // ignore rest of line	data_stream >> cont;	elements[i] = cont.get_kernel();	cont.clear();      }      else{	throw read_exception("Could not find enough kernel parts for aggregation kernel.");      };    };  };  delete []s;};void kernel_aggregation_c::output_aggregation(ostream& data_stream) const{  data_stream<<"number_parts "<<number_elements<<endl;  SVMINT i;  for(i=0;i<number_elements;i++){    data_stream<<"range "	       <<(from[i]+1)  // inner format: [from,to[, starting at 0                              // io format:    [from,to], starting at 1	       <<" "<<to[i]<<endl;  };  for(i=0;i<number_elements;i++){    data_stream<<"@kernel"<<endl	       <<"# "<<(i+1)<<". part of aggregation kernel"<<endl;    (elements[i])->output(data_stream);  };};void kernel_aggregation_c::output(ostream& data_stream)const{  data_stream<<"type aggregation"<<endl;  output_aggregation(data_stream);};SVMFLOAT kernel_aggregation_c::calculate_K(const svm_example x, const svm_example y){  SVMFLOAT result=0;  //  svm_example  new_x = x;  //  svm_example new_y = y;  SVMINT start;  SVMINT stop;  SVMINT count;  for(SVMINT i=0;i<number_elements;i++){    // find matching part of x and y    start=0;    while((start<x.length) && (((x.example)[start]).index < from[i])){      start++;    };    //    new_x.example = x.example + start;    stop=start;    count=0;    while((stop<x.length) && (((x.example)[stop]).index < to[i])){      (new_x.example)[count] = (x.example)[stop];      ((new_x.example)[count]).index -= from[i];       //      cout<<"x: "<<((new_x.example)[count]).index<<" --> "<<((new_x.example)[count]).att<<endl;      count++;      stop++;    };    new_x.length = stop-start;    start=0;    while((start<y.length) && (((y.example)[start]).index < from[i])){      start++;    };    //    new_y.example = y.example + start;    stop=start;    count=0;    while((stop<y.length) && (((y.example)[stop]).index < to[i])){      (new_y.example)[count] = (y.example)[stop];      ((new_y.example)[count]).index -= from[i];       //      cout<<"y: "<<((new_y.example)[count]).index<<" --> "<<((new_y.example)[count]).att<<endl;      count++;      stop++;    };    new_y.length = stop-start;    // default ist sum-kernel    result += (elements[i])->calculate_K(new_x,new_y);  };  //  exit(1);  return result;};/* * * * kernel_prod_aggregation_c : kernel, that consist of the  *                             prodcut of some other kernels * */kernel_prod_aggregation_c::kernel_prod_aggregation_c(){  number_elements = 0;  elements = 0;  from = 0;  to = 0;  new_x.example = 0;  new_y.example = 0;};kernel_prod_aggregation_c::~kernel_prod_aggregation_c(){  if(number_elements > 0){    delete []elements;    elements = 0;    delete []from;    from = 0;    delete[] to;    to = 0;    number_elements = 0;  };  if(new_x.example){ delete []new_x.example; };  if(new_y.example){ delete []new_y.example; };};void kernel_prod_aggregation_c::output(ostream& data_stream)const{  data_stream<<"type prod_aggregation"<<endl;  output_aggregation(data_stream);};SVMFLOAT kernel_prod_aggregation_c::calculate_K(const svm_example x, const svm_example y){  SVMFLOAT result=1;  //  svm_example new_x = x;  //  svm_example new_y = y;  SVMINT start;  SVMINT stop;  SVMINT count;  SVMINT i;  for(i=0;i<number_elements;i++){    // find matching part of x and y    start=0;    while((start<x.length) && (((x.example)[start]).index < from[i])){      start++;    };    //    new_x.example = x.example + start;    stop=start;    count=0;    while((stop<x.length) && (((x.example)[stop]).index < to[i])){      (new_x.example)[count] = (x.example)[stop];      ((new_x.example)[count]).index -= from[i];       count++;      stop++;    };    new_x.length = stop-start;    start=0;    while((start<y.length) && (((y.example)[start]).index < from[i])){      start++;    };    //    new_y.example = y.example + start;    stop=start;    count = 0;    while((stop<y.length) && (((y.example)[stop]).index < to[i])){      (new_y.example)[count] = (y.example)[stop];      ((new_y.example)[count]).index -= from[i];       count++;      stop++;    };    new_y.length = stop-start;    // default ist sum-kernel    result *= (elements[i])->calculate_K(new_x,new_y);  };  return result;};/* * * kernel_fourier_c: Kernel generating fourier expansions * */kernel_fourier_c::kernel_fourier_c(){  N = 1;};void kernel_fourier_c::input(istream& data_stream){    // read comments and parameters until next @  char next = data_stream.peek();  if(next == EOF){     // set stream to eof    next = data_stream.get();   };  int ok=0;  char* s = new char[MAXCHAR];  while((! data_stream.eof()) && (next != '@')){    if('#' == next){      // ignore comment      data_stream.getline(s,MAXCHAR);    }    else if('\n' == next){      // ignore line-end      next = data_stream.get();    }    else{      // trying to read in parameter      data_stream >> s;      if((0 == strcmp("n",s)) || 	 (0 == strcmp("N",s))){	data_stream >> N;	ok = 1;      }      else{	cout<<"Ignoring unknown parameter: "<<s<<endl;      };      data_stream.getline(s,MAXCHAR);    };    next = data_stream.peek();    if(next == EOF){       // set stream to eof      next = data_stream.get();     };  };  if(! ok){    throw read_exception("The parameters did not contain a valid description of a fourier kernel.");  };  delete []s;};void kernel_fourier_c::output(ostream& data_stream) const{  data_stream<<"type fourier"<<endl;  data_stream<<"N "<<N<<endl;};  SVMFLOAT kernel_fourier_c::calculate_K(const svm_example x, const svm_example y){  SVMFLOAT result=1;    SVMINT length_x = x.length;  SVMINT length_y = y.length;  svm_attrib* att_x = x.example;  svm_attrib* att_y = y.example;  SVMINT pos_x=0;  SVMINT pos_y=0;  SVMINT zeros=dim;  SVMFLOAT diff;  SVMFLOAT dummy;  while((pos_x < length_x) && (pos_y < length_y)){    if(att_x[pos_x].index == att_y[pos_y].index){      diff = att_x[pos_x++].att-att_y[pos_y++].att;    }    else if(att_x[pos_x].index < att_y[pos_y].index){      diff = att_x[pos_x++].att;    }    else{      diff = -att_y[pos_y++].att;    };    dummy = sin(diff/2);    if(0 == dummy){      dummy = 1/2+(SVMFLOAT)N;    }    else{      dummy = sin((2*(SVMFLOAT)N+1)/2*diff) / dummy;    };    result *= dummy;    zeros--;  };  while(pos_x < length_x){    diff = att_x[pos_x++].att;    dummy = sin(diff/2);    if(0 == dummy){      dummy = 1/2+(SVMFLOAT)N;    }    else{      dummy = sin((2*(SVMFLOAT)N+1)/2*diff) / dummy;    };    result *= dummy;    zeros--;  };  while(pos_y < length_y){    diff = att_y[pos_y++].att;    dummy = sin(diff/2);    if(0 == dummy){      dummy = 1/2+(SVMFLOAT)N;    }    else{      dummy = sin((2*(SVMFLOAT)N+1)/2*diff) / dummy;    };    result *= dummy;    zeros--;  };  SVMINT i;  for(i=0;i<zeros;i++){    result *=  1/2+(SVMFLOAT)N;  };  return result;};/* * * kernel_reg_fourier_c: Kernel generating regularized fourier expansions * */kernel_reg_fourier_c::kernel_reg_fourier_c(){  q = 0.5;};void kernel_reg_fourier_c::input(istream& data_stream){    // read comments and parameters until next @  char next = data_stream.peek();  if(next == EOF){     // set stream to eof    next = data_stream.get();   };  int ok=0;  char* s = new char[MAXCHAR];  while((! data_stream.eof()) && (next != '@')){    if('#' == next){      // ignore comment      data_stream.getline(s,MAXCHAR);    }    else if('\n' == next){      // ignore line-end      next = data_stream.get();    }    else{      // trying to read in parameter      data_stream >> s;      if((0 == strcmp("q",s)) || 	 (0 == strcmp("Q",s))){	data_stream >> q;	if((q>0) && (q<1)){	  ok = 1;	};      }      else{	cout<<"Ignoring unknown parameter: "<<s<<endl;      };      data_stream.getline(s,MAXCHAR);    };    next = data_stream.peek();    if(next == EOF){       // set stream to eof      next = data_stream.get();     };  };  if(! ok){    throw read_exception("The parameters did not contain a valid description of a regularized fourier kernel.");  };  delete []s;};void kernel_reg_fourier_c::output(ostream& data_stream) const{  data_stream<<"type reg_fourier"<<endl;  data_stream<<"q "<<q<<endl;};  SVMFLOAT kernel_reg_fourier_c::calculate_K(const svm_example x, const svm_example y){  SVMFLOAT result=1;    SVMINT length_x = x.length;  SVMINT length_y = y.length;  svm_attrib* att_x = x.example;  svm_attrib* att_y = y.example;  SVMINT pos_x=0;  SVMINT pos_y=0;  SVMINT zeros=dim;  SVMFLOAT diff;  SVMFLOAT q2 = q*q;  while((pos_x < length_x) && (pos_y < length_y)){    if(att_x[pos_x].index == att_y[pos_y].index){      diff = att_x[pos_x++].att-att_y[pos_y++].att;    }    else if(att_x[pos_x].index < att_y[pos_y].index){      diff = att_x[pos_x++].att;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩中文另类| 一区二区三区中文在线| 精品国产一区二区三区不卡 | 久久福利资源站| 丝袜美腿亚洲一区二区图片| 亚洲成精国产精品女| 午夜私人影院久久久久| 五月综合激情网| 天堂影院一区二区| 麻豆国产91在线播放| 蜜乳av一区二区| 国产一区二三区好的| 国产精品一区二区三区网站| 国产精品一区不卡| 成人av电影在线观看| 91福利在线导航| 欧美日韩不卡在线| 欧美一区二区三区人| 精品国产免费人成在线观看| 久久视频一区二区| 国产精品久久久久影院亚瑟 | av中文一区二区三区| 色综合激情久久| 欧美日本国产一区| 欧美成人在线直播| 国产亚洲短视频| 亚洲美女在线一区| 丝袜亚洲另类丝袜在线| 国产一区二区三区精品视频 | 久久婷婷一区二区三区| 亚洲国产精华液网站w| 亚洲精品国产a| 久久精品国产一区二区| 成人一区二区视频| 欧美综合一区二区| 欧美不卡在线视频| 最新久久zyz资源站| 亚洲国产欧美日韩另类综合| 精彩视频一区二区三区| 成人夜色视频网站在线观看| 91豆麻精品91久久久久久| 5858s免费视频成人| 中文字幕欧美激情一区| 亚洲一二三四久久| 国产一区二区三区综合| 欧美性受xxxx黑人xyx| 久久夜色精品国产噜噜av| 最新中文字幕一区二区三区| 奇米影视在线99精品| 成人自拍视频在线| 欧美一二三区在线观看| 日韩毛片一二三区| 九九在线精品视频| 欧美性猛片aaaaaaa做受| 久久亚洲影视婷婷| 五月激情六月综合| 99re这里只有精品视频首页| 欧美大胆一级视频| 一个色妞综合视频在线观看| 国产成人免费高清| 91精品国产综合久久福利| 中文字幕一区二区三区四区不卡 | 欧美疯狂性受xxxxx喷水图片| 国产三级欧美三级日产三级99 | 91九色最新地址| 久久久久99精品国产片| 亚洲成人综合在线| 99久久伊人精品| 精品不卡在线视频| 亚洲电影在线免费观看| eeuss鲁片一区二区三区| 久久综合av免费| 天天色综合成人网| 一本大道av伊人久久综合| 中文字幕欧美日本乱码一线二线 | 91麻豆精品秘密| 国产日韩欧美精品电影三级在线| 日韩电影在线一区二区| 色天天综合色天天久久| 中文字幕成人在线观看| 国产麻豆视频精品| 日韩一级精品视频在线观看| 午夜电影一区二区| 91久久线看在观草草青青| 国产精品视频观看| 国模一区二区三区白浆| 欧美一区二区视频观看视频| 香蕉乱码成人久久天堂爱免费| 91日韩精品一区| 国产精品不卡在线观看| 国产精品亚洲综合一区在线观看| 精品久久久久久无| 青青草精品视频| 欧美高清视频不卡网| 午夜久久电影网| 欧美日韩国产美| 午夜视频久久久久久| 欧美亚洲一区三区| 亚洲人成伊人成综合网小说| 91在线免费播放| 亚洲免费观看在线视频| 91丨九色丨蝌蚪富婆spa| 亚洲欧洲精品成人久久奇米网| av中文字幕不卡| 亚洲精品乱码久久久久久久久| 一本一道久久a久久精品| 亚洲欧美aⅴ...| 91精品办公室少妇高潮对白| 亚洲乱码国产乱码精品精可以看| 91国产视频在线观看| 亚洲一区中文日韩| 欧美亚洲动漫另类| 首页国产丝袜综合| 欧美一区国产二区| 蜜桃精品视频在线| 久久久久久久久岛国免费| 国产成人午夜高潮毛片| 日本一区免费视频| 99精品视频在线免费观看| 亚洲日本成人在线观看| 欧美影视一区在线| 亚洲成人一二三| 日韩精品中文字幕一区| 国产精品中文有码| 亚洲视频在线观看三级| 欧美性大战久久久久久久蜜臀| 性做久久久久久久久| 精品国免费一区二区三区| 国产精品88888| 亚洲精品乱码久久久久久| 欧美精品自拍偷拍动漫精品| 精品一区二区在线看| 国产精品午夜电影| 欧美视频在线不卡| 另类小说视频一区二区| 国产精品伦理在线| 精品视频一区三区九区| 九九九精品视频| 国产精品久99| 欧美精品色综合| 国产精品自拍三区| 一区二区三区日韩欧美| 日韩欧美精品三级| 99国产精品国产精品毛片| 午夜视频一区二区| 国产精品午夜在线观看| 欧美久久久久久蜜桃| 懂色av一区二区三区免费观看 | 在线免费观看日本一区| 久久国产三级精品| 亚洲欧美偷拍卡通变态| 日韩三级电影网址| 色综合天天在线| 久久9热精品视频| 亚洲精品美腿丝袜| 日韩精品一区二区三区视频| 91蜜桃婷婷狠狠久久综合9色| 黄色成人免费在线| 一区二区成人在线视频| 国产三级一区二区三区| 5月丁香婷婷综合| 一本久久a久久免费精品不卡| 韩国在线一区二区| 亚洲电影一区二区三区| 国产日产欧美精品一区二区三区| 久久综合色天天久久综合图片| 91久久线看在观草草青青| 国产一区二区三区在线观看免费视频 | 国产精品色婷婷| 91精品国产手机| 91福利在线导航| 成人精品免费视频| 蜜桃av噜噜一区| 亚洲成人av免费| 亚洲欧美日韩国产综合| 国产亚洲综合色| 日韩午夜av一区| 欧美日韩精品免费| 色综合天天性综合| 成人国产精品免费| 国产乱理伦片在线观看夜一区| 日韩在线一区二区三区| 一区二区激情小说| 亚洲人成小说网站色在线| 国产精品视频一二三| 精品国产99国产精品| 制服丝袜成人动漫| 欧美色倩网站大全免费| 99v久久综合狠狠综合久久| 国产精品一区免费在线观看| 久久精品国产亚洲高清剧情介绍| 丝袜亚洲另类丝袜在线| 亚洲电影在线免费观看| 一区二区三区免费| 亚洲啪啪综合av一区二区三区| 中文字幕成人av| 中文乱码免费一区二区| 国产亚洲欧美一区在线观看| 久久综合久色欧美综合狠狠| 精品人伦一区二区色婷婷|