source: molecuilder/src/graph.cpp@ b918031

Last change on this file since b918031 was 1f2e46, checked in by Frederik Heber <heber@…>, 15 years ago

Huge change: Log() << Verbose(.) --> DoLog(.) && (Log() << Verbose(.) << ...);

Most of the files are affected, but this is necessary as if DoLog() says verbosity is not enough, all the stream operators won"t get executed which saves substantial amount of computation time.

Signed-off-by: Frederik Heber <heber@…>

  • Property mode set to 100755
File size: 3.8 KB
Line 
1/** \file graph.cpp
2 *
3 * Function implementations for the class graph.
4 *
5 */
6
7using namespace std;
8
9#include "atom.hpp"
10#include "bond.hpp"
11#include "config.hpp"
12#include "graph.hpp"
13#include "log.hpp"
14#include "molecule.hpp"
15
16/***************************************** Implementations for graph classes ********************************/
17
18///** Constructor of class Graph.
19// */
20//Graph::Graph()
21//{
22//};
23//
24///** Destructor of class Graph.
25// * Destructor does release memory for nodes and edges contained in its lists as well.
26// */
27//Graph::~Graph()
28//{
29//};
30//
31///** Constructor of class SubGraph.
32// */
33//SubGraph::SubGraph()
34//{
35//};
36//
37///** Destructor of class SubGraph.
38// * Note that destructor does not deallocate either nodes or edges! (this is done by its subgraph!)
39// */
40//SubGraph::~SubGraph()
41//{
42//};
43//
44///** Constructor of class Node.
45// */
46//Node::Node()
47//{
48//};
49//
50///** Destructor of class Node.
51// */
52//Node::~Node()
53//{
54//};
55//
56///** Constructor of class Edge.
57// */
58//Edge::Edge()
59//{
60//};
61//
62///** Destructor of class Edge.
63// */
64//Edge::~Edge()
65//{
66//};
67
68
69//bool operator < (KeySet SubgraphA, KeySet SubgraphB)
70//{
71// return KeyCompare(SubgraphA, SubgraphB);
72//};
73
74/** Checking whether KeySet is not already present in Graph, if so just adds factor.
75 * \param *out output stream for debugging
76 * \param &set KeySet to insert
77 * \param &graph Graph to insert into
78 * \param *counter pointer to unique fragment count
79 * \param factor energy factor for the fragment
80 */
81void InsertFragmentIntoGraph(struct UniqueFragments *Fragment)
82{
83 GraphTestPair testGraphInsert;
84
85 testGraphInsert = Fragment->Leaflet->insert(GraphPair (*Fragment->FragmentSet,pair<int,double>(Fragment->FragmentCounter,Fragment->TEFactor))); // store fragment number and current factor
86 if (testGraphInsert.second) {
87 DoLog(2) && (Log() << Verbose(2) << "KeySet " << Fragment->FragmentCounter << " successfully inserted." << endl);
88 Fragment->FragmentCounter++;
89 } else {
90 DoLog(2) && (Log() << Verbose(2) << "KeySet " << Fragment->FragmentCounter << " failed to insert, present fragment is " << ((*(testGraphInsert.first)).second).first << endl);
91 ((*(testGraphInsert.first)).second).second += Fragment->TEFactor; // increase the "created" counter
92 DoLog(2) && (Log() << Verbose(2) << "New factor is " << ((*(testGraphInsert.first)).second).second << "." << endl);
93 }
94};
95//void inline InsertIntoGraph(KeyStack &stack, Graph &graph, int *counter, double factor)
96//{
97// // copy stack contents to set and call overloaded function again
98// KeySet set;
99// for(KeyStack::iterator runner = stack.begin(); runner != stack.begin(); runner++)
100// set.insert((*runner));
101// InsertIntoGraph(set, graph, counter, factor);
102//};
103
104/** Inserts each KeySet in \a graph2 into \a graph1.
105 * \param *out output stream for debugging
106 * \param graph1 first (dest) graph
107 * \param graph2 second (source) graph
108 * \param *counter keyset counter that gets increased
109 */
110void InsertGraphIntoGraph(Graph &graph1, Graph &graph2, int *counter)
111{
112 GraphTestPair testGraphInsert;
113
114 for(Graph::iterator runner = graph2.begin(); runner != graph2.end(); runner++) {
115 testGraphInsert = graph1.insert(GraphPair ((*runner).first,pair<int,double>((*counter)++,((*runner).second).second))); // store fragment number and current factor
116 if (testGraphInsert.second) {
117 DoLog(2) && (Log() << Verbose(2) << "KeySet " << (*counter)-1 << " successfully inserted." << endl);
118 } else {
119 DoLog(2) && (Log() << Verbose(2) << "KeySet " << (*counter)-1 << " failed to insert, present fragment is " << ((*(testGraphInsert.first)).second).first << endl);
120 ((*(testGraphInsert.first)).second).second += (*runner).second.second;
121 DoLog(2) && (Log() << Verbose(2) << "New factor is " << (*(testGraphInsert.first)).second.second << "." << endl);
122 }
123 }
124};
125
Note: See TracBrowser for help on using the repository browser.