Ignore:
Timestamp:
Feb 3, 2011, 9:51:19 AM (14 years ago)
Author:
Frederik Heber <heber@…>
Branches:
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
Children:
1d5a871
Parents:
3f9eba
git-author:
Frederik Heber <heber@…> (01/03/11 14:01:22)
git-committer:
Frederik Heber <heber@…> (02/03/11 09:51:19)
Message:

Bigger rewrite of RandomNumbers ... due to cloning of prototypes.

  • in order to copy the prototypes and not use the original instance, we have implemented a new pattern called "Creator" that wraps a templated class in a creation interface class such that this abstract class can instaniate the particular types (see here http://stackoverflow.com/questions/3506026/c-clone-abstract-base-class-without-meddling-with-derived). This is also wrapped up in ..._Creator.hpp files.
  • meanwhile we also tried to have factories for Engine and Distribution but this failed due to boost::variate_operator<> having to know the particular types of engine and distribution. One could go forth with some cast's but this is very unclean and not what we want. ... Downside is that we can't set global options for engines or distributions as of now.
  • For the moment Engine- and DistributionFactory both have a prototype table, i.e. the same wrapped ones as above, but they are not used for the GeneratorFactory.
Location:
src/RandomNumbers/unittests
Files:
6 added
3 edited

Legend:

Unmodified
Added
Removed
  • src/RandomNumbers/unittests/Makefile.am

    r3f9eba rc9bc2b7  
    88
    99TESTS = \
    10   RandomNumberGeneratorFactoryUnitTest
     10  RandomNumberDistributionFactoryUnitTest \
     11  RandomNumberEngineFactoryUnitTest \
     12  RandomNumberGeneratorFactoryUnitTest \
     13  RandomNumberGeneratorUnitTest
    1114
    1215
     
    3134PARSERLIBS = ../../Parser/libMolecuilderParser.la
    3235
     36RandomNumberDistributionFactoryUnitTest_SOURCES = $(top_srcdir)/src/unittests/UnitTestMain.cpp \
     37        RandomNumberDistributionFactoryUnitTest.cpp \
     38        RandomNumberDistributionFactoryUnitTest.hpp \
     39        $(srcdir)/../RandomNumberDistributionFactory.cpp \
     40        $(srcdir)/../RandomNumberDistributionFactory.hpp
     41RandomNumberDistributionFactoryUnitTest_LDADD = ${GSLLIBS}
     42
     43RandomNumberEngineFactoryUnitTest_SOURCES = $(top_srcdir)/src/unittests/UnitTestMain.cpp \
     44        RandomNumberEngineFactoryUnitTest.cpp \
     45        RandomNumberEngineFactoryUnitTest.hpp \
     46        $(srcdir)/../RandomNumberEngineFactory.cpp \
     47        $(srcdir)/../RandomNumberEngineFactory.hpp
     48RandomNumberEngineFactoryUnitTest_LDADD = ${GSLLIBS}
     49
    3350RandomNumberGeneratorFactoryUnitTest_SOURCES = $(top_srcdir)/src/unittests/UnitTestMain.cpp \
    3451        RandomNumberGeneratorFactoryUnitTest.cpp \
    3552        RandomNumberGeneratorFactoryUnitTest.hpp \
     53        $(srcdir)/../RandomNumberDistributionFactory.cpp \
     54        $(srcdir)/../RandomNumberDistributionFactory.hpp \
     55        $(srcdir)/../RandomNumberEngineFactory.cpp \
     56        $(srcdir)/../RandomNumberEngineFactory.hpp \
    3657        $(srcdir)/../RandomNumberGeneratorFactory.cpp \
    3758        $(srcdir)/../RandomNumberGeneratorFactory.hpp
    3859RandomNumberGeneratorFactoryUnitTest_LDADD = ${GSLLIBS}
    3960
     61RandomNumberGeneratorUnitTest_SOURCES = $(top_srcdir)/src/unittests/UnitTestMain.cpp \
     62        RandomNumberGeneratorUnitTest.cpp \
     63        RandomNumberGeneratorUnitTest.hpp \
     64        $(srcdir)/../RandomNumberDistributionFactory.cpp \
     65        $(srcdir)/../RandomNumberDistributionFactory.hpp \
     66        $(srcdir)/../RandomNumberEngineFactory.cpp \
     67        $(srcdir)/../RandomNumberEngineFactory.hpp \
     68        $(srcdir)/../RandomNumberGeneratorFactory.cpp \
     69        $(srcdir)/../RandomNumberGeneratorFactory.hpp
     70RandomNumberGeneratorUnitTest_LDADD = ${GSLLIBS}
     71
    4072
    4173#AUTOMAKE_OPTIONS = parallel-tests
  • src/RandomNumbers/unittests/RandomNumberGeneratorFactoryUnitTest.cpp

    r3f9eba rc9bc2b7  
    99 * RandomNumberGeneratorFactoryUnitTest.cpp
    1010 *
    11  *  Created on: Dec 31, 2010
     11 *  Created on: Jan 03, 2011
    1212 *      Author: heber
    1313 */
     
    2626#include "RandomNumberGeneratorFactoryUnitTest.hpp"
    2727
    28 #include "RandomNumbers/RandomNumberDistribution_Encapsulation.hpp"
    29 #include "RandomNumbers/RandomNumberEngine_Encapsulation.hpp"
    30 #include "RandomNumbers/RandomNumberGenerator_Encapsulation.hpp"
     28#include "RandomNumbers/RandomNumberGenerator.hpp"
     29#include "RandomNumbers/RandomNumberEngineFactory.hpp"
     30#include "RandomNumbers/RandomNumberDistributionFactory.hpp"
    3131#include "RandomNumbers/RandomNumberGeneratorFactory.hpp"
    3232
     
    8080void RandomNumberGeneratorFactoryTest::tearDown()
    8181{
     82  RandomNumberDistributionFactory::purgeInstance();
     83  RandomNumberEngineFactory::purgeInstance();
    8284  RandomNumberGeneratorFactory::purgeInstance();
    83 }
    84 
    85 void RandomNumberGeneratorFactoryTest::EngineTest()
    86 {
    87   // check default value
    88   CPPUNIT_ASSERT_EQUAL(
    89       std::string("minstd_rand0"),
    90       RandomNumberGeneratorFactory::getInstance().getEngine());
    91 
    92   // check one of the engines in the table
    93   CPPUNIT_ASSERT_EQUAL(
    94       std::string(typeid(boost::minstd_rand0).name()),
    95       RandomNumberGeneratorFactory::getInstance().
    96             EnginePrototypeTable[RandomNumberGeneratorFactory::minstd_rand0]->name()
    97   );
    98 }
    99 
    100 void RandomNumberGeneratorFactoryTest::DistributionTest()
    101 {
    102   // check default value
    103   CPPUNIT_ASSERT_EQUAL(
    104       std::string("uniform_smallint"),
    105       RandomNumberGeneratorFactory::getInstance().getDistribution());
    106 
    107   // check one of the distributions in the table
    108   CPPUNIT_ASSERT_EQUAL(
    109       std::string(typeid(boost::uniform_smallint<> ).name()),
    110       RandomNumberGeneratorFactory::getInstance().
    111             DistributionPrototypeTable[RandomNumberGeneratorFactory::uniform_smallint]->name()
    112   );
    11385}
    11486
    11587void RandomNumberGeneratorFactoryTest::GeneratorTest()
    11688{
     89  RandomNumberGenerator *rng = NULL;
    11790  // check one of the engines and distributions
     91  rng = RandomNumberGeneratorFactory::getInstance().
     92      GeneratorPrototypeTable[RandomNumberEngineFactory::minstd_rand0]
     93                              [RandomNumberDistributionFactory::uniform_smallint]->create();
    11894  CPPUNIT_ASSERT_EQUAL(
    11995      std::string(typeid(boost::minstd_rand0).name()),
    120       RandomNumberGeneratorFactory::getInstance().
    121             GeneratorPrototypeTable[RandomNumberGeneratorFactory::minstd_rand0][RandomNumberGeneratorFactory::uniform_smallint]
    122                                                                                 ->EngineName()
     96      rng->EngineName()
    12397  );
    12498  CPPUNIT_ASSERT_EQUAL(
    12599      std::string(typeid(boost::uniform_smallint<> ).name()),
    126       RandomNumberGeneratorFactory::getInstance().
    127             GeneratorPrototypeTable[RandomNumberGeneratorFactory::minstd_rand0][RandomNumberGeneratorFactory::uniform_smallint]
    128                                                                                 ->DistributionName()
     100      rng->DistributionName()
    129101  );
     102  delete rng;
    130103
    131   // obtain some random values for uniform_smallint
    132   RandomNumberGeneratorFactory::getInstance().setDistribution("uniform_smallint");
    133   RandomNumberGenerator &rng = RandomNumberGeneratorFactory::getInstance().makeRandomNumberGenerator();
    134   for (size_t i=0; i < 1000; ++i) {
    135     const int testint = rng();
    136     CPPUNIT_ASSERT_MESSAGE("randon number from uniform_smallint is out of [0:9]!", testint >= 0);
    137     CPPUNIT_ASSERT_MESSAGE("randon number from uniform_smallint is out of [0:9]!", testint <= 9);
    138   }
    139104}
    140105
  • src/RandomNumbers/unittests/RandomNumberGeneratorFactoryUnitTest.hpp

    r3f9eba rc9bc2b7  
    22 * RandomNumberGeneratorFactoryUnitTest.hpp
    33 *
    4  *  Created on: Dec 31, 2010
     4 *  Created on: Jan 03, 2011
    55 *      Author: heber
    66 */
     
    2020{
    2121  CPPUNIT_TEST_SUITE( RandomNumberGeneratorFactoryTest );
    22   CPPUNIT_TEST ( EngineTest );
    23   CPPUNIT_TEST ( DistributionTest );
    2422  CPPUNIT_TEST ( GeneratorTest );
    2523  CPPUNIT_TEST_SUITE_END();
     
    2927  void tearDown();
    3028
    31   void EngineTest();
    32   void DistributionTest();
    3329  void GeneratorTest();
    3430
Note: See TracChangeset for help on using the changeset viewer.