Ignore:
Timestamp:
Feb 24, 2013, 12:58:52 PM (12 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:
69ab84
Parents:
f68c68
git-author:
Frederik Heber <heber@…> (10/15/12 07:48:43)
git-committer:
Frederik Heber <heber@…> (02/24/13 12:58:52)
Message:

Shifted class TrainingData into its own module.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/LevMartester.cpp

    rf68c68 r68172a  
    6565#include "FunctionApproximation/FunctionApproximation.hpp"
    6666#include "FunctionApproximation/FunctionModel.hpp"
     67#include "FunctionApproximation/TrainingData.hpp"
    6768#include "Helpers/defs.hpp"
    6869#include "Potentials/Specifics/PairPotential_Morse.hpp"
     
    197198  else
    198199    return angle/divisor;
    199 }
    200 
    201 /** This class encapsulates the training data for a given potential function
    202  * to learn.
    203  *
    204  * The data is added piece-wise by calling the operator() with a specific
    205  * Fragment.
    206  */
    207 class TrainingData
    208 {
    209 public:
    210   //!> typedef for a range within the HomologyContainer at which fragments to look at
    211   typedef std::pair<
    212       HomologyContainer::const_iterator,
    213       HomologyContainer::const_iterator> range_t;
    214   //!> Training tuple input vector pair
    215   typedef FunctionApproximation::inputs_t InputVector_t;
    216   //!> Training tuple output vector pair
    217   typedef FunctionApproximation::outputs_t OutputVector_t;
    218   //!> Typedef for a function containing how to extract required information from a Fragment.
    219   typedef boost::function< FunctionModel::arguments_t (const Fragment &, const size_t)> extractor_t;
    220 
    221 public:
    222   /** Constructor for class TrainingData.
    223    *
    224    */
    225   explicit TrainingData(const extractor_t &_extractor) :
    226       extractor(extractor)
    227   {}
    228   /** Destructor for class TrainingData.
    229    *
    230    */
    231   ~TrainingData()
    232   {}
    233 
    234   /** We go through the given \a range of homologous fragments and call
    235    * TrainingData::extractor on them in order to gather the distance and
    236    * the energy value, stored internally.
    237    *
    238    * \param range given range within a HomologyContainer of homologous fragments
    239    */
    240   void operator()(const range_t &range) {
    241     double EnergySum = 0.; //std::numeric_limits<double>::max();
    242     size_t counter = 0.;
    243     for (HomologyContainer::const_iterator iter = range.first; iter != range.second; ++iter) {
    244       const double &energy = iter->second.second;
    245 //      if (energy <= EnergySum)
    246 //        EnergySum = energy;
    247       EnergySum += energy;
    248       ++counter;
    249     }
    250     EnergySum *= 1./(double)counter;
    251     for (HomologyContainer::const_iterator iter = range.first; iter != range.second; ++iter) {
    252       // get distance out of Fragment
    253       const Fragment &fragment = iter->second.first;
    254       FunctionModel::arguments_t args = extractor(
    255             fragment,
    256             DistanceVector.size()
    257           );
    258       DistanceVector.push_back( args );
    259       const double &energy = iter->second.second;
    260       EnergyVector.push_back( FunctionModel::results_t(1, energy-EnergySum) );
    261     }
    262   }
    263 
    264   /** Getter for const access to internal training data inputs.
    265    *
    266    * \return const ref to training tuple of input vector
    267    */
    268   const InputVector_t& getTrainingInputs() const {
    269     return DistanceVector;
    270   }
    271 
    272   /** Getter for const access to internal training data outputs.
    273    *
    274    * \return const ref to training tuple of output vector
    275    */
    276   const OutputVector_t& getTrainingOutputs() const {
    277     return EnergyVector;
    278   }
    279 
    280   /** Calculate the L2 error of a given \a model against the stored training data.
    281    *
    282    * \param model model whose L2 error to calculate
    283    * \return sum of squared differences at training tuples
    284    */
    285   const double getL2Error(const FunctionModel &model) const
    286   {
    287     double L2sum = 0.;
    288 
    289     FunctionApproximation::inputs_t::const_iterator initer = DistanceVector.begin();
    290     FunctionApproximation::outputs_t::const_iterator outiter = EnergyVector.begin();
    291     for (; initer != DistanceVector.end(); ++initer, ++outiter) {
    292       const FunctionModel::results_t result = model((*initer));
    293       const double temp = fabs((*outiter)[0] - result[0]);
    294       L2sum += temp*temp;
    295     }
    296     return L2sum;
    297   }
    298 
    299   /** Calculate the Lmax error of a given \a model against the stored training data.
    300    *
    301    * \param model model whose Lmax error to calculate
    302    * \return maximum difference over all training tuples
    303    */
    304   const double getLMaxError(const FunctionModel &model) const
    305   {
    306     double Lmax = 0.;
    307     size_t maxindex = -1;
    308     FunctionApproximation::inputs_t::const_iterator initer = DistanceVector.begin();
    309     FunctionApproximation::outputs_t::const_iterator outiter = EnergyVector.begin();
    310     for (; initer != DistanceVector.end(); ++initer, ++outiter) {
    311       const FunctionModel::results_t result = model((*initer));
    312       const double temp = fabs((*outiter)[0] - result[0]);
    313       if (temp > Lmax) {
    314         Lmax = temp;
    315         maxindex = std::distance(
    316             const_cast<const FunctionApproximation::inputs_t &>(DistanceVector).begin(),
    317             initer
    318             );
    319       }
    320     }
    321     return Lmax;
    322   }
    323 
    324 private:
    325   // prohibit use of default constructor, as we always require extraction functor.
    326   TrainingData();
    327 
    328 private:
    329   //!> private training data vector
    330   InputVector_t DistanceVector;
    331   OutputVector_t EnergyVector;
    332   //!> function to be used for training input data extraction from a fragment
    333   const extractor_t extractor;
    334 };
    335 
    336 // print training data for debugging
    337 std::ostream &operator<<(std::ostream &out, const TrainingData &data)
    338 {
    339   const TrainingData::InputVector_t &DistanceVector = data.getTrainingInputs();
    340   const TrainingData::OutputVector_t &EnergyVector = data.getTrainingOutputs();
    341   out << "(" << DistanceVector.size()
    342       << "," << EnergyVector.size() << ") data pairs: ";
    343   FunctionApproximation::inputs_t::const_iterator initer = DistanceVector.begin();
    344   FunctionApproximation::outputs_t::const_iterator outiter = EnergyVector.begin();
    345   for (; initer != DistanceVector.end(); ++initer, ++outiter) {
    346     for (size_t index = 0; index < (*initer).size(); ++index)
    347        out << "(" << (*initer)[index].indices.first << "," << (*initer)[index].indices.second
    348           << ") " << (*initer)[index].distance;
    349     out << " with energy " << *outiter;
    350   }
    351   return out;
    352200}
    353201
Note: See TracChangeset for help on using the changeset viewer.