import numpy as np

np.random.seed(42) 

def give_num(num=28):
    a = np.array([x for x in range(num)])
    np.random.shuffle(a)   
    return a

def Random_matrix(size=28):
    num_list = give_num(size)
    M = np.zeros((size, size))
    for i in range(len(M)):
        num = num_list[i]
        M[i][num] = 1
    return M

if __name__ == "__main__":
    M = Random_matrix(size=28)
    print(M)
    T_=np.linalg.inv(M)
    print(T_)
    np.savetxt('random_M.txt', M, fmt='%d')