【问题标题】:LU decomposition using python 3LU分解使用python 3
【发布时间】:2017-06-06 16:21:48
【问题描述】:

我需要实现 LU 分解,然后将其与 numpy 中的 np.linalg.solve 函数进行比较。

代码中的函数(见下文)运行没有任何问题,但是当我使用它来求解矩阵时,我不断收到错误:

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))

有什么想法吗?谢谢!

【问题讨论】:

    标签: python python-3.x numpy matrix-factorization


    【解决方案1】:

    您的matrixMul 方法不正确。试试这个:

    matrixMul([[1, 0], [0, 1]], [[1, 0], [0, 1]])
    

    这是两个单位矩阵相乘,应该返回[[1, 0], [0, 1]]。当我运行它时,它返回[[1, 0], []]。这意味着A2,在你的lu 里面只有一行,其余的都是空的。因此i == 1j == 0时的索引错误。

    这个失败的原因是TB是一个zip对象。这些只能迭代一次,消耗迭代器。我实际上认为您根本不需要 TB 对象,只需遍历 B 的元素即可。

    def matrixMul(A, B):
        return [[sum(ea*eb for ea,eb in zip(a,b)) for b in B] for a in A]
    

    这将返回所需的输出:

    >>> matrixMul([[1, 0], [0, 1]], [[1, 0], [0, 1]])
    >>> [[1, 0], [0, 1]]
    

    编辑:

    顺便说一句,您的解决方案还有其他问题。你的和 NumPy 的版本仍然不匹配。但是这里的解决方案将修复您的索引错误。

    【讨论】:

    • 知道如何匹配 NumPy 解决方案吗?
    • 我不太清楚,但是您在 lu 方法中的内部循环对我来说看起来很可疑。我不熟悉您正在实施的算法。我只使用过 Doolittle 算法,它减去原始矩阵 A 的连续行,而不是你在最内层循环中进行的 U/L 乘积(这是我怀疑的地方)。查看 Wikipedia 页面以获取有关 Doolittle 算法的信息:en.wikipedia.org/wiki/LU_decomposition#Doolittle_algorithm
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多