Changeset 04cc7e for src/FunctionApproximation
- Timestamp:
- Feb 24, 2013, 12:58:53 PM (12 years ago)
- 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)
- Location:
- src/FunctionApproximation
- Files:
-
- 1 added
- 3 edited
Legend:
- Unmodified
- Added
- Removed
-
src/FunctionApproximation/Makefile.am
r52e7da r04cc7e 11 11 FunctionApproximation/FunctionArgument.hpp \ 12 12 FunctionApproximation/FunctionModel.hpp \ 13 FunctionApproximation/TrainingData.hpp 14 13 FunctionApproximation/TrainingData.hpp \ 14 FunctionApproximation/writeDistanceEnergyTable.hpp 15 15 16 if CONDLEVMAR 16 17 FUNCTIONAPPROXIMATIONSOURCE += \ -
src/FunctionApproximation/TrainingData.cpp
r52e7da r04cc7e 38 38 #include "TrainingData.hpp" 39 39 40 #include <boost/bind.hpp> 40 41 #include <iostream> 41 42 43 #include "CodePatterns/Assert.hpp" 42 44 #include "CodePatterns/toString.hpp" 43 45 … … 93 95 } 94 96 97 const 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 95 127 std::ostream &operator<<(std::ostream &out, const TrainingData &data) 96 128 { -
src/FunctionApproximation/TrainingData.hpp
r52e7da r04cc7e 41 41 //!> Typedef for a function containing how to extract required information from a Fragment. 42 42 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; 43 45 44 46 public: … … 93 95 const double getLMaxError(const FunctionModel &model) const; 94 96 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 95 103 private: 96 104 // prohibit use of default constructor, as we always require extraction functor.
Note:
See TracChangeset
for help on using the changeset viewer.