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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? sc.c

?? 一個linux下的根文件系統(tǒng)的源碼
?? 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 <string.h>#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);}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久精品国产一区二区三区 | kk眼镜猥琐国模调教系列一区二区 | 免费在线观看不卡| 蜜桃视频免费观看一区| 久久成人免费电影| 国产成人免费在线视频| 99久久精品免费观看| 91久久精品一区二区三| 69p69国产精品| 久久久久97国产精华液好用吗 | 亚洲三级在线观看| 亚洲成人免费在线观看| 美女脱光内衣内裤视频久久网站| 精品一区二区免费视频| 99精品一区二区三区| 欧美美女直播网站| 久久久久一区二区三区四区| 一区二区成人在线观看| 精品一区免费av| 色综合久久88色综合天天| 日韩一区二区三区四区五区六区| 亚洲国产精品成人久久综合一区| 亚洲一区二区视频| 豆国产96在线|亚洲| 日韩欧美在线123| 亚洲影院久久精品| 成人黄动漫网站免费app| www.欧美.com| 欧美日产国产精品| 中文字幕一区二区三| 激情成人午夜视频| 制服丝袜在线91| 午夜精品一区在线观看| 91极品美女在线| 国产精品理论片| 成人综合婷婷国产精品久久免费| 欧美一级欧美三级在线观看| 亚洲午夜精品17c| 99久久婷婷国产精品综合| 国产欧美日韩三级| 国产精品99久久久久久有的能看| 在线成人免费视频| 亚洲va韩国va欧美va| 色8久久人人97超碰香蕉987| 成人欧美一区二区三区黑人麻豆| 国产成人av一区二区三区在线| 337p粉嫩大胆色噜噜噜噜亚洲| 91在线观看成人| 亚洲乱码日产精品bd| 欧美在线免费播放| 国产成人精品综合在线观看| 欧美另类久久久品| 日韩av电影天堂| 久久综合九色综合久久久精品综合| 国内一区二区在线| 国产精品久久免费看| 亚洲777理论| 2023国产一二三区日本精品2022| 九九精品视频在线看| 精品国产三级电影在线观看| 国产精品一区二区91| 国产精品每日更新| 欧美日韩国产高清一区二区三区| 天堂影院一区二区| 久久夜色精品一区| 在线免费一区三区| 国产麻豆精品一区二区| 亚洲天天做日日做天天谢日日欢| 欧美在线免费播放| 福利一区二区在线| 亚洲国产日韩一区二区| 久久久久一区二区三区四区| 色欧美88888久久久久久影院| 五月天激情综合网| 亚洲欧美在线另类| 精品国产成人系列| 欧美美女直播网站| 91亚洲精品久久久蜜桃| 黑人精品欧美一区二区蜜桃| 欧美探花视频资源| 日韩av一区二| 亚洲一区在线观看免费 | 中文字幕在线视频一区| 日韩午夜电影av| 欧美日韩国产一区| 91同城在线观看| 福利一区二区在线| 国产一区二区影院| 国产一区二区女| 久久黄色级2电影| 人人爽香蕉精品| 蜜桃视频在线观看一区二区| 亚洲国产色一区| 亚洲成人精品影院| 亚洲一区二区欧美激情| 亚洲欧美日韩在线不卡| 国产精品女主播在线观看| 久久色在线观看| 日韩精品综合一本久道在线视频| 欧美美女一区二区在线观看| 欧美日韩在线三级| 欧美午夜电影网| 欧美日韩国产影片| 日韩欧美国产系列| 久久女同性恋中文字幕| 中文字幕精品一区| 国产精品国产精品国产专区不蜜| 国产精品沙发午睡系列990531| 欧美激情综合网| 亚洲免费在线视频| 亚洲成av人片一区二区| 理论电影国产精品| 成人精品国产一区二区4080| 91女人视频在线观看| 在线播放国产精品二区一二区四区| 欧美高清视频一二三区 | 国产免费成人在线视频| 亚洲人成在线播放网站岛国| 夜夜精品浪潮av一区二区三区| 中文字幕一区二区不卡| 一片黄亚洲嫩模| 久久不见久久见中文字幕免费| 国产在线精品一区二区三区不卡 | 国产精品毛片高清在线完整版| 国产欧美日韩在线| 天天影视涩香欲综合网| 精品一区二区三区在线观看| 成人永久aaa| 欧美久久久久中文字幕| 亚洲人精品一区| 国产伦精品一区二区三区视频青涩 | 水蜜桃久久夜色精品一区的特点| 韩国理伦片一区二区三区在线播放| 成人av在线影院| 欧美精品一二三| 亚洲国产中文字幕| 成人av中文字幕| 国产亚洲婷婷免费| 精品一区二区三区久久久| 91国产免费观看| 国产精品免费观看视频| 久久99精品久久久| 欧美日韩国产小视频在线观看| 最新国产成人在线观看| 国产精品一区二区视频| 欧美精品一区二区三区高清aⅴ| 亚洲高清免费在线| 欧美亚洲免费在线一区| 一区二区三区不卡视频在线观看| 97超碰欧美中文字幕| 一区二区三区中文字幕电影| 一本色道久久综合狠狠躁的推荐| 国产精品久久久久久久久果冻传媒| 久久精品久久精品| 欧美精品一区二区三区久久久| 国产永久精品大片wwwapp| 国产欧美日韩一区二区三区在线观看| 国产91精品免费| 一区二区三区欧美日韩| 欧美精品乱码久久久久久| 美女看a上一区| 26uuu亚洲综合色欧美| 暴力调教一区二区三区| 亚洲午夜激情av| 精品国产露脸精彩对白| 99这里只有精品| 日本欧美久久久久免费播放网| 精品理论电影在线| 97se狠狠狠综合亚洲狠狠| 热久久免费视频| 国产精品色婷婷| 欧美揉bbbbb揉bbbbb| 国产美女久久久久| 亚洲国产aⅴ成人精品无吗| 精品成人一区二区| 欧美性色欧美a在线播放| 九九国产精品视频| 中文字幕日韩av资源站| 欧美片网站yy| av日韩在线网站| 国产一区不卡视频| 日本在线不卡视频| 成人欧美一区二区三区白人| 欧美大片在线观看一区二区| www.亚洲色图.com| 国内精品伊人久久久久av影院 | 成人小视频免费观看| 奇米一区二区三区| 亚洲精品第一国产综合野| 久久嫩草精品久久久久| 欧美成人vr18sexvr| 精品视频免费在线| 在线视频欧美区| 99精品国产91久久久久久| 国产在线观看一区二区| 免费欧美在线视频| 日产精品久久久久久久性色| 亚洲蜜臀av乱码久久精品| 亚洲精品国产精品乱码不99 | 久久精品国产秦先生|