source: src/Graph/DepthFirstSearchAnalysis.hpp

Candidate_v1.6.1
Last change on this file was 88c8ec, checked in by Frederik Heber <heber@…>, 12 years ago

REFACTOR: Replaced all "bond *" appearances by bond::ptr.

  • this is preparatory for making bond::ptr a boost::shared_ptr of bond.
  • NOTE: We had to remove a const prefix at four or five places and forward declarations had to be replaced by the true inclusion of bond.hpp at tne or so files. Apart from that, the replacement has been very smooth.
  • Property mode set to 100644
File size: 5.0 KB
Line 
1/*
2 * DepthFirstSearchAnalysis.hpp
3 *
4 * Created on: Feb 16, 2011
5 * Author: heber
6 */
7
8#ifndef DEPTHFIRSTSEARCHANALYSIS_HPP_
9#define DEPTHFIRSTSEARCHANALYSIS_HPP_
10
11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
16#include <deque>
17
18#include "Bond/bond.hpp"
19#include "ConnectedSubgraph.hpp"
20
21class atom;
22class ListOfLocalAtoms_t;
23class MoleculeLeafClass;
24class molecule;
25
26class DepthFirstSearchAnalysis
27{
28public:
29 /** Constructor of DepthFirstSearchAnalysis.
30 */
31 DepthFirstSearchAnalysis();
32
33 /** Destructor of DepthFirstSearchAnalysis.
34 */
35 ~DepthFirstSearchAnalysis();
36
37 /** Performs a Depth-First search on all atoms.
38 * Marks bonds in molecule as cyclic, bridge, ... and atoms as
39 * articulations points, ...
40 * We use the algorithm from [Even, Graph Algorithms, p.62].
41 * \param *&BackEdgeStack NULL pointer to std::deque<bond::ptr > with all the found back edges, allocated and filled on return
42 * \return list of each disconnected subgraph as an individual molecule class structure
43 */
44 void operator()();
45
46 /** Scans through all bonds and set bond::Cyclic to true where atom::LowpointNr of both ends is equal: LP criterion.
47 * \note Hydrogen bonds can never by cyclic, thus no check for that
48 * \return number of cyclic bonds
49 */
50 unsigned int CyclicBondAnalysis() const;
51
52 /** Removes all molecules and assign anew with known ListOfConnectedSubgraphs.
53 *
54 */
55 void UpdateMoleculeStructure() const;
56
57 /** Creates a chained list of all present molecules.
58 *
59 * \warning returns allocated chained list as reference, has to be free'd item by item through the list
60 *
61 * @return start node of chained molecules list
62 */
63 MoleculeLeafClass *getMoleculeStructure() const;
64
65 /** Picks from a global stack with all back edges the ones in the fragment.
66 *
67 * Reference is the internal BackEdgeStack.
68 *
69 * \param ListOfLocalAtoms array of father atom::nr to local atom::nr (reverse of atom::father)
70 * \param *LocalStack stack to be filled
71 * \return true - everything ok, false - ReferenceStack was empty
72 */
73 bool PickLocalBackEdges(const ListOfLocalAtoms_t &ListOfLocalAtoms, std::deque<bond::ptr > *&LocalStack) const;
74
75 /** Getter for BackEdgeStack.
76 *
77 * @return const reference to BackEdgeStack
78 */
79 const std::deque<bond::ptr >& getBackEdgeStack() const;
80
81private:
82 /** Resets GraphNodeInfo::ComponentNr and GraphNodeInfo::GraphrNr.
83 *
84 */
85 void Init();
86
87 /** Returns next unused bond for this atom \a *vertex or NULL of none exists.
88 * \param *vertex atom to regard
89 * \return bond class or NULL
90 */
91 bond::ptr FindNextUnused(atom *vertex) const;
92
93 /** Resets bond::Used flag of all bonds in this molecule.
94 * \return true - success, false - -failure
95 */
96 void ResetAllBondsToUnused() const;
97
98 /** Sets the next component number.
99 * This is O(N) as the number of bonds per atom is bound.
100 * \param *vertex atom whose next atom::*ComponentNr is to be set
101 * \param nr number to use
102 */
103 void SetNextComponentNumber(atom *vertex, int nr) const;
104
105 /** Sets atom::GraphNr and atom::LowpointNr to CurrentGraphNr.
106 * \param *Walker current node
107 */
108 void SetWalkersGraphNr(atom *&Walker);
109
110 /** During DFS goes along unvisited bond and touches other atom.
111 * Sets bond::type, if
112 * -# BackEdge: set atom::LowpointNr and push on \a BackEdgeStack
113 * -# TreeEgde: set atom::Ancestor and continue with Walker along this edge
114 * Continue until molecule::FindNextUnused() finds no more unused bonds.
115 * \param *&Walker current node
116 * \param *&Binder current edge
117 */
118 void ProbeAlongUnusedBond(atom *&Walker, bond::ptr &Binder);
119
120 /** Checks whether we have a new component.
121 * if atom::LowpointNr of \a *&Walker is greater than atom::GraphNr of its atom::Ancestor, we have a new component.
122 * Meaning that if we touch upon a node who suddenly has a smaller atom::LowpointNr than its ancestor, then we
123 * have a found a new branch in the graph tree.
124 * \param *&Walker current node
125 * \param &LeafWalker contains reference to destination subgraph
126 */
127 void CheckForaNewComponent(atom *&Walker, ConnectedSubgraph &LeafWalker);
128
129 /** Cleans the root stack when we have found a component.
130 * If we are not BackStepping, then we clear the root stack by putting everything into a
131 * component down till we meet Root.
132 * \param *&Walker current node
133 * \param *&Binder current edge
134 * \param &LeafWalker contains reference to destination subgraph
135 */
136 void CleanRootStackDownTillWalker(atom *&Walker, bond::ptr &Binder, ConnectedSubgraph &LeafWalker);
137
138 /** Output graph information per atom.
139 */
140 void OutputGraphInfoPerAtom() const;
141
142 /** Output graph information per bond.
143 */
144 void OutputGraphInfoPerBond() const;
145
146 std::deque<atom *> AtomStack;
147 std::deque<bond::ptr > BackEdgeStack;
148 int CurrentGraphNr;
149 int ComponentNumber;
150 atom *Root;
151 bool BackStepping;
152
153 typedef std::list< ConnectedSubgraph > ConnectedSubgraphList;
154
155 ConnectedSubgraphList ListOfConnectedSubgraphs;
156};
157
158#endif /* DEPTHFIRSTSEARCHANALYSIS_HPP_ */
Note: See TracBrowser for help on using the repository browser.