|
import numpy as np |
|
import scipy.sparse as sp |
|
import torch |
|
|
|
def scipy_to_torch_sparse(scp_matrix): |
|
values = scp_matrix.data |
|
indices = np.vstack((scp_matrix.row, scp_matrix.col)) |
|
i = torch.LongTensor(indices) |
|
v = torch.FloatTensor(values) |
|
shape = scp_matrix.shape |
|
|
|
sparse_tensor = torch.sparse.FloatTensor(i, v, torch.Size(shape)) |
|
return sparse_tensor |
|
|
|
|
|
def mOrgan(N): |
|
sub = np.zeros([N, N]) |
|
for i in range(0, N): |
|
sub[i, i-1] = 1 |
|
sub[i, (i+1)%N] = 1 |
|
return sub |
|
|
|
|
|
def mOrganD(N): |
|
N2 = int(np.ceil(N/2)) |
|
sub = np.zeros([N2, N]) |
|
|
|
for i in range(0, N2): |
|
if (2*i+1) == N: |
|
sub[i, 2*i] = 1 |
|
else: |
|
sub[i, 2*i] = 1/2 |
|
sub[i, 2*i+1] = 1/2 |
|
|
|
return sub |
|
|
|
def mOrganU(N): |
|
N2 = int(np.ceil(N/2)) |
|
sub = np.zeros([N, N2]) |
|
|
|
for i in range(0, N): |
|
if i % 2 == 0: |
|
sub[i, i//2] = 1 |
|
else: |
|
sub[i, i//2] = 1/2 |
|
sub[i, (i//2 + 1) % N2] = 1/2 |
|
|
|
return sub |
|
|
|
def genMatrixesLungsHeart(): |
|
RLUNG = 44 |
|
LLUNG = 50 |
|
HEART = 26 |
|
|
|
Asub1 = mOrgan(RLUNG) |
|
Asub2 = mOrgan(LLUNG) |
|
Asub3 = mOrgan(HEART) |
|
|
|
ADsub1 = mOrgan(int(np.ceil(RLUNG / 2))) |
|
ADsub2 = mOrgan(int(np.ceil(LLUNG / 2))) |
|
ADsub3 = mOrgan(int(np.ceil(HEART / 2))) |
|
|
|
Dsub1 = mOrganD(RLUNG) |
|
Dsub2 = mOrganD(LLUNG) |
|
Dsub3 = mOrganD(HEART) |
|
|
|
Usub1 = mOrganU(RLUNG) |
|
Usub2 = mOrganU(LLUNG) |
|
Usub3 = mOrganU(HEART) |
|
|
|
p1 = RLUNG |
|
p2 = p1 + LLUNG |
|
p3 = p2 + HEART |
|
|
|
p1_ = int(np.ceil(RLUNG / 2)) |
|
p2_ = p1_ + int(np.ceil(LLUNG / 2)) |
|
p3_ = p2_ + int(np.ceil(HEART / 2)) |
|
|
|
A = np.zeros([p3, p3]) |
|
|
|
A[:p1, :p1] = Asub1 |
|
A[p1:p2, p1:p2] = Asub2 |
|
A[p2:p3, p2:p3] = Asub3 |
|
|
|
AD = np.zeros([p3_, p3_]) |
|
|
|
AD[:p1_, :p1_] = ADsub1 |
|
AD[p1_:p2_, p1_:p2_] = ADsub2 |
|
AD[p2_:p3_, p2_:p3_] = ADsub3 |
|
|
|
D = np.zeros([p3_, p3]) |
|
|
|
D[:p1_, :p1] = Dsub1 |
|
D[p1_:p2_, p1:p2] = Dsub2 |
|
D[p2_:p3_, p2:p3] = Dsub3 |
|
|
|
U = np.zeros([p3, p3_]) |
|
|
|
U[:p1, :p1_] = Usub1 |
|
U[p1:p2, p1_:p2_] = Usub2 |
|
U[p2:p3, p2_:p3_] = Usub3 |
|
|
|
return A, AD, D, U |