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

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

?? svm_c.cpp

?? mySvm的最新源程序
?? CPP
?? 第 1 頁 / 共 4 頁
字號:
  examples->set_initialised_alpha();  parameters->working_set_size = param_wss;  return the_result;};void svm_c::shrink(){  // move shrinked examples to back  if(to_shrink>examples_total/10){    SVMINT i;    SVMINT last_pos=examples_total;    if(last_pos > working_set_size){	for(i=0;i<last_pos;i++){	    if(at_bound[i] >= shrink_const){		// shrinxk i		sum_alpha += all_alphas[i];		last_pos--;		examples->swap(i,last_pos);		kernel->overwrite(i,last_pos);		sum[i] = sum[last_pos];		at_bound[i] = at_bound[last_pos];		if(last_pos <= working_set_size){		    break;		};	    };	};	to_shrink=0;	examples_total = last_pos;	kernel->set_examples_size(examples_total);    };    if(parameters->verbosity>=4){      cout<<"shrinked to "<<examples_total<<" variables"<<endl;    };  };};int svm_c::convergence(){  long time_start = get_time();  SVMFLOAT the_lambda_eq = 0;  SVMINT total = 0;  SVMFLOAT alpha_sum=0;  SVMFLOAT alpha=0;  SVMINT i;  int result=1;  // actual convergence-test  total = 0; alpha_sum=0;  if(biased){    // calc lambda_eq    for(i=0;i<examples_total;i++){      alpha = all_alphas[i];      alpha_sum += alpha;      if((alpha>is_zero) && (alpha < Cneg)){ //-Cneg < -is_zero)){	// alpha^* = - nabla	the_lambda_eq += -nabla(i); //all_ys[i]-epsilon_neg-sum[i];	total++;      }      else if((alpha<-is_zero) && (alpha > -Cpos)){ //+Cpos > is_zero)){	// alpha = nabla	the_lambda_eq += nabla(i); //all_ys[i]+epsilon_pos-sum[i];	total++;      };    };        if(parameters->verbosity >= 4){      cout<<"lambda_eq = "<<(the_lambda_eq/total)<<endl;    };    if(total>0){      lambda_eq = the_lambda_eq / total;    }    else{      // keep WS lambda_eq      lambda_eq = lambda_WS; //(lambda_eq+4*lambda_WS)/5;      if(parameters->verbosity>= 4){	cout<<"*** no SVs in convergence(), lambda_eq = "<<lambda_eq<<"."<<endl;      };    };        if(target_count>2){      // estimate lambda from WS      if(target_count>20){	// desperate!	lambda_eq = ((40-target_count)*lambda_eq + (target_count-20)*lambda_WS)/20;	if(parameters->verbosity>=5){	  cout<<"Re-Re-calculated lambda from WS: "<<lambda_eq<<endl;	};	if(target_count>40){	  // really desperate, kick one example out!	  i = working_set[target_count%working_set_size];	  if(is_alpha_neg(i) > 0){	    lambda_eq = -nabla(i);	  }	  else{	    lambda_eq = nabla(i);	  };	  if(parameters->verbosity>=5){	    cout<<"set lambda_eq to nabla("<<i<<"): "<<lambda_eq<<endl;	  };	};      }      else{	lambda_eq = lambda_WS;	if(parameters->verbosity>=5){	  cout<<"Re-calculated lambda_eq from WS: "<<lambda_eq<<endl;	};      };    };    // check linear constraint    if(abs(alpha_sum+sum_alpha) > convergence_epsilon){      // equality constraint violated      project_to_constraint();      if(parameters->verbosity>= 4){	cout<<"No convergence: equality constraint violated: |"<<(alpha_sum+sum_alpha)<<"| >> 0"<<endl;      };      result = 0;      };  }  else{    // not biased    lambda_eq = 0.0;  };  i=0;  while(i<examples_total){    if(lambda(i)>=-convergence_epsilon){      i++;    }    else{      result = 0;      break;    };  };  time_convergence += get_time() - time_start;  return result;};void svm_c::minheap_heapify(SVMINT start, SVMINT size){  // build heap of array working_set[start:start+size-1]  // (i.e. "size" elements starting at "start"th element)  // minheap = 1 <=> maximal element at root   // (i.e. we build the heap of minimal elements)  // v_a[i] = w_s_v[start-1+i], count beginning at 1  SVMFLOAT* value_array = working_set_values+start-1;   SVMINT* pos_array = working_set+start-1;  int running = 1;  SVMINT pos = 1;  SVMINT left, right, largest;  SVMFLOAT dummyf;  SVMINT dummyi;  while(running){      left = 2*pos;      right = left+1;      if((left<=size) && 	 (value_array[left] > value_array[pos]))	largest = left;      else{	largest = pos;      };      if((right<=size) && 	 (value_array[right] > value_array[largest])){	largest = right;      };      if(largest == pos){	running = 0;      }      else{	//cout<<"switching "<<pos<<" and "<<largest<<endl;	dummyf = value_array[pos];	dummyi = pos_array[pos];	value_array[pos] = value_array[largest];	pos_array[pos] = pos_array[largest];	value_array[largest] = dummyf;	pos_array[largest] = dummyi;	pos = largest;      };  };};void svm_c::maxheap_heapify(SVMINT start, SVMINT size){  // build heap of array working_set[start:start+size-1]  // (i.e. "size" elements starting at "start"th element)  // minheap = 1 <=> maximal element at root   // (i.e. we build the heap of minimal elements)  // v_a[i] = w_s_v[start-1+i], count beginning at 1  SVMFLOAT* value_array = working_set_values+start-1;   SVMINT* pos_array = working_set+start-1;  int running = 1;  SVMINT pos = 1;  SVMINT left, right, largest;  SVMFLOAT dummyf;  SVMINT dummyi;  while(running){      left = 2*pos;      right = left+1;      if((left<=size) && 	 (value_array[left] < value_array[pos])){	largest = left;      }      else{	largest = pos;      };      if((right<=size) && 	 (value_array[right] < value_array[largest])){	  largest = right;      };      if(largest == pos){	running = 0;      }      else{	dummyf = value_array[pos];	dummyi = pos_array[pos];	value_array[pos] = value_array[largest];	pos_array[pos] = pos_array[largest];	value_array[largest] = dummyf;	pos_array[largest] = dummyi;	pos = largest;      };  };};SVMINT svm_c::maxheap_add(SVMINT size, const SVMINT element, const SVMFLOAT value){    if(size < (working_set_size/2+working_set_size%2)){	// add to max_heap	working_set_values[working_set_size/2+size] = value;	working_set[working_set_size/2+size] = element;	size++;	if(size == working_set_size/2+working_set_size%2){	    // build heap	    SVMINT j;	    for(j=size;j>0;j--){		maxheap_heapify(working_set_size/2+j-1,size+1-j);	    };	};    }    else if(value >= working_set_values[working_set_size/2]){	// replace min of max_heap	working_set_values[working_set_size/2] = value;	working_set[working_set_size/2] = element;	maxheap_heapify(working_set_size/2,size);    };    return size;};SVMINT svm_c::minheap_add(SVMINT size, const SVMINT element, const SVMFLOAT value){    if(size<working_set_size/2){	// add to min_heap	working_set_values[size] = value;	working_set[size] = element;	size++;	if(size == working_set_size/2){	    // build heap	    SVMINT j;	    for(j=size;j>0;j--){		minheap_heapify(j-1,size+1-j);	    };	};    }    else if(value < working_set_values[0]){	// replace max of min_heap	working_set_values[0] = value;	working_set[0] = element;	minheap_heapify(0,size);    };    return size;};void svm_c::calculate_working_set(){  /**   *   * Find top and bottom (w.r.t. in_alpha_neg*nabla) feasible    * variables for working_set   *   */  long time_start = get_time();  // reset WSS  if(working_set_size < parameters->working_set_size){    working_set_size=parameters->working_set_size;    if(working_set_size>examples_total) working_set_size = examples_total;  };  SVMINT heap_min=0;  SVMINT heap_max=0;  SVMINT i=0;  SVMFLOAT sort_value;  working_set_values[0] = infinity;  working_set_values[working_set_size/2] = -infinity;  SVMFLOAT the_lambda;  SVMFLOAT the_nabla;  int is_feasible;  int atbound;  SVMINT j;  while(i<examples_total) {    is_feasible = feasible(i,&the_nabla,&the_lambda,&atbound);    if(0 != is_feasible){      if(is_alpha_neg(i) > 0){	sort_value = -the_nabla;  // - : maximum inconsistency approach      }      else{	sort_value = the_nabla;      };      // add to heaps      heap_min = minheap_add(heap_min,i,sort_value);      heap_max = maxheap_add(heap_max,i,sort_value);    };    i++;  };  if(working_set_values[0] >= working_set_values[working_set_size/2]){    if((heap_min>0) &&       (heap_max>0)){      // there could be the same values in the min- and maxheap,      // sort them out (this is very unlikely)      j=0;      i=0;      while(i<heap_min){	// working_set[i] also in max-heap?        j=working_set_size/2;	while((j<working_set_size/2+heap_max) && 	      (working_set[j] != working_set[i])){	  j++;	};	if(j<working_set_size/2+heap_max){          // working_set[i] equals working_set[j]          if(heap_min<heap_max){            // remove j from WS	    working_set[j] = working_set[working_set_size/2-1+heap_max];	    heap_max--;	  }	  else{	    working_set[i] = working_set[heap_min-1];	    heap_min--;	  };	}	else{          i++;	};      };    };  };  if(heap_min+heap_max < working_set_size) {      // condense WS      for(i=0;i<heap_max;i++){	  working_set[heap_min+i] = working_set[working_set_size/2+i];      };      working_set_size = heap_min+heap_max;  };  //  if((working_set_size<examples_total) && (working_set_size>0)){  if(target_count>0){    // convergence error on last iteration?    // some more tests on WS    // unlikely to happen, so speed isn't so important    // are all variables at the bound?    SVMINT pos_abs;    int bounded_pos=1;    int bounded_neg=1;    SVMINT pos=0;    while((pos<working_set_size) && ((1 == bounded_pos) || (1 == bounded_neg))){      pos_abs = working_set[pos];      if(is_alpha_neg(pos_abs) > 0){	if(all_alphas[pos_abs]-Cneg < -is_zero){	  bounded_pos = 0;	};	if(all_alphas[pos_abs] > is_zero){	  bounded_neg = 0;	};      }      else{	if(all_alphas[pos_abs]+Cneg > is_zero){	  bounded_neg = 0;	};	if(all_alphas[pos_abs] < -is_zero){	  bounded_pos = 0;	};      };      pos++;    };    if(0 != bounded_pos){      // all alphas are at upper bound      // need alpha that can be moved upward      // use alpha with smallest lambda      SVMFLOAT max_lambda = infinity;      SVMINT max_pos=examples_total;      for(pos_abs=0;pos_abs<examples_total;pos_abs++){	if(is_alpha_neg(pos_abs) > 0){	  if(all_alphas[pos_abs]-Cneg < -is_zero){	    if(lambda(pos_abs) < max_lambda){	      max_lambda = lambda(pos_abs);	      max_pos = pos_abs;	    };	  };	}	else{	  if(all_alphas[pos_abs] < -is_zero){	    if(lambda(pos_abs) < max_lambda){	      max_lambda = lambda(pos_abs);	      max_pos = pos_abs;	    };	  };	};      };      if(max_pos<examples_total){	if(working_set_size<parameters->working_set_size){	  working_set_size++;	};	working_set[working_set_size-1] = max_pos;      };    }    else if(0 != bounded_neg){      // all alphas are at lower bound      // need alpha that can be moved downward      // use alpha with smallest lambda      SVMFLOAT max_lambda = infinity;      SVMINT max_pos=examples_total;      for(pos_abs=0;pos_abs<examples_total;pos_abs++){	if(is_alpha_neg(pos_abs) > 0){	  if(all_alphas[pos_abs] > is_zero){	    if(lambda(pos_abs) < max_lambda){	      max_lambda = lambda(pos_abs);	      max_pos = pos_abs;	    };	  };	}	else{	  if(all_alphas[pos_abs]+Cneg > is_zero){	    if(lambda(pos_abs) < max_lambda){	      max_lambda = lambda(pos_abs);	      max_pos = pos_abs;	    };	  };	};      };      if(max_pos<examples_total){	if(working_set_size<parameters->working_set_size){	  working_set_size++;	};	working_set[working_set_size-1] = max_pos;      };    };  };  if((working_set_size<parameters->working_set_size) &&     (working_set_size<examples_total)){    // use full working set    SVMINT pos = (SVMINT)((SVMFLOAT)examples_total*rand()/(RAND_MAX+1.0));    int ok;    while((working_set_size<parameters->working_set_size) &&	  (working_set_size<examples_total)){      // add pos into WS if it isn't already      ok = 1;      for(i=0;i<working_set_size;i++){	if(working_set[i] == pos){	  ok=0;	  i = working_set_size;	};      };      if(1 == ok){	working_set[working_set_size] = pos;	working_set_size++;      };      pos = (pos+1)%examples_total;    };  };  SVMINT ipos;  for(ipos=0;ipos<working_set_size;ipos++){    which_alpha[ipos] = is_alpha_neg(working_set[ipos]);  };  time_calc += get_time() - time_start;  return;};void svm_c::project_to_constraint(){  // project alphas to match the constraint  if(biased){    SVMFLOAT alpha_sum = sum_alpha;    SVMINT SVcount=0;    SVMFLOAT alpha;    SVMINT i;    for(i=0;i<examples_total;i++){      alpha = all_alphas[i];      alpha_sum += alpha;      if(((alpha>is_zero) && (alpha-Cneg < -is_zero)) ||	 ((alpha<-is_zero) && (alpha+Cpos > is_zero))){	SVcount++;      };    };    if(SVcount > 0){      // project      alpha_sum /= (SVMFLOAT)SVcount;      for(i=0;i<examples_total;i++){	alpha = all_alphas[i];	if(((alpha>is_zero) && (alpha-Cneg < -is_zero)) ||	   ((alpha<-is_zero) && (alpha+Cpos > is_zero))){	  all_alphas[i] -= alpha_sum;	};      };    };  };};void svm_c::init_working_set(){  // calculate sum  SVMINT i,j;  project_to_constraint();  // check bounds!  if(examples->initialised_alpha()){    if(parameters->verbosity >= 2){      cout<<"Initialising variables, this may take some time."<<endl;    };    for(i=0; i<examples_total;i++){      sum[i] = 0;      at_bound[i] = 0;      for(j=0; j<examples_total;j++){	sum[i] += all_alphas[j]*kernel->calculate_K(i,j);      };    };  }  else{    // skip kernel calculation as all alphas = 0    for(i=0; i<examples_total;i++){      sum[i] = 0;      at_bound[i] = 0;    };      };  if(examples->initialised_alpha()){    calculate_working_set();  }  else{    // first working set is random    j=0;    i=0;    while((i<working_set_size) && (j < examples_total)){      working_set[i] = j;      if(is_alpha_neg(j) > 0){	which_alpha[i] = 1;      }      else{	which_alpha[i] = -1;      };      i++;      j++;    };  };     update_working_set();};void svm_c::put_optimizer_values(){  // update nabla, sum, examples.  // sum[i] += (primal_j^*-primal_j-alpha_j^*+alpha_j)K(i,j)  // check for |nabla| < is_zero (nabla <-> nabla*)  //  cout<<"put_optimizer_values()"<<endl;  SVMINT i=0;   SVMINT j=0;  SVMINT pos_i;  SVMFLOAT the_new_alpha;  SVMFLOAT* kernel_row;  SVMFLOAT alpha_diff;  long time_start = get_time();  pos_i=working_set_size;  while(pos_i>0){    pos_i--;    if(which_alpha[pos_i]>0){      the_new_alpha = primal[pos_i];    }    else{      the_new_alpha = -primal[pos_i];    };    // next three statements: keep this order!    i = working_set[pos_i];    alpha_diff = the_new_alpha-all_alphas[i];    all_alphas[i] = the_new_alpha;    if(alpha_diff != 0){      // update sum ( => nabla)      kernel_row = kernel->get_row(i);      for(j=0;j<examples_total;j++){	sum[j] += alpha_diff*kernel_row[j];      };    };  };  time_update += get_time() - time_start;};void svm_c::update_working_set(){  long time_start = get_time();  // setup subproblem

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本特黄久久久高潮| 91久久精品一区二区二区| 波多野结衣一区二区三区 | 理论电影国产精品| 成人免费高清在线| 日韩欧美黄色影院| 亚洲综合男人的天堂| 国产成人亚洲综合a∨猫咪| 在线播放欧美女士性生活| **网站欧美大片在线观看| 麻豆91免费看| 欧美精选一区二区| 亚洲人成亚洲人成在线观看图片| 蜜臀av性久久久久蜜臀av麻豆| 日本韩国一区二区三区| 国产精品无圣光一区二区| 国产在线不卡一区| 日韩一区二区在线观看视频播放 | 欧美一级黄色录像| 亚洲一区视频在线观看视频| gogogo免费视频观看亚洲一| 国产亚洲欧洲997久久综合| 日本一区中文字幕| 欧美日韩国产综合久久| 亚洲国产精品精华液网站| 91免费版在线| 一区二区三区在线视频免费观看| 成人18视频在线播放| 欧美经典一区二区| 盗摄精品av一区二区三区| 国产色产综合产在线视频| 美女网站视频久久| 精品国产乱码久久久久久夜甘婷婷 | 欧美日韩中文字幕一区| 亚洲精品乱码久久久久久久久| 不卡高清视频专区| 国产精品久久久久久户外露出| 国产激情一区二区三区| 中文字幕免费观看一区| 成人性生交大片| 国产精品第五页| 色综合天天视频在线观看| 亚洲精品国久久99热| 欧洲日韩一区二区三区| 亚洲一区二区三区四区五区黄| 欧美日韩一区二区三区在线看| 亚洲h精品动漫在线观看| 亚洲成人先锋电影| 日产精品久久久久久久性色| av亚洲精华国产精华| 成人免费视频在线观看| 奇米影视7777精品一区二区| 久久先锋影音av鲁色资源| 精彩视频一区二区| 国产蜜臀av在线一区二区三区| 欧美一级二级在线观看| 日韩精品91亚洲二区在线观看 | 亚洲超丰满肉感bbw| 一区视频在线播放| 久久老女人爱爱| 欧美一区二区女人| 欧美三级电影一区| 色国产精品一区在线观看| 成人av网站在线| 国产在线视频不卡二| 日本人妖一区二区| 美女视频黄 久久| 视频一区二区三区入口| 亚洲二区在线观看| 午夜精品在线看| 亚洲福利国产精品| 亚洲va国产va欧美va观看| 亚洲成人av在线电影| 亚洲国产精品久久一线不卡| 亚洲一区二区精品久久av| 亚洲女同女同女同女同女同69| 国产精品天干天干在观线| 国产日产欧美一区| 国产精品久久久久久久蜜臀| 国产精品久久午夜| 亚洲日本青草视频在线怡红院 | 亚洲成人精品一区二区| 亚洲成在线观看| 无码av免费一区二区三区试看 | 成人av午夜电影| 99这里只有精品| 91麻豆国产精品久久| 91亚洲精品久久久蜜桃| 91麻豆免费观看| 欧美无砖专区一中文字| 欧美日韩国产另类一区| 欧美va亚洲va国产综合| 26uuu色噜噜精品一区二区| 欧美极品xxx| 亚洲精品中文在线影院| 亚洲国产精品久久久男人的天堂| 午夜精品久久久久久久久| 蜜臀av亚洲一区中文字幕| 国产精一区二区三区| www.日本不卡| 欧美日韩一级二级三级| 一本到一区二区三区| 3atv在线一区二区三区| 亚洲精品一区二区三区在线观看| 欧美激情在线观看视频免费| 亚洲人成亚洲人成在线观看图片 | 日韩综合一区二区| 激情欧美日韩一区二区| 国产成人精品网址| 一道本成人在线| 欧美成人三级电影在线| 国产精品天天看| 亚洲伊人色欲综合网| 九九九精品视频| av爱爱亚洲一区| 欧美日韩高清不卡| 国产欧美一区视频| 亚洲成人三级小说| 丁香婷婷综合激情五月色| 在线欧美一区二区| 久久久www成人免费无遮挡大片| 亚洲欧美日韩电影| 精东粉嫩av免费一区二区三区| 97超碰欧美中文字幕| 91精品国产手机| 亚洲天堂成人在线观看| 免费国产亚洲视频| 99久久国产综合精品女不卡| 91精品国产91综合久久蜜臀| 国产精品热久久久久夜色精品三区| 亚洲一区二区三区视频在线| 国产精品91xxx| 欧美体内she精高潮| 国产精品网曝门| 麻豆成人免费电影| 欧美性高清videossexo| 国产日韩欧美高清在线| 麻豆专区一区二区三区四区五区| 91亚洲大成网污www| 久久久亚洲精华液精华液精华液 | 9人人澡人人爽人人精品| 欧美大胆一级视频| 五月婷婷色综合| 91天堂素人约啪| 国产精品女上位| 国产精品一级二级三级| 欧美一级在线视频| 午夜精品在线看| 欧洲另类一二三四区| 亚洲视频一二三区| 99久久婷婷国产综合精品电影| 精品成人a区在线观看| 热久久一区二区| 在线电影国产精品| 亚洲va韩国va欧美va| 欧美亚洲动漫制服丝袜| 亚洲免费观看在线观看| 一本大道久久a久久综合婷婷| 中文字幕精品一区| 国产精品自拍一区| 久久久久久久综合日本| 激情六月婷婷久久| 久久久午夜电影| 国产福利不卡视频| 国产欧美精品区一区二区三区| 国产一区二区三区四| 久久久综合网站| 国产精品一区二区在线观看不卡 | 免费xxxx性欧美18vr| 欧美女孩性生活视频| 性久久久久久久久| 欧美亚洲尤物久久| 婷婷综合在线观看| 欧美一区二区视频在线观看| 青青国产91久久久久久| 欧美一区二区三区思思人 | 国产一区欧美一区| 久久影院视频免费| 国产精品69久久久久水密桃| 久久精品亚洲精品国产欧美kt∨| 国产一区二区不卡在线| 久久精品亚洲国产奇米99| 国产精品影音先锋| 亚洲色图欧洲色图| 欧美体内she精视频| 蜜桃视频在线一区| 国产日韩v精品一区二区| bt7086福利一区国产| 一区二区高清在线| 欧美一区二区三区小说| 久久国产综合精品| 国产精品视频一二三区| 色婷婷亚洲一区二区三区| 天天综合天天做天天综合| 精品黑人一区二区三区久久| 国产suv精品一区二区6| 亚洲小说欧美激情另类| 精品国产精品网麻豆系列| 91在线一区二区| 丝袜诱惑制服诱惑色一区在线观看|