Exemple #1
0
 def test_connected_components_disconnected(self):
     graph = Graph([[0, 1], [1, 2], [2, 0], [3, 4], [3, 5], [3, 6], [7, 8]])
     result = connected_components(graph)
     self.assertEqual(len(result), 3)
     self.assertTrue(result[0].id in [0, 1, 2])
     self.assertTrue(result[1].id in [3, 4, 5, 6])
     self.assertTrue(result[2].id in [7, 8])
    def test_1(self):
        graph = Graph([[0, 1], [0, 2], [1, 3], [2, 3]], True)
        find_topological_order(graph)

        self.check_labels(graph, 0, 1)
        self.check_labels(graph, 0, 2)
        self.check_labels(graph, 1, 3)
        self.check_labels(graph, 2, 3)
Exemple #3
0
 def test_bfs_check_order(self):
     g = Graph([[0, 1], [0, 2], [1, 3], [1, 4], [2, 5], [2, 6]])
     breadth_first_search(g, 0)
     self.assertTrue(
         g.get_node(0).visited < min(self.__get_visited_values(g, [1, 2])))
     self.assertTrue(
         g.get_node(1).visited < min(
             self.__get_visited_values(g, [3, 4, 5, 6])))
     self.assertTrue(
         g.get_node(2).visited < min(
             self.__get_visited_values(g, [3, 4, 5, 6])))
Exemple #4
0
    def test_dfs_disconnected(self):
        g = Graph([[0, 1], [2, 3]])
        depth_first_search(g, 0)

        for i in range(2):
            self.assertTrue(g.get_node(i).visited)

        for i in range(2, 4):
            self.assertFalse(g.get_node(i).visited)

        depth_first_search(g, 2)

        for i in range(2, 4):
            self.assertTrue(g.get_node(i).visited)
Exemple #5
0
    def test_dfs_check_order(self):
        g = Graph([[0, 1], [0, 2], [1, 3], [1, 4], [2, 5], [2, 6]])

        depth_first_search(g, 0)
        if g.get_node(1).visited < g.get_node(2).visited:
            self.assertTrue(g.get_node(3).visited < g.get_node(2).visited)
            self.assertTrue(g.get_node(4).visited < g.get_node(2).visited)
        else:
            self.assertTrue(g.get_node(5).visited < g.get_node(1).visited)
            self.assertTrue(g.get_node(6).visited < g.get_node(1).visited)

        self.assertTrue(g.get_node(0).visited < g.get_node(1).visited)
        self.assertTrue(g.get_node(0).visited < g.get_node(2).visited)
        self.assertTrue(g.get_node(1).visited < g.get_node(3).visited)
        self.assertTrue(g.get_node(1).visited < g.get_node(4).visited)
        self.assertTrue(g.get_node(2).visited < g.get_node(5).visited)
        self.assertTrue(g.get_node(2).visited < g.get_node(6).visited)
Exemple #6
0
    def __init__(self, *args, **kwargs):
        super(TestGraphSearch, self).__init__(*args, **kwargs)
        
        # -----------------------------
        # ----- Graph 1: Directed -----
        # -----------------------------

        """
        graph1 = {
            '0': ['1', '2'],
            '1': ['2'],
            '2': ['0', '3'],
            '3': ['3'],
        }
        """
        self.graph1 = Graph(directed=True)
        self.graph1.add_edge(0, 1)
        self.graph1.add_edge(0, 2)
        self.graph1.add_edge(1, 2)
        self.graph1.add_edge(2, 0)
        self.graph1.add_edge(2, 3)
        self.graph1.add_edge(3, 3)

        # -------------------------------
        # ----- Graph 2: Undirected -----
        # -------------------------------
        
        """
        graph2 = {
            '1': ['2', '5', '6'],
            '2': ['1', '3', '5'],
            '3': ['2', '4'],
            '4': ['3', '5'],
            '5': ['1', '2', '4'],
            '6': ['1'],
        }
        """
        self.graph2 = Graph(directed=False)
        self.graph2.add_edge(1, 2)
        self.graph2.add_edge(1, 5)
        self.graph2.add_edge(1, 6)
        self.graph2.add_edge(2, 3)
        self.graph2.add_edge(2, 5)
        self.graph2.add_edge(3, 4)
        self.graph2.add_edge(4, 5)

        # -----------------------------------------
        # ----- Graph 3: Undirected Bipartite -----
        # -----------------------------------------
        
        """
        graph3 = {
            '1': ['2', '5', '6'],
            '2': ['1', '3', '4'],
            '3': ['2', '4'],
            '4': ['3', '5'],
            '5': ['1', '3', '4'],
            '6': ['1'],
        }
        """
        self.graph3 = Graph(directed=False)
        self.graph3.add_edge(1, 2)
        self.graph3.add_edge(1, 5)
        self.graph3.add_edge(1, 6)
        self.graph3.add_edge(2, 3)
        self.graph3.add_edge(2, 4)
        self.graph3.add_edge(3, 5)
        self.graph3.add_edge(4, 5)
Exemple #7
0
    def test_bfs_simple_connected(self):
        g = Graph([[0, 1], [1, 2], [2, 0]])
        breadth_first_search(g, 0)

        for i in range(3):
            self.assertTrue(g.get_node(i).visited)
Exemple #8
0
    def test_dfs_self_edges(self):
        g = Graph([[0, 0], [0, 1], [1, 1], [2, 2], [2, 0]])
        depth_first_search(g, 0)

        for i in range(3):
            self.assertTrue(g.get_node(i).visited)
Exemple #9
0
    def test_bfs_parallel_edges(self):
        g = Graph([[0, 1], [1, 2], [1, 2], [2, 1], [0, 1], [0, 2]])
        breadth_first_search(g, 0)

        for i in range(3):
            self.assertTrue(g.get_node(i).visited)
Exemple #10
0
 def test_connected_components_fully_connected(self):
     graph = Graph([[0, 1], [1, 2], [2, 0]])
     result = connected_components(graph)
     self.assertEqual(len(result), 1)
     self.assertTrue(result[0].id in [0, 1, 2])