Fortran lapck求数组的逆矩阵

这两个Fortran子程序分别用于计算复数和双精度实数矩阵的逆,通过LAPACK95库实现LU分解。首先进行LU分解,如果失败则输出错误信息并停止程序,然后计算逆矩阵,同样会覆盖原输入矩阵。
摘要由CSDN通过智能技术生成
    subroutine inv_cmplx(A,inv_A,N)
    use lapack95
    implicit none

    integer:: N ! 矩阵的大小
    integer:: info, lda, lwork, i
    integer:: ipiv(N)
    complex*16:: A(N,N), inv_A(N,N), work(N*N)

    inv_A = A
    ! 分配内存
    lda = N
    lwork = N*N

    ! 计算矩阵的LU分解
    call zgetrf(N, N, inv_A, lda, ipiv, info)

    if (info /= 0) then
        write(*,*) "LU分解失败!"
        stop
    end if

    ! 计算逆矩阵
    call zgetri(N, inv_A, lda, ipiv, work, lwork, info)
    end subroutine inv_cmplx

    subroutine inv_double(A,inv_A,N)
    use lapack95
    implicit none

    integer:: N ! 矩阵的大小
    integer:: info, lda, lwork, i
    integer:: ipiv(N)
    real*8:: A(N,N), inv_A(N,N), work(N*N)

    inv_A = A
    ! 分配内存
    lda = N
    lwork = N*N

    ! 计算矩阵的LU分解
    call dgetrf(N, N, inv_A, lda, ipiv, info)

    if (info /= 0) then
        write(*,*) "LU分解失败!"
        stop
    end if

    ! 计算逆矩阵
    call dgetri(N, inv_A, lda, ipiv, work, lwork, info)
    end subroutine inv_double

第一个函数是求复数的,第二个是求双精度的,注意求解的时候会覆写输入的数组。和MATLAB的INV函数是一致的。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

空花缱绻三分

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值