Ignore:
Timestamp:
Aug 9, 2013, 2:20:36 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:
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)
Message:

TrainingData now generates internal list of all arguments.

Location:
src/FunctionApproximation
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • src/FunctionApproximation/TrainingData.cpp

    r31a2be raf2c7ec  
    5050#include "Fragmentation/Summation/SetValues/Fragment.hpp"
    5151#include "FunctionApproximation/FunctionModel.hpp"
     52#include "FunctionApproximation/Extractors.hpp"
    5253
    5354void TrainingData::operator()(const range_t &range) {
    5455  for (HomologyContainer::const_iterator iter = range.first; iter != range.second; ++iter) {
    55     // get distance out of Fragment
    5656    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()
    6062        );
    61     DistanceVector.push_back( args );
     63    DistanceVector.push_back( all_args );
    6264    const double &energy = iter->second.second;
    6365    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 );
    6470  }
    6571}
     
    6975  double L2sum = 0.;
    7076
    71   FunctionApproximation::inputs_t::const_iterator initer = DistanceVector.begin();
     77  FunctionApproximation::inputs_t::const_iterator initer = ArgumentVector.begin();
    7278  FunctionApproximation::outputs_t::const_iterator outiter = EnergyVector.begin();
    73   for (; initer != DistanceVector.end(); ++initer, ++outiter) {
     79  for (; initer != ArgumentVector.end(); ++initer, ++outiter) {
    7480    const FunctionModel::results_t result = model((*initer));
    7581    const double temp = fabs((*outiter)[0] - result[0]);
     
    8288{
    8389  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();
    8692  FunctionApproximation::outputs_t::const_iterator outiter = EnergyVector.begin();
    87   for (; initer != DistanceVector.end(); ++initer, ++outiter) {
     93  for (; initer != ArgumentVector.end(); ++initer, ++outiter) {
    8894    const FunctionModel::results_t result = model((*initer));
    8995    const double temp = fabs((*outiter)[0] - result[0]);
    9096    if (temp > Lmax) {
    9197      Lmax = temp;
    92       maxindex = std::distance(
    93           const_cast<const FunctionApproximation::inputs_t &>(DistanceVector).begin(),
    94           initer
    95           );
     98//      maxindex = std::distance(
     99//          const_cast<const FunctionApproximation::inputs_t &>(ArgumentVector).begin(),
     100//          initer
     101//          );
    96102    }
    97103  }
     
    102108{
    103109  TrainingData::DistanceEnergyTable_t table;
    104   const InputVector_t &DistanceVector = getTrainingInputs();
    105   const OutputVector_t &EnergyVector = getTrainingOutputs();
    106110
    107111  /// extract distance member variable from argument_t and first value from results_t
    108112  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) {
    111115    ASSERT( ergiter != EnergyVector.end(),
    112116        "TrainingData::getDistanceEnergyTable() - less output than input values.");
     
    149153std::ostream &operator<<(std::ostream &out, const TrainingData &data)
    150154{
    151   const TrainingData::InputVector_t &DistanceVector = data.getTrainingInputs();
     155  const TrainingData::InputVector_t &DistanceVector = data.getAllArguments();
    152156  const TrainingData::OutputVector_t &EnergyVector = data.getTrainingOutputs();
    153157  out << "(" << DistanceVector.size()
  • src/FunctionApproximation/TrainingData.hpp

    r31a2be raf2c7ec  
    2626 * The data is added piece-wise by calling the operator() with a specific
    2727 * 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 *
    2833 */
    2934class TrainingData
     
    4550   *
    4651   */
    47   explicit TrainingData(const FunctionModel::extractor_t &_extractor) :
    48       extractor(_extractor)
     52  explicit TrainingData(const FunctionModel::filter_t &_filter) :
     53      filter(_filter)
    4954  {}
     55
    5056  /** Destructor for class TrainingData.
    5157   *
     
    5561
    5662  /** We go through the given \a range of homologous fragments and call
    57    * TrainingData::extractor on them in order to gather the distance and
     63   * TrainingData::filter on them in order to gather the distance and
    5864   * the energy value, stored internally.
    5965   *
     
    6773   */
    6874  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 {
    6983    return DistanceVector;
    7084  }
     
    114128  InputVector_t DistanceVector;
    115129  OutputVector_t EnergyVector;
     130  //!> list of all filtered arguments over all tuples
     131  InputVector_t ArgumentVector;
    116132  //!> function to be used for training input data extraction from a fragment
    117   const FunctionModel::extractor_t extractor;
     133  const FunctionModel::filter_t filter;
    118134};
    119135
Note: See TracChangeset for help on using the changeset viewer.