import numpy as np

e1 = [[1,2], [2, 3], [3, 4],[4,1],[5, 6], [6,7], [7, 8], [8, 5], [0, 1], [0, 2], [0, 3], [0, 4], [0, 5], [0, 6], [0, 7], [0, 8]]
e2 = [[1,2], [2, 3], [3, 4],[4,5],[5, 6], [6,7], [7, 8], [8, 0], [0, 1], [0, 2], [0, 3], [0, 4], [0, 5], [0, 6], [0, 7], [0, 8]]

e1 = np.array(e1).T
e2 = np.array(e2).T


mat1  = np.zeros((9, 9))
mat2  = np.zeros((9, 9))
mat1[e1[0], e1[1]] = 1
mat2[e1[0], e1[1]] = 1
mat1 = mat1 + mat1.T
mat2 = mat2 + mat2.T

D1 = mat1.sum(axis=1)
D2 = mat2.sum(axis=1)

mat1 = np.diag(1/np.sqrt(D1))@mat1@np.diag(1/np.sqrt(D1))
mat2 = np.diag(1/np.sqrt(D2))@mat2@np.diag(1/np.sqrt(D2))

print(np.linalg.eigvalsh(mat1)- np.linalg.eigvalsh(mat2))
tmat1 = mat1
tmat2 = mat2
for i in range(9):
    tmat1 = tmat1 @ mat1
    tmat2 = tmat2 @ mat2
    print(np.diag(tmat1)-np.diag(tmat2))


import numpy as np

e1 = [[0,1], [1,2], [2,0],[3,4],[4,5],[5,3], [6,0],[6,1],[6,2], [6,3], [6,4], [6,5]]
e2 = [[0,1], [1,2], [2,3],[3,4],[4,5],[5,0], [6,0],[6,1],[6,2], [6,3], [6,4], [6,5]]

e1 = np.array(e1).T
e2 = np.array(e2).T


mat1  = np.zeros((7, 7))
mat2  = np.zeros((7, 7))
mat1[e1[0], e1[1]] = 1
mat2[e1[0], e1[1]] = 1
mat1 = mat1 + mat1.T
mat2 = mat2 + mat2.T

D1 = mat1.sum(axis=1)
D2 = mat2.sum(axis=1)

mat1 = np.diag(1/np.sqrt(D1))@mat1@np.diag(1/np.sqrt(D1))
mat2 = np.diag(1/np.sqrt(D2))@mat2@np.diag(1/np.sqrt(D2))

print(np.linalg.eigvalsh(mat1), np.linalg.eigvalsh(mat2))
tmat1 = mat1
tmat2 = mat2
for i in range(8):
    tmat1 = tmat1 @ mat1
    tmat2 = tmat2 @ mat2
    print(np.diag(tmat1)-np.diag(tmat2))