source: src/Fragmentation/Homology/HomologyGraph.hpp@ 1b64b2f

ForceAnnealing_goodresults ForceAnnealing_tocheck
Last change on this file since 1b64b2f was b0bc13, checked in by Frederik Heber <heber@…>, 9 years ago

FIX: HomologyGraph has explicit cstors for KeySet and IndexSet.

  • this prevents unwanted conversions.
  • Property mode set to 100644
File size: 6.1 KB
RevLine 
[7b6b21f]1/*
2 * HomologyGraph.hpp
3 *
4 * Created on: Sep 24, 2012
5 * Author: heber
6 */
7
8#ifndef HOMOLOGYGRAPH_HPP_
9#define HOMOLOGYGRAPH_HPP_
10
11
12// include config.h
13#ifdef HAVE_CONFIG_H
14#include <config.h>
15#endif
16
[67db80]17#include <boost/serialization/export.hpp>
[28e203]18#include <boost/serialization/map.hpp>
[67db80]19
[28e203]20#include <map>
[54a561]21#include <iosfwd>
[7b6b21f]22
23#include "Fragmentation/Homology/FragmentEdge.hpp"
24#include "Fragmentation/Homology/FragmentNode.hpp"
25
[372c912]26class IndexSet;
[77b350]27class KeySet;
28
[7b6b21f]29/** This class contains the representation of a molecular fragment as a graph.
30 *
31 * Only, we do not store the full graph in here. We have to include symmetries
32 * such that two hydrogens may switch places. Eventually, we only look for the
33 * set of distances of a fragment. If two hydrogens switch places, then also in
34 * the set of distances some distances are interchanged but the whole fragment
35 * remains the same. Hence, we have to store the bond graph representation in
36 * such a way as to automatically include these symmetries.
37 *
38 * To this end, we use FragmentNode and FragmentEdge to store the vital
39 * information.
40 *
41 */
42class HomologyGraph
43{
[54a561]44 //!> grant output operator access to internals
45 friend std::ostream& operator<<(std::ostream& ost, const HomologyGraph &graph);
[7b6b21f]46public:
47 //!> typedef for a set of nodes representing node information
[28e203]48 typedef std::map<FragmentNode, size_t> nodes_t;
[7b6b21f]49 //!> typedef for a set of nodes representing edge information
[28e203]50 typedef std::map<FragmentEdge, size_t> edges_t;
[7b6b21f]51public:
52 /** Default constructor for class HomologyGraph.
53 *
54 * This is required to allow placement in STL containers
55 *
56 */
57 HomologyGraph() {}
58
59 /** Constructor for class HomologyGraph.
60 *
61 * @param _nodes information on nodes of this graph
62 * @param _edges information on edges of this graph
63 */
64 HomologyGraph(const nodes_t &_nodes, const edges_t &_edges) :
65 nodes(_nodes),
66 edges(_edges)
67 {}
68
[77b350]69 /** Constructor for class HomologyGraph from a keyset (i.e. from atoms in the World).
70 *
71 * @param keyset global ids of atoms to pick
72 */
[b0bc13]73 explicit HomologyGraph(const KeySet &keyset);
[77b350]74
[372c912]75 /** Constructor for class HomologyGraph from a IndexSet (i.e. from atoms in the World).
76 *
77 * @param index global ids of atoms to pick
78 */
[b0bc13]79 explicit HomologyGraph(const IndexSet &index);
[372c912]80
[7b6b21f]81 /** Destructor for class HomologyGraph.
82 *
83 */
84 ~HomologyGraph() {}
85
86 // comparators (allows sorting and hence quicker finding in STL containers)
87 bool operator<(const HomologyGraph &graph) const;
88 bool operator>(const HomologyGraph &graph) const;
89 bool operator==(const HomologyGraph &graph) const;
90 bool operator!=(const HomologyGraph &graph) const {
91 return (!(*this == graph));
92 }
93
[28e203]94 /** Checks whether this graph contains a specific \a node.
95 *
96 * @param node node to look for
97 * @param count how often this node must occur
98 * @return true - graph contains this node at least once, false - else
99 */
100 bool hasNode(const FragmentNode &node, const size_t count = 1) const {
101 nodes_t::const_iterator iter = nodes.find(node);
102 if (iter == nodes.end())
103 return count == 0;
104 else
105 return (iter->second == count);
106 }
107
108 /** Checks whether this graph contains a specific \a edge.
109 *
110 * @param edge edge to look for
111 * @param count how often this edge must occur
112 * @return true - graph contains this edge at least once, false - else
113 */
114 bool hasEdge(const FragmentEdge &edge, const size_t count = 1) const {
115 edges_t::const_iterator iter = edges.find(edge);
116 if (iter == edges.end())
117 return count == 0;
118 else
119 return (iter->second == count);
120 }
121
[e920d3d]122 /** Checks whether this graph has \b exactly \a _times nodes with \a _number
123 * atomic number.
124 *
125 * @param _number desired atomic number
126 * @param _times number this must occur
127 * @return true - graph has exactly \a _times nodes with \a _number, false - else
128 */
129 bool hasTimesAtomicNumber(const size_t _number, const size_t _times) const;
130
[7c1091]131 /** Checks whether this graph has \b greater equal \a _times nodes with \a _number
132 * atomic number.
133 *
134 * @param _number desired atomic number
135 * @param _times number this must occur
136 * @return true - graph has greater equal \a _times nodes with \a _number, false - else
137 */
138 bool hasGreaterEqualTimesAtomicNumber(const size_t _number, const size_t _times) const;
139
[7b6b21f]140 /** Assignment operator for class HomologyGraph.
141 *
142 * This is required to allow placement in STL container as we need to
143 * const_cast override our const member variables.
144 *
145 */
146 HomologyGraph& operator=(const HomologyGraph &graph);
147
[0afe00]148 /** Prints the nodes in the graph to stream \a ost.
149 *
150 * \param ost stream to print to
151 */
152 void printNodes(std::ostream& ost) const;
153
154 /** Prints the edges in the graph to stream \a ost.
155 *
156 * \param ost stream to print to
157 */
158 void printEdges(std::ostream& ost) const;
159
[4e6a60]160 /** Getter for the nodes contained in this graph.
161 *
162 * \return const ref to vector of FragmentNode
163 */
164 const nodes_t &getNodes() const
165 { return nodes; }
166
167 /** Getter for the edges contained in this graph.
168 *
169 * \return const ref to vector of FragmentEdge
170 */
171 const edges_t &getEdges() const
172 { return edges; }
173
[7b6b21f]174private:
175 //!> information on the nodes of the graph
176 const nodes_t nodes;
177 //!> information on the edges of the graph
178 const edges_t edges;
[67db80]179
180private:
181 friend class boost::serialization::access;
182 // serialization
183 template <typename Archive>
184 void serialize(Archive& ar, const unsigned int version)
185 {
186 ar & const_cast<nodes_t &>(nodes);
187 ar & const_cast<edges_t &>(edges);
188 }
[7b6b21f]189};
190
[54a561]191std::ostream& operator<<(std::ostream& ost, const HomologyGraph &graph);
192
[67db80]193// we need to give this class a unique key for serialization
194BOOST_CLASS_EXPORT_KEY(HomologyGraph)
195
[77b350]196// define some helpers outside to allow for light-weight unit testing
197namespace detail {
198 const HomologyGraph::nodes_t getNodesFromKeySet(const KeySet &keyset);
199 const HomologyGraph::edges_t getEdgesFromKeySet(const KeySet &keyset);
[372c912]200 const HomologyGraph::nodes_t getNodesFromIndexSet(const IndexSet &keyset);
201 const HomologyGraph::edges_t getEdgesFromIndexSet(const IndexSet &keyset);
[77b350]202};
203
[7b6b21f]204
205#endif /* HOMOLOGYGRAPH_HPP_ */
Note: See TracBrowser for help on using the repository browser.