Esempio n. 1
0
 def test_constructor3(self):
     g = MatrixGraph(edges=[(0, 1), (1, 2), (2, 3)])
     self.assertEqual(4, g.order())
     self.assertEqual(3, g.size())
     self.assertIn({0, 1}, g)
     self.assertIn({1, 2}, g)
     self.assertIn({3, 2}, g)
Esempio n. 2
0
 def test_intersection(self):
     G = MatrixGraph(order=10).add(0, 1).add(2, 3).add(4, 5).add(8, 9)
     H = MatrixGraph(order=5).add(0, 1).add(1, 2).add(2, 3)
     GnH = G.intersection(H)
     self.assertEqual(5, GnH.order())
     self.assertEqual(2, GnH.size())
     edges = GnH.E()
     self.assertIn(Edge(0, 1), GnH)
     self.assertIn(Edge(2, 3), GnH)
Esempio n. 3
0
    def test_edges(self):
        g = MatrixGraph(5)
        edges_in = [(0, 1), (1, 2), (2, 3), (3, 4), (4, 0)]
        for (a, b) in edges_in:
            g.add(a, b)

        counter = 0
        for a, b in g.E():
            self.assertTrue((a, b) in edges_in or (b, a) in edges_in)
            counter += 1
        self.assertEqual(len(edges_in), counter)
Esempio n. 4
0
def J(v, k, i, type='matrix'):
    """
    Create a Johnson graph over a set of size v with samples of size k and
    intersection size i.

    :param v:
    :param k:
    :param i:
    :return:
    """
    if type == 'matrix':
        xs = [x for x in range(v)]
        order = choose(v, k)
        vertices = []  # A list of length order with combinations below
        for a, c in enumerate(combinations(xs, k)):
            print(a)
            vertices.append(c)

        def edge_predicate(x, y):
            if len(set(vertices[x]).intersection(set(vertices[y]))) == i:
                return True
            return False

        return MatrixGraph(order=order, edges=edge_predicate)
    else:
        raise RuntimeError("Unrecognized Graph type: {}".format(type))
Esempio n. 5
0
 def test_iter(self):
     g = MatrixGraph(3).add(0, 1).add(0, 2).add(1, 2)
     assert len(list(g)) == 3
     l = list(g)
     self.assertIn(Edge(0, 1), l)
     self.assertIn(Edge(0, 2), l)
     self.assertIn(Edge(1, 2), l)
Esempio n. 6
0
def do_you_speak_barrington(g_string):
    """
    Given a representation of a graph of the form:
        0 01 101 1111
    create the associated graph.

    :param g_string: string containing the graph information
    :return: The appropriate MatrixGraph
    """
    if ':' in g_string:
        g_string = g_string[g_string.index(':') + 1:]
    g_string = g_string.strip()
    g_strings = g_string.split()
    print (g_strings)
    order = len(g_strings) + 1
    G = MatrixGraph(order=order)
    for i, s in enumerate(g_strings):
        for j, c in enumerate(s):
            if c == '1':
                G.add(i+1, j)
    return G
Esempio n. 7
0
 def test_d(self):
     """
     Test the degree function
     """
     g = MatrixGraph(order=4).add(0, 1).add(1, 2).add(2, 3).add(3, 0)
     self.assertEqual(2, g.d(0))
     self.assertEqual(2, g.d(1))
     self.assertEqual(2, g.d(2))
     self.assertEqual(2, g.d(3))
     g.add(0,2)
     self.assertEqual(3, g.d(0))
     self.assertEqual(2, g.d(1))
     self.assertEqual(3, g.d(2))
     self.assertEqual(2, g.d(3))
Esempio n. 8
0
    def test_create_random(self):
        total_edges = 0
        density = 0.5
        test_runs = 10
        for i in range(test_runs):
            g = MatrixGraph.create_random(32, density=density)
            for _, _ in g.E():
                total_edges += 1

        expected = test_runs * choose(32, 2) * density
        actual = total_edges
        self.assertLessEqual(expected * 0.9, actual)
        self.assertLessEqual(actual, expected * 1.10)
Esempio n. 9
0
    def test_complement(self):
        g = MatrixGraph(4)
        g.add(0, 1)
        g.add(1, 2)
        g.add(2, 3)
        g.add(3, 0)
        c = g.complement()

        self.assertIn((0, 2), c)
        self.assertIn((1, 3), c)
        self.assertNotIn((0, 1), c)
        self.assertNotIn((1, 2), c)
        self.assertNotIn((2, 3), c)
        self.assertNotIn((3, 0), c)
Esempio n. 10
0
def bipartite(m, n, type='matrix'):
    """
    Create a bipartite graph on (m,n) veritces
    :param m:
    :param n:
    :param type:
    :return:
    """

    if type == 'matrix':

        def edge_predicate(i, j):
            return i < m == j >= m

        return MatrixGraph(order=m + n, edges=edge_predicate)
    else:
        raise RuntimeError("Unrecognized Graph type: {}".format(type))
Esempio n. 11
0
def C(n, circulant_set=None, type='matrix'):

    if type == 'matrix':
        if circulant_set is None:
            circulant_set = {1}
        cs = {int(x)
              for x in circulant_set}.union({-int(x)
                                             for x in circulant_set})

        def edge_predicate(i, j):
            x, y = int(i), int(j)  # In case we are using uint32s
            return (x - y) % n in cs or (y - x) % n in cs

        g = MatrixGraph(order=n, edges=edge_predicate)
        return g
    else:
        raise RuntimeError("Unrecognized Graph type: {}".format(type))
Esempio n. 12
0
 def test_E(self):
     g = MatrixGraph(5)
     edges = [(0, 1), (1, 2), (2, 3), (3, 4), (4, 0)]
     for a,b in edges:
         g.add(a,b)
     for a,b in generate_lower_triangle(5, diagonal=True):
         if (a, b) in g:
             self.assertTrue(g.is_edge(a, b))
             self.assertTrue(g.is_edge(b, a))
         else:
             self.assertFalse(g.is_edge(a, b))
             self.assertFalse(g.is_edge(b, a))
Esempio n. 13
0
    def test_adjacent(self):
        g = MatrixGraph(5).add(0, 1).add(1, 2).add(2, 3).add(3, 4)
        adj = g.adjacent(0)
        self.assertEqual(1, len(adj))
        self.assertIn(1, adj)

        adj = g.adjacent(1)
        self.assertEqual(2, len(adj))
        self.assertIn(0, adj)
        self.assertIn(2, adj)

        adj = g.adjacent(2)
        self.assertEqual(2, len(adj))
        self.assertIn(1, adj)
        self.assertIn(3, adj)

        adj = g.adjacent(3)
        self.assertEqual(2, len(adj))
        self.assertIn(2, adj)
        self.assertIn(4, adj)

        adj = g.adjacent(4)
        self.assertEqual(1, len(adj))
        self.assertIn(3, adj)
Esempio n. 14
0
 def test_connected1(self):
     g = MatrixGraph(4, [(0,1), (2,3)])
     self.assertFalse(g.connected())
Esempio n. 15
0
 def test_density_random(self):
     for i in range(10):
         g = MatrixGraph.create_random(order=10)
         expected = g.size() / (g.size() + g.complement().size())
         self.assertEqual(expected, g.density())
Esempio n. 16
0
 def test_add(self):
     g = MatrixGraph(4)
     self.assertFalse(g.is_edge(0, 1))
     g.add(0, 1)
     self.assertTrue(g.is_edge(0, 1))
Esempio n. 17
0
 def test_constructor3(self):
     g = MatrixGraph(edges=[[1,2,3], [2,3], [], []])
     self.assertEqual(4, g.order())
     self.assertEqual(5, g.size())
Esempio n. 18
0
    def test_distance1(self):
        g = MatrixGraph(order=5, edges=[(0, 1), (1, 2), (2, 3), (3, 4)])
        self.assertEqual(0, g.distance(0, 0))
        self.assertEqual(0, g.distance(1, 1))
        self.assertEqual(0, g.distance(2, 2))
        self.assertEqual(0, g.distance(3, 3))
        self.assertEqual(0, g.distance(4, 4))

        self.assertEqual(1, g.distance(0, 1))
        self.assertEqual(1, g.distance(1, 2))
        self.assertEqual(1, g.distance(2, 3))
        self.assertEqual(1, g.distance(3, 4))
        self.assertEqual(1, g.distance(1, 0))
        self.assertEqual(1, g.distance(2, 1))
        self.assertEqual(1, g.distance(3, 2))
        self.assertEqual(1, g.distance(4, 3))

        self.assertEqual(2, g.distance(0, 2))
        self.assertEqual(2, g.distance(1, 3))
        self.assertEqual(2, g.distance(2, 4))
        self.assertEqual(2, g.distance(4, 2))
        self.assertEqual(2, g.distance(3, 1))
        self.assertEqual(2, g.distance(2, 0))
Esempio n. 19
0
 def test_density3(self):
     g = MatrixGraph(4).add(0, 1).add(0, 2).add(0, 3).add(1, 2).add(1, 3).add(2, 3)
     self.assertEqual(1.0, g.density())
Esempio n. 20
0
 def test_density2(self):
     g = MatrixGraph(10)
     self.assertEqual(0, g.density())
Esempio n. 21
0
 def test_remove(self):
     g = MatrixGraph(3)
     g.add(0, 1)
     g.remove(0, 1)
     self.assertNotIn((0, 1), g)
     self.assertNotIn((1, 0), g)
Esempio n. 22
0
 def test_constructor1(self):
     g = MatrixGraph(4)
     self.assertEqual(4, g.order())
     self.assertEqual(0, g.size())
Esempio n. 23
0
def random(order, density=0.5, type='matrix'):
    if type == 'matrix':
        return MatrixGraph.create_random(order, density)
    else:
        raise RuntimeError("Unrecognized Graph type: {}".format(type))
Esempio n. 24
0
 def test_constructor2(self):
     g = MatrixGraph(order=4, edges=[(0, 1), (1, 2)])
     self.assertEqual(4, g.order())
     self.assertEqual(2, g.size())
     self.assertIn({0, 1}, g)
     self.assertIn({1, 2}, g)
Esempio n. 25
0
 def test_distance2(self):
     g = MatrixGraph(order=5).add(0, 1).add(3, 4)
     self.assertEqual(inf, g.distance(0,4))
Esempio n. 26
0
 def test_connected2(self):
     g = MatrixGraph(4, [(0,1), (1,2), (2,3), (3,0)])
     self.assertTrue(g.connected())
Esempio n. 27
0
 def test_connected3(self):
     g = MatrixGraph(5, [(0,1), (0,2), (0,3), (0,4)])
     self.assertTrue(g.connected())
Esempio n. 28
0
 def test_order(self):
     g = MatrixGraph(3)
     self.assertEqual(3, g.order())
     g = MatrixGraph(10)
     self.assertEqual(10, g.order())
Esempio n. 29
0
 def test_density1(self):
     g = MatrixGraph(10).add(0, 1).add(1, 2).add(2, 3).add(3, 4).add(4, 5)
     self.assertEqual(5/choose(10, 2), g.density())
Esempio n. 30
0
 def test_directed(self):
     self.assertFalse(MatrixGraph(10).directed())