コード例 #1
0
	def test_vr_topsort(self):
	        n = 5
        	partial_order = [(1,2), (2,3), (1,5)]
		g = digraphtools.graph_from_edges(digraphtools.from_partial_order(partial_order))
        	grid = topsort.partial_order_to_grid(partial_order,n)
        	for le in topsort.vr_topsort(n,grid):
			digraphtools.verify_partial_order(digraphtools.iter_partial_order(g), le)
コード例 #2
0
	def test_vr_topsort(self):
	        n = 5
        	partial_order = [(1,2), (2,3), (1,5)]
		g = digraphtools.graph_from_edges(digraphtools.from_partial_order(partial_order))
        	grid = topsort.partial_order_to_grid(partial_order,n)
        	for le in topsort.vr_topsort(n,grid):
			digraphtools.verify_partial_order(digraphtools.iter_partial_order(g), le)
コード例 #3
0
    def graph_from_items(cls, items):
        # pre: all items in graph are passed
        def edges_from_items(items):
            for i in items:
                for d in i.depends:
                    yield (i, d)

        return digraphtools.graph_from_edges(edges_from_items(items))
コード例 #4
0
	def test_copy_graph(self):
		edges = set([(1,2),(1,3),(2,3)])
		g = digraphtools.graph_from_edges(edges)
		gg = digraphtools.copy_graph(g)
		self.assertEqual(g,gg)
		gedges = set(digraphtools.iter_edges(g))
		ggedges = set(digraphtools.iter_edges(gg))
		self.assertEqual(gedges,ggedges)
		gg[2].remove(3)
		self.assertNotEqual(g,gg)
		gedges = set(digraphtools.iter_edges(g))
		ggedges = set(digraphtools.iter_edges(gg))
		self.assertNotEqual(gedges,ggedges)
コード例 #5
0
def recognize(lex,partialOrderingEdges,adj,start,minP,inpt): # initialize and begin
    sA = stringValsOfG(lex)
    (lA,tA) = gIntoLexArrayTypeArray(sA,lex)
    intAdj = stringAdjDictToIntAdjDict(sA,adj)
    intOrderingEdges = stringOrderingToIntOrderingEdges(sA,partialOrderingEdges)
    partialOrdering = graph_from_edges(intOrderingEdges)
    startInt = intsOfF(sA,('cat',start))[1]
    h = lA[startInt]
    m = [[]]*len(sA)
    mx = [[]]*len(sA)
    ic = ((h,m),([],mx))
    iq = [([],ic)]
    heapq.heapify(iq)
    dq = [(-1.0,inpt,iq)]
    heapq.heapify(dq)
    return derive((sA,lA,tA),partialOrdering,intAdj,minP,dq)
コード例 #6
0
 def graph_from_item_deps(cls, item):
     return digraphtools.graph_from_edges(cls.edges_from_item_deps(item))
コード例 #7
0
	def test_graph_from_edges(self):
		g = digraphtools.graph_from_edges([(1,2),(1,3),(2,3)])
		self.assertEqual(set(g[1]),set([2,3]))
		self.assertEqual(set(g[2]),set([3]))
		self.assertEqual(set(g[3]),set())
コード例 #8
0
	def test_get_connected_subgraph(self):
		g = digraphtools.graph_from_edges([(1,2),(1,3),(2,3)])
		self.assertEqual(g, digraphtools.get_connected_subgraph(g,1))
		sg = digraphtools.graph_from_edges([(2,3)])
		self.assertEqual(sg, digraphtools.get_connected_subgraph(g,2))
コード例 #9
0
	def test_dfs_iter_edges(self):
		g = digraphtools.graph_from_edges([(1,2),(1,3),(2,3)])
		edgeiter = digraphtools.dfs_iter_edges(g,1)
		self.assertEqual([(1,2),(2,3),(1,3)],list(edgeiter))
コード例 #10
0
	def test_dfs_topsort_traversal(self):
		edges = set([(1,2),(1,3),(2,3)])
		g = digraphtools.graph_from_edges(edges)
		po = list(digraphtools.dfs_topsort_traversal(g,1))
		self.assertEqual([3,2,1],po)
コード例 #11
0
	def test_postorder_traversal(self):
		edges = set([(1,2),(1,3),(2,3)])
		g = digraphtools.graph_from_edges(edges)
		po = list(digraphtools.postorder_traversal(g,1))
		self.assertEqual([3,2,3,1],po)
コード例 #12
0
	def test_iter_edges(self):
		edges = set([(1,2),(1,3),(2,3)])
		g = digraphtools.graph_from_edges(edges)
		gedges = set(digraphtools.iter_edges(g))
		self.assertEqual(edges,gedges)
コード例 #13
0
	def test_verify_partial_order(self):
		g = digraphtools.graph_from_edges([(1,2),(1,3),(2,3)])
		# Will raise an exception if incorrect
		digraphtools.verify_partial_order(digraphtools.iter_partial_order(g), [3,2,1])
		self.assertRaises(digraphtools.OrderViolationException,digraphtools.verify_partial_order, digraphtools.iter_partial_order(g), [3,1,2])
コード例 #14
0
ファイル: deptools.py プロジェクト: anchor/make-magic
	def graph_from_items(cls, items):
		# pre: all items in graph are passed
		def edges_from_items(items):
			for i in items:
				for d in i.depends: yield (i,d)
		return digraphtools.graph_from_edges( edges_from_items(items) )
コード例 #15
0
ファイル: deptools.py プロジェクト: anchor/make-magic
	def graph_from_item_deps(cls, item):
		return digraphtools.graph_from_edges( cls.edges_from_item_deps(item) )