Changeset 68172a for src/LevMartester.cpp
- Timestamp:
- Feb 24, 2013, 12:58:52 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:
- 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)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
src/LevMartester.cpp
rf68c68 r68172a 65 65 #include "FunctionApproximation/FunctionApproximation.hpp" 66 66 #include "FunctionApproximation/FunctionModel.hpp" 67 #include "FunctionApproximation/TrainingData.hpp" 67 68 #include "Helpers/defs.hpp" 68 69 #include "Potentials/Specifics/PairPotential_Morse.hpp" … … 197 198 else 198 199 return angle/divisor; 199 }200 201 /** This class encapsulates the training data for a given potential function202 * to learn.203 *204 * The data is added piece-wise by calling the operator() with a specific205 * Fragment.206 */207 class TrainingData208 {209 public:210 //!> typedef for a range within the HomologyContainer at which fragments to look at211 typedef std::pair<212 HomologyContainer::const_iterator,213 HomologyContainer::const_iterator> range_t;214 //!> Training tuple input vector pair215 typedef FunctionApproximation::inputs_t InputVector_t;216 //!> Training tuple output vector pair217 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 call235 * TrainingData::extractor on them in order to gather the distance and236 * the energy value, stored internally.237 *238 * \param range given range within a HomologyContainer of homologous fragments239 */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 Fragment253 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 vector267 */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 vector275 */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 calculate283 * \return sum of squared differences at training tuples284 */285 const double getL2Error(const FunctionModel &model) const286 {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 calculate302 * \return maximum difference over all training tuples303 */304 const double getLMaxError(const FunctionModel &model) const305 {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 initer318 );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 vector330 InputVector_t DistanceVector;331 OutputVector_t EnergyVector;332 //!> function to be used for training input data extraction from a fragment333 const extractor_t extractor;334 };335 336 // print training data for debugging337 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.second348 << ") " << (*initer)[index].distance;349 out << " with energy " << *outiter;350 }351 return out;352 200 } 353 201
Note:
See TracChangeset
for help on using the changeset viewer.