| [0275ad] | 1 | /* | 
|---|
|  | 2 | * RandomNumberEngine_Parameters.hpp | 
|---|
|  | 3 | * | 
|---|
|  | 4 | *  Created on: Jan 6, 2011 | 
|---|
|  | 5 | *      Author: heber | 
|---|
|  | 6 | */ | 
|---|
|  | 7 |  | 
|---|
|  | 8 | #ifndef RANDOMNUMBERENGINE_PARAMETERS_HPP_ | 
|---|
|  | 9 | #define RANDOMNUMBERENGINE_PARAMETERS_HPP_ | 
|---|
|  | 10 |  | 
|---|
|  | 11 | // include config.h | 
|---|
|  | 12 | #ifdef HAVE_CONFIG_H | 
|---|
|  | 13 | #include <config.h> | 
|---|
|  | 14 | #endif | 
|---|
|  | 15 |  | 
|---|
|  | 16 | #include <iosfwd> | 
|---|
|  | 17 | #include <map> | 
|---|
|  | 18 |  | 
|---|
|  | 19 | class RandomNumberEngine; | 
|---|
|  | 20 |  | 
|---|
|  | 21 | struct RandomNumberEngine_Parameters | 
|---|
|  | 22 | { | 
|---|
|  | 23 | /** Constructor of class RandomNumberEngine_Parameters. | 
|---|
|  | 24 | * | 
|---|
|  | 25 | *  @note sets all values to  noset_value. | 
|---|
|  | 26 | */ | 
|---|
|  | 27 | RandomNumberEngine_Parameters(); | 
|---|
|  | 28 |  | 
|---|
|  | 29 | /** Copy constructor of class RandomNumberEngine_Parameters. | 
|---|
|  | 30 | * | 
|---|
|  | 31 | * | 
|---|
|  | 32 | *  @param _ref reference to instance to copy | 
|---|
|  | 33 | */ | 
|---|
|  | 34 | RandomNumberEngine_Parameters(const RandomNumberEngine_Parameters &_ref); | 
|---|
|  | 35 |  | 
|---|
|  | 36 | /** Destructor of class RandomNumberEngine_Parameters. | 
|---|
|  | 37 | * | 
|---|
|  | 38 | */ | 
|---|
|  | 39 | ~RandomNumberEngine_Parameters(); | 
|---|
|  | 40 |  | 
|---|
|  | 41 | enum ParamList { | 
|---|
|  | 42 | param_seed, | 
|---|
|  | 43 | }; | 
|---|
|  | 44 |  | 
|---|
|  | 45 | /** This value is chosen such that no parameter can have it as a sensible | 
|---|
|  | 46 | * value. | 
|---|
|  | 47 | */ | 
|---|
|  | 48 | static const double noset_value; | 
|---|
|  | 49 |  | 
|---|
|  | 50 | /** Fills the structure from the parameters obtained from \a engine. | 
|---|
|  | 51 | * | 
|---|
|  | 52 | * @param _engine | 
|---|
|  | 53 | */ | 
|---|
|  | 54 | void getParameters(const RandomNumberEngine* const _engine); | 
|---|
|  | 55 |  | 
|---|
|  | 56 | /** Merges this parameter set with another, where other has priority. | 
|---|
|  | 57 | * | 
|---|
|  | 58 | * @note we ignore entries in \a _params with noset_value. | 
|---|
|  | 59 | * | 
|---|
|  | 60 | * @param _params other parameter set to update with | 
|---|
|  | 61 | */ | 
|---|
|  | 62 | void update(const RandomNumberEngine_Parameters &_params); | 
|---|
|  | 63 |  | 
|---|
|  | 64 | /** Checks whether all parameters are set to noset_value values. | 
|---|
|  | 65 | * | 
|---|
|  | 66 | * noset_value | 
|---|
|  | 67 | * | 
|---|
|  | 68 | * @return true - all are equal noset_value, | 
|---|
|  | 69 | *         false - at least is not equal noset_value | 
|---|
|  | 70 | */ | 
|---|
|  | 71 | bool isDefault() const; | 
|---|
|  | 72 |  | 
|---|
|  | 73 |  | 
|---|
|  | 74 | int seed; //!< seed of random number engine | 
|---|
|  | 75 |  | 
|---|
|  | 76 | typedef std::map< | 
|---|
|  | 77 | std::string, | 
|---|
|  | 78 | ParamList | 
|---|
|  | 79 | > ParamNames; | 
|---|
|  | 80 |  | 
|---|
|  | 81 | static ParamNames params; | 
|---|
|  | 82 | }; | 
|---|
|  | 83 |  | 
|---|
|  | 84 | std::ostream & operator << (std::ostream& ost, const RandomNumberEngine_Parameters ¶ms); | 
|---|
|  | 85 | std::istream & operator >> (std::istream& ist, RandomNumberEngine_Parameters ¶ms); | 
|---|
|  | 86 |  | 
|---|
|  | 87 |  | 
|---|
|  | 88 | #endif /* RANDOMNUMBERENGINE_PARAMETERS_HPP_ */ | 
|---|