⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 cutility.cpp

📁 强化学习算法(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.

#ifndef M_PI
#define M_PI 3.14159265358979323846
#endif

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

int my_round(rlt_real value)
{
	int intvalue = (int) floor(value);
	if (value - intvalue > 0.5)
	{
		intvalue ++;
	}
	return intvalue;
}

rlt_real my_exp(rlt_real value)
{
	if (value > MAX_EXP)
	{
		value = MAX_EXP;
	}
	else
	{
		if (value < MIN_EXP)
		{
			value = MIN_EXP;
		}
	}
	return exp(value);
}


CMyVector::CMyVector(unsigned int dimensions, rlt_real *data)
{
	this->dimensions = dimensions;
	this->data = new rlt_real[dimensions];
	
	if (data)
	{
		memcpy(this->data, data, dimensions * sizeof(rlt_real));
	}
	else
	{
		for (unsigned int i = 0; i < dimensions; i++)
		{
			this->data[i] = 0.0;
		}
	}
}

CMyVector::~CMyVector()
{
	delete [] data;
}

void CMyVector::dotVector(CMyVector *vector)
{
	rlt_real *data_vec =  vector->getData();
	for (unsigned int i = 0;i < getNumDimensions(); i++)
	{
		data[i] *= data_vec[i];
	}
}

rlt_real CMyVector::scalarProduct(CMyVector *vector)
{
	assert(getNumDimensions() == vector->getNumDimensions());
	rlt_real *data2 = vector->getData();
	rlt_real skalarprod = 0.0;

	for (unsigned int i = 0; i < getNumDimensions(); i++)
	{
		skalarprod += data[i] * data2[i];
	}
	return skalarprod;
}

rlt_real CMyVector::getDistance(CMyVector *vector)
{
	assert(getNumDimensions() == vector->getNumDimensions());
	rlt_real *data2 = vector->getData();
	rlt_real distance = 0.0;

	for (unsigned int i = 0; i < getNumDimensions(); i++)
	{
		distance += pow(data[i] - data2[i], 2);
	}
	return sqrt(distance);
}

void CMyVector::addVector(CMyVector *vector)
{
	assert(getNumDimensions() == vector->getNumDimensions());
	rlt_real *data2 = vector->getData();
	
	for (unsigned int i = 0; i < getNumDimensions(); i++)
	{
		data[i] += data2[i];
	}
}

void CMyVector::addScalar(rlt_real factor)
{
	for (unsigned int i = 0; i < getNumDimensions(); i++)
	{
		data[i] += factor;
	}
}

void CMyVector::multMatrix(CMyMatrix *matrix, CMyVector *output)
{
	assert(getNumDimensions() == matrix->getNumRows() && output->getNumDimensions() == matrix->getNumColumns());
	rlt_real *dataRow;
	rlt_real *dataOutput = output->getData();
	
	rlt_real *vectorData;
	bool newVec = false;

	if (dataOutput == data)
	{
		vectorData = new rlt_real[getNumDimensions()];
		memcpy(vectorData, data, getNumDimensions() * sizeof(rlt_real));
		newVec = true;
	}
	else
	{
		vectorData = data;
	}

	output->initVector(0.0);

	for (unsigned int i = 0; i < matrix->getNumRows(); i++)
	{
		dataRow = matrix->getRow(i);

		for (unsigned int j = 0; j < matrix->getNumColumns(); j++)
		{
			dataOutput[j] += dataRow[j] * vectorData[i];
		}
	}
	if (newVec)
	{
		delete vectorData;
	}
}

void CMyVector::multMatrix(CMyMatrix *matrix)
{
	assert(getNumDimensions() == matrix->getNumColumns() && getNumDimensions() == matrix->getNumRows());

    multMatrix(matrix, this);
}


void CMyVector::multVector(CMyVector *vector, CMyMatrix *output)
{
	assert(getNumDimensions() == output->getNumRows() && vector->getNumDimensions() == output->getNumColumns());
	rlt_real *data2 = vector->getData();
	rlt_real *dataRow = NULL;

	for (unsigned int j = 0; j < output->getNumRows(); j++)
	{
		dataRow = output->getRow(j);
		for (unsigned int i = 0; i < output->getNumColumns(); i++)
		{
			dataRow[i] = data[j] * data2[i];
		}
	}
}

void CMyVector::multScalar(rlt_real scalar)
{
	for (unsigned int i = 0; i < getNumDimensions(); i++)
	{
		data[i] *= scalar;
	}
}

rlt_real CMyVector::getElement(unsigned int index)
{
	assert(index < getNumDimensions());
	return data[index];
}

void CMyVector::saveASCII(FILE *stream)
{
	fprintf(stream,"[ ");
	for(unsigned int i = 0; i < getNumDimensions(); i++)
	{
		fprintf(stream, "%f ", data[i]);
	}
	fprintf(stream, "]\n");
}

void CMyVector::loadASCII(FILE *stream)
{
	fscanf(stream,"[ ");
	for(unsigned int i = 0; i < getNumDimensions(); i++)
	{
		fscanf(stream, "%f ", &data[i]);
	}
	fscanf(stream, "]\n");
}

void CMyVector::setElement(unsigned int index, rlt_real value)
{
	assert(index < getNumDimensions());
	data[index] = value;
}

unsigned int CMyVector::getNumDimensions()
{
	return dimensions;
}

rlt_real *CMyVector::getData()
{
	return data;
}

void CMyVector::setVector(CMyVector *vector)
{
	assert(vector->getNumDimensions() == getNumDimensions());
	memcpy(data, vector->getData(), getNumDimensions() * sizeof(rlt_real));
}

void CMyVector::initVector(rlt_real init)
{
	for (unsigned int i = 0; i < getNumDimensions(); i++)
	{
		data[i] = init;
	}
}

rlt_real CMyVector::getLength()
{
	rlt_real length = 0;
	for (unsigned int i = 0; i < getNumDimensions(); i++)
	{
		length += pow(data[i], 2);
	}
	return sqrt(length);
}

void CMyVector::normalizeVector()
{
	rlt_real length = getLength();
	if (length > 0.00001)
	{
		multScalar(1.0 / length);
	}
}


CMyMatrix::CMyMatrix(unsigned int rows, unsigned int columns, rlt_real *data)
{
	this->rows = rows;
	this->columns = columns;
	this->data = new rlt_real[rows * columns];

	if (data != NULL)
	{
		memcpy(this->data, data, rows * columns * sizeof(rlt_real));
	}
}

CMyMatrix::~CMyMatrix()
{
	delete data;
}

void CMyMatrix::addVector(CMyVector *vector)
{
	rlt_real *rowData;
	
	for (unsigned int i = 0; i < getNumRows(); i++)
	{
		rowData = getRow(i);
		for (unsigned int j = 0; j < getNumColumns(); j++)
		{
			rowData[j] += vector->getElement(i);
		}
	}
}

void CMyMatrix::addScalar(rlt_real scalar)
{	
	rlt_real *rowData;

	for (unsigned int i = 0; i < getNumRows(); i++)
	{
		rowData = getRow(i);
		for (unsigned int j = 0; j < getNumColumns(); j++)
		{
			rowData[j] += scalar;
		}
	}
}


void CMyMatrix::multMatrix(CMyMatrix *matrix, CMyMatrix *output)
{
	assert(this->getNumColumns() == matrix->getNumRows() && output->getNumRows() == this->getNumRows() && output->getNumColumns() == matrix->getNumColumns());

	rlt_real *rowData = NULL;

	for (unsigned int i = 0; i < getNumRows(); i++)
	{
		rowData = output->getRow(i);
		for (unsigned int j = 0; j < getNumColumns(); j++)
		{
			rowData[j] = 0.0;
			for (unsigned int k = 0; k < getNumColumns(); k++)
			{
				rowData[j] += getElement(i, k) * matrix->getElement(k, j);
			}
		}
	}
}

void CMyMatrix::multVector(CMyVector *vector, CMyVector *output)
{
	assert(vector->getNumDimensions() == getNumColumns() && output->getNumDimensions() == getNumRows());
	rlt_real *dataRow;
	rlt_real *dataOutput = output->getData();

	rlt_real *vectorData = vector->getData();

	for (unsigned int i = 0; i < getNumRows(); i++)
	{
		dataRow = getRow(i);
		dataOutput[i] = 0.0;
		for (unsigned int j = 0; j < getNumColumns(); j++)
		{
			dataOutput[i] += dataRow[j] * vectorData[j];
		}
	}
}

void CMyMatrix::multScalar(rlt_real scalar)
{
	rlt_real *rowData;

	for (unsigned int i = 0; i < getNumRows(); i++)
	{
		rowData = getRow(i);
		for (unsigned int j = 0; j < getNumColumns(); j++)
		{
			rowData[j] *= scalar;
		}
	}
}

rlt_real CMyMatrix::getElement(unsigned int row, unsigned int column)
{
	return data[row * getNumColumns() + column];
}

void CMyMatrix::setElement(unsigned int row, unsigned int column, rlt_real value)
{
	data[row * getNumColumns() + column] = value;
}

rlt_real *CMyMatrix::getRow(unsigned int row)
{
	return (data + row * getNumColumns());
}

rlt_real *CMyMatrix::getData()
{
	return data;
}

unsigned int CMyMatrix::getNumRows()
{
	return rows;
}

unsigned int CMyMatrix::getNumColumns()
{

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -