ForceAnnealing_goodresults
        ForceAnnealing_tocheck
      
      
        
          | Last change
 on this file since 50e6b7 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 | 
      
      
| Rev | Line |  | 
|---|
| [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 | */ | 
|---|
|  | 19 | class GraphEdge | 
|---|
|  | 20 | { | 
|---|
|  | 21 | public: | 
|---|
|  | 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 |  | 
|---|
|  | 57 | private: | 
|---|
|  | 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.