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

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

?? sc.c

?? 神龍卡開發原代碼
?? C
字號:
/***********************************************************************sc.c - creates classifiers from feature vectors of examples, as well as   classifying example feature vectors.Copyright (C) 1991 Dean RubineThis program is free software; you can redistribute it and/or modifyit under the terms of the GNU General Public License as published bythe Free Software Foundation; either version 1, 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 ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See theGNU General Public License for more details.You should have received a copy of the GNU General Public Licensealong with this program (in ../COPYING); if not, write to the FreeSoftware Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.***********************************************************************/#include "bitvector.h"#include "matrix.h"#include "util.h"#include "sc.h"#include "stdio.h"#include "stdlib.h"#include "math.h"#include "zdebug.h"#define	EPS	(1.0e-6)	/* for singular matrix check */sClassifiersNewClassifier(){	register sClassifier sc = allocate(1, struct sclassifier);	sc->nfeatures = -1;	sc->nclasses = 0;	sc->classdope = allocate(MAXSCLASSES, sClassDope);	sc->w = NULL;	return sc;}voidsFreeClassifier(sc)register sClassifier sc;{	register int i;	register sClassDope scd;	for(i = 0; i < sc->nclasses; i++) {		scd = sc->classdope[i];		if(scd->name) free(scd->name);		if(scd->sumcov) FreeMatrix(scd->sumcov);		if(scd->average) FreeVector(scd->average);		free(scd);		if(sc->w && sc->w[i]) FreeVector(sc->w[i]);	}	free(sc->classdope);	if(sc->w) free(sc->w);	if(sc->cnst) FreeVector(sc->cnst);	if(sc->invavgcov) FreeMatrix(sc->invavgcov);	free(sc);}sClassDopesClassNameLookup(sc, classname)register sClassifier sc;register char *classname;{	register int i;	register sClassDope scd;	static sClassifier lastsc = NULL;	static sClassDope lastscd = NULL;	/* quick check for last class name */	if(lastsc == sc && lastscd != NULL && STREQ(lastscd->name, classname))		return lastscd;	/* linear search through all classes for name */	for(i = 0; i < sc->nclasses; i++) {		scd = sc->classdope[i];		if(STREQ(scd->name, classname))			return lastsc = sc, lastscd = scd;	}	lastsc = NULL;	lastscd = NULL;	return NULL;}static sClassDopesAddClass(sc, classname)register sClassifier sc;char *classname;{	register sClassDope scd;	sc->classdope[sc->nclasses] = scd = allocate(1, struct sclassdope);	scd->name = scopy(classname);	scd->number = sc->nclasses;	scd->nexamples = 0;	scd->sumcov = NULL;	++sc->nclasses;	return scd;}voidsAddExample(sc, classname, y)register sClassifier sc;char *classname;Vector y;{	register sClassDope scd;	register int i, j;	double nfv[50];	double nm1on, recipn;	scd = sClassNameLookup(sc, classname);	if(scd == NULL) {/* fprintf(stderr, "sAddExample: calling sAddClass on %s.\n", classname); */		scd = sAddClass(sc, classname);	      }	if(sc->nfeatures == -1) {		sc->nfeatures = NROWS(y);/*		fprintf(stderr, "sAddExample: setting sc->nfeatures to NROWS(y).\n"); */	      }	if(scd->nexamples == 0) {/* 		fprintf(stderr, "sAddExample: allocating  & zeroing scd->average & scd->sumcov.\n"); */		scd->average = NewVector(sc->nfeatures);		ZeroVector(scd->average);		scd->sumcov = NewMatrix(sc->nfeatures, sc->nfeatures);		ZeroMatrix(scd->sumcov);	}	if(sc->nfeatures != NROWS(y)) {		PrintVector(y, "sAddExample: funny feature vector nrows!=%d", 			sc->nfeatures);		return;	}	scd->nexamples++;	nm1on = ((double) scd->nexamples-1)/scd->nexamples;	recipn = 1.0/scd->nexamples;	/* incrementally update covariance matrix */        for(i = 0; i < sc->nfeatures; i++)		nfv[i] = y[i] - scd->average[i];	/* only upper triangular part computed */        for(i = 0; i < sc->nfeatures; i++)	   for(j = i; j < sc->nfeatures; j++)		scd->sumcov[i][j] += nm1on * nfv[i] * nfv[j];	/* incrementally update mean vector */	for(i = 0; i < sc->nfeatures; i++)		scd->average[i] = nm1on * scd->average[i] + recipn * y[i];}voidsDoneAdding(sc)register sClassifier sc;{	register int i, j;	int c;	int ne, denom;	double oneoverdenom;	register Matrix s;	register Matrix avgcov;	double det;	register sClassDope scd;	if(sc->nclasses == 0) {		error("No classes for adding to classifier");		return;	    }	/* Given covariance matrices for each class (* number of examples - 1)	    compute the average (common) covariance matrix */	avgcov = NewMatrix(sc->nfeatures, sc->nfeatures);	ZeroMatrix(avgcov);	ne = 0;	for(c = 0; c < sc->nclasses; c++) {		scd = sc->classdope[c];		ne += scd->nexamples;		s = scd->sumcov;		for(i = 0; i < sc->nfeatures; i++)			for(j = i; j < sc->nfeatures; j++)				avgcov[i][j] += s[i][j]; 	}	denom = ne - sc->nclasses;	if(denom <= 0) {	    error("Number of classes must be less than number of examples");	    return;	}	oneoverdenom = 1.0 / denom;	for(i = 0; i < sc->nfeatures; i++)		for(j = i; j < sc->nfeatures; j++)			avgcov[j][i] = avgcov[i][j] *= oneoverdenom;	Z('a') PrintMatrix(avgcov, "Average Covariance Matrix\n");	/* invert the avg covariance matrix */	sc->invavgcov = NewMatrix(sc->nfeatures, sc->nfeatures);	det = InvertMatrix(avgcov, sc->invavgcov);	if(fabs(det) <= EPS)		FixClassifier(sc, avgcov);		/* now compute discrimination functions */	sc->w = allocate(sc->nclasses, Vector);	sc->cnst = NewVector(sc->nclasses);	for(c = 0; c < sc->nclasses; c++) {		scd = sc->classdope[c];		sc->w[c] = NewVector(sc->nfeatures);		VectorTimesMatrix(scd->average, sc->invavgcov, sc->w[c]);		sc->cnst[c] = -0.5 * InnerProduct(sc->w[c], scd->average);		/* could add log(priorprob class c) to cnst[c] */	}	FreeMatrix(avgcov);	return;}sClassDopesClassify(sc, fv) {	return sClassifyAD(sc, fv, NULL, NULL);}sClassDopesClassifyAD(sc, fv, ap, dp)sClassifier sc;Vector fv;double *ap;double *dp;{	double disc[MAXSCLASSES];	register int i, maxclass;	double denom, exp();	register sClassDope scd;	double d;	if(sc->w == NULL) {		error("%x not a trained classifier", sc);		return(NULL);       }	for(i = 0; i < sc->nclasses; i++) {/* ari */	  double IP;	  IP = InnerProduct(sc->w[i], fv);/*	  fprintf(stderr, "sClassifyAD:  InnerProduct for class %s is %f.\n", sc->classdope[i]->name, IP); *//*	  fprintf(stderr, "sClassifyAD:  sc->cnst[i] = %f.\n", sc->cnst[i]); */	  disc[i] = IP + sc->cnst[i];/*	  fprintf(stderr, "sClassifyAD:  Set disc = %f for class %s.\n", disc[i],sc->classdope[i]->name); */	    /*	  disc[i] = InnerProduct(sc->w[i], fv) + sc->cnst[i]; */	}	maxclass = 0;	for(i = 1; i < sc->nclasses; i++)		if(disc[i] > disc[maxclass])			maxclass = i;/* ari *//* PF_INIT_COS	0	 initial angle (cos)                         *//* PF_INIT_SIN	1	 initial angle (sin)                         *//* PF_BB_LEN	2	 length of bounding box diagonal             *//* PF_BB_TH	3	 angle of bounding box diagonal              *//* PF_SE_LEN	4	 length between start and end points         *//* PF_SE_COS	5	 cos of angle between start and end points   *//* PF_SE_SIN	6	 sin of angle between start and end points   *//* PF_LEN	7	 arc length of path                          *//* PF_TH	8	 total angle traversed                       *//* PF_ATH	9	 sum of abs vals of angles traversed         *//* PF_SQTH	10	 sum of squares of angles traversed          *//* PF_DUR	11	 duration of path                            */ /* ifndef USE_TIME                                                   *//* 	NFEATURES	12                                           *//* else                                                              *//* 	PF_MAXV		12	   maximum speed                     *//* 	NFEATURES	13                                           *//* endif                                                             *//** fprintf(stderr, "\nFeature vector:\n");* fprintf(stderr, "    start cosine      %8.4f    path length       %8.4f\n",* 	fv[PF_INIT_COS], fv[PF_LEN]);* fprintf(stderr, "    start sine        %8.4f    total angle       %8.4f\n",* 	fv[PF_INIT_SIN], fv[PF_TH]);* fprintf(stderr, "    b.b. length       %8.4f    total abs. angle  %8.4f\n",* 	fv[PF_BB_LEN], fv[PF_ATH]);* fprintf(stderr, "    b.b. angle        %8.4f    total sq. angle   %8.4f\n",* 	fv[PF_BB_TH], fv[PF_SQTH]);* fprintf(stderr, "    st-end length     %8.4f    duration          %8.4f\n",* 	fv[PF_SE_LEN], fv[PF_DUR]);* fprintf(stderr, "    st-end cos        %8.4f\n", fv[PF_SE_COS]);* fprintf(stderr, "    st-end sin        %8.4f\n", fv[PF_SE_SIN]);*/ 	ZZ('C') {		scd = sc->classdope[maxclass];		PrintVector(fv, "%10.10s  ", scd->name);		ZZZ('C') {			for(i = 0; i < sc->nclasses; i++) {				scd = sc->classdope[i];				PrintVector(scd->average, "%5.5s %5g ",					scd->name, disc[i]);			}		}	}	scd = sc->classdope[maxclass];/* ari *//* fprintf(stderr,"%s", scd->name); *//*   fprintf(stderr,"Stroke identified as %s [ ", scd->name);   for (i = 0; i < sc->nclasses; i++) {      if ( (disc[maxclass] - disc[i] < 5.0) && (i != maxclass) )         fprintf(stderr,"%s ", sc->classdope[i]->name);   }   fprintf(stderr,"], ");*/	if(ap) {	/* calculate probability of non-ambiguity */		for(denom = 0, i = 0; i < sc->nclasses; i++)			/* quick check to avoid computing negligible term */			if((d = disc[i] - disc[maxclass]) > -7.0)				denom += exp(d);		*ap = 1.0 / denom;	}	if(dp) 	/* calculate distance to mean of chosen class */		*dp = MahalanobisDistance(fv, scd->average, sc->invavgcov);	return scd;}/* Compute (v-u)' sigma (v-u) */doubleMahalanobisDistance(v, u, sigma)register Vector v, u;register Matrix sigma;{	register int i;	static Vector space;	double result;	if(space == NULL || NROWS(space) != NROWS(v)) {		if(space) FreeVector(space);		space = NewVector(NROWS(v));	}	for(i = 0; i < NROWS(v); i++)		space[i] = v[i] - u[i];	result =  QuadraticForm(space, sigma);	return result;}voidFixClassifier(sc, avgcov)register sClassifier sc;Matrix avgcov;{	int i;	double det;	BitVector bv;	Matrix m, r;	/* just add the features one by one, discarding any that cause	   the matrix to be non-invertible */	CLEAR_BIT_VECTOR(bv);	for(i = 0; i < sc->nfeatures; i++) {		BIT_SET(i, bv);		m = SliceMatrix(avgcov, bv, bv);		r = NewMatrix(NROWS(m), NCOLS(m));		det = InvertMatrix(m, r);		if(fabs(det) <= EPS)			BIT_CLEAR(i, bv);		FreeMatrix(m);		FreeMatrix(r);	}	m = SliceMatrix(avgcov, bv, bv);	r = NewMatrix(NROWS(m), NCOLS(m));	det = InvertMatrix(m, r);	if(fabs(det) <= EPS) {		error("Can't fix classifier!");		return;	    }	DeSliceMatrix(r, 0.0, bv, bv, sc->invavgcov);	FreeMatrix(m);	FreeMatrix(r);}voidsDumpClassifier(sc)register sClassifier sc;{	register sClassIndex c;	printf("\n----Classifier %x, %d features:-----\n", (int)sc, sc->nfeatures);	printf("%d classes: ", sc->nclasses);	for(c = 0; c < sc->nclasses; c++)		printf("%s  ", sc->classdope[c]->name);	printf("Discrimination functions:\n");	for(c = 0; c < sc->nclasses; c++) {		PrintVector(sc->w[c], "%s: %g + ", sc->classdope[c]->name, sc->cnst[c]);		printf("Mean vectors:\n");		PrintVector(sc->classdope[c]->average, "%s: ", sc->classdope[c]->name);	    }	if( sc->invavgcov != NULL ) {	    PrintMatrix(sc->invavgcov, "Inverse average covariance matrix:\n");	}	printf("\n---------\n\n");}voidsWrite(outfile, sc)FILE *outfile;sClassifier sc;{	int i;	register sClassDope scd;	fprintf(outfile, "%d classes\n", sc->nclasses);	for(i = 0; i < sc->nclasses; i++) {		scd = sc->classdope[i];		fprintf(outfile, "%s\n", scd->name);	}	for(i = 0; i < sc->nclasses; i++) {		scd = sc->classdope[i];		OutputVector(outfile, scd->average);		OutputMatrix(outfile, scd->sumcov);		OutputVector(outfile, sc->w[i]);	}	OutputVector(outfile, sc->cnst);	OutputMatrix(outfile, sc->invavgcov);}sClassifiersRead(infile)FILE *infile;{	int i, n;	register sClassifier sc;	register sClassDope scd;	char buf[100];		Z('a') printf("Reading classifier \n");	sc = sNewClassifier();	fgets(buf, 100, infile);	if(sscanf(buf, "%d", &n) != 1) {	    error("Input error in classifier file");	    sFreeClassifier(sc);	    return(NULL);	}	Z('a') printf("  %d classes \n", n);	for(i = 0; i < n; i++) {		fscanf(infile, "%s", buf);		scd = sAddClass(sc, buf);		Z('a') printf("  %s \n", scd->name);	}	sc->w = allocate(sc->nclasses, Vector);	for(i = 0; i < sc->nclasses; i++) {		scd = sc->classdope[i];		scd->average = InputVector(infile);		scd->sumcov = InputMatrix(infile);		sc->w[i] = InputVector(infile);	}	sc->cnst = InputVector(infile);	sc->invavgcov = InputMatrix(infile);	Z('a') printf("\n");	return sc;}voidsDistances(sc, nclosest)register sClassifier sc;{	register Matrix d = NewMatrix(sc->nclasses, sc->nclasses);	register int i, j;	double min, max = 0;	int n, mi, mj;	printf("-----------\n");	printf("Computing %d closest pairs of classes\n", nclosest);	for(i = 0; i < NROWS(d); i++) {		for(j = i+1; j < NCOLS(d); j++) {			d[i][j] = MahalanobisDistance(						sc->classdope[i]->average,						sc->classdope[j]->average,						sc->invavgcov);			if(d[i][j] > max) max = d[i][j];		}	}	for(n = 1; n <= nclosest; n++) {		min = max;		mi = mj = -1;		for(i = 0; i < NROWS(d); i++) {			for(j = i+1; j < NCOLS(d); j++) {				if(d[i][j] < min)					min = d[mi=i][mj=j];			}		}		if(mi == -1)			break;		printf("%2d) %10.10s to %10.10s d=%g nstd=%g\n",			n,			sc->classdope[mi]->name,			sc->classdope[mj]->name,			d[mi][mj],			sqrt(d[mi][mj]));		d[mi][mj] = max+1;	}	printf("-----------\n");	FreeMatrix(d);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
五月激情综合色| 9色porny自拍视频一区二区| 国产原创一区二区三区| 国产欧美日韩麻豆91| 国产亚洲欧美激情| 亚洲激情图片小说视频| 亚洲成人一二三| 国产在线精品一区二区| 欧洲av一区二区嗯嗯嗯啊| 欧美精品在欧美一区二区少妇| 欧美影片第一页| 久久日一线二线三线suv| 亚洲视频一区二区在线| 精品欧美久久久| 五月婷婷激情综合网| 国产高清不卡一区二区| 欧美性受xxxx黑人xyx性爽| 国产亚洲成av人在线观看导航 | 国产美女视频一区| 精品少妇一区二区| 日韩欧美资源站| 亚洲一区二区三区四区在线观看| 韩国在线一区二区| 在线播放亚洲一区| 最新国产の精品合集bt伙计| 精品一区二区三区久久| 宅男在线国产精品| 亚洲国产精品久久久久婷婷884| 99久久99久久精品免费看蜜桃| 国产网红主播福利一区二区| 日本视频免费一区| 欧美日韩一区在线观看| 亚洲欧美激情插| 成人美女视频在线观看18| 久久午夜色播影院免费高清| 蜜臀av一区二区| 欧美一级精品大片| 三级欧美韩日大片在线看| 欧美精品在线观看一区二区| 午夜精品久久久| 欧美精品一区二区三区视频| 偷拍一区二区三区四区| 91精品国产欧美日韩| 九九**精品视频免费播放| 精品国产精品网麻豆系列| 精品一区二区三区免费播放 | 麻豆精品视频在线观看视频| 日韩一级成人av| 国产一区二区三区久久久| 国产性色一区二区| 成人动漫中文字幕| 一区二区三区波多野结衣在线观看| 色综合久久久久综合体| 亚洲福利视频三区| 日韩欧美你懂的| 国产在线精品一区二区三区不卡 | 91麻豆国产香蕉久久精品| 亚洲欧美成人一区二区三区| 国产精品高潮呻吟久久| 视频在线观看一区| 欧美大度的电影原声| 91亚洲资源网| 婷婷六月综合网| 国产日产欧美精品一区二区三区| 91蝌蚪porny| 久久99精品视频| 一区二区免费在线| 亚洲精品一线二线三线| 成人sese在线| 麻豆精品新av中文字幕| 亚洲视频综合在线| 精品国产麻豆免费人成网站| 在线精品视频免费播放| 成人综合激情网| 麻豆精品蜜桃视频网站| 91精品婷婷国产综合久久性色| 成人av网址在线| 久久99精品国产.久久久久| 亚洲综合小说图片| 亚洲区小说区图片区qvod| 久久九九国产精品| 欧美裸体bbwbbwbbw| 99久久99久久精品免费看蜜桃| 精品一区二区成人精品| 日韩成人免费看| 亚洲激情图片一区| 亚洲天堂网中文字| 国产精品不卡一区二区三区| 国产拍揄自揄精品视频麻豆| 国产iv一区二区三区| 日韩影院在线观看| 亚洲美女免费视频| 亚洲视频一区二区在线观看| 欧美精品一区二区三区蜜臀 | 日韩主播视频在线| 日韩欧美在线影院| 欧美二区在线观看| 欧美一区在线视频| 精品久久久久久久久久久久包黑料 | 精品日韩一区二区三区免费视频| 欧美视频在线播放| 99re视频精品| 欧美无砖专区一中文字| 欧美一区二区三区在线观看视频| 日韩免费在线观看| 国产亲近乱来精品视频| 一区二区三区四区不卡在线 | 欧美日韩电影一区| 欧美剧情电影在线观看完整版免费励志电影 | 在线亚洲一区二区| 欧美日本视频在线| 久久亚洲精品小早川怜子| 国产日产欧美一区| 一区二区在线电影| 亚洲成人精品一区| 国产一区中文字幕| 一本大道久久a久久综合| 制服丝袜亚洲色图| 亚洲国产成人一区二区三区| 玉足女爽爽91| 色婷婷综合久久久久中文 | 成人一级片在线观看| 精品视频全国免费看| 精品国产乱码久久久久久1区2区 | 国产99久久久久| 欧美精品久久久久久久久老牛影院| 亚洲精品在线电影| 三级久久三级久久| 精品国产青草久久久久福利| 欧美久久久一区| 中文字幕一区二区三区在线不卡| 青青青爽久久午夜综合久久午夜| jiyouzz国产精品久久| 日韩精品中午字幕| 亚洲在线中文字幕| 97精品视频在线观看自产线路二| 成人自拍视频在线| 日韩精品一区二区三区三区免费| 亚洲综合一区二区三区| 成人午夜精品一区二区三区| 久久久噜噜噜久噜久久综合| 亚洲一区二区在线免费观看视频| 成人黄动漫网站免费app| 久久久久久久精| 国产高清精品久久久久| 久久人人爽爽爽人久久久| 日本sm残虐另类| 日韩一区二区精品在线观看| 午夜欧美电影在线观看| 在线观看视频一区二区欧美日韩| 亚洲日本一区二区| 99re免费视频精品全部| 亚洲精品网站在线观看| 日本道免费精品一区二区三区| 《视频一区视频二区| 成人av网站在线观看| 亚洲区小说区图片区qvod| 欧美国产欧美综合| 一本一本久久a久久精品综合麻豆| 国产精品久久久爽爽爽麻豆色哟哟| 国产成a人亚洲| 一区二区三区国产精华| 欧美一级高清大全免费观看| 奇米色777欧美一区二区| 精品成人在线观看| 91丨porny丨蝌蚪视频| 亚洲欧美激情一区二区| 久久综合狠狠综合| 粉嫩aⅴ一区二区三区四区五区| 国产精品美女久久久久久久久| 91丨porny丨蝌蚪视频| 另类调教123区| 综合色中文字幕| 欧美一区二区三级| 成人国产电影网| 久久国产精品99久久久久久老狼| 国产精品看片你懂得 | 99久久综合精品| 日韩影院在线观看| 国产精品免费视频观看| 88在线观看91蜜桃国自产| caoporn国产精品| 精品亚洲成a人在线观看| 日韩一区二区三区免费观看| 国产美女娇喘av呻吟久久| 日日骚欧美日韩| 夜夜爽夜夜爽精品视频| 国产女主播视频一区二区| 欧美日韩黄视频| 一本到不卡精品视频在线观看| 久久99深爱久久99精品| 亚洲成人一区在线| 亚洲乱码中文字幕| 中文字幕精品—区二区四季| 欧美一级专区免费大片| 精品成人私密视频| 成人黄页在线观看| 成人a免费在线看| 国产99久久久久久免费看农村| 另类调教123区|