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

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

?? lineardiscriminant.cpp

?? 線形判別分析算法和knn最近鄰算法的實現
?? CPP
字號:
#include <stdio.h>
#include <stdlib.h>
#include <iostream.h>
using namespace std;
#define TOTAL_NUMBER 50//樣本總數
#define TRAINING_NUMBER 30//用于訓練的樣本數量
#define TESTING_NUMBER 20//用于測試的樣本數量
#define BITMAP_SIZE 64//位圖大小
#define FEATURE_NUMBER//提取的特征數量
#define START_VALUE//w各分量的初值
#define STEP_LENGTH 5//步長

char map[BITMAP_SIZE][BITMAP_SIZE];//位圖
float feature[FEATURE_NUMBER+2];//特征第1位為對應的數字,第二位到倒數第二位為所有的特征,最后一位為擴展位(等于1)
int w0[FEATURE_NUMBER+1],w1[FEATURE_NUMBER+1],w4[FEATURE_NUMBER+1],w5[FEATURE_NUMBER+1],w6[FEATURE_NUMBER+1],w7[FEATURE_NUMBER+1],w8[FEATURE_NUMBER+1],w9[FEATURE_NUMBER+1];//判別函數(8類共8個)

void FeatureExtraction(int i)//處理數組map,提取特征,存入feature
{
}

void training()
{
	int i,j,f,g,h;
	int sum,get_figure;

    while(f<8*TRAINING_NUMBER){
		f=0;
		for(i=1;i<=8*TRAINING_NUMBER;i++){
			//從training_feature.txt中讀取一個樣本,存于數組feature中
			sum=0;
			get_figure=0;
			h=0;
			for(j=1;j<=FEATURE_NUMBER+1;j++){
				g=feature[j]*w0[j-1];
			    h=h+g;
			}
			if(h>sum){
				sum=h;
				get_figure=0;
			}

			for(j=1;j<=FEATURE_NUMBER+1;j++){
				g=feature[j]*w1[j-1];
			    h=h+g;
			}
			if(h>sum){
				sum=h;
				get_figure=1;
			}

			for(j=1;j<=FEATURE_NUMBER+1;j++){
				g=feature[j]*w4[j-1];
			    h=h+g;
			}
			if(h>sum){
				sum=h;
				get_figure=4;
			}

			for(j=1;j<=FEATURE_NUMBER+1;j++){
				g=feature[j]*w5[j-1];
			    h=h+g;
			}
			if(h>sum){
				sum=h;
				get_figure=5;
			}

			for(j=1;j<=FEATURE_NUMBER+1;j++){
				g=feature[j]*w6[j-1];
			    h=h+g;
			}
			if(h>sum){
				sum=h;
				get_figure=6;
			}

			for(j=1;j<=FEATURE_NUMBER+1;j++){
				g=feature[j]*w7[j-1];
			    h=h+g;
			}
			if(h>sum){
				sum=h;
				get_figure=7;
			}

			for(j=1;j<=FEATURE_NUMBER+1;j++){
				g=feature[j]*w8[j-1];
			    h=h+g;
			}
			if(h>sum){
				sum=h;
				get_figure=8;
			}

			for(j=1;j<=FEATURE_NUMBER+1;j++){
				g=feature[j]*w9[j-1];
			    h=h+g;
			}
			if(h>sum){
				sum=h;
				get_figure=9;
			}

			if(get_figure!=feature[0]){
				switch(get_figure)
				{
				case 0:
					{
						for(j=0;j<=FEATURE_NUMBER;j++)
							w0[j]=w0[j]+feature[j+1]*STEP_LENGTH;
					}
		        case 1:
					{
						for(j=0;j<=FEATURE_NUMBER;j++)
							w1[j]=w1[j]+feature[j+1]*STEP_LENGTH;
					}
		        case 4:
					{
						for(j=0;j<=FEATURE_NUMBER;j++)
							w4[j]=w4[j]+feature[j+1]*STEP_LENGTH;
					}
		        case 5:
					{
						for(j=0;j<=FEATURE_NUMBER;j++)
							w5[j]=w5[j]+feature[j+1]*STEP_LENGTH;
					}
		        case 6:
					{
						for(j=0;j<=FEATURE_NUMBER;j++)
							w6[j]=w6[j]+feature[j+1]*STEP_LENGTH;
					}
		        case 7:
					{
						for(j=0;j<=FEATURE_NUMBER;j++)
							w7[j]=w7[j]+feature[j+1]*STEP_LENGTH;
					}
		        case 8:
					{
						for(j=0;j<=FEATURE_NUMBER;j++)
							w8[j]=w8[j]+feature[j+1]*STEP_LENGTH;
					}
		        case 9:
					{
						for(j=0;j<=FEATURE_NUMBER;j++)
							w9[j]=w9[j]+feature[j+1]*STEP_LENGTH;
					}
		        default:break;
				}
			}
			else
				f++;
		}
	}
	return;
}

void testing()
{
	int i,j,g,h;
	int sum,get_figure;

	for(i=1;i<=8*TRAINING_NUMBER;i++){
		//從testing_feature.txt中讀取一個樣本,存于數組feature中
		sum=0;
		get_figure=0;
		h=0;
		for(j=1;j<=FEATURE_NUMBER+1;j++){
			g=feature[j]*w0[j-1];
		    h=h+g;
		}
		if(h>sum){
			sum=h;
			get_figure=0;
		}

		for(j=1;j<=FEATURE_NUMBER+1;j++){
			g=feature[j]*w1[j-1];
		    h=h+g;
		}
		if(h>sum){
			sum=h;
			get_figure=1;
		}

		for(j=1;j<=FEATURE_NUMBER+1;j++){
			g=feature[j]*w4[j-1];
		    h=h+g;
		}
		if(h>sum){
			sum=h;
			get_figure=4;
		}

		for(j=1;j<=FEATURE_NUMBER+1;j++){
			g=feature[j]*w5[j-1];
		    h=h+g;
		}
		if(h>sum){
			sum=h;
			get_figure=5;
		}

		for(j=1;j<=FEATURE_NUMBER+1;j++){
			g=feature[j]*w6[j-1];
		    h=h+g;
		}
		if(h>sum){
			sum=h;
			get_figure=6;
		}

		for(j=1;j<=FEATURE_NUMBER+1;j++){
			g=feature[j]*w7[j-1];
		    h=h+g;
		}
		if(h>sum){
			sum=h;
			get_figure=7;
		}

		for(j=1;j<=FEATURE_NUMBER+1;j++){
			g=feature[j]*w8[j-1];
		    h=h+g;
		}
		if(h>sum){
			sum=h;
			get_figure=8;
		}

		for(j=1;j<=FEATURE_NUMBER+1;j++){
			g=feature[j]*w9[j-1];
		    h=h+g;
		}
		if(h>sum){
			sum=h;
			get_figure=9;
		}
		cout<<feature[0]<<" "<<get_figure<<"\n";//真實值與識別值的對比
	}
}

int main()
{
	int i,j;
//----------------------特征提取---------------------
//1,選取特征
//2,輸入8個文件(8個數字,每個數字一個文件,每個文件中包含50個樣本)
//   輸出兩個文件(一個文件存訓練樣本提取出的8*30個特征向量,另一個文件存測試樣本提取出的8*20個特征向量)
	ifstream inf;
	ofstream training_outf,testing_outf;
    training_outf.open("training_feature.txt");
	testing_outf.open("testing_feature.txt");
	for(i=0;i<=9;i++){
		switch(i)
		{
		case 0:inf.open("digit0.dat");
		case 1:inf.open("digit1.dat");
		case 4:inf.open("digit4.dat");
		case 5:inf.open("digit5.dat");
		case 6:inf.open("digit6.dat");
		case 7:inf.open("digit7.dat");
		case 8:inf.open("digit8.dat");
		case 9:inf.open("digit9.dat");
		default:break;
		}

		char c;
		inf>>noskipws;//不忽略空白,把每行最后那個'\n'也讀進來
		int sample_number=0;//已提取特征的樣本數,前30個用于訓練,存入文件(training_feature.txt),后20個用于測試,存入文件(testing_feature.txt)
		int j;
		float d;

		while(inf>>c){
			int s=0,t=0;
			int stopline=0;

			while((inf>>c)&&(stopline!=BITMAP_SIZE)){
				if(c!='\n'){
					map[s][t]=c;
					t++;
				}
                else{
                    s++;
					t=0;
					stopline++;
				}
			}
			sample_number++;
			//處理數組map,包括提取特征,存入feature,再將feature存入文件(training_feature.txt)或(testing_feature.txt)			
			FeatureExtraction(i);//i代表數字'i'
			if(sample_number<=30){
				for(j=0;j<=FEATURE_NUMBER+1;j++){
					d=feature[j];
				    training_outf<<d;
					if(j<FEATURE_NUMBER+1)
						training_outf<<" ";
					else
						training_outf<<"\n";
				}
			}
			else{
				for(j=0;j<=FEATURE_NUMBER+1;j++){
					d=feature[j];
				    testing_outf<<d;
				    if(j<FEATURE_NUMBER+1)
						testning_outf<<" ";
					else
						testing_outf<<"\n";
			}
		}
		inf.close();
	}
	training_outf.close();
	testing_outf.close();

//----------------------訓練-------------------------
//1,設定一個步長STEP_LENGTH
//2,為每一個判別函數(8類共8個)的系數向量w設初值,維數=特征個數+1(對應判別函數中的常數)
/*3,用訓練樣本訓練判別函數,每一步都是把一個樣本作為8個函數的輸入,分別計算輸出,
     得出分類結果(輸出值最大的那個類),如果分類結果正確,則無需修改函數的系數w向量,
	 如果分類結果錯誤,則修改應分得的類的判別函數的系數w,w是一個向量,對于每一個
	 分量,都增加一個因子:(訓練樣本的相應分量*步長STEP_LENGTH)
*/
//4,循環,每次循環都要使用全部的訓練樣本(8*30個),直到在一次循環中10個判別函數的系數都不改變
	for(i=0;i<=FEATURE_NUMBER){
		w0[i]=START_VALUE;
	}
	for(i=0;i<=FEATURE_NUMBER){
		w1[i]=START_VALUE;
	}
	for(i=0;i<=FEATURE_NUMBER){
		w4[i]=START_VALUE;
	}
	for(i=0;i<=FEATURE_NUMBER){
		w5[i]=START_VALUE;
	}
	for(i=0;i<=FEATURE_NUMBER){
		w6[i]=START_VALUE;
	}
	for(i=0;i<=FEATURE_NUMBER){
		w7[i]=START_VALUE;
	}
	for(i=0;i<=FEATURE_NUMBER){
		w8[i]=START_VALUE;
	}
	for(i=0;i<=FEATURE_NUMBER){
		w9[i]=START_VALUE;
	}
	training();

//----------------------測試-------------------------
//1,選一個測試樣本作為8個函數的輸入,分別計算輸出,得出分類結果(輸出值最大的那個類)
//2,循環,對每個測試樣本計算分類結果
	testing();

	system("PAUSE");
	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品毛片高清在线完整版| 色综合久久中文综合久久牛| 一区二区三区国产精华| 国产精品伦理一区二区| 国产日本欧洲亚洲| 久久久五月婷婷| 国产亚洲精久久久久久| 久久蜜臀精品av| 久久午夜老司机| 国产欧美一区二区在线观看| 久久久国产精品麻豆| 国产亚洲精品aa午夜观看| 国产日韩v精品一区二区| 中文字幕一区在线观看视频| 中文一区二区在线观看| 国产精品国产自产拍高清av| 亚洲日本中文字幕区| 亚洲一区二区美女| 日韩av网站在线观看| 狠狠色狠狠色综合日日91app| 国产综合色精品一区二区三区| 国产成人精品亚洲午夜麻豆| jiyouzz国产精品久久| 欧美性生活影院| 欧美大片在线观看一区| 国产精品久久久久久久久免费樱桃 | 97se狠狠狠综合亚洲狠狠| 91色porny在线视频| 欧美在线不卡一区| 精品国产一区二区精华| 日本一区二区视频在线| 亚洲一区二区视频| 精品一区二区三区在线观看国产| 成人综合婷婷国产精品久久蜜臀| 色综合天天天天做夜夜夜夜做| 欧美色涩在线第一页| 精品日韩在线观看| 国产精品福利一区| 免费三级欧美电影| 波多野结衣视频一区| 欧美色视频在线观看| 久久久99久久| 亚洲一区二区偷拍精品| 国产在线麻豆精品观看| 色婷婷久久综合| 26uuu精品一区二区| 夜夜操天天操亚洲| 韩国午夜理伦三级不卡影院| 91久久精品一区二区二区| 久久久欧美精品sm网站| 亚洲综合丁香婷婷六月香| 国产乱人伦偷精品视频免下载 | 欧美色图一区二区三区| 欧美极品另类videosde| 日本欧美一区二区三区乱码| 91网站最新地址| 久久综合精品国产一区二区三区 | 亚洲国产成人va在线观看天堂| 国产精品影视在线| 欧美成人伊人久久综合网| 亚洲一区二区av在线| 成人精品一区二区三区四区| 欧美成人综合网站| 视频一区二区三区入口| 在线免费视频一区二区| 亚洲人精品午夜| 成人动漫av在线| 日本一区二区三区在线不卡| 国产一区二区三区免费看 | 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 欧美不卡在线视频| 日本成人在线视频网站| 欧美日韩国产高清一区| 亚洲一区在线播放| 欧美色倩网站大全免费| 一区二区三区精密机械公司| 色欲综合视频天天天| 亚洲特黄一级片| 91一区二区在线| 国产精品国产三级国产| 成人福利视频在线| 国产精品美女久久久久久| 大桥未久av一区二区三区中文| 欧美高清在线精品一区| 成人中文字幕在线| 国产精品色哟哟| 一本高清dvd不卡在线观看| 亚洲欧美日韩中文字幕一区二区三区| 成人激情午夜影院| 一区二区高清视频在线观看| 色综合久久天天| 亚洲高清不卡在线观看| 日韩一区二区三区四区五区六区| 日韩黄色免费电影| 国产午夜精品久久久久久免费视| 成人一区二区三区在线观看| 中文字幕一区二区三区在线不卡 | 国产精品99久久不卡二区| 国产午夜亚洲精品理论片色戒| 成人开心网精品视频| 亚洲精品成a人| 在线综合亚洲欧美在线视频| 久久精品国产99国产精品| 欧美高清在线精品一区| 91行情网站电视在线观看高清版| 三级一区在线视频先锋| 久久蜜桃香蕉精品一区二区三区| 不卡影院免费观看| 午夜欧美2019年伦理| 久久久精品黄色| 欧洲亚洲精品在线| 麻豆国产精品一区二区三区| 亚洲国产经典视频| 欧美精品v国产精品v日韩精品 | 国产亚洲一区二区三区四区| 99精品视频一区| 免费看欧美女人艹b| 亚洲日本va午夜在线电影| 91精品国产欧美一区二区成人 | 亚洲成人精品影院| 久久天堂av综合合色蜜桃网| 欧美视频一二三区| 成人禁用看黄a在线| 欧美aⅴ一区二区三区视频| 最新日韩在线视频| 精品三级在线看| 欧美午夜精品一区| 国产91丝袜在线播放九色| 日韩电影免费在线观看网站| 亚洲日本青草视频在线怡红院| 26uuu精品一区二区在线观看| 欧美日韩一区二区三区视频 | 亚洲综合成人在线| 国产日韩精品视频一区| 欧美一区二区三区人| 色欧美日韩亚洲| www.亚洲精品| 国产精品99精品久久免费| 美女一区二区久久| 香蕉久久夜色精品国产使用方法 | 日韩欧美专区在线| 在线一区二区三区四区五区| 国产不卡视频一区二区三区| 久久99久国产精品黄毛片色诱| 亚洲va欧美va天堂v国产综合| 国产精品久久久久久久第一福利| 精品久久国产老人久久综合| 欧美一级日韩不卡播放免费| 欧美日韩精品高清| 91久久一区二区| 一本色道久久综合亚洲91| www.日韩av| 99国产精品久久久久| 99久久综合精品| av激情亚洲男人天堂| 91亚洲精品久久久蜜桃| 99久久精品免费精品国产| 成人听书哪个软件好| 99国产精品久久久久久久久久 | 日韩限制级电影在线观看| 91精品婷婷国产综合久久| 欧美日韩高清在线| 欧美日本韩国一区二区三区视频| 欧美色偷偷大香| 91精品国产欧美一区二区| 欧美一区二区三区免费观看视频| 777久久久精品| 日韩三级免费观看| 国产三级三级三级精品8ⅰ区| 久久久久国色av免费看影院| 国产日韩欧美麻豆| 伊人色综合久久天天| 午夜精品一区二区三区免费视频| 蜜桃精品在线观看| 国产69精品一区二区亚洲孕妇| 91亚洲国产成人精品一区二区三 | 国产婷婷色一区二区三区| 国产欧美一区二区精品仙草咪 | 亚欧色一区w666天堂| 日韩精品亚洲专区| 国产一本一道久久香蕉| 99riav一区二区三区| 欧美精品99久久久**| 国产视频一区在线观看 | 欧美妇女性影城| 久久影视一区二区| 日韩码欧中文字| 蜜臀av性久久久久蜜臀aⅴ流畅 | 国产免费观看久久| 亚洲精品乱码久久久久久久久 | 成人欧美一区二区三区视频网页| 亚洲欧美一区二区三区孕妇| 蜜桃av噜噜一区| 97久久精品人人爽人人爽蜜臀| 欧美日韩精品电影| 国产精品免费人成网站| 亚洲123区在线观看| www.在线成人| 2023国产精品自拍| 手机精品视频在线观看|