Changeset af2c7ec for src/FunctionApproximation
- Timestamp:
- Aug 9, 2013, 2:20:36 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:
- b5f548
- Parents:
- 31a2be
- git-author:
- Frederik Heber <heber@…> (06/25/13 13:08:43)
- git-committer:
- Frederik Heber <heber@…> (08/09/13 14:20:36)
- Location:
- src/FunctionApproximation
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
src/FunctionApproximation/TrainingData.cpp
r31a2be raf2c7ec 50 50 #include "Fragmentation/Summation/SetValues/Fragment.hpp" 51 51 #include "FunctionApproximation/FunctionModel.hpp" 52 #include "FunctionApproximation/Extractors.hpp" 52 53 53 54 void TrainingData::operator()(const range_t &range) { 54 55 for (HomologyContainer::const_iterator iter = range.first; iter != range.second; ++iter) { 55 // get distance out of Fragment56 56 const Fragment &fragment = iter->second.first; 57 FunctionModel::arguments_t args = extractor( 58 fragment, 59 DistanceVector.size() 57 // create internal list of arguments 58 FunctionModel::arguments_t all_args = Extractors::gatherAllSymmetricDistances( 59 fragment.getPositions(), 60 fragment.getCharges(), 61 DistanceVector.size() 60 62 ); 61 DistanceVector.push_back( a rgs );63 DistanceVector.push_back( all_args ); 62 64 const double &energy = iter->second.second; 63 65 EnergyVector.push_back( FunctionModel::results_t(1, energy) ); 66 // filter distances out of list of all arguments 67 FunctionModel::arguments_t args = filter(all_args); 68 LOG(3, "DEBUG: Filtered arguments are " << args << "."); 69 ArgumentVector.push_back( args ); 64 70 } 65 71 } … … 69 75 double L2sum = 0.; 70 76 71 FunctionApproximation::inputs_t::const_iterator initer = DistanceVector.begin();77 FunctionApproximation::inputs_t::const_iterator initer = ArgumentVector.begin(); 72 78 FunctionApproximation::outputs_t::const_iterator outiter = EnergyVector.begin(); 73 for (; initer != DistanceVector.end(); ++initer, ++outiter) {79 for (; initer != ArgumentVector.end(); ++initer, ++outiter) { 74 80 const FunctionModel::results_t result = model((*initer)); 75 81 const double temp = fabs((*outiter)[0] - result[0]); … … 82 88 { 83 89 double Lmax = 0.; 84 size_t maxindex = -1;85 FunctionApproximation::inputs_t::const_iterator initer = DistanceVector.begin();90 // size_t maxindex = -1; 91 FunctionApproximation::inputs_t::const_iterator initer = ArgumentVector.begin(); 86 92 FunctionApproximation::outputs_t::const_iterator outiter = EnergyVector.begin(); 87 for (; initer != DistanceVector.end(); ++initer, ++outiter) {93 for (; initer != ArgumentVector.end(); ++initer, ++outiter) { 88 94 const FunctionModel::results_t result = model((*initer)); 89 95 const double temp = fabs((*outiter)[0] - result[0]); 90 96 if (temp > Lmax) { 91 97 Lmax = temp; 92 maxindex = std::distance(93 const_cast<const FunctionApproximation::inputs_t &>(DistanceVector).begin(),94 initer95 );98 // maxindex = std::distance( 99 // const_cast<const FunctionApproximation::inputs_t &>(ArgumentVector).begin(), 100 // initer 101 // ); 96 102 } 97 103 } … … 102 108 { 103 109 TrainingData::DistanceEnergyTable_t table; 104 const InputVector_t &DistanceVector = getTrainingInputs();105 const OutputVector_t &EnergyVector = getTrainingOutputs();106 110 107 111 /// extract distance member variable from argument_t and first value from results_t 108 112 OutputVector_t::const_iterator ergiter = EnergyVector.begin(); 109 for (InputVector_t::const_iterator iter = DistanceVector.begin();110 iter != DistanceVector.end(); ++iter, ++ergiter) {113 for (InputVector_t::const_iterator iter = ArgumentVector.begin(); 114 iter != ArgumentVector.end(); ++iter, ++ergiter) { 111 115 ASSERT( ergiter != EnergyVector.end(), 112 116 "TrainingData::getDistanceEnergyTable() - less output than input values."); … … 149 153 std::ostream &operator<<(std::ostream &out, const TrainingData &data) 150 154 { 151 const TrainingData::InputVector_t &DistanceVector = data.get TrainingInputs();155 const TrainingData::InputVector_t &DistanceVector = data.getAllArguments(); 152 156 const TrainingData::OutputVector_t &EnergyVector = data.getTrainingOutputs(); 153 157 out << "(" << DistanceVector.size() -
src/FunctionApproximation/TrainingData.hpp
r31a2be raf2c7ec 26 26 * The data is added piece-wise by calling the operator() with a specific 27 27 * Fragment. 28 * 29 * In TrainingData::operator() we construct first all pair-wise distances as 30 * list of all arguments. Then, these are filtered depending on the specific 31 * FunctionModel's Filter and only these are handed to down to evaluate it. 32 * 28 33 */ 29 34 class TrainingData … … 45 50 * 46 51 */ 47 explicit TrainingData(const FunctionModel:: extractor_t &_extractor) :48 extractor(_extractor)52 explicit TrainingData(const FunctionModel::filter_t &_filter) : 53 filter(_filter) 49 54 {} 55 50 56 /** Destructor for class TrainingData. 51 57 * … … 55 61 56 62 /** We go through the given \a range of homologous fragments and call 57 * TrainingData:: extractor on them in order to gather the distance and63 * TrainingData::filter on them in order to gather the distance and 58 64 * the energy value, stored internally. 59 65 * … … 67 73 */ 68 74 const InputVector_t& getTrainingInputs() const { 75 return ArgumentVector; 76 } 77 78 /** Getter for const access to internal list of all pair-wise distances. 79 * 80 * \return const ref to all arguments 81 */ 82 const InputVector_t& getAllArguments() const { 69 83 return DistanceVector; 70 84 } … … 114 128 InputVector_t DistanceVector; 115 129 OutputVector_t EnergyVector; 130 //!> list of all filtered arguments over all tuples 131 InputVector_t ArgumentVector; 116 132 //!> function to be used for training input data extraction from a fragment 117 const FunctionModel:: extractor_t extractor;133 const FunctionModel::filter_t filter; 118 134 }; 119 135
Note:
See TracChangeset
for help on using the changeset viewer.