2001-12-27 19:54:36 +00:00
|
|
|
//============================================================================
|
|
|
|
//
|
|
|
|
// SSSS tt lll lll
|
|
|
|
// SS SS tt ll ll
|
|
|
|
// SS tttttt eeee ll ll aaaa
|
|
|
|
// SSSS tt ee ee ll ll aa
|
|
|
|
// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator"
|
|
|
|
// SS SS tt ee ll ll aa aa
|
|
|
|
// SSSS ttt eeeee llll llll aaaaa
|
|
|
|
//
|
2014-01-12 17:23:42 +00:00
|
|
|
// Copyright (c) 1995-2014 by Bradford W. Mott, Stephen Anthony
|
2010-04-10 21:37:23 +00:00
|
|
|
// and the Stella Team
|
2001-12-27 19:54:36 +00:00
|
|
|
//
|
2010-01-10 03:23:32 +00:00
|
|
|
// See the file "License.txt" for information on usage and redistribution of
|
2001-12-27 19:54:36 +00:00
|
|
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
|
|
|
//
|
2009-05-13 13:55:40 +00:00
|
|
|
// $Id$
|
2001-12-27 19:54:36 +00:00
|
|
|
//============================================================================
|
|
|
|
|
|
|
|
#ifndef RANDOM_HXX
|
|
|
|
#define RANDOM_HXX
|
|
|
|
|
2008-05-16 23:56:31 +00:00
|
|
|
class OSystem;
|
|
|
|
|
2001-12-27 19:54:36 +00:00
|
|
|
#include "bspf.hxx"
|
|
|
|
|
|
|
|
/**
|
|
|
|
This is a quick-and-dirty random number generator. It is based on
|
|
|
|
information in Chapter 7 of "Numerical Recipes in C". It's a simple
|
|
|
|
linear congruential generator.
|
|
|
|
|
|
|
|
@author Bradford W. Mott
|
2009-05-13 13:55:40 +00:00
|
|
|
@version $Id$
|
2001-12-27 19:54:36 +00:00
|
|
|
*/
|
|
|
|
class Random
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
Create a new random number generator
|
|
|
|
*/
|
|
|
|
Random();
|
|
|
|
|
|
|
|
public:
|
2009-11-05 00:41:44 +00:00
|
|
|
/**
|
|
|
|
Re-initialize the random number generator with a new seed,
|
|
|
|
to generate a different set of random numbers.
|
|
|
|
*/
|
|
|
|
void initSeed();
|
|
|
|
|
2001-12-27 19:54:36 +00:00
|
|
|
/**
|
|
|
|
Answer the next random number from the random number generator
|
|
|
|
|
|
|
|
@return A random number
|
|
|
|
*/
|
|
|
|
uInt32 next();
|
|
|
|
|
2008-05-16 23:56:31 +00:00
|
|
|
/**
|
|
|
|
Class method which sets the OSystem in use; the constructor will
|
|
|
|
use this to reseed the random number generator every time a new
|
|
|
|
instance is created
|
|
|
|
|
|
|
|
@param system The system currently in use
|
|
|
|
*/
|
|
|
|
static void setSystem(const OSystem* system) { ourSystem = system; }
|
|
|
|
|
2001-12-27 19:54:36 +00:00
|
|
|
private:
|
|
|
|
// Indicates the next random number
|
|
|
|
uInt32 myValue;
|
|
|
|
|
2008-05-16 23:56:31 +00:00
|
|
|
// Set the OSystem we're using
|
|
|
|
static const OSystem* ourSystem;
|
2001-12-27 19:54:36 +00:00
|
|
|
};
|
|
|
|
|
2008-05-16 23:56:31 +00:00
|
|
|
#endif
|