| [357fba] | 1 | /*
 | 
|---|
 | 2 |  * bond.hpp
 | 
|---|
 | 3 |  *
 | 
|---|
 | 4 |  *  Created on: Aug 3, 2009
 | 
|---|
 | 5 |  *      Author: heber
 | 
|---|
 | 6 |  */
 | 
|---|
 | 7 | 
 | 
|---|
 | 8 | #ifndef BOND_HPP_
 | 
|---|
 | 9 | #define BOND_HPP_
 | 
|---|
 | 10 | 
 | 
|---|
 | 11 | using namespace std;
 | 
|---|
 | 12 | 
 | 
|---|
| [f66195] | 13 | /*********************************************** includes ***********************************/
 | 
|---|
 | 14 | 
 | 
|---|
| [cd4ccc] | 15 | // include config.h
 | 
|---|
 | 16 | #ifdef HAVE_CONFIG_H
 | 
|---|
 | 17 | #include <config.h>
 | 
|---|
 | 18 | #endif
 | 
|---|
 | 19 | 
 | 
|---|
| [f66195] | 20 | /****************************************** forward declarations *****************************/
 | 
|---|
 | 21 | 
 | 
|---|
| [e41951] | 22 | class atom;
 | 
|---|
| [4455f4] | 23 | class ParticleInfo;
 | 
|---|
| [357fba] | 24 | 
 | 
|---|
| [f66195] | 25 | /********************************************** declarations *******************************/
 | 
|---|
 | 26 | 
 | 
|---|
| [357fba] | 27 | /** Bonds between atoms.
 | 
|---|
| [266237] | 28 |  * Class incorporates bonds between atoms in a molecule.
 | 
|---|
 | 29 |  * Note that we regard bond always as something in a molecule,
 | 
|---|
 | 30 |  * as it is the glue making up the connected subgrapgh and
 | 
|---|
 | 31 |  * hence the molecule. Thus, bonds belong globally to the molecule
 | 
|---|
 | 32 |  * (and are free'd there) and only locally to the atom classs.
 | 
|---|
| [357fba] | 33 |  */
 | 
|---|
 | 34 | class bond {
 | 
|---|
 | 35 |   public:
 | 
|---|
 | 36 |     atom *leftatom;    //!< first bond partner
 | 
|---|
 | 37 |     atom *rightatom;  //!< second bond partner
 | 
|---|
 | 38 |     bond *previous; //!< previous atom in molecule list
 | 
|---|
 | 39 |     bond *next;     //!< next atom in molecule list
 | 
|---|
 | 40 |     int HydrogenBond;  //!< Number of hydrogen atoms in the bond
 | 
|---|
 | 41 |     int BondDegree;    //!< single, double, triple, ... bond
 | 
|---|
 | 42 |     int nr;           //!< unique number in a molecule, updated by molecule::CreateAdjacencyList()
 | 
|---|
 | 43 |     bool Cyclic;      //!< flag whether bond is part of a cycle or not, given in DepthFirstSearchAnalysis()
 | 
|---|
 | 44 |     enum EdgeType Type;//!< whether this is a tree or back edge
 | 
|---|
 | 45 | 
 | 
|---|
| [fb73b8] | 46 |   atom * GetOtherAtom(const ParticleInfo * const Atom) const;
 | 
|---|
| [357fba] | 47 | 
 | 
|---|
| [fb73b8] | 48 |   bool MarkUsed(const enum Shading color);
 | 
|---|
| [357fba] | 49 |   enum Shading IsUsed();
 | 
|---|
 | 50 |   void ResetUsed();
 | 
|---|
| [fb73b8] | 51 |   bool Contains(const ParticleInfo * const ptr);
 | 
|---|
| [357fba] | 52 |   bool Contains(const int nr);
 | 
|---|
| [b9947d] | 53 |   double GetDistance() const;
 | 
|---|
 | 54 |   double GetDistanceSquared() const;
 | 
|---|
| [357fba] | 55 | 
 | 
|---|
 | 56 |   bond();
 | 
|---|
| [fb73b8] | 57 |   bond(atom *left, atom *right, const int degree=1, const int number=0);
 | 
|---|
| [357fba] | 58 |   ~bond();
 | 
|---|
 | 59 | 
 | 
|---|
 | 60 |   private:
 | 
|---|
 | 61 |     enum Shading Used;        //!< marker in depth-first search, DepthFirstSearchAnalysis()
 | 
|---|
 | 62 | };
 | 
|---|
 | 63 | 
 | 
|---|
 | 64 | ostream & operator << (ostream &ost, const bond &b);
 | 
|---|
 | 65 | 
 | 
|---|
 | 66 | #endif /* BOND_HPP_ */
 | 
|---|