LU分解を実装し、numpyのnp.linalg.solve
関数と比較する必要があります。Pythonを使用したLU分解3
コード内の関数は、(下記参照)何の問題もなく動作しますが、私はエラーを取得しておく行列を解決するためにそれを使用する場合:ライン上の
IndexError: list index out of range
:
L[i][j] = (A2[i][j] - s2)/U[j][j]
コード全体は
def matrixMul(A, B):
TB = zip(*B)
return [[sum(ea*eb for ea,eb in zip(a,b)) for b in TB] for a in A]
def pivotize(m):
#Creates the pivoting matrix for m.
n = len(m)
ID = [[float(i == j) for i in range(n)] for j in range(n)]
for j in range(n):
row = max(range(j, n), key=lambda i: abs(m[i][j]))
if j != row:
ID[j], ID[row] = ID[row], ID[j]
return ID
def lu(A):
#Decomposes a nxn matrix A by PA=LU and returns L, U and P.
n = len(A)
L = [[0.0] * n for i in range(n)]
U = [[0.0] * n for i in range(n)]
P = pivotize(A)
A2 = matrixMul(P, A)
for j in range(n):
L[j][j] = 1.0
for i in range(j+1):
s1 = sum(U[k][j] * L[i][k] for k in range(i))
U[i][j] = A2[i][j] - s1
for i in range(j, n):
s2 = sum(U[k][j] * L[i][k] for k in range(j))
L[i][j] = (A2[i][j] - s2)/U[j][j]
return (L)
A = np.array([[1,1,3],[5,3,1],[2,3,1]])
b = np.array([2,3,-1])
print('LU factorization: ', lu(A))
A = np.array([[1,1,3],[5,3,1],[2,3,1]])
b = np.array([2,3,-1])
print('Internal solver : ', np.linalg.solve(A,b))
です。ありがとう!
NumPyソリューションとどのように一致させることができますか? – xFugtree
私は正確にはわかりませんが、 'lu'メソッドの内部ループは私には疑わしいです。私は実装しているアルゴリズムに精通していません。私は最初の行列Aの連続する行を引くDoolittleアルゴリズムを使って作業しました。あなたの最も内側のループで起こっているU/L製品ではありません(私の疑惑が生じているところです)。 Doolittleアルゴリズムに関する情報については、Wikipediaのページをご覧ください:https://en.wikipedia.org/wiki/LU_decomposition#Doolittle_algorithm – bnaecker