--- nfo/python/scripts/sixdegrees/boostgraph.py 2008/02/21 04:46:47 1.3 +++ nfo/python/scripts/sixdegrees/boostgraph.py 2008/02/22 13:34:26 1.5 @@ -1,6 +1,6 @@ #!/usr/bin/env python -# $Id: boostgraph.py,v 1.3 2008/02/21 04:46:47 joko Exp $ +# $Id: boostgraph.py,v 1.5 2008/02/22 13:34:26 joko Exp $ # (c) 2008 Andreas Motl # (c) 2008 Sebastian Utz @@ -63,12 +63,15 @@ class tree_edges_dfs_visitor(bgl.dfs_visitor): #class tree_edges_bfs_visitor(bgl.bfs_visitor): - def __init__(self, maxdepth, name_map, color_map): + def __init__(self, startVertex, endVertex, maxdepth, color_map): print dir(self) #bgl.dfs_visitor.__init__(self) - self.name_map = name_map + #self.name_map = name_map + + self.startVertex = startVertex + self.endVertex = endVertex # for recognizing path switches self.state = True @@ -87,10 +90,19 @@ self.level = 0 + def back_edge(self, e, g): + self._touch_edge(e, g, 'back_edge') + + def forward_or_cross_edge(self, e, g): + self._touch_edge(e, g, 'forward_or_cross_edge') + + def tree_edge(self, e, g): + self._touch_edge(e, g, 'tree_edge') + def examine_edge(self, e, g): - self.tree_edge2(e, g, 'examine_edge') + self._touch_edge(e, g, 'examine_edge') - def tree_edge2(self, e, g, label='tree_edge'): + def _touch_edge(self, e, g, label=''): (u, v) = (g.source(e), g.target(e)) @@ -106,25 +118,61 @@ end_vertex = g.target(child_edge) #self.color_map[end_vertex] = bgl.Color(bgl.Color.gray) """ - + + name_map = g.vertex_properties['node_id'] if label: - print "%s:" % label, - print "Tree edge ", - print self.name_map[u], + print "%s:\t" % label, + #print "edge ", + print name_map[u], print " -> ", - print self.name_map[v] - sys.stdout.flush() - self.state = True - self.current_path.append(e) - #return False + print name_map[v] + + #self.state = True + + if u == self.startVertex: + print "starting" + self.current_path = [] + + # skip circular references + if v != self.startVertex: + self.current_path.append(e) + + if v == self.endVertex and self.current_path: + print "found:" + print self.current_path + self.paths.append(self.current_path) + self.current_path = [] + + + def _touch_vertex(self, v, g, label=''): + name_map = g.vertex_properties['node_id'] + id = name_map[v] + print '%s:\t%s' % (label, id) + + + def start_vertex(self, v, g): + self._touch_vertex(v, g, 'start_vertex') + def discover_vertex(self, v, g): + self._touch_vertex(v, g, 'discover_vertex') + + def initialize_vertex(self, v, g): + self._touch_vertex(v, g, 'initialize_vertex') + + def examine_vertex(self, v, g): + self._touch_vertex(v, g, 'examine_vertex') + + def finish_vertex(self, v, g): + self._touch_vertex(v, g, 'finish_vertex') + + + """ def start_vertex(self, v, g): self._seperator('start_vertex') #pass #print 'sssss' - def discover_vertex(self, v, g): #print '>>>' self._seperator('discover_vertex') @@ -144,6 +192,7 @@ self.current_path = [] self.depth = 0 self._seperator('finish_vertex') + """ def _seperator(self, label = 'unknown'): if 1 or self.state: @@ -186,7 +235,7 @@ e3 = graph.add_edge(v3, v4) e4 = graph.add_edge(v1, v4) - #e5 = graph.add_edge(v3, v2) + e5 = graph.add_edge(v2, v3) #e6 = graph.add_edge(v2, v4) """ @@ -261,6 +310,15 @@ print ' -> '.join(track_ids) +def dump_edges(g, edges): + name_map = g.vertex_properties['node_id'] + for e in edges: + (u, v) = (g.source(e), g.target(e)) + print "edge ", + print name_map[u], + print " -> ", + print name_map[v] + def find_path_solutions(source, target, graph, paths): print @@ -304,6 +362,7 @@ #mst_edges = bgl.kruskal_minimum_spanning_tree(graph, weight) #bgl.depth_first_search(graph, root_vertex = None, visitor = None, color_map = None) + """ for root in graph.vertices: print print '=' * 42 @@ -316,6 +375,7 @@ #bgl.breadth_first_search(graph, root_vertex = root, visitor = visitor, color_map = None) #find_path_solutions(index['1'], index['4'], graph, visitor.paths) #sys.exit(0) + """ startIndex = random.choice(index.keys()) endIndex = random.choice(index.keys()) @@ -329,10 +389,13 @@ def doCompute(): cmap = graph.vertex_property_map('color') - visitor = tree_edges_dfs_visitor(MAX_SEARCH_DEPTH, graph.vertex_properties['node_id'], cmap) + visitor = tree_edges_dfs_visitor(startVertex, endVertex, MAX_SEARCH_DEPTH, cmap) bgl.depth_first_search(graph, root_vertex = startVertex, visitor = visitor, color_map = None) #bgl.depth_first_visit(graph, root_vertex = startVertex, visitor = visitor, color_map = cmap) - find_path_solutions(startVertex, endVertex, graph, visitor.paths) + #find_path_solutions(startVertex, endVertex, graph, visitor.paths) + for path in visitor.paths: + print '-' * 21 + dump_edges(graph, path) if ENABLE_PROFILING: global paths