73 lines
1.9 KiB
Go
73 lines
1.9 KiB
Go
// LU_Doolittle
|
||
/*
|
||
------------------------------------------------------
|
||
作者 : Black Ghost
|
||
日期 : 2018-11-21
|
||
版本 : 0.0.0
|
||
------------------------------------------------------
|
||
求矩阵Doolittlede LU分解
|
||
理论:
|
||
参考 李信真, 车刚明, 欧阳洁, 等. 计算方法. 西北工业大学
|
||
出版社, 2000, pp 53-56.
|
||
------------------------------------------------------
|
||
输入 :
|
||
A 矩阵
|
||
输出 :
|
||
L, U 下三角矩阵和上三角矩阵
|
||
err 解出标志:false-未解出或达到步数上限;
|
||
true-全部解出
|
||
------------------------------------------------------
|
||
*/
|
||
|
||
package goNum
|
||
|
||
// LU_Doolittle 求矩阵Doolittlede LU分解
|
||
func LU_Doolittle(A Matrix) (Matrix, Matrix, bool) {
|
||
/*
|
||
求矩阵Doolittlede LU分解
|
||
输入 :
|
||
A 矩阵
|
||
输出 :
|
||
L, U 下三角矩阵和上三角矩阵
|
||
err 解出标志:false-未解出或达到步数上限;
|
||
true-全部解出
|
||
*/
|
||
var err bool = false
|
||
|
||
if A.Rows != A.Columns {
|
||
panic("goNum.LU_Doolittle: A is not a square matrix")
|
||
}
|
||
|
||
L := ZeroMatrix(A.Rows, A.Columns)
|
||
U := ZeroMatrix(A.Rows, A.Columns)
|
||
|
||
for j := 0; j < A.Rows; j++ {
|
||
U.SetMatrix(0, j, A.GetFromMatrix(0, j))
|
||
}
|
||
for i := 1; i < A.Rows; i++ {
|
||
L.SetMatrix(i, 0, A.GetFromMatrix(i, 0)/U.GetFromMatrix(0, 0))
|
||
}
|
||
|
||
for k := 1; k < A.Rows; k++ {
|
||
|
||
for j := k; j < A.Rows; j++ {
|
||
var sum float64
|
||
for m := 0; m < k; m++ {
|
||
sum += L.GetFromMatrix(k, m) * U.GetFromMatrix(m, j)
|
||
}
|
||
U.SetMatrix(k, j, A.GetFromMatrix(k, j)-sum)
|
||
}
|
||
|
||
for i := k + 1; i < A.Rows; i++ {
|
||
var sum float64
|
||
for m := 0; m < k; m++ {
|
||
sum += L.GetFromMatrix(i, m) * U.GetFromMatrix(m, k)
|
||
}
|
||
L.SetMatrix(i, k, (A.GetFromMatrix(i, k)-sum)/U.GetFromMatrix(k, k))
|
||
}
|
||
}
|
||
|
||
err = true
|
||
return L, U, err
|
||
}
|