Changeset c9bc2b7 for src/Actions


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/Actions/RandomNumbersAction
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • src/Actions/RandomNumbersAction/SetRandomNumbersDistributionAction.cpp

    r3f9eba rc9bc2b7  
    4545  CommandSetRandomNumbersDistributionState *state =
    4646      new CommandSetRandomNumbersDistributionState(
    47           RandomNumberGeneratorFactory::getInstance().getDistribution(),
     47          RandomNumberGeneratorFactory::getInstance().getDistributionName(),
    4848          params);
    4949  RandomNumberGeneratorFactory::getInstance().setDistribution(params.distribution_type);
    5050
    5151  DoLog(0) && (Log() << Verbose(0) << "Distribution of random number generator is now: "
    52       << RandomNumberGeneratorFactory::getInstance().getDistribution() << std::endl);
     52      << RandomNumberGeneratorFactory::getInstance().getDistributionName() << std::endl);
    5353
    5454  return Action::state_ptr(state);
     
    6060  CommandSetRandomNumbersDistributionState *newstate =
    6161      new CommandSetRandomNumbersDistributionState(
    62           RandomNumberGeneratorFactory::getInstance().getDistribution(),
     62          RandomNumberGeneratorFactory::getInstance().getDistributionName(),
    6363          state->params);
    6464  RandomNumberGeneratorFactory::getInstance().setDistribution(state->old_distribution_type);
    6565
    6666  DoLog(0) && (Log() << Verbose(0) << "Distribution of random number generator is undone to: "
    67       << RandomNumberGeneratorFactory::getInstance().getDistribution() << std::endl);
     67      << RandomNumberGeneratorFactory::getInstance().getDistributionName() << std::endl);
    6868
    6969  return Action::state_ptr(newstate);
  • src/Actions/RandomNumbersAction/SetRandomNumbersEngineAction.cpp

    r3f9eba rc9bc2b7  
    4545  CommandSetRandomNumbersEngineState *state =
    4646      new CommandSetRandomNumbersEngineState(
    47           RandomNumberGeneratorFactory::getInstance().getEngine(),
     47          RandomNumberGeneratorFactory::getInstance().getEngineName(),
    4848          params);
    4949  RandomNumberGeneratorFactory::getInstance().setEngine(params.engine_type);
    5050
    5151  DoLog(0) && (Log() << Verbose(0) << "Engine of random number generator is now: "
    52       << RandomNumberGeneratorFactory::getInstance().getEngine() << std::endl);
     52      << RandomNumberGeneratorFactory::getInstance().getEngineName() << std::endl);
    5353
    5454  return Action::state_ptr(state);
     
    6060  CommandSetRandomNumbersEngineState *newstate =
    6161      new CommandSetRandomNumbersEngineState(
    62           RandomNumberGeneratorFactory::getInstance().getEngine(),
     62          RandomNumberGeneratorFactory::getInstance().getEngineName(),
    6363          state->params);
    6464  RandomNumberGeneratorFactory::getInstance().setEngine(state->old_engine_type);
    6565
    6666  DoLog(0) && (Log() << Verbose(0) << "Engine of random number generator is undone to: "
    67       << RandomNumberGeneratorFactory::getInstance().getEngine() << std::endl);
     67      << RandomNumberGeneratorFactory::getInstance().getEngineName() << std::endl);
    6868
    6969  return Action::state_ptr(newstate);
Note: See TracChangeset for help on using the changeset viewer.