24小时热门版块排行榜    

查看: 3732  |  回复: 1

dongming198

金虫 (小有名气)

[求助] LU分解法求解线性方程组FORTRAN程序代码已有1人参与

如题,请详细注释一下,最好给个算例,谢谢!
另外,LU分解法对线性方程组的系数矩阵有要求吗?
我主要是想要一个通用的求解线性方程组程序,其它迭代方法也可以的。
可以用网盘
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

dbb627

荣誉版主 (著名写手)

【答案】应助回帖

★ ★ ★ ★ ★
dongming198: 金币+3, 有帮助, 这个我有的,不过验证的时候不正确。现在不需要这个啦,还是很感谢啦 2015-06-04 20:48:30
ben_ladeng: 金币+2, 谢谢指教 2015-06-05 01:00:03
http://blog.chinaunix.net/uid-479984-id-2114914.html
CODE:
Author:RainMan
!2009-12-20
!LU分解法解线性方程组AX=B
!该程序从文件输入,格式为
!矩阵的维数是 3
!A矩阵
!4 2 1
!8 7 4
!16 17 15
!B矩阵
!11 34 95
PROGRAM solve_equation
    REAL,DIMENSION(:,:),ALLOCATABLE::A
    REAL,DIMENSION(:),ALLOCATABLE::B
    CHARACTER*(80):: inputfile = 'dengjin.txt'
    INTEGER DIM
    CALL GET_DIM(inputfile,DIM)
    ALLOCATE(A(DIM,DIM),B(DIM))
    CALL INPUT_MATRIX(A,B,DIM,inputfile)
    CALL LU(A,DIM)
    CALL solve(A,B,B,DIM)
    PRINT*,B
END

SUBROUTINE GET_DIM(inputfile,n)
    CHARACTER*(*) inputfile
    CHARACTER*(80) str
    INTEGER n
    OPEN(10,FILE = inputfile)
    READ(10,*)str,n
    CLOSE(10)
END

SUBROUTINE INPUT_MATRIX(A,B,DIM,inputfile)
    CHARACTER*(*) inputfile
    INTEGER DIM
    INTEGER A(DIM,DIM),B(DIM)
   
    OPEN(20,FILE=inputfile)
    READ(20,*)
    READ(20,*)
    READ(20,*) ((A(I,J),J=1,DIM),I=1,DIM)
    READ(20,*)
    READ(20,*) (B(I),I=1,DIM)
    CLOSE(20)
END

SUBROUTINE LU(A,DIM)
    INTEGER DIM
    REAL A(DIM,DIM)
   
    DO I=2,DIM
        DO J=I,DIM
            A(J,I-1) = A(J,I-1)*1.0/A(I-1,I-1)
            m = A(J,I-1)
            DO K=I,DIM
                A(J,K) = A(J,K)-m*A(I-1,K)
            ENDDO
        ENDDO
    ENDDO
END

SUBROUTINE solve(A,B,X,DIM)
    INTEGER:: DIM
    REAL A(DIM,DIM),B(DIM),X(DIM)
!----------LY = B
    DO I=2,DIM
        DO J=1,I-1
            B(I) = B(I) - A(I,J)*B(J)
        ENDDO
    ENDDO

    B(DIM) = B(DIM)/A(DIM,DIM)
!---------UX=Y Y stores in B,same as X
    DO I=DIM-1,1,-1
        DO J=I+1,DIM
            B(I) = B(I) - A(I,J)*B(J)
        ENDDO
        B(I) = B(I)/A(I,I)
    ENDDO
END

The more you learn, the more you know, the more you know, and the more you forget. The more you forget, the less you know. So why bother to learn.
2楼2015-06-03 14:27:53
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 dongming198 的主题更新
信息提示
请填处理意见