Ignore:
Timestamp:
Feb 27, 2013, 12:39:03 PM (13 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, Candidate_v1.7.0, Candidate_v1.7.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:
0dad5f
Parents:
d52819
git-author:
Frederik Heber <heber@…> (11/30/12 16:44:24)
git-committer:
Frederik Heber <heber@…> (02/27/13 12:39:03)
Message:

Triplefunction for Saturation and Tersoff potential have to be given extra.

  • this avoids a loop with TrainingData and getFragmentSpecificExtractor.
File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/Potentials/Specifics/SaturationPotential.hpp

    rd52819 r775dd1a  
    5050public:
    5151  SaturationPotential(
    52       const ParticleTypes_t &_ParticleTypes,
    53       const double _saturation_cutoff,
    54       boost::function< std::vector<arguments_t>(const argument_t &, const double)> &_triplefunction
     52      const ParticleTypes_t &_ParticleTypes
    5553      );
    5654  SaturationPotential(
     
    6159      const double _morse_dissociation_energy,
    6260      const double _angle_spring_constant,
    63       const double _angle_equilibrium_distance,
     61      const double _angle_equilibrium_distance
     62      );
     63  virtual ~SaturationPotential() {}
     64
     65  /** Setter for parameters as required by FunctionModel interface.
     66   *
     67   * \param _params given set of parameters
     68   */
     69  void setParameters(const parameters_t &_params);
     70
     71  /** Getter for parameters as required by FunctionModel interface.
     72   *
     73   * \return set of parameters
     74   */
     75  parameters_t getParameters() const;
     76
     77  /** Sets the parameter randomly within the sensible range of each parameter.
     78   *
     79   * \param data container with training data for guesstimating range
     80   */
     81  void setParametersToRandomInitialValues(const TrainingData &data);
     82
     83  /** Getter for the number of parameters of this model function.
     84   *
     85   * \return number of parameters
     86   */
     87  size_t getParameterDimension() const
     88  { return MAXPARAMS; }
     89
     90  /** Sets the magic triple function that we use for getting angle distances.
     91   *
     92   * \param _saturation_cutoff cutoff for the triplefunction
     93   * @param _triplefunction function that returns a list of triples (i.e. the
     94   *        two remaining distances) to a given pair of points (contained as
     95   *        indices within the argument)
     96   */
     97  void setTriplefunction(
    6498      const double _saturation_cutoff,
    6599      boost::function< std::vector<arguments_t>(const argument_t &, const double)> &_triplefunction
    66       );
    67   virtual ~SaturationPotential() {}
    68 
    69   /** Setter for parameters as required by FunctionModel interface.
    70    *
    71    * \param _params given set of parameters
    72    */
    73   void setParameters(const parameters_t &_params);
    74 
    75   /** Getter for parameters as required by FunctionModel interface.
    76    *
    77    * \return set of parameters
    78    */
    79   parameters_t getParameters() const;
    80 
    81   /** Sets the parameter randomly within the sensible range of each parameter.
    82    *
    83    * \param data container with training data for guesstimating range
    84    */
    85   void setParametersToRandomInitialValues(const TrainingData &data);
    86 
    87   /** Getter for the number of parameters of this model function.
    88    *
    89    * \return number of parameters
    90    */
    91   size_t getParameterDimension() const
    92   { return MAXPARAMS; }
     100      )
     101  {
     102    saturation_cutoff = _saturation_cutoff;
     103    triplefunction = _triplefunction;
     104  }
    93105
    94106  /** Evaluates the harmonic potential function for the given arguments.
     
    196208
    197209  //!> bound function that obtains the triples for the internal coordinationb summation.
    198   const boost::function< std::vector< arguments_t >(const argument_t &, const double)> &triplefunction;
    199   const double saturation_cutoff;
     210  boost::function< std::vector< arguments_t >(const argument_t &, const double)> triplefunction;
     211  double saturation_cutoff;
    200212
    201213  //!> static definitions of the parameter name for this potential
Note: See TracChangeset for help on using the changeset viewer.