Source code for hiperwalk.graph.complete
import numpy as np
from .graph import Graph
from types import MethodType
from scipy.sparse import eye
def adjacent(self, u, v):
return u != v
def _entry(self, row, col):
entry = row*(self._num_vert - 1) + col
if col < row:
entry += 1
return entry
def _find_entry(self, entry):
# row = (entry - 1) % (self._num_vert - 1)
# col = entry - row*(self._num_vert - 1)
# if row >= col:
# col -= 1
# return (row, col)
tail = entry // (self._num_vert - 1)
head = entry % (self._num_vert - 1)
if head >= tail:
head += 1
return (tail, head)
def _neighbor_index(self, vertex, neigh):
return neigh - 1 if neigh > vertex else neigh
def neighbors(self, vertex):
neigh = np.arange(self._num_vert)
return np.delete(neigh, vertex)
def number_of_vertices(self):
return self._num_vert
def number_of_edges(self):
return self._num_vert * (self._num_vert - 1) >> 1
def degree(self, vertex):
return self._num_vert - 1
def vertex_number(self, vertex):
vertex = int(vertex)
if vertex < 0 or vertex >= self._num_vert:
raise ValueError("Vertex label out of range. " +
"Expected integer value from 0 to" +
str(self._num_vert - 1))
return vertex
def adjacency_matrix(self):
adj_matrix = np.ones((self._num_vert, self._num_vert),
dtype=np.int8)
for i in range(self._num_vert):
adj_matrix[i, i] = 0
return adj_matrix
def laplacian_matrix(self):
lpl_matrix = - np.ones((self._num_vert, self._num_vert),
dtype=np.int32)
for i in range(self._num_vert):
lpl_matrix[i, i] = self._num_vert - 1
return lpl_matrix
[docs]
def Complete(num_vert, multiedges=None, weights=None):
r"""
Complete graph.
The graph on which any vertex is connected to
every other vertex.
Parameters
----------
num_vert : int
Number of vertices in the complete graph.
multiedges, weights: scipy.sparse.csr_array, default=None
See :ref:`graph_constructors`.
Returns
-------
:class:`hiperwalk.Graph`
See :ref:`graph_constructors` for details.
See Also
--------
:ref:`graph_constructors`.
"""
if weights is not None or multiedges is not None:
raise NotImplementedError()
if num_vert <= 0:
raise ValueError("Expected positive value of vertices."
+ " Received " + str(num_vert) + "instead.")
# toy graph
g = Graph(eye(num_vert).tocsr())
# changes attributes
del g._adj_matrix
g._adj_matrix = None
g._num_vert = num_vert
g._num_loops = 0
g.adjacent = MethodType(adjacent, g)
g._entry = MethodType(_entry, g)
g._find_entry = MethodType(_find_entry, g)
g._neighbor_index = MethodType(_neighbor_index, g)
g.neighbors = MethodType(neighbors, g)
g.number_of_vertices = MethodType(number_of_vertices, g)
g.number_of_edges = MethodType(number_of_edges, g)
g.degree = MethodType(degree, g)
g.vertex_number = MethodType(vertex_number, g)
g.adjacency_matrix = MethodType(adjacency_matrix, g)
g.laplacian_matrix = MethodType(laplacian_matrix, g)
return g