Candidate_v1.7.0
        stable
      
      
        
          | 
            Last change
 on this file since e70818 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.