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

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

?? cutility.h

?? 強化學習算法(R-Learning)難得的珍貴資料
?? H
字號:
// 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.

#ifndef C_UTILITY_H
#define C_UTILITY_H

#include "cfeaturefunction.h"
#include "ril_debug.h"
#include <map>
#include <assert.h>

class CMyMatrix;
class CMyVector;

int my_round(rlt_real value);

rlt_real my_exp(rlt_real value);

class CMyVector 
{
protected:
	rlt_real *data;
	unsigned int dimensions;

public:
	CMyVector(unsigned int dimension, rlt_real *data = NULL);
	virtual ~CMyVector();

	void addVector(CMyVector *vector);
	void addScalar(rlt_real scalar);

	void dotVector(CMyVector *vector);

	void multMatrix(CMyMatrix *matrix, CMyVector *output);
	void multMatrix(CMyMatrix *matrix);

	void multVector(CMyVector *vector, CMyMatrix *output);
	
	void multScalar(rlt_real scalar);

	rlt_real getLength();
	void normalizeVector();
	
	rlt_real scalarProduct(CMyVector *vector);
	virtual rlt_real getDistance(CMyVector *vector);

	rlt_real getElement(unsigned int index);
	void setElement(unsigned int index, rlt_real value);

	unsigned int getNumDimensions();
//	bool isColumnVector();

	rlt_real *getData();

	void setVector(CMyVector *vector);
	void initVector(rlt_real init);

	void saveASCII(FILE *stream);
	void loadASCII(FILE *stream);
};

class CMyMatrix
{
protected:
	rlt_real *data;
	unsigned int columns;
	unsigned int rows;

public:
	CMyMatrix(unsigned int rows, unsigned int columns, rlt_real *data = NULL);
	~CMyMatrix();

	void addVector(CMyVector *vector);
	void addScalar(rlt_real scalar);

	void multMatrix(CMyMatrix *matrix, CMyMatrix *output);

	void multVector(CMyVector *vector, CMyVector *output);

	void multScalar(rlt_real scalar);

	rlt_real getElement(unsigned int row, unsigned int column);
	void setElement(unsigned int row, unsigned int column, rlt_real value);

	rlt_real *getRow(unsigned int row);

	unsigned int getNumRows();
	unsigned int getNumColumns();

	rlt_real *getData();

	void setMatrix(CMyMatrix *matrix);
	void initMatrix(rlt_real init);

	void saveASCII(FILE *stream);
};

/// A multidimensional Array
/**
Stores an one dimensional array of Type T1, and provides the simulation of a multi-dimensional array.
The number of dimensions and the size of each dimension is given to the constructor. There are accessing functions
for one dimensional an multidimensional indices.

*/
template <typename T1> class CMyArray 
{
protected:
	T1 *data;

	int *dim;
	int numDim;

	int size;

	CMyArray() {};

	void initialize(int numDim, int dim[])
	{
		this->numDim = numDim;
		this->dim = new int[numDim];

		memcpy(this->dim, dim, numDim * sizeof(int));

		size = 1;

		for (int i = 0; i < numDim; i++)
		{
			size = size * dim[i];
		}

		data = new T1 [size];
	}

public:
	CMyArray(int numDim, int dim[])
	{
		initialize(numDim, dim);
	}

	~CMyArray()
	{
		delete dim;
		delete data;
	}

	T1 get(int indices[])
	{
		int index = 0, size = 1;

		for (int i = 0; i < numDim; i++)
		{
			assert(indices[i] < dim[i] && indices[i] >=0);

			index += indices[i] * size;
			size = size * dim[i];
		}
		return data[index];
	}

	void set(int indices[], T1 d)
	{
		int index = 0, size = 1;

		for (int i = 0; i < numDim; i++)
		{
			assert(indices[i] < dim[i] && indices[i] >=0);

			index += indices[i] * size;
			size = size * dim[i];
		}
		data[index] = d;
	
	}

	void init(T1 initVal)
	{
		for (int i = 0; i < size; i++)
		{
			data[i] = initVal;
		}
	}

	int getSize()
	{
		return size;
	}

	void set1D(int index1d, T1 d)
	{
		data[index1d] = d;
	}

	T1 get1D(int index1d)
	{
		return data[index1d];
	}
};

/// Collection of Distributions
class CDistributions
{
public:
///Returns the gibs distribution (soft max)
/** beta is the head, used by the formular  In the values array there are given the single values. The function
writes then the propability of the indices in the array.
*/
	static void getGibbsDistribution(rlt_real beta, rlt_real *values, unsigned int numValues);

	static void getS1L0Distribution(rlt_real *values, unsigned int numValues);

	static rlt_real getNormalDistributionSample(rlt_real mu, rlt_real sigma);

	static int getSampledIndex(rlt_real *distribution, int numValues);
};



/// 2 dimensional Array
template<typename T1> class CMyArray2D : public CMyArray<T1>
{
public:
	CMyArray2D(int xDim, int yDim) 
	{
		int *l_dim = new int[2];
		l_dim[0] = xDim;
		l_dim[1] = yDim;

		initialize(2, l_dim);

		delete l_dim;
	}

	~CMyArray2D()
	{
	}

	T1 get(int xIndex, int yIndex)
	{
		int indices[2];
		indices[0] = xIndex;
		indices[1] = yIndex;

		return CMyArray<T1>::get(indices);
	}

	void set(int xIndex, int yIndex, T1 d)
	{
		int indices[2];
		indices[0] = xIndex;
		indices[1] = yIndex;

		CMyArray<T1>::set(indices, d);
	}
};

/// 3 dimensional array
template<typename T1> class CMyArray3D : public CMyArray<T1>
{
public:
	CMyArray3D(int xDim, int yDim, int zDim) : CMyArray<T1>()
	{
		int *ldim = new int[3];
		ldim[0] = xDim;
		ldim[1] = yDim;
		ldim[2] = zDim;

		initialize(3, ldim);
	}

	~CMyArray3D()
	{
		delete dim;
	}

	T1 get(int xIndex, int yIndex, int zIndex)
	{
		int indices[3];
		indices[0] = xIndex;
		indices[1] = yIndex;
		indices[2] = zIndex;

		return CMyArray<T1>::get(indices);
	}

	void set(int xIndex, int yIndex, int zIndex, T1 d)
	{
		int indices[3];
		indices[0] = xIndex;
		indices[1] = yIndex;
		indices[2] = zIndex;

		CMyArray<T1>::set(indices, d);
	}
};

// Maps feature indices to feature factors
class CFeatureMap : public std::map<int, rlt_real>
{
protected:
	rlt_real stdValue;

public:
	CFeatureMap(rlt_real stdValue = 0.0);

	rlt_real getValue(unsigned int featureIndex);
};
/*
/// N-dimensional Sparse for features
class CFeatureSparse
{
protected:
	CMyArray<CFeatureList *> *sparse;
	rlt_real stdValue;
	char *sparseName;

	int numDim;
	int *dim;

	void initSparse(int numDim, int dim[]);

	CFeatureSparse();

public:
	CFeatureSparse(FILE *file, int numDim = 0, int *dim = NULL);
	CFeatureSparse(int numDim, int dim[]);
	virtual ~CFeatureSparse();

	virtual rlt_real getFactor(int indeces[], unsigned int featureIndex);
	void setFactor(rlt_real factor, int indeces[], unsigned int featureIndex);
	void addFactor(rlt_real factor, int indeces[], unsigned int featureIndex);
	void loadASCII(FILE *stream);

	CFeature *getCFeature(int indeces[], unsigned int featureIndex);
	CFeature *getCFeature1D(int index1D, unsigned int featureIndex);
	virtual CFeatureList *getFeatureList(int indeces[]);
	
	void saveASCII(FILE *stream);
};

/// 2 dimensional feature sparse.
//so there a a 2 dimensional array of feature lists.

class CFeatureSparse2D : public CFeatureSparse
{
public:
	CFeatureSparse2D(FILE *file);
	CFeatureSparse2D(int dim1, int dim2);
	virtual ~CFeatureSparse2D();

	virtual rlt_real getFactor(int ind1, int ind2, unsigned int featureIndex);
	virtual void setFactor(rlt_real factor, int ind1, int ind2, unsigned int featureIndex);
	virtual void addFactor(rlt_real factor, int ind1, int ind2, unsigned int featureIndex);

	virtual CFeatureList *getFeatureList(int ind1, int ind2);

	CFeature* getCFeature(int ind1, int ind2, unsigned int featureIndex);

	
};*/

#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 久久99国产乱子伦精品免费| 欧美日韩一区二区欧美激情| 久久精品久久综合| 欧美一级高清片在线观看| 日本美女视频一区二区| 欧美v亚洲v综合ⅴ国产v| 狠狠狠色丁香婷婷综合激情 | 欧美视频在线观看一区| 亚洲电影你懂得| 91精品国产欧美一区二区成人| 日本色综合中文字幕| 精品久久国产字幕高潮| 成人小视频免费在线观看| 国产精品久线观看视频| 欧美色老头old∨ideo| 麻豆高清免费国产一区| 国产女同互慰高潮91漫画| 91蜜桃网址入口| 日韩不卡一二三区| 国产欧美日本一区视频| 欧美亚洲禁片免费| 国产一区二区三区免费| 18成人在线观看| 日韩欧美激情四射| 91视频在线观看免费| 天堂在线亚洲视频| 国产精品网站在线播放| 欧美色国产精品| 风间由美一区二区三区在线观看 | 国产一区二区三区黄视频 | 久久久久久久久久久久电影 | 国产精品久久久久久久久快鸭| www.欧美精品一二区| 香蕉成人伊视频在线观看| 久久久久久久久伊人| 欧美在线视频日韩| 成人夜色视频网站在线观看| 亚洲国产精品久久人人爱| 精品乱人伦小说| 欧洲精品一区二区| 国产精品一区二区不卡| 婷婷六月综合亚洲| 国产精品二区一区二区aⅴ污介绍| 欧美日韩亚洲丝袜制服| 成人污视频在线观看| 美腿丝袜亚洲一区| 亚洲一区在线免费观看| 中文字幕免费不卡| 日韩亚洲欧美中文三级| 欧美在线你懂得| 99久久精品国产一区二区三区| 麻豆精品视频在线观看| 天天影视网天天综合色在线播放| 中文字幕在线不卡一区| 久久影院电视剧免费观看| 欧美sm极限捆绑bd| 欧美精品在线观看一区二区| 97超碰欧美中文字幕| 国产成人综合视频| 麻豆专区一区二区三区四区五区| 亚洲国产裸拍裸体视频在线观看乱了| 中文字幕av免费专区久久| 2023国产精品视频| 日韩精品在线一区| 欧美一区二区三区日韩视频| 欧美日韩精品福利| 欧美视频在线播放| 欧美怡红院视频| 欧美影院午夜播放| 欧美性猛片aaaaaaa做受| 色综合久久中文综合久久97| 99久久99久久精品免费看蜜桃| 国产成人在线视频免费播放| 国产一区二区电影| 国产麻豆精品theporn| 国内精品久久久久影院薰衣草| 蜜臀av性久久久久av蜜臀妖精 | 不卡电影一区二区三区| 国产传媒久久文化传媒| 国产精品一区二区三区99| 国产精品亚洲第一区在线暖暖韩国| 蜜臀av性久久久久蜜臀aⅴ流畅| 美女脱光内衣内裤视频久久网站| 日韩av午夜在线观看| 青青草国产成人av片免费| 日本91福利区| 国内精品免费**视频| 国产成人综合自拍| 成人教育av在线| 色综合激情久久| 欧美日韩精品一区二区三区| 欧美日韩极品在线观看一区| 日韩欧美一级二级三级| 2020日本不卡一区二区视频| 欧美激情一区二区三区蜜桃视频| 国产欧美日本一区视频| 中文字幕在线一区| 亚洲精品国产一区二区精华液 | 久久综合视频网| 国产视频一区二区在线| 亚洲图片激情小说| 亚洲国产日韩在线一区模特| 美国av一区二区| 成人av在线一区二区| 欧洲一区二区三区在线| 日韩三级av在线播放| 国产嫩草影院久久久久| 一区二区三区中文字幕精品精品 | 蜜臀久久久99精品久久久久久| 久久国产精品一区二区| jlzzjlzz亚洲日本少妇| 欧洲av一区二区嗯嗯嗯啊| 欧美mv日韩mv国产| 一区二区中文视频| 首页欧美精品中文字幕| 国产传媒欧美日韩成人| 欧美日韩成人综合| 久久久精品国产免大香伊| 一区二区三区在线免费播放| 狠狠色丁香久久婷婷综合_中| 成人av免费网站| 欧美男女性生活在线直播观看| 久久久久久久久久久99999| 亚洲国产精品天堂| 成人激情视频网站| 欧美一区二区三区免费观看视频| 国产精品乱码一区二三区小蝌蚪| 亚洲成人精品影院| 成人午夜电影久久影院| 欧美一区二区三区喷汁尤物| 亚洲美女屁股眼交| 国产精品资源站在线| 欧美高清一级片在线| 国产精品久久久久国产精品日日| 蜜臀国产一区二区三区在线播放 | 欧美日韩国产综合久久| 国产日韩视频一区二区三区| 奇米影视一区二区三区小说| 91蜜桃传媒精品久久久一区二区| 精品成人a区在线观看| 一区二区三区中文字幕精品精品| 国产91色综合久久免费分享| 日韩欧美你懂的| 日韩高清中文字幕一区| 色偷偷久久人人79超碰人人澡 | 亚洲综合999| 不卡av免费在线观看| 久久精品在线观看| 麻豆精品视频在线观看视频| 欧美日韩免费电影| 亚洲一区二区三区四区的| 成人免费视频国产在线观看| 久久久久99精品一区| 久久精品国产99国产精品| 欧美日韩国产一级| 亚洲精品视频一区二区| 成人精品国产福利| 国产欧美一区二区三区沐欲| 国产一区二区不卡老阿姨| 欧美一二三区精品| 日欧美一区二区| 欧美性生活久久| 亚洲韩国精品一区| 欧美日韩在线免费视频| 亚洲福利视频一区| 欧美精品 日韩| 蜜桃一区二区三区在线| 日韩欧美在线1卡| 秋霞午夜av一区二区三区| 欧美一区二视频| 男男视频亚洲欧美| 日韩亚洲欧美高清| 免费观看91视频大全| 日韩欧美一二三四区| 精品在线播放午夜| 国产午夜一区二区三区| 成人综合在线视频| 中文字幕国产一区二区| 91香蕉国产在线观看软件| 一区二区三区在线高清| 欧美美女一区二区在线观看| 男男成人高潮片免费网站| 精品久久久久香蕉网| 国产宾馆实践打屁股91| 亚洲乱码国产乱码精品精可以看| 91性感美女视频| 日日夜夜免费精品视频| 欧美精品乱码久久久久久按摩| 琪琪久久久久日韩精品| 国产亚洲精品久| 日本高清成人免费播放| 婷婷综合五月天| 久久久久久久久久久久久女国产乱| 99国产一区二区三精品乱码| 亚洲三级在线免费| 欧美一区二区二区| 国产传媒一区在线| 亚洲国产成人高清精品| 精品国产一区二区三区久久久蜜月|