source: src/Fragmentation/Homology/AtomFragmentsMap.hpp@ 78202b

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Added_ParseSaveFragmentResults 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_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 IndependentFragmentGrids IndependentFragmentGrids_IndividualZeroInstances IndependentFragmentGrids_IntegrationTest IndependentFragmentGrids_Sole_NN_Calculation JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix 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
Last change on this file since 78202b was 78202b, checked in by Frederik Heber <heber@…>, 9 years ago

Adding potential action to parse and save atom fragment associations.

  • Made KeySet serializable.
  • added documentation on save and parse atom fragments.
  • Property mode set to 100644
File size: 1.9 KB
Line 
1/*
2 * AtomFragmentsMap.hpp
3 *
4 * Created on: Mar 7, 2016
5 * Author: heber
6 */
7
8
9#ifndef ATOMFRAGMENTSMAP_HPP_
10#define ATOMFRAGMENTSMAP_HPP_
11
12// include config.h
13#ifdef HAVE_CONFIG_H
14#include <config.h>
15#endif
16
17#include "CodePatterns/Singleton.hpp"
18
19#include <list>
20#include <map>
21
22#include <boost/serialization/export.hpp>
23#include <boost/serialization/set.hpp>
24#include <boost/serialization/list.hpp>
25#include <boost/serialization/map.hpp>
26#include <boost/serialization/version.hpp>
27
28#include "types.hpp"
29
30class KeySet;
31class Graph;
32
33/** This class creates in instantiation a map connecting each atom with
34 * the (known) fragments it takes part in.
35 *
36 * In the HomologyGraph and its -Container we do not have this information
37 * any longer. However, we need this in order to make statements about atomic
38 * properties from calculated fragment properties.
39 *
40 */
41class AtomFragmentsMap : public Singleton<AtomFragmentsMap>
42{
43public:
44 //** Function to insert new fragments into storage container.
45 void insert(
46 const Graph &_graph,
47 size_t _MaxOrder);
48
49 /** Function to clear the container.
50 *
51 */
52 void clear()
53 { atommap.clear(); }
54
55 typedef std::list<KeySet> keysets_t;
56 //!> typedef for the internal map
57 typedef std::map<atomId_t, keysets_t> AtomFragmentsMap_t;
58
59 const AtomFragmentsMap_t& getMap() const
60 { return atommap; }
61
62private:
63 //!> grant singleton pattern access to private cstor/dstor
64 friend class Singleton<AtomFragmentsMap>;
65
66 /** Private default cstor.
67 *
68 */
69 AtomFragmentsMap() {}
70
71 /** Private default dstor.
72 *
73 */
74 ~AtomFragmentsMap() {}
75
76private:
77 //!> internal map filled on instantiation
78 AtomFragmentsMap_t atommap;
79
80private:
81 friend class boost::serialization::access;
82 // serialization
83 template <typename Archive>
84 void serialize(Archive& ar, const unsigned int version)
85 {
86 ar & atommap;
87 }
88};
89
90
91#endif /* ATOMFRAGMENTSMAP_HPP_ */
Note: See TracBrowser for help on using the repository browser.