矩阵三角分解法(LU分解)

        矩阵分解法是高斯消元法的变形,它的复杂度和高斯消元法一样都是O(n^3),但是矩阵分解法在处理线性方程组系(具有相同的系数矩阵,但是右端项不同的方程组)时,运算比较方便。

        下面是矩阵分解原理的原理:

   矩阵三角分解法(LU分解)_第1张图片

    矩阵三角分解法(LU分解)_第2张图片

   矩阵三角分解法(LU分解)_第3张图片

     下面是如何来求解L和U矩阵:

     矩阵三角分解法(LU分解)_第4张图片

    在求L和U矩阵的时候,要注意两点:

   1>先求U矩阵中的一行,然后在求L矩阵的一列。次序不能颠倒。

   2>不论求L和U矩阵,都要用到相应的A矩阵中的数值。

   下面是求LU矩阵的python实现。

data = [[2, 2, 3], [4, 7, 7], [-2, 4, 5]]


#在实施LU分解的时候,所有的操作都在data矩阵上进行。因为LU分解的过程决定,它是一行一行进行分解的,所以用完的行可以被
#LU矩阵中的值所代替。
i = 0
size = len(data)
while i < size:
    if i == 0:
        j = 1
        while j < size:
            data[j][0]=data[j][0]/data[0][0]
            j += 1
    else:
        #下面是对U矩阵进行操作,操作过程是,先求一行U矩阵,后求一列L矩阵
        j = i
        while j < size:
            sum_column = 0
            flag_sum = i - 1
            while flag_sum >= 0:
                if j == i:
                    sum_column += data[flag_sum][j]*data[j][flag_sum]
                else:
                    sum_column += data[flag_sum][j]*data[j-1][flag_sum]
                flag_sum -= 1
            data[i][j] = data[i][j]-sum_column
            j += 1

        #下面的是对L矩阵进行操作,操作过程是求一列L矩阵
        m = i+1
        while m = 0:
                sum_column_L += data[i][flag_sum_L]*data[m][flag_sum_L]
                flag_sum_L -= 1
            data[m][i] = (data[m][i]-sum_column_L)/data[i][i]
            m += 1
    i += 1


"输出LU矩阵"
L = []
U = []
l = 0
while l < size:
    r = 0
    temp=[]
    temp1=[]
    while r < size:
        if l > r:
            temp.append(data[l][r])
            temp1.append(0)
        else:
            if l == r:
                temp.append(1)
                temp1.append((data[l][r]))
            else:
                temp.append(0)
                temp1.append(data[l][r])
        r += 1
    L.append(temp)
    U.append(temp1)
    l += 1

print("L矩阵为:\n")
for x in L:
    print(x)
print("\n")

print("U矩阵为:\n")
for x in U:
    print(x)




你可能感兴趣的:(数值分析)