Ignore:
Timestamp:
Feb 24, 2013, 12:58:53 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:
37e910
Parents:
52e7da
git-author:
Frederik Heber <heber@…> (11/21/12 11:06:00)
git-committer:
Frederik Heber <heber@…> (02/24/13 12:58:53)
Message:

Added pretty printer for distance-energy tables.

  • added TrainingData::getDistanceEnergyTable() for obtaining data in unified table.
  • added pretty printer writeDistanceEnergyTable() in header file in namespace _detail.
Location:
src/FunctionApproximation
Files:
1 added
3 edited

Legend:

Unmodified
Added
Removed
  • src/FunctionApproximation/Makefile.am

    r52e7da r04cc7e  
    1111        FunctionApproximation/FunctionArgument.hpp \
    1212        FunctionApproximation/FunctionModel.hpp \
    13         FunctionApproximation/TrainingData.hpp
    14        
     13        FunctionApproximation/TrainingData.hpp \
     14        FunctionApproximation/writeDistanceEnergyTable.hpp
     15
    1516if CONDLEVMAR
    1617FUNCTIONAPPROXIMATIONSOURCE += \
  • src/FunctionApproximation/TrainingData.cpp

    r52e7da r04cc7e  
    3838#include "TrainingData.hpp"
    3939
     40#include <boost/bind.hpp>
    4041#include <iostream>
    4142
     43#include "CodePatterns/Assert.hpp"
    4244#include "CodePatterns/toString.hpp"
    4345
     
    9395}
    9496
     97const TrainingData::DistanceEnergyTable_t TrainingData::getDistanceEnergyTable() const
     98{
     99  TrainingData::DistanceEnergyTable_t table;
     100  const InputVector_t &DistanceVector = getTrainingInputs();
     101  const OutputVector_t &EnergyVector = getTrainingOutputs();
     102
     103  /// extract distance member variable from argument_t and first value from results_t
     104  OutputVector_t::const_iterator ergiter = EnergyVector.begin();
     105  for (InputVector_t::const_iterator iter = DistanceVector.begin();
     106      iter != DistanceVector.end(); ++iter, ++ergiter) {
     107    ASSERT( ergiter != EnergyVector.end(),
     108        "TrainingData::getDistanceEnergyTable() - less output than input values.");
     109    std::vector< double > values(iter->size(), 0.);
     110    // transform all distances
     111    const FunctionModel::arguments_t &args = *iter;
     112    std::transform(
     113        args.begin(), args.end(),
     114        values.begin(),
     115        boost::bind(&argument_t::distance, _1));
     116
     117    // get first energy value
     118    values.push_back((*ergiter)[0]);
     119
     120    // push as table row
     121    table.push_back(values);
     122  }
     123
     124  return table;
     125}
     126
    95127std::ostream &operator<<(std::ostream &out, const TrainingData &data)
    96128{
  • src/FunctionApproximation/TrainingData.hpp

    r52e7da r04cc7e  
    4141  //!> Typedef for a function containing how to extract required information from a Fragment.
    4242  typedef boost::function< FunctionModel::arguments_t (const Fragment &, const size_t)> extractor_t;
     43  //!> Typedef for a table with columns of all distances and the energy
     44  typedef std::vector< std::vector<double> > DistanceEnergyTable_t;
    4345
    4446public:
     
    9395  const double getLMaxError(const FunctionModel &model) const;
    9496
     97  /** Creates a table of columns with all distances and the energy.
     98   *
     99   * \return array with first columns containing distances, last column energy
     100   */
     101  const DistanceEnergyTable_t getDistanceEnergyTable() const;
     102
    95103private:
    96104  // prohibit use of default constructor, as we always require extraction functor.
Note: See TracChangeset for help on using the changeset viewer.