// ============================================================== // This file is part of MegaGlest Shared Library (www.megaglest.org) // // Copyright (C) 2012 Mark Vejvoda, Titus Tscharntke // 2001-2008 MartiƱo Figueroa // // You can redistribute this code and/or modify it under // the terms of the GNU General Public License as published // by the Free Software Foundation; either version 2 of the // License, or (at your option) any later version // ============================================================== #include "randomgen.h" #include #include "util.h" #include #include "platform_util.h" #include "math_util.h" #include "leak_dumper.h" using namespace std; using namespace Shared::Graphics; namespace Shared { namespace Util { // ===================================================== // class RandomGen // ===================================================== const int RandomGen::m= 714025; const int RandomGen::a= 1366; const int RandomGen::b= 150889; RandomGen::RandomGen(){ //#ifdef USE_STREFLOP // lastNumber = streflop::RandomInit(0); // streflop //#else lastNumber= 0; //#endif //SystemFlags::OutputDebug(SystemFlags::debugSystem,"In [%s::%s Line: %d] lastNumber = %d\n",__FILE__,__FUNCTION__,__LINE__,lastNumber); } void RandomGen::init(int seed){ //#ifdef USE_STREFLOP // lastNumber = streflop::RandomInit(seed); // streflop //#else lastNumber= seed % m; //#endif //SystemFlags::OutputDebug(SystemFlags::debugSystem,"In [%s::%s Line: %d] seed = %d, lastNumber = %d\n",__FILE__,__FUNCTION__,__LINE__,seed,lastNumber); } int RandomGen::rand(string lastCaller) { //SystemFlags::OutputDebug(SystemFlags::debugSystem,"In [%s::%s Line: %d] lastNumber = %d\n",__FILE__,__FUNCTION__,__LINE__,lastNumber); this->lastNumber = (a*lastNumber + b) % m; //this->lastCaller.push_back(lastCaller); //SystemFlags::OutputDebug(SystemFlags::debugSystem,"In [%s::%s Line: %d] lastNumber = %d\n",__FILE__,__FUNCTION__,__LINE__,lastNumber); return lastNumber; } std::string RandomGen::getLastCaller() const { std::string result = ""; if(lastCaller.empty() == false) { for(unsigned int index = 0; index < lastCaller.size(); ++index) { result += lastCaller[index] + " "; } } return result; } int RandomGen::randRange(int min, int max,string lastCaller) { //assert(min<=max); if(min > max) { char szBuf[8096]=""; snprintf(szBuf,8096,"In [%s::%s Line: %d] min > max, min = %d, max = %d",__FILE__,__FUNCTION__,__LINE__,min,max); throw megaglest_runtime_error(szBuf); } //#ifdef USE_STREFLOP // int res = streflop::Random(min, max); // streflop //#else int diff= max-min; //int res= min + static_cast(truncateDecimal(static_cast(diff+1),2)*RandomGen::rand() / m); double numerator = static_cast(diff + 1) * static_cast(RandomGen::rand(lastCaller)); int res= min + static_cast(truncateDecimal(numerator / static_cast(m))); //int res= min + static_cast(truncateDecimal(static_cast(diff+1 * RandomGen::rand()) / static_cast(m))); //#endif //assert(res>=min && res<=max); if(res < min || res > max) { char szBuf[8096]=""; snprintf(szBuf,8096,"In [%s::%s Line: %d] res < min || res > max, min = %d, max = %d, res = %d",__FILE__,__FUNCTION__,__LINE__,min,max,res); throw megaglest_runtime_error(szBuf); } //SystemFlags::OutputDebug(SystemFlags::debugSystem,"In [%s::%s Line: %d] min = %d, max = %d, res = %d\n",__FILE__,__FUNCTION__,__LINE__,min,max,res); return res; } float RandomGen::randRange(float min, float max,string lastCaller) { //assert(min<=max); if(min > max) { char szBuf[8096]=""; snprintf(szBuf,8096,"In [%s::%s Line: %d] min > max, min = %f, max = %f",__FILE__,__FUNCTION__,__LINE__,min,max); throw megaglest_runtime_error(szBuf); } //#ifdef USE_STREFLOP // float res = streflop::Random(min, max, randomState); // streflop //#else float rand01= static_cast(RandomGen::rand(lastCaller))/(m-1); float res= min+(max-min)*rand01; res = truncateDecimal(res); //#endif //assert(res>=min && res<=max); if(res < min || res > max) { char szBuf[8096]=""; snprintf(szBuf,8096,"In [%s::%s Line: %d] res < min || res > max, min = %f, max = %f, res = %f",__FILE__,__FUNCTION__,__LINE__,min,max,res); throw megaglest_runtime_error(szBuf); } //SystemFlags::OutputDebug(SystemFlags::debugSystem,"In [%s::%s Line: %d] min = %f, max = %f, res = %f\n",__FILE__,__FUNCTION__,__LINE__,min,max,res); return res; } }}//end namespace