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

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

?? classifier.cpp

?? - XCS for Dynamic Environments + Continuous versions of XCS + Test problem: real multiplexer +
?? CPP
字號:
/*	XCSR_DE1.0
*	--------------------------------------------------------
*	Learning classifier system based on accuracy in dynamic environments
*
*	by  Huong Hai (Helen) Dam
*	z3140959@itee.adfa.edu.au
*	UNSW @ ADFA, Canberra Australia
*	Artificial Life and Adaptive Robotics Laboratory
*	http://www.itee.adfa.edu.au/~alar
*
*	Last modified: 24-11-2005
*
*/
#include "classifier.h"
#include"iostream.h"

Classifier::Classifier(int type)
{
	m_interval = new d_interval_t;
	m_fitness = FITNESS;
	m_prediction = PREDICTION;
	m_prediction_error = PERROR;
	m_accuracy = 0.01;
	m_num = 1;
	m_exp = 0;
	m_as = 1;
	m_timestamp = 0;
	rep_type = type;
	schema = -1;
	
}
Classifier::~Classifier()
{
	delete m_interval;
	
}
void Classifier::resetParam()
{
	m_fitness = FITNESS;
	m_prediction = PREDICTION;
	m_prediction_error = PERROR;
	m_accuracy = 0.01;
	m_num = 1;
	m_exp = 0;
	m_as = 1;
	
}
int Classifier::matchClassifier(Classifier *c)
{
	int check1 = TRUE, check2 = TRUE, check3=TRUE;
	
	if(getAction() != c->getAction())
		check1 = FALSE;
	
	for(int j = 0; j < COND_OFFSET; j++)
	{
		if((m_interval->point1[j] != c->getInterval()->point1[j])||
			(m_interval->point2[j] != c->getInterval()->point2[j]))
		{
			check2 = FALSE;
			break;
		}
#ifdef NOISE_AT_ALLELE
		if(m_interval->noise[j] != c->getInterval()->noise[j])
			check3 = FALSE;
#endif
	}
	return check1 && check2 && check3;
}

int Classifier::matchInput(input_t *input)
{
	int check = TRUE;
	for(int j = 0; j <COND_OFFSET; j++)
	{
		if((input->attrs[j]<getIntervalMin(j)) ||
			(input->attrs[j] >= getIntervalMax(j)))
		{
			
			check = FALSE;
			break;
		}
	}
	
	return check;
}
void Classifier::classifiercpy(Classifier *c)
{
	
	for(int i = 0; i < COND_OFFSET; i++)
	{
		m_interval->point1[i] = c->getInterval()->point1[i];
		m_interval->point2[i] = c->getInterval()->point2[i];
#ifdef NOISE_AT_ALLELE
		m_interval->noise[i] = c->getInterval()->noise[i];
#endif
	}
	m_interval->action = c->getAction();
	
	m_fitness = c->getFitness();
	m_prediction = c->getPrediction();
	m_prediction_error = c->getPredictionError();
	m_exp = c->getExp();
	m_num = c->getNum();
	m_as = c->getAS();
	m_timestamp = c->getTimeStamp();
	rep_type = c->getRepresentationType();
	
}

double Classifier::getIntervalMin(int i)
{
	double min;
	if (rep_type == MIN_MAX)
	{
		if(m_interval->point1[i] > m_interval->point2[i])
			min = m_interval->point2[i];
		else
			min = m_interval->point1[i];
	}
	else if (rep_type == CENTER_SPREAD)
	{
		min = m_interval->point1[i] - m_interval->point2[i];
	}
	else if (rep_type == CENTER_PERCENTAGE)
	{
		double minrange = UPPER_BOUND - m_interval->point1[i];
		if(minrange > m_interval->point1[i] - LOWER_BOUND)
			minrange = m_interval->point1[i] - LOWER_BOUND;
		
		double spread = m_interval->point2[i] * minrange;
		min = m_interval->point1[i] - spread;
	}
	else if(rep_type == MIN_PERCENTAGE)
	{
		min = m_interval->point1[i];
		
	}
	if(min > UPPER_BOUND)
		min = UPPER_BOUND;
	if(min < LOWER_BOUND)
		min = LOWER_BOUND;
	return min;
}

double Classifier::getIntervalMax(int i)
{
	double max;
	if (rep_type == MIN_MAX)
	{
		if(m_interval->point1[i] > m_interval->point2[i])
			max = m_interval->point1[i];
		else
			max = m_interval->point2[i];
	}
	else if (rep_type == CENTER_SPREAD)
	{
		max = m_interval->point1[i] + m_interval->point2[i];
	}
	else if (rep_type == CENTER_PERCENTAGE)
	{
		double minrange = UPPER_BOUND - m_interval->point1[i];
		if(minrange > m_interval->point1[i] - LOWER_BOUND)
			minrange = m_interval->point1[i] - LOWER_BOUND;
		
		double spread = m_interval->point2[i] * minrange;
		max = m_interval->point1[i] + spread;
	}
	else if(rep_type == MIN_PERCENTAGE)
	{
		double minrange = UPPER_BOUND - m_interval->point1[i];
		max = m_interval->point1[i] + minrange * m_interval->point2[i];
	}
	if (max > UPPER_BOUND)
		max = UPPER_BOUND;
	if(max < LOWER_BOUND)
		max = LOWER_BOUND;
	return max;
}
int Classifier::getSchemaOrder()
{
	int order = 0;
	int p1 = 0, p2 = 0;
	for(int i = 0; i < COND_OFFSET; i++)
	{
		if(getIntervalMin(i) <= EPSILON && getIntervalMax(i) >= 1-EPSILON)
		{
			order ++;
		}
	}
	return order;
}

int Classifier::getSchemaLength()
{
	int length = 0;
	int p1 = 0, p2 = 0;
	for(int i = 0; i < COND_OFFSET; i++)
	{
		if(getIntervalMin(i) <= EPSILON && getIntervalMax(i) >= 1-EPSILON)
		{
			if(p1 == 0)
				p1 = i+1;
			else
				p2 = i+1;
		}
	}
	if(p2 == 0 && p1 !=0)
		length = 1;
	else
		length = p2 - p1;
	return length;
}


void Classifier::validateClassifier()
{
	//	cout<<"Come here"<<endl;
	for(int i = 0; i < COND_OFFSET; i++)
	{
		if(m_interval->point1[i] > UPPER_BOUND)
			m_interval->point1[i] = UPPER_BOUND;
		if(m_interval->point2[i] > UPPER_BOUND)
			m_interval->point2[i] = UPPER_BOUND;
		if(m_interval->point1[i] < LOWER_BOUND)
			m_interval->point1[i] = LOWER_BOUND;
		if(m_interval->point2[i] < LOWER_BOUND)
			m_interval->point2[i] = LOWER_BOUND;
	}
}
void Classifier::savePopulation(ofstream &of)
{
	
}
#ifdef MP
int Classifier::isASchema(double real_threshold, int id)
{
	int res = FALSE, check = TRUE;
	int i, pos = 0, num = 0;
	for(i = ADDR_OFFSET -1; i >= 0; i--)
	{
		if(	getIntervalMax(i)<=real_threshold+EPSILON)//0
		{
			pos++;
		}
		else if(getIntervalMin(i)>=real_threshold-EPSILON)// &&
		{
			num += (int)pow(2,pos);
			pos++;
		}
		else
		{
			check = FALSE;
			break;
		}
	}
	if(check == TRUE && num == (int)id/2) // Considering only the classifier which has the same address as the schema
	{
		if((id%2 == 0 && //getIntervalMin(ADDR_OFFFSET+num) <LOWER_BOUND+EPSILON &&
			getIntervalMax(ADDR_OFFSET + num) <= real_threshold+EPSILON)||
			//Considering only the classifier which the data at the address is 0
			(id%2 == 1 && getIntervalMin(ADDR_OFFSET + num) >=real_threshold-EPSILON))
			
		{
			res = TRUE;
			for(i = COND_OFFSET -1; i > ADDR_OFFSET -1; i--)
			{
				if(i!= ADDR_OFFSET + num)
				{
					if(getIntervalMin(i)> LOWER_BOUND + EPSILON ||
						getIntervalMax(i)< UPPER_BOUND - EPSILON)
					{
						res = FALSE;
						break;
					}
				}
			} 
		}
	}
	return res;
}
int Classifier::belongToSchema(double real_threshold, int id)
{
	int res = FALSE, check = TRUE;
	int i;
	int pos = 0, num=0;
	for(i = ADDR_OFFSET -1; i >= 0; i--)
	{
		if( getIntervalMax(i)<=real_threshold+EPSILON)//0
		{
			pos++;
		}
		else if(getIntervalMin(i)>=real_threshold-EPSILON )//1
		{
			num += (int)pow(2,pos);
			pos++;
		}
		else
		{
			check = FALSE;
			break;
		}
	}
	if(check == TRUE && num == (int)id/2) // Considering only the classifier which has the same address as the schema
	{
		if((id%2 == 0 && getIntervalMax(ADDR_OFFSET + num) <= real_threshold+EPSILON)||
			//Considering only the classifier which the data at the address is 0
			(id%2 == 1 && getIntervalMin(ADDR_OFFSET + num) >=real_threshold-EPSILON))
		{
			res = TRUE;
		}
	}
	
	
	return res;
}

#endif
void Classifier::print()
{
	for(int i = 0; i < COND_OFFSET; i++)
		cout<<getIntervalMin(i)<<", "<<getIntervalMax(i)<<" |";
	cout<<getAction()<<endl;
}
#ifdef MP

#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美三级乱人伦电影| 欧美三电影在线| 麻豆一区二区三| 婷婷国产v国产偷v亚洲高清| 亚洲午夜精品一区二区三区他趣| 亚洲人成伊人成综合网小说| 亚洲精品国产精华液| 亚洲综合色婷婷| 日本成人中文字幕在线视频| 美女mm1313爽爽久久久蜜臀| 国产综合久久久久影院| 国产99久久久国产精品| 成人涩涩免费视频| 91蜜桃免费观看视频| 欧美亚洲日本一区| 91精品国产综合久久福利| 日韩欧美色综合网站| 欧美国产成人精品| 亚洲永久免费av| 久久机这里只有精品| 国产成人精品一区二区三区网站观看| 成人蜜臀av电影| 欧美日韩三级一区二区| 久久久九九九九| 一区二区在线免费| 紧缚奴在线一区二区三区| 成人污视频在线观看| 7777精品伊人久久久大香线蕉经典版下载 | 国产另类ts人妖一区二区| 成人午夜视频福利| 欧美日韩日日摸| 久久亚洲一区二区三区四区| 欧美tickling网站挠脚心| 中文字幕欧美一区| 三级一区在线视频先锋| 国产.欧美.日韩| 欧美高清你懂得| 亚洲天堂av一区| 国产一区999| 欧美日本一区二区三区四区| 国产日韩精品一区| 免费在线成人网| 色哟哟日韩精品| 国产日韩欧美不卡| 久久99精品久久久久久| 欧美丝袜丝交足nylons图片| 久久综合成人精品亚洲另类欧美| 一区二区三区自拍| 国产91清纯白嫩初高中在线观看| 在线成人av影院| 亚洲美女视频一区| 丁香六月综合激情| 久久综合九色综合欧美98| 婷婷中文字幕一区三区| 91成人免费电影| 亚洲精品视频在线| 不卡的电影网站| 欧美激情综合五月色丁香小说| 免费观看在线综合色| 欧美精品亚洲一区二区在线播放| 亚洲美女在线一区| 粉嫩av一区二区三区| 精品久久久久久综合日本欧美 | 91精品免费在线观看| 亚洲欧洲国产专区| 成人免费观看视频| 精品国产一二三区| 久久97超碰国产精品超碰| 91精品国产91热久久久做人人| 亚洲国产综合91精品麻豆| 日本道精品一区二区三区| 中文字幕在线免费不卡| av中文字幕不卡| 136国产福利精品导航| 97久久精品人人爽人人爽蜜臀| 欧美激情在线观看视频免费| 国产精品18久久久久久vr| 精品国产乱码久久久久久图片| 免费人成精品欧美精品| 日韩欧美国产午夜精品| 久久精品国产久精国产爱| 日韩精品中午字幕| 狠狠狠色丁香婷婷综合久久五月| 日韩区在线观看| 国产一区二区看久久| 久久精品人人爽人人爽| 丰满白嫩尤物一区二区| 久久亚洲精品国产精品紫薇| 国产福利一区二区三区在线视频| 国产亚洲婷婷免费| 97精品久久久午夜一区二区三区| 亚洲三级在线免费观看| 欧美三级欧美一级| 激情久久久久久久久久久久久久久久| 久久综合久久鬼色中文字| 丁香五精品蜜臀久久久久99网站 | 欧美日韩国产综合一区二区| 亚洲国产精品影院| 欧美va天堂va视频va在线| 国产成人综合亚洲网站| 综合色天天鬼久久鬼色| 欧美三级日韩在线| 国产一区二区三区综合| 日韩一区欧美一区| 欧美一区二区日韩一区二区| 懂色av一区二区在线播放| 一区二区三区波多野结衣在线观看| 91 com成人网| jlzzjlzz国产精品久久| 日韩高清在线电影| 国产欧美日韩另类视频免费观看| 91色在线porny| 久99久精品视频免费观看| 亚洲欧美成aⅴ人在线观看| 日韩三级.com| 欧洲一区二区三区免费视频| 美国毛片一区二区| 一区二区三区.www| 国产日韩欧美综合在线| 91精品久久久久久久91蜜桃| 波多野结衣亚洲| 久久精品国产免费| 丝袜美腿亚洲一区二区图片| 国产精品丝袜黑色高跟| 欧美不卡一区二区三区四区| 不卡在线观看av| 国产一区二区三区免费| 日本一区中文字幕| 亚洲一二三四在线| 综合中文字幕亚洲| 中文字幕高清不卡| 久久亚洲一级片| 日韩欧美久久一区| 欧美日韩精品欧美日韩精品一| 成人免费毛片嘿嘿连载视频| 精品一区在线看| 青青草国产精品97视觉盛宴| 亚洲高清中文字幕| 亚洲免费高清视频在线| 亚洲图片激情小说| 中文字幕av一区二区三区| 久久久久久久免费视频了| 欧美mv日韩mv| 日韩一区二区三区精品视频| 欧美猛男男办公室激情| 欧美三级在线播放| 欧美日产在线观看| 91麻豆精品国产91久久久资源速度| 91激情五月电影| 91一区在线观看| 91麻豆国产香蕉久久精品| 成人黄色软件下载| 成人av资源站| 9l国产精品久久久久麻豆| 国产高清精品在线| 成人三级伦理片| 99国产精品国产精品毛片| a亚洲天堂av| 在线观看网站黄不卡| 精品视频在线免费| 91精品国产入口| 欧美精品一区男女天堂| 久久天堂av综合合色蜜桃网| 久久九九影视网| 中文字幕一区二区三区不卡| 亚洲黄色av一区| 亚洲成a人片在线观看中文| 日本不卡一二三| 国产精品资源站在线| 国产不卡视频在线播放| 色视频一区二区| 制服丝袜中文字幕亚洲| 亚洲精品一区在线观看| 国产精品九色蝌蚪自拍| 亚洲va国产va欧美va观看| 蜜桃一区二区三区在线| 国产精品白丝jk白祙喷水网站| 成人精品视频一区二区三区| 色8久久精品久久久久久蜜| 91麻豆精品国产综合久久久久久| 久久在线免费观看| 日韩欧美中文字幕一区| 日一区二区三区| 国产精品亚洲视频| 亚洲一区二区精品3399| 日韩黄色片在线观看| 国产美女在线精品| 91色在线porny| 欧美成va人片在线观看| 亚洲婷婷综合色高清在线| 国产精品久久久久久久蜜臀 | 欧美视频自拍偷拍| 国产精品久久久久久久久免费桃花 | 久久精品日产第一区二区三区高清版| 国产福利精品一区二区| 一区二区三区日本| 日韩精品一区二区三区视频播放| 日韩免费视频一区| 99精品热视频| 91亚洲资源网|