source: src/RandomNumbers/RandomNumberEngine_Encapsulation.hpp@ 081e5d

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Added_ParseSaveFragmentResults AddingActions_SaveParseParticleParameters Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_ParticleName_to_Atom Adding_StructOpt_integration_tests AtomFragments Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.5.4 Candidate_v1.6.0 Candidate_v1.6.1 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator CombiningParticlePotentialParsing Combining_Subpackages Debian_Package_split Debian_package_split_molecuildergui_only Disabling_MemDebug Docu_Python_wait EmpiricalPotential_contain_HomologyGraph EmpiricalPotential_contain_HomologyGraph_documentation Enable_parallel_make_install Enhance_userguide Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Example_ManyWaysToTranslateAtom Exclude_Hydrogens_annealWithBondGraph FitPartialCharges_GlobalError Fix_BoundInBox_CenterInBox_MoleculeActions Fix_ChargeSampling_PBC Fix_ChronosMutex Fix_FitPartialCharges Fix_FitPotential_needs_atomicnumbers Fix_ForceAnnealing Fix_IndependentFragmentGrids Fix_ParseParticles Fix_ParseParticles_split_forward_backward_Actions Fix_PopActions Fix_QtFragmentList_sorted_selection Fix_Restrictedkeyset_FragmentMolecule Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns Fix_fitting_potentials Fixes ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion FragmentAction_writes_AtomFragments FragmentMolecule_checks_bonddegrees GeometryObjects Gui_Fixes Gui_displays_atomic_force_velocity ImplicitCharges IndependentFragmentGrids IndependentFragmentGrids_IndividualZeroInstances IndependentFragmentGrids_IntegrationTest IndependentFragmentGrids_Sole_NN_Calculation JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix MoreRobust_FragmentAutomation ODR_violation_mpqc_open PartialCharges_OrthogonalSummation PdbParser_setsAtomName PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks Rewrite_FitPartialCharges RotateToPrincipalAxisSystem_UndoRedo SaturateAtoms_findBestMatching SaturateAtoms_singleDegree StoppableMakroAction Subpackage_CodePatterns Subpackage_JobMarket Subpackage_LinearAlgebra Subpackage_levmar Subpackage_mpqc_open Subpackage_vmg Switchable_LogView ThirdParty_MPQC_rebuilt_buildsystem TrajectoryDependenant_MaxOrder TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps TremoloParser_setsAtomName Ubuntu_1604_changes stable
Last change on this file since 081e5d was 081e5d, checked in by Frederik Heber <heber@…>, 14 years ago

Implemented all possible parameter functions for engine and distribution in interface.

  • template member function has an ASSERT.
  • and then for each actually present parameter function of a specific engine or distribution there is a function specialization that passes on the request.
  • minimal use is made in the engine and distribution factory unit tests and everything is fine so far.
  • Property mode set to 100644
File size: 3.0 KB
Line 
1/*
2 * RandomNumberEngine_Encapsulation.hpp
3 *
4 * Created on: Jan 01, 2011
5 * Author: heber
6 */
7
8#ifndef RANDOMNUMBERENGINE_ENCAPSULATION_HPP_
9#define RANDOMNUMBERENGINE_ENCAPSULATION_HPP_
10
11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
16#include <typeinfo>
17
18#include <boost/nondet_random.hpp>
19#include <boost/random.hpp>
20#include <boost/random/additive_combine.hpp>
21#include <boost/random/discard_block.hpp>
22#include <boost/random/inversive_congruential.hpp>
23#include <boost/random/lagged_fibonacci.hpp>
24#include <boost/random/linear_congruential.hpp>
25#include <boost/random/linear_feedback_shift.hpp>
26#include <boost/random/mersenne_twister.hpp>
27#include <boost/random/random_number_generator.hpp>
28#include <boost/random/ranlux.hpp>
29#include <boost/random/shuffle_output.hpp>
30#include <boost/random/subtract_with_carry.hpp>
31#include <boost/random/xor_combine.hpp>
32
33#include "CodePatterns/Clone.hpp"
34#include "RandomNumberEngine.hpp"
35
36class RandomNumberEngineFactory;
37
38/** Template class that encapsulates the random number engines from
39 * random::boost.
40 *
41 *
42 * We need one template parameters:
43 * -# the engine - generates uniform random numbers
44 */
45template <class engine>
46class RandomNumberEngine_Encapsulation :
47 public RandomNumberEngine,
48 public Clone<RandomNumberEngine>
49{
50 /**
51 * Factory is friend such that it can access private cstor when filling its
52 * table
53 */
54 friend class RandomNumberEngineFactory;
55
56public:
57 /** Set the engine's seed.
58 *
59 * @param _seed seed to set to
60 */
61 void seed(unsigned int _seed) {
62 value_seed = _seed;
63 engine_type.seed(value_seed);
64 }
65
66 /** Getter for the engine's seed.
67 *
68 * @return seed
69 */
70 unsigned int getseed() const {
71 return value_seed;
72 }
73
74 /** Getter for smallest value the engine produces.
75 *
76 * @return smallest value
77 */
78 double min() const {
79 return engine_type.min();
80 }
81
82 /** Getter for largest value the engine produces.
83 *
84 * @return largest value
85 */
86 double max() const {
87 return engine_type.max();
88 }
89
90 /** Getter for the type name of the internal engine.
91 *
92 */
93 std::string name() {
94 return typeid(engine_type).name();
95 }
96
97 /** Getter for the engine instance.
98 *
99 * @return reference to instance
100 */
101 engine& getEngine() {
102 return engine_type;
103 }
104
105 /** Clones the current instance.
106 *
107 * Implementation of Clone pattern.
108 *
109 * @return interface reference to cloned instance
110 */
111 RandomNumberEngine* clone() const {
112 RandomNumberEngine* MyClone = NULL;
113 MyClone = new RandomNumberEngine_Encapsulation<engine>();
114 MyClone->seed(getseed());
115 return MyClone;
116 }
117
118protected:
119 /** Constructor that instantiates a specific random number generator and
120 * distribution.
121 * @param _engine_type instance of the desired engine
122 */
123 RandomNumberEngine_Encapsulation() :
124 value_seed(1)
125 {}
126
127 /** Destructor of the class.
128 *
129 */
130 virtual ~RandomNumberEngine_Encapsulation() {}
131private:
132 engine engine_type;
133 unsigned int value_seed;
134};
135
136#endif /* RANDOMNUMBERENGINE_ENCAPSULATION_HPP_ */
Note: See TracBrowser for help on using the repository browser.