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

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

?? evaluation.c

?? 螞蟻聚類算法源代碼(ant based clustering algorithm)
?? C
字號:
/*  Ant-based Clustering    Copyright (C) 2004 Julia Handl    Email: Julia.Handl@gmx.de    This program is free software; you can redistribute it and/or modify    it under the terms of the GNU General Public License as published by    the Free Software Foundation; either version 2 of the License, or    (at your option) any later version.    This program is distributed in the hope that it will be useful,    but WITHOUT ANY WARRANTY; without even the implied warranty of    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the    GNU General Public License for more details.    You should have received a copy of the GNU General Public License    along with this program; if not, write to the Free Software    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA*/#include "evaluation.h"#include <time.h>evaluation::evaluation(conf * c) {    par = c;    docindex = NULL;}evaluation::~evaluation() {  if (docindex != NULL) {    for (int i=0; i<par->binsize; i++) {      delete docindex[i];    }    delete [] docindex;  }	    }void evaluation::init(databin<USED_DATA_TYPE> * b, clustering * cl) {    bin = b;    clust = cl;    docindex = NULL;}void evaluation::init(databin<USED_DATA_TYPE> * b, grid * g, clustering * cl, position<double> ** index) {    bin = b;    env = g;    clust = cl;    if (index != NULL) {	docindex = index;    }    else {	if (env != NULL) {		    // store the positions for all data elements	    docindex = new position<double>*[par->binsize];	    for (int i=0; i<par->binsize; i++) {		docindex[i] = NULL;	    }	    	    for (int i=0; i<par->imax; i++) {		for (int j=0; j<par->jmax; j++) {		    		    if ((*env)(i,j) != FREE) {			docindex[(*env)(i,j)] = new position<double>(i,j);		    }		    		}	    }	}        else docindex = NULL;    }}double evaluation::square(double x) {    return x*x;}double evaluation::spatialdistance(position<int> * p1, position<int> * p2, int torus) {    int dx = abs((*p1)[0]-(*p2)[0]);    if (torus == TRUE) dx = min(dx, par->imax - dx);    int dy = abs((*p1)[1]-(*p2)[1]);    if (torus == TRUE) dy = min(dy, par->jmax - dy);    return sqrt(square(dx)+square(dy));}double evaluation::spatialdistance(position<double> * p1, position<double> * p2, int torus) {    double dx = abs((*p1)[0]-(*p2)[0]);    if (torus == TRUE) dx = min(dx, par->imax - dx);    double dy = abs((*p1)[1]-(*p2)[1]);    if (torus == TRUE) dy = min(dy, par->jmax - dy);    return sqrt(square(dx)+square(dy));}/**************************************************************************************** Evaluation measures for unsupervised clustering, i.e. when the real partitions are NOT known  - Variance - Dunn index Both were used in the final experiments ****************************************************************************************/double evaluation::dunn_av() {    if (clust->num <= 1) {	//cerr << "Dunn Index cannot be computed for one single cluster" << endl;	return 0;    }    double diam = 0.0;    double diamold  = 0.0;    int ** assignment = new int * [clust->num];    int * ctr = new int[clust->num];    for (int i=0; i<clust->num; i++) {    	ctr[i] = 0;	assignment[i] = new int[par->binsize+1];	for (int j=0; j<=par->binsize; j++) {	    assignment[i][j] = FREE;	}    }    for (int i=0; i<par->binsize; i++) {	int index = (*clust)[i];	assignment[index][ctr[index]] = i;	ctr[index]++;    }    // find maximum cluster diameter based on average distance    for (int i=0; i<clust->num; i++) {	int j = 0;	diam = 0.0;	int ctr = 0;	while (assignment[i][j] != FREE) {	    int k = j+1;	    while (assignment[i][k] != FREE) {		diam += bin->precomputed_d(assignment[i][j],assignment[i][k]);		ctr++;		k++;	    }	    j++;	}	diam /= double(ctr);	diam = max(diam, diamold);	diamold = diam;    }    // find minimal cluster distance    double mind = 0;    for (int i=0; i<clust->num; i++) {	data<USED_DATA_TYPE> di(par, clust->centres[i]);	for (int j=0; j<i; j++) {	    data<USED_DATA_TYPE> dj(par, clust->centres[j]);	    if ((i == 1) && (j == 0)) mind = di.distanceto(dj) / par->max;	    mind = min(mind, di.distanceto(dj) / par->max);	}    }    for (int i=0; i<clust->num; i++) {      delete [] assignment[i];    }    delete [] assignment;    delete [] ctr;    return mind / diam;}double evaluation::variance() {    double * var = new double[clust->num];    int * ctr = new int[clust->num];    // initialisation    for (int i=0; i<clust->num; i++) {	var[i] = 0.0;	ctr[i] = 0;    }    for (int i=0; i<par->binsize; i++) {	double diff = 0.0;	int p = clust->partition[i];	data<USED_DATA_TYPE> di(par, clust->centres[p]);	diff = (*bin)[i].distanceto(di);	var[p] += diff*diff;    }       double totalvariance = 0.0;    for (int i=0; i<clust->num; i++) {	totalvariance += var[i];    }    totalvariance /= double(par->binsize);        delete [] var;    delete [] ctr;    return sqrt(totalvariance);}/**************************************************************************************** Evaluation measures for supervised clustering, i.e. when the real partitions are known  - Number of identified clusters  - F-Measure - Rand-Index In the final experiments only the F-Measure and the Rand-Index were used. ****************************************************************************************/double evaluation::number() {    return double(clust->num);}double evaluation::clusternumber() {    return double(clust->num);} double evaluation::fmeasure(int b) {    int ** assignments = new int* [clust->num];    for (int i=0; i<clust->num; i++) {	assignments[i] = new int [par->kclusters];	for (int j=0; j<par->kclusters; j++) {	    assignments[i][j] = 0;	}    }    for (int i=0; i<par->binsize; i++) {	int p = clust->partition[i];	int real_p = (*bin)[i].cluster;	assignments[p][real_p]++;    }    double totalf = 0.0;    int num = clust->num;    double ** f = new double *[clust->num];    for (int i=0; i<clust->num; i++) {	f[i] = new double[par->kclusters];    }    for (int i=0; i<clust->num; i++) {	int max = 0;	int maxnum = 0;	int size = 0;	for (int j=0; j<par->kclusters; j++) {	    // determine n_j	    size += assignments[i][j];	}			for (int j=0; j<par->kclusters; j++) {	    if ((size != 0) && (assignments[i][j] != 0)){		// n_ij / n_i		double r = double(assignments[i][j]) / double(par->size_cluster[j]);		// n_ij / n_j		double p = double(assignments[i][j]) / double(size);		// F-value for class j and cluster i		f[i][j] = (double(b*b)+1.0)*p*r / (double(b*b)*p + r);	    }	    else f[i][j] = 0;	}    }    for (int j=0; j<par->kclusters; j++) {	// find max{F(i,j)}	double maxf = 0.0;	for (int i=0; i<clust->num; i++) {	    maxf = max(maxf, f[i][j]);	}	totalf += double(par->size_cluster[j]) / double(par->binsize) * maxf;    }     for (int i=0; i<clust->num; i++) {	delete [] assignments[i];	delete [] f[i];    }    delete [] assignments;    delete [] f;    return totalf;} double evaluation::randindex() {    int a = 0;    int b = 0;    int c = 0;    int d = 0;    double r = 0.0;    for (int i=0; i<par->binsize; i++) {	int p1 = clust->partition[i];	int q1 = (*bin)[i].cluster;	for (int j=0; j<par->binsize; j++) {	    int p2 = clust->partition[j];	    int q2 = (*bin)[j].cluster;	    if ((p1 == p2) && (q1 == q2)) a++;	    if ((p1 == p2) && !(q1 == q2)) b++;	    if (!(p1 == p2) && (q1 == q2)) c++;	    if (!(p1 == p2) && !(q1 == q2)) d++;	}    }    r = double(a+d)/double(a+b+c+d);    return r;}double evaluation::randindex(clustering * c1, clustering * c2, int size) {    int a = 0;    int b = 0;    int c = 0;    int d = 0;    double r = 0.0;    for (int i=0; i<size; i++) {	int p1 = c1->partition[i];	int q1 = c2->partition[i];	for (int j=0; j<size; j++) {	    int p2 = c1->partition[j];	    int q2 = c2->partition[j];	    if ((p1 == p2) && (q1 == q2)) a++;	    if ((p1 == p2) && !(q1 == q2)) b++;	    if (!(p1 == p2) && (q1 == q2)) c++;	    if (!(p1 == p2) && !(q1 == q2)) d++;	}    }    r = double(a+d)/double(a+b+c+d);    return r;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品青草综合久久久久99| 欧美日韩中文另类| 久久久噜噜噜久噜久久综合| 日本亚洲最大的色成网站www| 欧美挠脚心视频网站| 午夜久久久久久电影| 日韩三级在线观看| 国产一区二区三区不卡在线观看| 国产丝袜在线精品| 暴力调教一区二区三区| 亚洲黄色在线视频| 在线综合+亚洲+欧美中文字幕| 久久91精品国产91久久小草| 久久亚洲综合色| 99久久综合狠狠综合久久| 亚洲精品视频自拍| 91精品国产全国免费观看 | 日韩欧美色综合网站| 看国产成人h片视频| 久久久噜噜噜久噜久久综合| 99久久综合精品| 首页综合国产亚洲丝袜| 精品福利一二区| 91亚洲国产成人精品一区二三| 一区二区国产盗摄色噜噜| 日韩午夜在线观看视频| 不卡大黄网站免费看| 午夜激情一区二区| 久久久久国产精品麻豆| 91黄色激情网站| 精品一区二区三区免费播放| 日韩美女啊v在线免费观看| 欧美猛男超大videosgay| 国产一区久久久| 亚洲精品视频在线观看免费 | 精品一区二区在线视频| 国产精品久久久久桃色tv| 欧美日韩一区二区在线观看视频| 久久精品国内一区二区三区| 中文字幕一区二区三中文字幕| 欧美美女bb生活片| 成人国产在线观看| 奇米四色…亚洲| 亚洲免费av在线| 欧美国产在线观看| 欧美一区二区三区男人的天堂| 成人中文字幕合集| 日产国产欧美视频一区精品| 亚洲欧美日韩在线不卡| 久久亚洲综合色一区二区三区| 欧美日韩一区成人| 成人av在线网站| 国产资源在线一区| 日韩中文字幕1| 一区二区三区成人在线视频| 欧美激情一区二区三区四区| 日韩三级免费观看| 欧美日韩成人综合| 在线精品视频一区二区| www.成人在线| 国产一区999| 精品一区二区三区影院在线午夜| 亚洲va天堂va国产va久| 一区二区免费视频| 国产精品成人免费| 亚洲国产精品二十页| 久久综合狠狠综合久久激情 | 日本一区二区三区国色天香| 欧美xxx久久| 精品国免费一区二区三区| 欧美伦理影视网| 51精品国自产在线| 91精品国产色综合久久ai换脸| 欧美日韩你懂的| 欧美视频日韩视频| 欧美日韩国产一级| 欧美一区二区私人影院日本| 777奇米四色成人影色区| 欧美日本一区二区三区四区| 欧美日韩国产综合一区二区三区| 欧美日韩免费电影| 欧美一区二区视频在线观看| 欧美一区二区三区在线看| 91精品国产91久久综合桃花| 欧美电影免费观看高清完整版在 | 亚洲女人的天堂| 亚洲精品乱码久久久久久黑人| 亚洲视频免费在线观看| 亚洲欧美日韩久久精品| 亚洲一二三级电影| 午夜国产不卡在线观看视频| 免费看欧美女人艹b| 精品一区在线看| 成人激情小说网站| 在线中文字幕一区二区| 欧美男男青年gay1069videost| 91精品国产91久久久久久最新毛片 | 色av成人天堂桃色av| 在线精品视频小说1| 91精品在线观看入口| 久久男人中文字幕资源站| 亚洲国产精品二十页| 亚洲精品视频在线| 日本不卡不码高清免费观看| 国产精品综合av一区二区国产馆| 成年人国产精品| 欧美日韩第一区日日骚| 久久综合久色欧美综合狠狠| 成人欧美一区二区三区白人| 亚洲国产精品久久久久婷婷884| 美腿丝袜亚洲色图| 成人三级伦理片| 欧美色网站导航| 久久伊99综合婷婷久久伊| 亚洲欧美日韩系列| 国内精品视频666| proumb性欧美在线观看| 7777精品伊人久久久大香线蕉 | 欧美日韩在线一区二区| 国产亚洲欧洲一区高清在线观看| 亚洲女人小视频在线观看| 久久不见久久见中文字幕免费| www.欧美精品一二区| 日韩欧美一级二级三级久久久| 国产精品久线在线观看| 美女免费视频一区二区| 91香蕉视频mp4| 欧美精品一区二| 午夜久久久久久久久久一区二区| 国产99久久久精品| 欧美一区三区二区| 亚洲美女电影在线| 国产一区二区不卡在线 | 91精品黄色片免费大全| 国产精品女人毛片| 麻豆国产精品官网| 欧美日韩精品一区二区| 亚洲人被黑人高潮完整版| 国产精品小仙女| 日韩欧美一区二区视频| 亚洲电影在线播放| 色综合天天综合色综合av | 在线免费亚洲电影| 久久九九久久九九| 久久国产免费看| 精品视频全国免费看| 亚洲欧洲无码一区二区三区| 国内久久婷婷综合| 日韩精品一区二区三区视频播放| 亚洲国产成人91porn| 91小视频免费看| 欧美精彩视频一区二区三区| 久久se精品一区二区| 在线综合视频播放| 日日摸夜夜添夜夜添亚洲女人| 欧美综合一区二区三区| 亚洲人精品午夜| 色综合久久中文字幕| 国产精品久久影院| 懂色av一区二区三区免费看| 久久美女高清视频 | 国产99精品在线观看| 精品国产伦一区二区三区观看体验| 午夜免费欧美电影| 欧美另类z0zxhd电影| 午夜精品视频在线观看| 欧美三级一区二区| 亚洲成av人影院| 欧美三片在线视频观看| 亚洲一区二区精品视频| 欧美亚洲综合在线| 手机精品视频在线观看| 欧美一区二区三区思思人| 久久精品国产精品青草| 欧美精品一区二区在线观看| 极品尤物av久久免费看| 国产亚洲一区字幕| 99热这里都是精品| 亚洲自拍另类综合| 91麻豆精品国产无毒不卡在线观看| 日韩国产欧美在线观看| 精品99999| 懂色av噜噜一区二区三区av| 精品一区二区三区欧美| 久久影院午夜论| youjizz国产精品| 亚洲精品国产第一综合99久久 | 99re热视频精品| 亚洲综合在线免费观看| 欧美高清精品3d| 久久精品72免费观看| 国产欧美日韩精品a在线观看| 91在线视频免费91| 亚洲福利一区二区| www久久精品| 色综合久久中文综合久久97| 日韩电影在线看| 国产日韩欧美高清| 欧美日韩国产区一| 国产精品一品二品|