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

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

?? clda.cpp

?? 該程序包實現了模式識別中的兩個特征提取算法
?? CPP
字號:
#include "stdlib.h"
#include <iostream>
#include <string.h>
#include <fstream>
#include <math.h>
using namespace std;
#include "global.h"

CLda::CLda()
{
	this->numF = -1;
}

CLda::~CLda()
{
}

bool CLda::extract(char* trainFile, char* newTrainFile, char* testFile, char* newTestFile)
{
	bool ret = true;
	int i, j, k, index, cnum;
	if (this->numF <= 0)
		this->numF = 1;
	ret = this->sdata.readFile(trainFile);//讀入訓練數據
	if (!ret)
		return false;//如果數據格式不正確,退出程序。
	int numClass = this->sdata.numClass;
	int numFeature = this->sdata.numFeature;
	int numSample = this->sdata.numSample;
	CSampleData testData;
	ret = testData.readFile(testFile);
	if (!ret)
		return false;//如果數據格式不正確,退出程序。
	DOUBLE temp1, temp2;
	if (this->numF > this->sdata.numFeature)
		this->numF = this->sdata.numFeature;
	int newNumF = this->numF;
	DOUBLE *sumX = new DOUBLE[numClass*numFeature];
	DOUBLE *sumXX = new DOUBLE[numClass*numFeature*numFeature];
	int* classSample = new int[numClass];
	int total;
	for (i=0; i<numClass; i++)
	{
		classSample[i]=0;
	}
	total = numClass * numFeature;
	for (i=0; i<total; i++)
	{
		sumX[i]=0;
	}
	total = numClass * numFeature * numFeature;
	for (i=0; i<total; i++)
	{
		sumXX[i]=0;
	}
	for (i=0; i<numSample; i++)
	{
		cnum = this->sdata.ydata[i];
		classSample[cnum] ++;
		for (j=0; j<numFeature; j++)
		{
			sumX[cnum*numFeature+j] += this->sdata.xdata[i*numFeature+j];
			for (k=j; k<numFeature; k++)
			{
				sumXX[(cnum*numFeature+j)*numFeature+k] +=this->sdata.xdata[i*numFeature+j] * this->sdata.xdata[i*numFeature+k];
			}
		}
	}
	for (i=0; i<numClass; i++)
	{
		for (j=0; j<numFeature; j++)
		{
			sumX[i*numFeature+j] = sumX[i*numFeature+j] / ((DOUBLE) classSample[i]);
		}
	}
	for (i=0; i<numClass; i++)
	{
		for (j=0; j<numFeature; j++)
		{
			for (k=j; k<numFeature; k++)
			{
				index = (i*numFeature+j)*numFeature+k;
				sumXX[index] = sumXX[index]/((DOUBLE)classSample[i])-(sumX[i*numFeature+j]*sumX[i*numFeature+k]);
			}
		}
	}
	DOUBLE *U0 = new DOUBLE[numFeature];
	DOUBLE *SW = new DOUBLE[numFeature*numFeature];
	DOUBLE *SB = new DOUBLE[numFeature*numFeature];
	for (j=0; j<numFeature; j++)
	{
		U0[j] = 0;
		for (k=0; k<numClass; k++)
		{
			U0[j] += sumX[k*numFeature+j]*((DOUBLE)classSample[k]);
		}
		U0[j] = U0[j]/((DOUBLE)numSample);
	}
	for (i=0; i<numFeature; i++)
	{
		for (j=i; j<numFeature; j++)
		{
			index = i*numFeature+j;
			SW[index] = 0;
			for (k=0; k<numClass; k++)
			{
				SW[index] += sumXX[((k*numFeature)+i)*numFeature+j]*classSample[k];
			}
			SW[index] = SW[index]/((DOUBLE)numSample);
		}
	}
	for (i=0; i<numFeature; i++)
	{
		for (j=i; j<numFeature; j++)
		{
			index = i*numFeature+j;
			SB[index] = 0;
			for (k=0; k<numClass; k++)
			{
				SB[index] += (sumX[k*numFeature+i]-U0[i])*(sumX[k*numFeature+j]-U0[j])*((DOUBLE)classSample[k]);
			}
			SB[index] = SB[index]/((DOUBLE)numSample);
		}
	}
	for (j=1; j<numFeature; j++)
	{
		for (k=0; k<j; k++)
		{
			SW[j*numFeature+k] = SW[k*numFeature+j];
			SB[j*numFeature+k] = SB[k*numFeature+j];
		}
	}
	/*for (j=0; j<numFeature; j++)//限制協方差矩陣的對角元素的下限
	{
		if (SW[j*numFeature+j]<0.001)
		{
			SW[j*numFeature+j] = 0.001;
		}
	}*/


	//計算特征值
	CMatrix theMat;
	float** Cova;
	// Allocate space for the covariance matrix
	Cova = theMat.allocMat(numFeature);		// n: dimensionality of vector
	for (i=0; i<numFeature; i++)
	{
		for (j=0; j<numFeature; j++)
		{
			Cova[i][j] = (float)SW[i*numFeature+j];
		}
	}
	// Compute the covariance matrix......
	// Diagonalization
	// P: matrix with columns as the eigenvectors
	float** P;
	P = theMat.allocMat(numFeature);
	theMat.diagonalize( Cova, numFeature, P );
	//顯示計算的特征值
	for (i=0; i<numFeature; i++)
	{
		cout<<endl;
		for (j=0; j<numFeature; j++)
		{
			temp2 = 0;
			for (k=0; k<numFeature; k++)
			{
				temp2 += SW[i*numFeature+k]*((DOUBLE)P[k][j]);
			}
			cout<<temp2/P[i][j]<<"  ";
		}
	}
	cout<<endl;

	DOUBLE* featureValue = new DOUBLE[numFeature];
	int* featureIndex = new int[numFeature];
	for (i=0; i<numFeature; i++)
	{
		featureValue[i] = 0;
		featureIndex[i] = i;
	}
	for (j=0; j<numFeature; j++)//計算特征值
	{
		temp1 = 0;
		for (i=0; i<numFeature; i++)
		{
			temp2 = 0;
			for (k=0; k<numFeature; k++)
			{
				temp2 += SW[i*numFeature+k]*((DOUBLE)P[k][j]);
			}
			if (P[i][j]>0)
			{
				temp1 += (DOUBLE)P[i][j];
				featureValue[j] += temp2;
			}
			else
			{
				temp1 -= (DOUBLE)P[i][j];
				featureValue[j] -= temp2;
			}
		}
		featureValue[j] = featureValue[j]/temp1;
		cout<<featureValue[j]<<endl;
	}
	DOUBLE* W1 = new DOUBLE[numFeature*numFeature];//計算W1
	for (i=0; i<numFeature; i++)
	{
		if (featureValue[i]<0.001)//限制特征值最小值為0.001
		{
			temp1 = sqrt(0.001);
		}
		else
		{
			temp1 = sqrt(featureValue[i]);
		}
		for (j=0; j<numFeature; j++)
		{
			W1[j*numFeature+i] = ((DOUBLE)P[j][i])/temp1;
		}
	}
	for (i=0; i<numFeature; i++)
	{
		for (j=0; j<numFeature; j++)
		{
			sumXX[i*numFeature+j] = 0;
			for (k=0; k<numFeature; k++)
			{
				sumXX[i*numFeature+j] += W1[k*numFeature+i]*SB[k*numFeature+j];
			}
		}
	}
	for (i=0; i<numFeature; i++)
	{
		for (j=i; j<numFeature; j++)
		{
			SB[i*numFeature+j] = 0;
			for (k=0; k<numFeature; k++)
			{
				SB[i*numFeature+j] += sumXX[i*numFeature+k]*W1[k*numFeature+j];
			}
		}
	}
	for (i=1; i<numFeature; i++)
	{
		for (j=0; j<i; j++)
		{
			SB[i*numFeature+j] = SB[j*numFeature+i];
		}
	}
	cout<<endl;
	for (i=0; i<numFeature; i++)
	{
		cout<<endl;
		for (j=0; j<numFeature; j++)
		{
			Cova[i][j] = (float)SB[i*numFeature+j];
			cout<<Cova[i][j]<<"  ";
		}
	}
	cout<<endl;
	theMat.diagonalize( Cova, numFeature, P );//
	//顯示計算的特征值
	for (i=0; i<numFeature; i++)
	{
		cout<<endl;
		for (j=0; j<numFeature; j++)
		{
			temp2 = 0;
			for (k=0; k<numFeature; k++)
			{
				temp2 += SB[i*numFeature+k]*((DOUBLE)P[k][j]);
			}
			cout<<temp2/P[i][j]<<"  ";
		}
	}
	cout<<endl;

	for (i=0; i<numFeature; i++)
	{
		featureValue[i] = 0;
		featureIndex[i] = i;
	}
	for (j=0; j<numFeature; j++)//計算特征值
	{
		temp1 = 0;
		for (i=0; i<numFeature; i++)
		{
			temp2 = 0;
			for (k=0; k<numFeature; k++)
			{
				temp2 += SB[i*numFeature+k]*((DOUBLE)P[k][j]);
			}
			if (P[i][j]>0)
			{
				temp1 += (DOUBLE)P[i][j];
				featureValue[j] += temp2;
			}
			else
			{
				temp1 -= (DOUBLE)P[i][j];
				featureValue[j] -= temp2;
			}
		}
		featureValue[j] = featureValue[j]/temp1;
		cout<<featureValue[j]<<endl;
	}
	for (i=0; i<numFeature-1; i++)//特征值排序
	{
		for (j=numFeature-1; j>i; j--)
		{
			if (featureValue[j-1]<featureValue[j])
			{
				temp1 = featureValue[j-1];
				featureValue[j-1] = featureValue[j];
				featureValue[j] = temp1;
				k = featureIndex[j-1];
				featureIndex[j-1] = featureIndex[j];
				featureIndex[j] = k;
			}
		}
	}
	for (i=0; i<numFeature; i++)
	{
		for (j=0; j<numFeature; j++)
		{
			sumXX[i*numFeature+j] = (DOUBLE)P[i][featureIndex[j]];
		}
	}
	DOUBLE* W = new DOUBLE[numFeature*numFeature];//計算W
	for (i=0; i<numFeature; i++)
	{
		for (j=0; j<numFeature; j++)
		{
			W[i*numFeature+j] = 0;
			for (k=0; k<numFeature; k++)
			{
				W[i*numFeature+j] += W1[i*numFeature+k]*sumXX[k*numFeature+j];
			}
		}
	}
	//提取特征
	DOUBLE *temp = new DOUBLE[newNumF];
	for (i=0; i<numSample; i++)//中心化
	{
		for (j=0; j<numFeature; j++)
		{
			this->sdata.xdata[i*numFeature+j] -= U0[j];
		}
	}
	for (i=0; i<numSample; i++)
	{
		for (j=0; j<newNumF; j++)
		{
			temp[j] = 0;
		}
		for (j=0; j<newNumF; j++)
		{
			for (k=0; k<numFeature; k++)
			{
				temp[j] += (W[k*numFeature+j])*this->sdata.xdata[i*numFeature+k];
			}
		}
		for (j=0; j<newNumF; j++)
		{
			this->sdata.xdata[i*newNumF+j] = temp[j];
		}
	}
	this->sdata.numFeature = newNumF;
	this->sdata.writeFile(newTrainFile);//寫新的訓練數據文件
	
	for (i=0; i<testData.numSample; i++)//中心化測試數據
	{
		for (j=0; j<numFeature; j++)
		{
			testData.xdata[i*numFeature+j] -= U0[j];
		}
	}
	for (i=0; i<testData.numSample; i++)
	{
		for (j=0; j<newNumF; j++)
		{
			temp[j] = 0;
		}
		for (j=0; j<newNumF; j++)
		{
			for (k=0; k<numFeature; k++)
			{
				temp[j] += (W[k*numFeature+j])*testData.xdata[i*numFeature+k];
			}
		}
		for (j=0; j<newNumF; j++)
		{
			testData.xdata[i*newNumF+j] = temp[j];
		}
	}
	testData.numFeature = newNumF;
	testData.writeFile(newTestFile);
	delete[] Cova;
	delete[] P;
	delete[] temp;
	delete[] featureValue;
	delete[] featureIndex;
	delete[] W1;
	delete[] W;
	delete[] sumX;
	delete[] sumXX;
	delete[] U0;
	delete[] SW;
	delete[] SB;
	return ret;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲日韩欧美一区二区在线| 亚洲色图另类专区| 91在线一区二区三区| 天天综合色天天综合| 日本一二三不卡| 欧美一区二区美女| 色综合久久久久| 国产精品亚洲一区二区三区在线 | 国产精品素人一区二区| 亚洲欧洲一区二区在线播放| 欧美四级电影在线观看| 成人av小说网| 国产精选一区二区三区| 日韩综合一区二区| 一区二区三区四区视频精品免费 | 欧美性淫爽ww久久久久无| 国产高清亚洲一区| 日本伊人午夜精品| 亚洲一区二区三区三| 国产精品免费看片| 久久蜜桃av一区精品变态类天堂 | 日韩免费高清av| 欧美日韩国产一区| 日本韩国欧美一区二区三区| 丰满岳乱妇一区二区三区| 狠狠色伊人亚洲综合成人| 日本在线观看不卡视频| 亚洲6080在线| 亚洲一区二区黄色| 一区二区三区日韩精品视频| 亚洲欧洲精品一区二区精品久久久| 欧美成人性福生活免费看| 欧美日本免费一区二区三区| 欧美亚洲国产bt| 欧美性做爰猛烈叫床潮| 欧美日韩一区二区三区在线看| 色屁屁一区二区| 国产精品毛片无遮挡高清| 欧美激情资源网| 欧美国产日韩a欧美在线观看| 国产亚洲成aⅴ人片在线观看| 日韩欧美一区二区视频| 日韩精品一区二区三区中文精品| 91精品福利在线一区二区三区| 欧美三级电影在线观看| 欧美丰满一区二区免费视频| 欧美日韩和欧美的一区二区| 欧美色爱综合网| 在线不卡免费欧美| 欧美一区二区在线免费观看| 日韩精品一区二区三区在线| 亚洲精品在线观看网站| 国产欧美精品一区| 亚洲欧洲精品一区二区精品久久久 | 91免费视频网| 91精品办公室少妇高潮对白| 欧美亚洲禁片免费| 91精品综合久久久久久| 91精品中文字幕一区二区三区| 欧美福利一区二区| 日韩久久久精品| 精品国产3级a| 欧美国产乱子伦| 一区二区中文视频| 亚洲国产日韩精品| 婷婷夜色潮精品综合在线| 日本一不卡视频| 久久国产精品99久久久久久老狼 | 欧美aaa在线| 国产一区二区在线观看视频| 不卡视频在线看| 在线观看成人小视频| 日韩欧美激情一区| 国产欧美精品一区二区三区四区| 成人av资源站| 欧美日韩视频在线观看一区二区三区| 欧美一区二区女人| 欧美国产视频在线| 亚洲va在线va天堂| 国产精品一二一区| 欧美在线观看一区二区| 精品国产一区二区亚洲人成毛片| 欧美国产激情二区三区 | 国产ts人妖一区二区| 色综合视频在线观看| 777午夜精品免费视频| 国产无人区一区二区三区| 亚洲精品视频一区| 久草这里只有精品视频| 色偷偷88欧美精品久久久| 精品国产区一区| 亚洲一区电影777| 国产激情偷乱视频一区二区三区| 在线观看中文字幕不卡| 久久免费精品国产久精品久久久久| 亚洲精品久久7777| 国产风韵犹存在线视精品| 欧美女孩性生活视频| 国产精品成人一区二区艾草 | 成人av资源在线观看| 日韩欧美成人激情| 艳妇臀荡乳欲伦亚洲一区| 国产精品白丝av| 在线不卡的av| 一区二区三区在线高清| 国产99久久久精品| 日韩午夜在线观看| 亚洲成人7777| 一本色道久久加勒比精品| 国产日本欧洲亚洲| 久久狠狠亚洲综合| 欧美男人的天堂一二区| 亚洲欧洲精品一区二区三区| 国产精品主播直播| 精品美女在线播放| 石原莉奈在线亚洲三区| 欧美在线一区二区三区| 亚洲欧洲日韩一区二区三区| 国产成人精品免费网站| 欧美成va人片在线观看| 奇米综合一区二区三区精品视频| 在线免费观看日韩欧美| 国产在线精品一区在线观看麻豆| 欧美日韩久久久| 亚洲图片一区二区| 欧美亚日韩国产aⅴ精品中极品| 亚洲视频每日更新| 91同城在线观看| 亚洲视频在线一区| 91免费观看国产| 亚洲免费大片在线观看| 91在线小视频| 亚洲女子a中天字幕| 91在线观看高清| 亚洲欧美激情视频在线观看一区二区三区| 国产精品99久久久久久久vr| 久久久久久99久久久精品网站| 久久99精品国产.久久久久 | 亚洲人成7777| 色一情一乱一乱一91av| 亚洲一区在线观看免费 | 91麻豆国产在线观看| 亚洲另类在线制服丝袜| 欧洲一区二区av| 亚洲国产综合在线| 欧美日韩不卡一区| 久久精品99国产国产精| 久久夜色精品国产噜噜av| 国产激情91久久精品导航 | 日韩电影在线免费| 日韩三级视频中文字幕| 国产一区二三区| 国产日本一区二区| 91美女在线看| 亚洲国产精品自拍| 日韩一二在线观看| 欧美一区二区三区色| 久久成人av少妇免费| 国产日产欧美一区二区视频| proumb性欧美在线观看| 亚洲伊人色欲综合网| 91精品国产高清一区二区三区蜜臀| 麻豆视频观看网址久久| 国产色一区二区| 色88888久久久久久影院按摩| 亚洲国产cao| 亚洲精品在线观看视频| 波多野结衣欧美| 午夜电影网一区| 久久色在线观看| 色av成人天堂桃色av| 日韩高清电影一区| 国产人久久人人人人爽| 欧美性猛交xxxx黑人交| 裸体一区二区三区| 成人欧美一区二区三区黑人麻豆| 欧美色涩在线第一页| 狠狠色伊人亚洲综合成人| 亚洲欧美乱综合| 欧美精品一区二区蜜臀亚洲| 99久久精品国产一区二区三区| 亚洲不卡一区二区三区| 欧美精品一区二区不卡| 91麻豆精品秘密| 久久99国产精品尤物| 亚洲激情图片一区| 精品国产免费一区二区三区香蕉| 91网页版在线| 国产精品综合av一区二区国产馆| 亚洲午夜一区二区三区| 久久精品人人做人人爽人人| 欧美日韩一区二区三区四区| 粉嫩一区二区三区在线看| 日韩精品免费视频人成| 亚洲欧美偷拍三级| 久久久久九九视频| 欧美疯狂做受xxxx富婆| 91黄色小视频| 成人免费视频网站在线观看| 久久疯狂做爰流白浆xx|