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

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

?? vfem-engine.c

?? 數據挖掘方面的源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
#include "vfem-engine.h"#include <math.h>#include <stdlib.h>extern float gNeededDelta;extern float gSigmaSquare;extern int gNormalApprox;IterationStatsPtr IterationStatsInitial(VoidAListPtr initialClusters) {   IterationStatsPtr is;   int i;   is = MNewPtr(sizeof(IterationStats));   is->centroids = VLNew();   for(i = 0 ; i < VALLength(initialClusters) ; i++) {      VALAppend(is->centroids, ExampleClone(VALIndex(initialClusters, i)));   }   is->cMax = VLNew();   for(i = 0 ; i < VALLength(initialClusters) ; i++) {      VALAppend(is->cMax, ExampleClone(VALIndex(initialClusters, i)));   }   is->cMaxAssignment = VLNew();   for(i = 0 ; i < VALLength(initialClusters) ; i++) {      VALAppend(is->cMaxAssignment,                 ExampleClone(VALIndex(initialClusters, i)));   }   is->cMin = VLNew();   for(i = 0 ; i < VALLength(initialClusters) ; i++) {      VALAppend(is->cMin, ExampleClone(VALIndex(initialClusters, i)));   }   is->cMinAssignment = VLNew();   for(i = 0 ; i < VALLength(initialClusters) ; i++) {      VALAppend(is->cMinAssignment,                 ExampleClone(VALIndex(initialClusters, i)));   }   is->lastBound = MNewPtr(sizeof(float) * VALLength(is->centroids));   is->lastAssignmentBound = MNewPtr(sizeof(float) * VALLength(is->centroids));   is->w = MNewPtr(sizeof(double) * VALLength(is->centroids));   is->wPlus = MNewPtr(sizeof(double) * VALLength(is->centroids));   is->wPlusSquare = MNewPtr(sizeof(double) * VALLength(is->centroids));   is->wMinus = MNewPtr(sizeof(double) * VALLength(is->centroids));   is->wx = MNewPtr(sizeof(double *) * VALLength(is->centroids));   is->wxPlus = MNewPtr(sizeof(double *) * VALLength(is->centroids));   is->wxMinus = MNewPtr(sizeof(double *) * VALLength(is->centroids));   is->deltaPlus = MNewPtr(sizeof(double *) * VALLength(is->centroids));   is->deltaMinus = MNewPtr(sizeof(double *) * VALLength(is->centroids));   for(i = 0 ; i < VALLength(initialClusters) ; i++) {      is->wx[i] = MNewPtr(sizeof(double) *           ExampleGetNumAttributes(VALIndex(is->centroids, 0)));      is->wxPlus[i] = MNewPtr(sizeof(double) *           ExampleGetNumAttributes(VALIndex(is->centroids, 0)));      is->wxMinus[i] = MNewPtr(sizeof(double) *           ExampleGetNumAttributes(VALIndex(is->centroids, 0)));      is->deltaPlus[i] = MNewPtr(sizeof(double) *           ExampleGetNumAttributes(VALIndex(is->centroids, 0)));      is->deltaMinus[i] = MNewPtr(sizeof(double) *           ExampleGetNumAttributes(VALIndex(is->centroids, 0)));   }   IterationStatsClearCounts(is);   /* we always have a perfect bound for an initial is */   is->foundBound = 1;   is->isFirstIteration = 1;   return is;}void IterationStatsClearCounts(IterationStatsPtr is) {   int i, j;   is->n = 0;   for(i = 0 ; i < VALLength(is->centroids) ; i++) {      is->lastBound[i] = 0;      is->lastAssignmentBound[i] = 0;      is->w[i] = 0;      is->wPlus[i] = 0;      is->wPlusSquare[i] = 0;      is->wMinus[i] = 0;      for(j = 0 ; j < ExampleGetNumAttributes(VALIndex(is->centroids, 0)) ; j++) {         is->wx[i][j] = 0;         is->wxPlus[i][j] = 0;         is->wxMinus[i][j] = 0;         is->deltaPlus[i][j] = 0;         is->deltaMinus[i][j] = 0;      }   }   is->maxEkd = 0;   is->possibleIDConverge = 0;   is->guarenteeIDConverge = 0;   is->wouldEMConverge = 0;   is->convergeVFEM = 0;}void IterationStatsFree(IterationStatsPtr is) {   int numCentroids = VALLength(is->centroids);   int i;   ExamplePtr e;   for(i = 0 ; i < numCentroids ; i++) {      e = VALIndex(is->centroids, i);      ExampleFree(e);      e = VALIndex(is->cMin, i);      ExampleFree(e);      e = VALIndex(is->cMinAssignment, i);      ExampleFree(e);      e = VALIndex(is->cMax, i);      ExampleFree(e);      e = VALIndex(is->cMaxAssignment, i);      ExampleFree(e);   }   VALFree(is->centroids);   VALFree(is->cMinAssignment);   VALFree(is->cMaxAssignment);   VALFree(is->cMin);   VALFree(is->cMax);   MFreePtr(is->lastBound);   MFreePtr(is->lastAssignmentBound);   for(i = 0 ; i < VALLength(is->cMin) ; i++) {      MFreePtr(is->wx[i]);      MFreePtr(is->wxPlus[i]);      MFreePtr(is->wxMinus[i]);      MFreePtr(is->deltaMinus[i]);      MFreePtr(is->deltaPlus[i]);   }   MFreePtr(is->w);   MFreePtr(is->wx);   MFreePtr(is->wPlus);   MFreePtr(is->wPlusSquare);   MFreePtr(is->wMinus);   MFreePtr(is->wxPlus);   MFreePtr(is->wxMinus);   MFreePtr(is->deltaMinus);   MFreePtr(is->deltaPlus);   MFreePtr(is);}/* this is so terrible */static void _MakeNewCentroids(VoidAListPtr centers, VoidAListPtr newCenters,    VoidAListPtr newAssignment, double **wx, double *w, double *wPlusSquare,    double *wMinus, long n, ExampleSpecPtr es, float delta, int useSampleError,       int boundUpper, int pedroBound, double **deltaPlus,               double **deltaMinus) {   double epsilon, *thisWx;   ExamplePtr newCenter, newCenterAssignment = 0, e;   int i,j;   double assignmentError;   /* free any old centers from the list */   while(VALLength(newCenters) > 0) {      i = VALLength(newCenters) - 1;      e = VALRemove(newCenters, i);      ExampleFree(e);   }   if(useSampleError) {      while(VALLength(newAssignment) > 0) {         i = VALLength(newAssignment) - 1;         e = VALRemove(newAssignment, i);         ExampleFree(e);      }   }   // This is my bound   //if(useBound) {   //   epsilon = ((double)n) * log(2.0 / delta);   //   epsilon /= 2.0;   //   epsilon = sqrt(epsilon);   //} else {   //   epsilon = 0;   //}   if(gMessageLevel > 2) {      printf("Making new centroids.\n");      fflush(stdout);   }   /* make the list of new centers */   for(i = 0 ; i < VALLength(centers) ; i++) {      if(useSampleError) {         newCenterAssignment = ExampleNew(es);         ExampleSetClass(newCenterAssignment, 0);      }      newCenter = ExampleNew(es);      ExampleSetClass(newCenter, 0);      if(useSampleError) {         epsilon = wPlusSquare[i] / (wMinus[i] * wMinus[i]);         if(epsilon > 1) {            epsilon = 1;         } else if(epsilon < (1.0 / n)) {            epsilon = 1.0 / n;         }         epsilon *= log(2.0 / delta);         epsilon /= 2.0;         epsilon = sqrt(epsilon);         if(gNormalApprox) {            epsilon /= 50;         }         //printf("i %d j %d\tw/w %lf epsilon %lf\n",          //i, j, thisWSquare[j] / (thisW[j] * thisW[j]), epsilon);      } else {         epsilon = 0;      }      thisWx = wx[i];      for(j = 0 ; j < ExampleSpecGetNumAttributes(es) ; j++) {         if(pedroBound) {            assignmentError = max(deltaPlus[i][j], deltaMinus[i][j]) /                          wMinus[i];            if(gMessageLevel > 2) {               printf("   assignment bound cluster %d dim %d: %.2f\n", i, j,                        assignmentError);            }         } else {            assignmentError = 0;         }         if(ExampleSpecIsAttributeContinuous(es, j)) {            if(!(w[i] <= 0 || (boundUpper && (w[i] - epsilon <= 0)))) {               if(boundUpper) {                  ExampleSetContinuousAttributeValue(newCenter, j,                      (thisWx[j] / w[i]) + epsilon + assignmentError);               } else { /* bound lower */                  /* HERE remove this min at some point */                  ExampleSetContinuousAttributeValue(newCenter, j,                      max((thisWx[j] / w[i]) - (epsilon + assignmentError),                           0));               }               if(useSampleError) {                  /* make the assignment error only center */                  if(boundUpper) {                     ExampleSetContinuousAttributeValue(newCenterAssignment, j,                         (thisWx[j] / w[i]) + assignmentError);                  } else {                  /* HERE remove this min at some point */                     ExampleSetContinuousAttributeValue(newCenterAssignment, j,                         max((thisWx[j] / w[i]) - assignmentError, 0));                  }               }            } else {               /* not enough weight so leave the center the same */               if(gMessageLevel > 1) {                  printf("not enough weight: %f epsilon: %f, possible div by zero c: %d a: %d!\n",                                w[i], epsilon, i,j);               }               ExampleSetContinuousAttributeValue(newCenter, j,                 ExampleGetContinuousAttributeValue(VALIndex(centers, i),j));            }         } else {            /* HERE what to do about discrete attributes */         }      }      VALAppend(newCenters, newCenter);      if(useSampleError) {         VALAppend(newAssignment, newCenterAssignment);      }   }}float AssignmentScaledDeltaMax(ExamplePtr e,                          ExamplePtr centroid, ExamplePtr min,                            ExamplePtr max, float epsilon);float AssignmentScaledDeltaMin(ExamplePtr e,                          ExamplePtr centroid, ExamplePtr min,                            ExamplePtr max, float epsilon);static void _RecordPedroBoundInfo(FILE *boundData, IterationStatsPtr is, VoidAListPtr newCentroids, ExampleSpecPtr es) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人性生交大合| 一区二区成人在线| 国产精品影音先锋| 国产偷国产偷精品高清尤物| 国产麻豆精品在线| 中文字幕欧美三区| 91亚洲国产成人精品一区二区三| 综合电影一区二区三区| 色综合网站在线| 亚洲一二三专区| 日韩美女视频一区二区在线观看| 精品一区二区三区影院在线午夜| 26uuu久久天堂性欧美| 成人夜色视频网站在线观看| 亚洲精品国产第一综合99久久| 欧洲一区二区三区免费视频| 午夜电影网一区| 26uuu色噜噜精品一区二区| www.99精品| 视频在线观看国产精品| 国产亚洲一区二区在线观看| 91麻豆swag| 免费黄网站欧美| 欧美国产欧美亚州国产日韩mv天天看完整 | 国产一区二区视频在线播放| 国产日韩欧美麻豆| 色婷婷综合久久久久中文一区二区 | 日韩精品一二区| 国产欧美日韩麻豆91| 欧美伊人久久大香线蕉综合69| 精品亚洲aⅴ乱码一区二区三区| 国产精品国产三级国产专播品爱网 | 免费看欧美美女黄的网站| 国产精品伦一区| 欧美v日韩v国产v| 欧美吻胸吃奶大尺度电影| 国产一区二区福利视频| 亚洲国产精品影院| 欧美国产一区在线| 欧美一区三区四区| 91香蕉视频黄| 国产一二三精品| 日韩精品免费视频人成| 国产精品国产三级国产有无不卡 | 中文字幕日韩一区二区| 欧美一区二区三区的| 99国产精品一区| 久久aⅴ国产欧美74aaa| 洋洋av久久久久久久一区| 国产欧美一区二区在线观看| 欧美一区二区日韩| 91亚洲精品久久久蜜桃网站 | 97久久精品人人做人人爽| 狠狠色丁香久久婷婷综合丁香| 一区二区三区不卡在线观看| 国产亚洲福利社区一区| 日韩视频永久免费| 欧美区在线观看| 欧美亚洲国产一区在线观看网站| 成人免费视频一区二区| 国产精品综合久久| 久久99精品久久久| 日本美女一区二区三区| 亚洲电影第三页| 亚洲国产综合色| 亚洲国产综合人成综合网站| 亚洲一级二级在线| 亚洲自拍偷拍综合| 亚洲影院久久精品| 亚洲一区二区三区国产| 艳妇臀荡乳欲伦亚洲一区| 亚洲欧美一区二区三区孕妇| 亚洲国产成人在线| 中文字幕一区二区三区视频 | 欧美色综合天天久久综合精品| 色综合久久综合中文综合网| 成人av影视在线观看| 粗大黑人巨茎大战欧美成人| 成人激情小说乱人伦| 99久久99久久精品免费观看 | 欧美一区二区三区四区久久| 欧美精品免费视频| 在线成人高清不卡| 日韩写真欧美这视频| 欧美成人综合网站| 久久久久久夜精品精品免费| 久久亚洲一区二区三区四区| 国产欧美视频在线观看| 国产精品欧美一区二区三区| 综合在线观看色| 亚洲www啪成人一区二区麻豆| 天天综合网天天综合色| 经典一区二区三区| 成人精品gif动图一区| 色综合久久66| 91麻豆精品国产自产在线| 欧美成人综合网站| 国产精品久久三| 五月综合激情婷婷六月色窝| 美女精品一区二区| 国产suv精品一区二区三区| 色呦呦一区二区三区| 8v天堂国产在线一区二区| 久久久www免费人成精品| ...xxx性欧美| 日韩不卡一区二区| 国产91色综合久久免费分享| 色婷婷国产精品久久包臀| 欧美一级搡bbbb搡bbbb| 欧美激情综合网| 亚洲福利一区二区| 国产精品自拍网站| 欧洲一区二区三区在线| 久久伊人中文字幕| 一区二区三区小说| 精品一区二区日韩| 在线免费亚洲电影| 久久亚洲私人国产精品va媚药| 亚洲精品一二三区| 精品影视av免费| 91传媒视频在线播放| 久久久精品tv| 日精品一区二区三区| 成人妖精视频yjsp地址| 欧美一区二区三区在线观看视频 | 在线观看日韩av先锋影音电影院| 欧美一区二区视频在线观看| 亚洲视频一区二区在线| 国产一区二区三区最好精华液 | 91精品国产品国语在线不卡| 国产精品视频在线看| 蜜臀久久久久久久| 色综合色综合色综合| 国产午夜精品一区二区三区四区| 亚洲一区二区三区四区在线观看 | 欧美成人精品福利| 一区二区不卡在线视频 午夜欧美不卡在 | 91亚洲精华国产精华精华液| 欧美videos中文字幕| 亚洲.国产.中文慕字在线| av成人老司机| 国产亚洲成年网址在线观看| 麻豆精品国产传媒mv男同| 精品视频在线视频| 亚洲精品欧美激情| av电影天堂一区二区在线观看| 久久精品一二三| 精品一区二区三区在线播放| 91精品一区二区三区在线观看| 亚洲激情自拍偷拍| 91丨国产丨九色丨pron| 中文字幕国产一区二区| 国产精品自在在线| 久久综合色8888| 久久99热这里只有精品| 欧美一区二区高清| 丝袜美腿亚洲色图| 欧美日韩免费观看一区二区三区 | 欧美一区二区福利在线| 婷婷亚洲久悠悠色悠在线播放| 色老头久久综合| 亚洲一区在线免费观看| 在线看日韩精品电影| 亚洲主播在线播放| 欧美亚洲禁片免费| 亚州成人在线电影| 91精品国产综合久久香蕉的特点| 亚洲h动漫在线| 欧美一区二区视频在线观看2020| 日韩国产成人精品| 欧美一区二区三区在线观看视频| 日韩精品每日更新| 日韩精品一区二区三区在线| 精品一区二区三区免费毛片爱| 久久这里只有精品首页| 国产激情视频一区二区在线观看 | 韩日av一区二区| 国产亚洲自拍一区| fc2成人免费人成在线观看播放| 国产精品高潮呻吟久久| 色综合激情五月| 视频一区欧美日韩| 日韩欧美一区二区三区在线| 国内精品在线播放| 中文字幕精品一区二区三区精品| 91蜜桃免费观看视频| 亚洲成人一区二区在线观看| 欧美一级二级三级蜜桃| 国产麻豆成人精品| 自拍偷拍欧美激情| 精品视频在线视频| 国产资源精品在线观看| 国产精品国产成人国产三级 | 久久99久久精品| 中文在线免费一区三区高中清不卡| 一本大道久久精品懂色aⅴ| 天天综合网 天天综合色| 久久精品亚洲国产奇米99| 色综合中文字幕| 极品少妇一区二区三区精品视频|