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

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

?? cluster1.c

?? 聚類算法全集以及內附數據集
?? C
?? 第 1 頁 / 共 4 頁
字號:
/*----------------------------------------------------------------------  File    : cluster1.c  Contents: cluster and cluster set management (basic functions)  Author  : Christian Borgelt  History : 05.09.2001 file created            11.09.2001 functions cls_range, cls_reg, cls_expand added            15.09.2001 first version of fuzzy c-means completed            07.08.2002 parsing function completed            30.01.2003 data normalization code added            01.02.2003 extended functions (for tuples) added            02.02.2003 extended parse function added            07.02.2003 reinitialization added to function cls_range            09.03.2003 some initialization moved to separate routines            13.03.2003 membership degree normalization made optional            10.04.2003 matrix initialization bug in _params fixed            15.05.2003 membership normalization modes added            16.05.2003 noise clustering added            06.08.2003 bug in mapping binary attributes fixed            11.08.2003 adapted to new module attmap            12.08.2003 adapted to new module nstats            14.08.2003 bug in _params fixed (covariance matrix reading)            15.08.2003 adapted to new module radfn            16.02.2004 bug in _params for vector of variances fixed            23.02.2004 bug in function _params fixed            25.02.2004 adapted to changed radfn, bug in cls_exec fixed            27.02.2004 function cls_deletex added            01.03.2004 update functions moved to a separate file            17.03.2004 missing evaluation of cluster weight added            18.03.2004 normalization parameters added            25.04.2004 bug in function cls_unscale fixed            21.06.2004 reading covariances made more robust            28.07.2004 bug in function _params (cls_parse) fixed            12.08.2004 adapted to new module parse----------------------------------------------------------------------*/#include <stdlib.h>#include <limits.h>#include <float.h>#include <string.h>#include <assert.h>#include "cluster.h"/*----------------------------------------------------------------------  Preprocessor Definitions----------------------------------------------------------------------*/#define BLKSIZE      16         /* block size for cluster vector */#define MINVAR       1e-12      /* minimal variance */#define MAXVAR       1e+12      /* maximal variance */#define MINDET       1e-48      /* minimal determinant */#define MAXDET       1e+48      /* maximal determinant *//*----------------------------------------------------------------------  Constants----------------------------------------------------------------------*/static char *nrmnames[] =       /* names of normalization modes */  { "none", "sum1", "max1", "hard" };/*----------------------------------------------------------------------  Auxiliary Functions----------------------------------------------------------------------*/static void _init (CLSET *clset, int incnt, int clscnt){                               /* --- initialize some variables */  clset->type     = CLS_CENTER; /* prototypes consist of centers only */  clset->incnt    = incnt;  clset->clscnt   = clscnt;  clset->radfn    = rf_cauchy;  /* default radial function: */  clset->rfnps[0] = 2;          /* \mu(x) = 1/d^2(\vec{x},\vec{c}) */  clset->rfnps[1] = 0;          /* (standard fuzzy clustering) */  clset->norm     = rf_cauchy(-incnt, clset->rfnps);  clset->noise    = clset->msd[0] = clset->msd[1] = 0;  clset->nrmps[0] = 1;          /* default normalization: */  clset->nrmps[1] = 0;          /* u_ij = u_ij^* /sum_k u_{kj}^* */  clset->mode     = CLS_SUM1;  clset->method   = CLS_ALTOPT|CLS_NONE;  clset->msexp    = 2;          /* exponent: std. fuzzy clustering */  clset->regps[0] = 0;          /* regularization parameters */  clset->regps[1] = 1;          /* (b, a, s, h, w) */  clset->regps[2] = 1;  clset->regps[3] = 0;  clset->regps[4] = 0;  clset->moment   = 0;  clset->growth   = 1.2;  clset->shrink   = 0.5;  clset->maxchg   = 1;  clset->cls      = NULL;       /* initialize pointers, */  clset->vec      = NULL;       /* so that deletion */  clset->mat      = NULL;       /* with cls_delete works */  clset->nst      = NULL;  clset->init     = clset->steps = 0;}  /* _init() *//*--------------------------------------------------------------------*/static int _cluster (CLUSTER *c, int dim){                               /* --- init. a cluster prototype */  c->cov = mat_create(dim, dim);  c->inv = mat_create(dim, dim);  c->smp = mat_create(dim, dim);  c->chv = mat_create(dim, dim);  c->bfv = mat_create(dim, dim);  if (!c->cov || !c->inv || !c->smp || !c->chv || !c->bfv)    return -1;                  /* create cluster-specific matrices */  c->ctr = mat_buf(c->cov);     /* and get their buffer vectors */  c->dif = mat_buf(c->inv);     /* for easier access */  c->sum = mat_buf(c->smp);  c->chc = mat_buf(c->chv);  c->bfc = mat_buf(c->bfv);  c->var = c->wgt = c->scl = 1;  return 0;                     /* return 'ok' */}  /* _cluster() *//*----------------------------------------------------------------------  Cluster Set Functions----------------------------------------------------------------------*/CLSET* cls_create (int incnt, int clscnt){                               /* --- create a set of clusters */  int     i;                    /* loop variable */  CLSET   *clset;               /* created set of clusters */  CLUSTER *c;                   /* to traverse the clusters */  assert((incnt > 0) && (clscnt > 0));/* check the function arguments */  clset = (CLSET*)malloc(sizeof(CLSET));  if (!clset) return NULL;      /* create the base structure */  _init(clset, incnt, clscnt);  /* and initialize the variables */  clset->cls = c = (CLUSTER*)malloc(clscnt *sizeof(CLUSTER));  if (!clset->cls) { cls_delete(clset); return NULL; }  for (c += i = clscnt; --i >= 0; ) { /* clear pointers for cleanup */    --c; c->cov = c->inv = c->smp = c->chv = c->bfv = NULL; }  for (c += i = clscnt; --i >= 0; )   /* initialize the clusters */    if (_cluster(--c, incnt) != 0) { cls_delete(clset); return NULL; }  clset->vec = (double*)malloc(3 *incnt *sizeof(double));  if (!clset->vec) { cls_delete(clset); return NULL; }  clset->buf = clset->vec +incnt;  /* create the numeric vectors */  clset->mat = mat_create(incnt, incnt);  clset->nst = nst_create(incnt);  /* create the numerical statistics */  if (!clset->mat || !clset->nst) { cls_delete(clset); return NULL; }  #ifdef CLS_EXTFN              /* if extended function set, */  clset->attset = NULL;         /* clear the attribute set and */  clset->attmap = NULL;         /* attribute map pointers as a flag */  #endif                        /* for a normal cluster set */  return clset;                 /* return created set of clusters */}  /* cls_create() *//*--------------------------------------------------------------------*/void cls_delete (CLSET *clset){                               /* --- delete a set of clusters */  int     i;                    /* loop variable */  CLUSTER *c;                   /* to traverse the clusters */  assert(clset);                /* check the function argument */  #ifdef CLS_EXTFN              /* if to compile extended functions, */  if (clset->attmap) free(clset->attmap);     /* delete the att. map */  #endif  if (clset->nst) nst_delete(clset->nst);  if (clset->mat) mat_delete(clset->mat);  if (clset->vec) free(clset->vec);  if (clset->cls) {             /* if there is a cluster vector */    for (c = clset->cls +(i = clset->clscnt); --i >= 0; ) {      --c;                      /* traverse the clusters */      if (c->cov) mat_delete(c->cov);      if (c->inv) mat_delete(c->inv);      if (c->smp) mat_delete(c->smp);      if (c->chv) mat_delete(c->chv);      if (c->bfv) mat_delete(c->bfv);    }                           /* delete all matrices */    free(clset->cls);           /* and the cluster vector */  }  free(clset);                  /* delete the base structure */}  /* cls_delete() *//*--------------------------------------------------------------------*/#ifdef CLS_EXTFNCLSET* cls_createx (ATTSET *attset, int marked, int clscnt){                               /* --- create a cluster set */  CLSET  *clset;                /* created cluster set */  ATTMAP *attmap;               /* created attribute map */  assert(attset && (clscnt > 0));  /* check the function arguments */  attmap = am_create(attset, marked, -1);  if (!attmap) return NULL;     /* create an attribute map */  clset  = cls_create(am_incnt(attmap), clscnt);  if (!clset) { am_delete(attmap); return NULL; }  clset->attset = attset;       /* create a cluster set and */  clset->attmap = attmap;       /* note the attribute set and map */  return clset;                 /* return the created cluster set */}  /* cls_cr4sup() *//*--------------------------------------------------------------------*/CLSET* cls_cr4sup (ATTMAP *attmap, int clscnt){                               /* --- create a cluster set */  CLSET *clset;                 /* created cluster set */  assert(attmap && (clscnt > 0));  /* check the function arguments */  clset  = cls_create(am_incnt(attmap), clscnt);  if (!clset) return NULL;      /* create a cluster set */  clset->attset = am_attset(attmap);  clset->attmap = attmap;       /* note the attribute set and map */  return clset;                 /* return the created cluster set */}  /* cls_cr4sup() *//*--------------------------------------------------------------------*/void cls_deletex (CLSET *clset, int delas){                               /* --- delete a set of clusters */  if (delas) as_delete(clset->attset);  cls_delete(clset);            /* delete attribute set */}  /* cls_deletex() */          /* and cluster set */#endif/*--------------------------------------------------------------------*/void cls_reg (CLSET *clset, const double *vec, double weight){                               /* --- register a data point */  #ifdef CLS_EXTFN              /* if to compile extended functions */  int i, k, off;                /* loop variables, offset */  #endif  assert(clset);                /* check the function argument */  nst_reg(clset->nst, vec, weight);  #ifdef CLS_EXTFN              /* if to compile extended functions */  if (vec || !clset->attmap)    /* if not termination or normal */    return;                     /* clustering, abort the function */  for (i = am_attcnt(clset->attmap); --i >= 0; ) {    if (am_type(clset->attmap, i) < 0) continue;    off = am_off(clset->attmap, i);    k   = am_cnt(clset->attmap, i) +off;    while (--k >= off) nst_scale(clset->nst, k, 0, 1);  }                             /* set identity for symbolic attribs. */  #endif                        /* (prevent distortion by scaling) */}  /* cls_reg() *//*--------------------------------------------------------------------*/void cls_value (CLSET *clset, int index, double value){                               /* --- set an input value */  clset->vec[index] = (value -nst_offset(clset->nst, index))                             *nst_factor(clset->nst, index);}  /* cls_value() *//*--------------------------------------------------------------------*/#ifdef CLS_EXTFNvoid cls_regx (CLSET *clset, const TUPLE *tpl){                               /* --- register a training tuple */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
美女www一区二区| 久久成人综合网| 极品少妇一区二区三区精品视频| av网站免费线看精品| 欧美日韩大陆一区二区| 久久蜜桃一区二区| 五月天久久比比资源色| av一区二区三区四区| 久久美女高清视频 | 亚洲一区二区精品3399| 激情综合网激情| 日韩三级视频在线观看| 免费观看91视频大全| 欧美日韩激情一区| 亚洲制服丝袜av| 欧美日韩一区二区三区视频| 亚洲欧美一区二区久久| 色94色欧美sute亚洲线路一久| 亚洲女与黑人做爰| 日韩女优av电影| 色猫猫国产区一区二在线视频| 亚洲成在人线在线播放| 精品国产区一区| 色综合久久中文综合久久牛| 美女一区二区久久| 亚洲日本电影在线| 欧美日韩夫妻久久| 蜜臀av亚洲一区中文字幕| 精品国内二区三区| 99国产精品久久久久久久久久久| 亚洲一区欧美一区| 欧美一区二区三区不卡| 国产乱码精品一区二区三区忘忧草| 亚洲精品一区二区三区四区高清| 国产成人精品免费视频网站| 国产精品毛片无遮挡高清| 色婷婷久久99综合精品jk白丝| 亚洲福利视频导航| 亚洲精品老司机| 精品国产乱码久久久久久蜜臀| 欧美日韩国产另类一区| 国产不卡在线播放| 亚洲在线视频网站| 久久伊人中文字幕| 精品成a人在线观看| 欧美一区二区在线免费播放| 成人高清视频在线| 麻豆精品视频在线观看免费| 亚洲午夜激情网页| 日韩成人精品在线观看| 亚洲视频中文字幕| 国产拍欧美日韩视频二区| 久久久久国产精品麻豆| 国产欧美日韩亚州综合| 久久理论电影网| 久久精品欧美一区二区三区不卡| 91精品蜜臀在线一区尤物| 在线国产亚洲欧美| 欧美亚洲一区二区在线| 成年人午夜久久久| 成人国产一区二区三区精品| jizzjizzjizz欧美| 欧美日韩美少妇| 在线播放视频一区| 欧美成人精品高清在线播放| 精品国产乱码久久久久久老虎 | 中文字幕精品综合| 国产精品视频一二三| 久久午夜色播影院免费高清| 中文在线资源观看网站视频免费不卡| 国产精品区一区二区三区| 国产精品伦理在线| 亚洲一区在线视频观看| 天天色天天操综合| 色综合天天综合网天天看片| 911精品国产一区二区在线| 久久久亚洲精品一区二区三区| 久久网这里都是精品| 亚洲精品日韩一| 99视频有精品| 精品99999| 一区二区激情小说| 精品一区二区三区免费播放 | 亚洲资源在线观看| 国产麻豆午夜三级精品| 色www精品视频在线观看| 欧美日韩三级一区| 日韩午夜精品视频| 精品福利av导航| 亚洲综合在线视频| 高清成人在线观看| 67194成人在线观看| 久久综合色婷婷| 精品影视av免费| 日韩免费电影一区| 午夜激情一区二区三区| 日韩欧美国产一区二区在线播放 | 久久久久国产精品麻豆| 视频一区二区中文字幕| 日本韩国一区二区三区视频| 久久伊99综合婷婷久久伊| 一区二区三区美女| 色综合天天综合网天天看片| 自拍偷在线精品自拍偷无码专区| 国产综合久久久久影院| 欧美一卡二卡在线观看| 亚洲成人中文在线| 69成人精品免费视频| 国产福利精品一区二区| 欧美va亚洲va香蕉在线| 九九**精品视频免费播放| 国产精品电影院| av在线不卡电影| 自拍偷拍国产精品| 欧美色大人视频| 国产一区二区0| 国产人成亚洲第一网站在线播放| 丁香啪啪综合成人亚洲小说| 国产精品女同一区二区三区| 91小宝寻花一区二区三区| 一区二区三区日韩在线观看| 亚洲精品欧美二区三区中文字幕| 日韩欧美电影一区| 色网综合在线观看| 国产精品伊人色| 国产在线精品国自产拍免费| 中文成人av在线| 欧美日韩国产高清一区二区三区 | 青青青伊人色综合久久| 国产精品三级电影| 久久综合久色欧美综合狠狠| 欧美性xxxxxxxx| 91在线免费视频观看| 欧美aa在线视频| 午夜久久久久久| 午夜亚洲福利老司机| 亚洲色图欧美在线| 国产日韩v精品一区二区| 欧美一区二区视频在线观看2020| 91麻豆免费在线观看| 波波电影院一区二区三区| 蜜芽一区二区三区| 蜜臀国产一区二区三区在线播放| 日韩vs国产vs欧美| 亚洲超碰97人人做人人爱| 一区二区三区在线播放| 亚洲黄色免费电影| 日韩国产成人精品| 亚洲综合一区二区| 亚洲亚洲人成综合网络| 日韩精品一级二级 | 欧美三级电影精品| 欧美最猛性xxxxx直播| 91丨九色porny丨蝌蚪| 91久久精品国产91性色tv| 91免费小视频| 欧美日韩一区二区三区四区| 欧美视频在线一区二区三区| 精品福利视频一区二区三区| www国产成人免费观看视频 深夜成人网| 91精品在线免费观看| 久久精品人人做人人综合| 中文字幕精品一区| 亚洲一区二区三区精品在线| 日韩一区精品视频| av在线这里只有精品| 91精品国产一区二区三区蜜臀| 日韩欧美卡一卡二| 自拍偷拍国产精品| 精品午夜久久福利影院| 97久久精品人人做人人爽 | 成人激情文学综合网| 欧美私人免费视频| 国产色综合久久| 日韩黄色免费电影| 成人av电影在线播放| 日韩一区国产二区欧美三区| 久久精品水蜜桃av综合天堂| 午夜一区二区三区视频| 国产v日产∨综合v精品视频| 国产91色综合久久免费分享| 欧美精品电影在线播放| 欧美一区二区日韩一区二区| 国产精品毛片a∨一区二区三区| 国产情人综合久久777777| 精品影视av免费| 欧美丰满一区二区免费视频| 中文字幕第一区综合| 夜色激情一区二区| 成人在线一区二区三区| 国产亚洲欧美日韩俺去了| 精品一区二区免费看| 欧美丝袜自拍制服另类| 亚洲黄色小说网站| 99精品国产99久久久久久白柏| 日本一区二区在线不卡| 国产高清久久久久| 久久精品网站免费观看| av在线不卡电影| 亚洲成人精品一区|