source: src/Bond/GraphEdge.hpp@ adbeca

ForceAnnealing_goodresults ForceAnnealing_tocheck
Last change on this file since adbeca was 129204, checked in by Frederik Heber <heber@…>, 15 years ago

Moved bond.* to Bond/, new class GraphEdge which contains graph parts of bond.

  • enums Shading and EdgeType are now part of GraphEdge, hence bigger change in the code where these are used.
  • Property mode set to 100644
File size: 1.4 KB
RevLine 
[129204]1/*
2 * GraphEdge.hpp
3 *
4 * Created on: Feb 25, 2011
5 * Author: heber
6 */
7
8#ifndef GRAPHEDGE_HPP_
9#define GRAPHEDGE_HPP_
10
11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
16/** This class represents all features of a bond as used within graph
17 * algorithms.
18 */
19class GraphEdge
20{
21public:
22 /** Constructor.
23 */
24 GraphEdge();
25 /** Destructor.
26 */
27 virtual ~GraphEdge();
28
29 enum EdgeType { Undetermined, TreeEdge, BackEdge }; //!< edge type in a graph after Depth-First-Search analysis.
30 enum Shading { white, lightgray, darkgray, black }; //!< color in Breadth-First-Search analysis
31
32 bool Cyclic; //!< flag whether bond is part of a cycle or not, given in DepthFirstSearchAnalysis()
33 enum EdgeType Type;//!< whether this is a tree or back edge
34
35 /** Marks vertex as used in DFS.
36 * \param color color to mark bond with
37 * \return bond::Used, false if bond was already marked used
38 */
39 bool MarkUsed(const enum Shading color);
40
41 /** Returns whether vertex was used in DFS.
42 * \return bond::Used
43 */
44 enum Shading IsUsed();
45
46 /** Resets used flag in DFS.
47 * \return bond::Used
48 */
49 void ResetUsed();
50
51 /** Returns Shading as a char string.
52 * \param color the Shading
53 * \return string of the flag
54 */
55 static std::string getColorName(enum Shading color);
56
57private:
58 enum Shading Used; //!< marker in depth-first search, DepthFirstSearchAnalysis()
59
60};
61
62#endif /* GRAPHEDGE_HPP_ */
Note: See TracBrowser for help on using the repository browser.