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

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

?? clinearfafeaturecalculator.cpp

?? 強化學(xué)習(xí)算法(R-Learning)難得的珍貴資料
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// Copyright (C) 2003
// Gerhard Neumann (gerhard@igi.tu-graz.ac.at)

//                
// This file is part of RL Toolbox.
// http://www.igi.tugraz.at/ril_toolbox
//
// All rights reserved.
// 
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions
// are met:
// 1. Redistributions of source code must retain the above copyright
//    notice, this list of conditions and the following disclaimer.
// 2. Redistributions in binary form must reproduce the above copyright
//    notice, this list of conditions and the following disclaimer in the
//    documentation and/or other materials provided with the distribution.
// 3. The name of the author may not be used to endorse or promote products
//    derived from this software without specific prior written permission.
// 
// THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
// IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
// OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
// IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
// NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
// THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

#include "ril_debug.h"
#include "clinearfafeaturecalculator.h"
#include <assert.h>
#include <math.h>

CFeatureOperatorOr::CFeatureOperatorOr() : CFeatureCalculator()
{
	addType(FEATURESTATEDERIVATIONX);

	this->featureFactors = new std::map<CStateModifier *, rlt_real>();
}

CFeatureOperatorOr::~CFeatureOperatorOr()
{
	delete featureFactors;
}

void CFeatureOperatorOr::getModifiedState(CStateCollection *stateCol, CState *state)
{
	assert(bInit);

	std::list<CStateModifier *>::iterator it = getStateModifiers()->begin();
	std::list<CState *>::iterator stateIt = states->begin();

	CState *stateBuf;

	int i = 0;
	int numFeatures = 0;

	for (; it != getStateModifiers()->end(); it++, stateIt++)
	{
		if (stateCol->isMember(*it))
		{
			stateBuf = stateCol->getState(*it);
		}
		else
		{
			stateBuf = *stateIt;
			(*it)->getModifiedState(stateCol, stateBuf);
		}
		rlt_real featureStateFactor = (*this->featureFactors)[*it];
		if (stateBuf->getStateProperties()->isType(FEATURESTATE))
		{
			for (unsigned int j = 0; j < stateBuf->getNumDiscreteStates(); j++)
			{
				state->setDiscreteState(i, stateBuf->getDiscreteState(j) + numFeatures);
				state->setContinuousState(i, stateBuf->getContinuousState(j) * featureStateFactor);
				i ++;
			}
		}
		else
		{
			if (stateBuf->getStateProperties()->isType(DISCRETESTATE))
			{
				state->setDiscreteState(i, stateBuf->getDiscreteState(0) + numFeatures);
				state->setContinuousState(i, featureStateFactor);
				i ++;
			}
		}

		numFeatures += (*it)->getDiscreteStateSize();
	}
	normalizeFeatures(state);
}

void CFeatureOperatorOr::addStateModifier(CStateModifier *featCalc, rlt_real factor)
{
	CStateMultiModifier::addStateModifier(featCalc);
	
    if (!featCalc->isType(STATEDERIVATIONX))
	{
		type = getType() & ~ STATEDERIVATIONX;	
	}
	(*this->featureFactors)[featCalc] = factor;

}

CStateModifier *CFeatureOperatorOr::getStateModifier(int feature)
{
	std::list<CStateModifier *>::iterator it = getStateModifiers()->begin();
	int numFeatures = (*it)->getDiscreteStateSize();

	while (it != getStateModifiers()->end() && numFeatures < feature)
	{
		it ++;

		numFeatures += (*it)->getDiscreteStateSize();
	}

	if (it != getStateModifiers()->end())
	{
		return *it;
	}
	else
	{
		return NULL;
	}
}

void CFeatureOperatorOr::getFeatureDerivationX(int feature, CStateCollection *state, CMyVector *targetVector)
{
	CStateModifier *stateMod = getStateModifier(feature);

	if (stateMod->isType(FEATURESTATEDERIVATIONX))
	{
		CFeatureCalculator *featCalc = dynamic_cast<CFeatureCalculator *>(stateMod);
		featCalc->getFeatureDerivationX(feature, state, targetVector);
	}
}

void CFeatureOperatorOr::initFeatureOperator()
{
	assert(!bInit);

	std::list<CStateModifier *>::iterator it;
	int numFeatures = 0;
	int numActiveFeatures = 0;
	for (it = this->modifiers->begin(); it != modifiers->end(); it ++)
	{
		numActiveFeatures += (*it)->getNumDiscreteStates();

		numFeatures += (*it)->getDiscreteStateSize(0);
	}
	
	initFeatureCalculator(numFeatures, numActiveFeatures);
}

CFeatureOperatorAnd::CFeatureOperatorAnd() : CFeatureCalculator()
{
	addType(FEATURESTATEDERIVATIONX);
}


void CFeatureOperatorAnd::getModifiedState(CStateCollection *stateCol, CState *featState)
{
	int featureOffset = 1;

	std::list<CStateModifier *>::iterator it = getStateModifiers()->begin();
	std::list<CState *>::iterator stateIt = states->begin();


	CState *stateBuf;

	for (unsigned int i = 0; i < getNumDiscreteStates();i ++)
	{
		featState->setDiscreteState(i, 0);
		featState->setContinuousState(i, 1.0);
	}

	int repetitions = getNumDiscreteStates();
	for (int j = 0; it != getStateModifiers()->end(); it ++, stateIt ++, j ++)
	{
		repetitions /= (*it)->getNumDiscreteStates();
		stateBuf = NULL;
		if (stateCol->isMember(*it))
		{
			stateBuf = stateCol->getState(*it);
		}
		else
		{
			stateBuf = *stateIt;
			(*it)->getModifiedState(stateCol, stateBuf);
		}
		
		if (stateBuf->getStateProperties()->isType(FEATURESTATE))
		{
			for (unsigned int i = 0; i < getNumDiscreteStates(); i++)
			{
				unsigned int singleStateFeatureNum = (i / repetitions) % stateBuf->getNumDiscreteStates();
				featState->setDiscreteState(i, featState->getDiscreteState(i) + featureOffset * stateBuf->getDiscreteState(singleStateFeatureNum));
				featState->setContinuousState(i, featState->getContinuousState(i) * stateBuf->getContinuousState(singleStateFeatureNum));
			}
		}
		else
		{
			for (unsigned int i = 0; i < getNumDiscreteStates(); i++)
			{
				featState->setDiscreteState(i, featState->getDiscreteState(i) + featureOffset * stateBuf->getDiscreteState(0));				
			}
		}

		featureOffset = featureOffset * (*it)->getDiscreteStateSize();
	}
	normalizeFeatures(featState);
}

void CFeatureOperatorAnd::getFeatureDerivationX(int feature, CStateCollection *stateCol, CMyVector *derivation)
{
	std::list<CStateModifier *>::iterator it = getStateModifiers()->begin();
	std::list<CState *>::iterator stateIt = states->begin();


	CState *stateBuf;

	rlt_real featureFactor = 1.0;
	CMyVector tempVector(derivation->getNumDimensions());
	
	derivation->initVector(0.0);
	int lfeature = 0;
	rlt_real lfeatureFactor = 0.0;

	for (; it != getStateModifiers()->end(); it ++, stateIt ++)
	{
		stateBuf = NULL;
		
		assert((*it)->isType(FEATURESTATEDERIVATIONX));
		CFeatureCalculator *devXFeatCalc = dynamic_cast<CFeatureCalculator *>(*it);

		tempVector.initVector(0.0);
		if (stateCol->isMember(*it))
		{
			stateBuf = stateCol->getState(*it);
		}
		else
		{
			stateBuf = *stateIt;
			(*it)->getModifiedState(stateCol, stateBuf);
		}
		unsigned int i = 0;
		lfeatureFactor = 0.0;
		lfeature = feature % (*it)->getDiscreteStateSize();
		feature = feature / (*it)->getDiscreteStateSize();

		while (i < stateBuf->getNumDiscreteStates() && stateBuf->getDiscreteState(i) != lfeature)
		{
			i++;
		}
		if (i < stateBuf->getNumDiscreteStates())
		{
			lfeatureFactor = stateBuf->getContinuousState(i);
		}

		devXFeatCalc->getFeatureDerivationX(lfeature, stateCol, &tempVector);
		
		tempVector.multScalar(featureFactor);
		derivation->multScalar(lfeatureFactor);
		
		derivation->addVector(&tempVector);

		featureFactor *= lfeatureFactor;
	}
}

void CFeatureOperatorAnd::addStateModifier(CStateModifier *featCalc)
{
	CStateMultiModifier::addStateModifier(featCalc);

	if (!featCalc->isType(STATEDERIVATIONX))
	{
		type = getType() & ~ STATEDERIVATIONX;	
	}
}

void CFeatureOperatorAnd::initFeatureOperator()
{
	assert(!bInit);
	std::list<CStateModifier *>::iterator it;
	int numFeatures = 1;
	int numActiveFeatures = 1;
	for (it = this->modifiers->begin(); it != modifiers->end(); it ++)
	{
		numActiveFeatures *= (*it)->getNumDiscreteStates();

		numFeatures *= (*it)->getDiscreteStateSize(0);
	}

	initFeatureCalculator(numFeatures, numActiveFeatures);
}

CGridFeatureCalculator::CGridFeatureCalculator(unsigned int numDim, unsigned int dimensions[], unsigned int part[], rlt_real off[], unsigned int numActiveFeatures) : CFeatureCalculator(numActiveFeatures, numActiveFeatures)
{
	this->numDim = numDim;
	this->dimensions = new unsigned int[numDim];
	this->partitions = new unsigned int[numDim];
	this->offsets = new rlt_real[numDim];

	dimensionSize = new unsigned int[numDim];

	numFeatures = 1;
	for (unsigned int i = 0; i < numDim; i ++)
	{
		this->dimensions[i] = dimensions[i];
		this->partitions[i] = part[i];
		this->offsets[i] = off[i];
        dimensionSize[i] = numFeatures;
		numFeatures *= partitions[i];
	}

	for (unsigned int i = 0; i < this->getNumDiscreteStates(); i++)
	{
		this->setDiscreteStateSize(i, numFeatures);
	}

	for (unsigned int i = 0; i < this->getNumContinuousStates(); i++)
	{
		this->setMinValue(i, 0.0);
		this->setMaxValue(i, 1.0);
	}

	gridScale = new rlt_real[numDim];

	for (int i = 0; i < numDim; i++)
	{
		gridScale[i] = 1.0;
	}

	originalState = NULL;
}

CGridFeatureCalculator::~CGridFeatureCalculator()
{
	delete offsets;
	delete partitions;
	delete dimensions;
	delete dimensionSize;

	delete gridScale;
}


unsigned int CGridFeatureCalculator::getNumDimensions()
{
	return numDim;
}

void CGridFeatureCalculator::setGridScale(int dimension, rlt_real scale)
{
	gridScale[dimension] = scale;
}

void CGridFeatureCalculator::getFeaturePosition(unsigned int feature, CMyVector *position)
{
	int partition = 0;
	unsigned int temp = feature;
	
	for (unsigned int i = 0; i < numDim; i++)
	{
		partition = temp % partitions[i];
		position->setElement(i, offsets[i] + 1.0 / partitions[i] * (0.5 + partition) * gridScale[i]);

		temp = temp / partitions[i];
	}
}

unsigned int CGridFeatureCalculator::getActiveFeature(CState *state)
{
	rlt_real part = 0;
	int singleStateFeature = 0;
	unsigned int feature = 0;

	for (unsigned int i = 0; i < numDim; i++)
	{	
		assert(dimensions[i] < state->getNumContinuousStates());

		part = (state->getNormalizedContinuousState(dimensions[i]) - offsets[i]);

		if (state->getStateProperties()->getPeriodicity(i) && gridScale[i] >= 1.0)
		{
			part = part - floor(part);
		}

		singleStateFeature = (int) floor(part * partitions[i] / gridScale[i]);

		if (singleStateFeature < 0)
			singleStateFeature = 0;
		if (singleStateFeature >= partitions[i])
			singleStateFeature = partitions[i] - 1;

		feature += singleStateFeature * dimensionSize[i];
	}
	return feature;
}

void CGridFeatureCalculator::getSingleActiveFeature(CState *state, unsigned int *activeFeature)
{
	rlt_real part = 0;
	int tempSingleStateFeature = 0;

	for (unsigned int i = 0; i < numDim; i++)
	{	
		assert(dimensions[i] < state->getNumContinuousStates());

		part = (state->getNormalizedContinuousState(dimensions[i]) - offsets[i]);

		if (state->getStateProperties()->getPeriodicity(i) && gridScale[i] >= 1.0)
		{
			part = part - floor(part);
		}

		tempSingleStateFeature = (unsigned int) floor(part * partitions[i] / gridScale[i]);

		if (tempSingleStateFeature < 0)
			tempSingleStateFeature = 0;
		if (tempSingleStateFeature >= partitions[i])
			tempSingleStateFeature = partitions[i] - 1;

		activeFeature[i] = tempSingleStateFeature;
	}
}

unsigned int CGridFeatureCalculator::getFeatureIndex(int position[])
{
	unsigned int feature = 0;

	for (unsigned int i = 0; i < numDim; i++)
	{	
		feature +=  position[i] * dimensionSize[i];
	}
	return feature;
}

CTilingFeatureCalculator::CTilingFeatureCalculator(unsigned int numDim, unsigned int dimensions[], unsigned int partitions[], rlt_real offsets[]) : CGridFeatureCalculator(numDim, dimensions, partitions, offsets, 1)
{
}

CTilingFeatureCalculator::~CTilingFeatureCalculator()
{
}
	
void CTilingFeatureCalculator::getModifiedState(CStateCollection *state, CState *featState)
{
	featState->setDiscreteState(0, getActiveFeature(state->getState(originalState)));
	featState->setContinuousState(0, 1.0);
}


CLinearMultiFeatureCalculator::CLinearMultiFeatureCalculator(unsigned int numDim, unsigned int dimensions[], unsigned int partitions[], rlt_real offsets[], unsigned int numActiveFeatures) : CGridFeatureCalculator(numDim, dimensions, partitions, offsets, numActiveFeatures)
{
	areaSize = new unsigned int[numDim];	

	activePosition = new CMyVector(numDim);
	featurePosition = new CMyVector(numDim);
	actualPartition = new unsigned int[numDim];
	singleStateFeatures = new unsigned int[numDim];
}

CLinearMultiFeatureCalculator::~CLinearMultiFeatureCalculator()
{
	delete areaSize;

	delete activePosition;
	delete featurePosition;
	delete [] actualPartition;
	delete [] singleStateFeatures;

}

void CLinearMultiFeatureCalculator::initAreaSize()
{
	memset(areaSize, 0, sizeof(unsigned int) * numDim);
}
	
void CLinearMultiFeatureCalculator::calcNumActiveFeatures()
{
	areaNumPart = 1;
	for (unsigned int i = 0; i < numDim; i++)
	{
		areaNumPart *= areaSize[i];
	}
	this->continuousStates = areaNumPart;
	this->discreteStates = areaNumPart;

	numActiveFeatures = areaNumPart;

	this->discreteStateSize = new unsigned int[discreteStates];
	this->minValues = new rlt_real[continuousStates];
	this->maxValues = new rlt_real[continuousStates];

	for (unsigned int i = 0; i < this->getNumDiscreteStates(); i++)
	{
		this->setDiscreteStateSize(i, numFeatures);
	}

	for (unsigned int i = 0; i < this->getNumContinuousStates(); i++)
	{
		this->setMinValue(i, 0.0);
		this->setMaxValue(i, 1.0);
	}
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区中文日韩| 色婷婷香蕉在线一区二区| 精品一区二区三区免费毛片爱| 美腿丝袜一区二区三区| 粉嫩av一区二区三区粉嫩| 91麻豆国产自产在线观看| 7777女厕盗摄久久久| 国产欧美日韩在线看| 亚洲精品亚洲人成人网在线播放| 亚洲国产人成综合网站| 国产成人免费xxxxxxxx| 欧美另类videos死尸| 国产精品久久久久四虎| 免费观看在线色综合| 色婷婷狠狠综合| 国产精品久久久久久户外露出| 精品在线你懂的| 日韩一级片网址| 午夜欧美在线一二页| 一本一道波多野结衣一区二区| 精品粉嫩超白一线天av| 久久er99精品| 久久免费的精品国产v∧| 性做久久久久久| 欧美日本国产一区| 亚洲成av人片在线观看| 欧美日韩黄色影视| 无码av免费一区二区三区试看| 在线视频一区二区三区| 亚洲午夜在线视频| 国产精品77777| 国产日韩欧美亚洲| 成人免费视频播放| 亚洲综合免费观看高清完整版在线| 91美女精品福利| 青青草国产精品97视觉盛宴| 在线91免费看| 国产精品一区专区| 一区二区三区在线播放| 5566中文字幕一区二区电影| 国产一区二区主播在线| 亚洲欧美日韩人成在线播放| 99国产精品久久久久久久久久| 亚洲三级在线免费| 欧美一区二区在线免费播放| 黄色资源网久久资源365| 亚洲欧洲精品一区二区三区不卡| 不卡欧美aaaaa| 蜜桃久久久久久| 综合在线观看色| 久久综合国产精品| 欧美三级电影在线观看| 91捆绑美女网站| 成人毛片在线观看| 丁香五精品蜜臀久久久久99网站| 7878成人国产在线观看| 国产99精品视频| 精品无人码麻豆乱码1区2区| 亚洲v日本v欧美v久久精品| 国产精品网曝门| 国产女人aaa级久久久级 | 国产精品色在线观看| 久久亚洲一级片| xnxx国产精品| 久久久久久久久久久久久女国产乱| 91精品国产黑色紧身裤美女| 91精品免费在线观看| 精品久久一区二区| 精品粉嫩超白一线天av| 国产午夜精品一区二区三区嫩草| 91麻豆精品91久久久久同性| 欧美一级在线视频| 国产欧美日韩视频在线观看| 国产精品国产三级国产专播品爱网| 日本一区二区动态图| 成人欧美一区二区三区白人| 最新日韩在线视频| 亚洲午夜在线视频| 国内精品不卡在线| 欧美自拍偷拍午夜视频| 国产亚洲欧美日韩日本| 亚洲高清三级视频| 国产福利精品导航| 欧美日本国产一区| 亚洲欧美福利一区二区| 美女诱惑一区二区| 欧美亚洲日本国产| 久久综合久色欧美综合狠狠| 亚洲国产裸拍裸体视频在线观看乱了 | 欧美精品乱人伦久久久久久| 国产精品盗摄一区二区三区| 欧美aaa在线| 日韩一级成人av| 亚洲一二三区不卡| 欧美日韩一区二区不卡| 亚洲精品高清在线| 91在线无精精品入口| 中文字幕免费不卡| 成人午夜精品在线| 国产网红主播福利一区二区| 蜜臀av在线播放一区二区三区| 91黄视频在线| 亚洲精选在线视频| 一本久久a久久免费精品不卡| 亚洲天堂免费看| 欧美中文字幕亚洲一区二区va在线 | 国产麻豆日韩欧美久久| 久久久高清一区二区三区| 国产精品一区二区黑丝| 国产精品国产三级国产| 在线观看91精品国产入口| 麻豆精品视频在线观看视频| 国产精品萝li| 91精品国产综合久久福利| 高清国产一区二区| 亚洲一区二区三区国产| 久久久精品黄色| 99久久久国产精品免费蜜臀| 亚洲精品精品亚洲| 欧美v国产在线一区二区三区| 久久精品国产澳门| 一区二区三区精品久久久| 精品久久久网站| 欧美色倩网站大全免费| 国产激情一区二区三区四区| 亚洲一区二区三区在线| 久久久蜜臀国产一区二区| 欧美猛男超大videosgay| 国产美女精品在线| 美洲天堂一区二卡三卡四卡视频| 中文字幕一区二区视频| 国产色综合久久| 国产日韩精品一区二区三区在线| 在线观看91精品国产麻豆| 欧美天天综合网| 欧美午夜精品免费| 欧美日韩国产高清一区二区三区 | 欧美国产丝袜视频| 国产亚洲va综合人人澡精品| 国产视频一区在线观看| 精品va天堂亚洲国产| 日韩欧美国产一二三区| 欧美精品一区二区三区很污很色的| 91精品国产综合久久精品性色| 欧美系列亚洲系列| 欧洲日韩一区二区三区| 精品视频一区二区三区免费| 欧美日韩久久一区| 日韩欧美你懂的| 欧美国产日本视频| 亚洲激情校园春色| 日韩精品福利网| 顶级嫩模精品视频在线看| 91性感美女视频| 91麻豆精品国产91久久久久久| 精品国内片67194| 亚洲蜜臀av乱码久久精品| 视频一区二区中文字幕| 国产精品中文有码| 欧美色精品在线视频| 中文字幕不卡在线播放| 另类小说综合欧美亚洲| 91丨porny丨户外露出| 精品国产乱码久久久久久1区2区| 亚洲视频1区2区| 国产黄色精品网站| 日韩免费高清视频| 日韩高清不卡在线| 91老司机福利 在线| 国产欧美一区二区精品忘忧草| 蜜臀91精品一区二区三区| 在线这里只有精品| 一区二区三区欧美日韩| 91啪在线观看| 成人欧美一区二区三区| 成人小视频免费在线观看| 国产亚洲人成网站| 成人av网址在线| 中文字幕亚洲欧美在线不卡| 成人妖精视频yjsp地址| 国产婷婷精品av在线| 粉嫩aⅴ一区二区三区四区五区| 久久久国产精品午夜一区ai换脸| 国产麻豆精品视频| 亚洲色图制服诱惑| 69p69国产精品| 国产自产高清不卡| 中文字幕在线不卡一区 | 国产精品美女久久久久aⅴ国产馆| 国产精品1区二区.| 亚洲欧美日韩中文播放| 在线亚洲人成电影网站色www| 亚洲v精品v日韩v欧美v专区| 精品捆绑美女sm三区| 色网站国产精品| 国产在线国偷精品免费看| 亚洲欧美日韩国产综合在线| 久久综合视频网| 在线观看亚洲成人| 韩国毛片一区二区三区|