24小时热门版块排行榜    

Znn3bq.jpeg
查看: 1209  |  回复: 0

chaoszero253

新虫 (初入文坛)

[求助] 关于Jacobi法矩阵对角化

想用fortran语言通过Jacobi方法对角化一个对称矩阵,但是求出来的结果和matlab内置的对角化程序员结果不一样。请问我的对角化程序是哪里出问题了。

subroutine SOLVE(A,N,tezheng,tol)
      !jacobi法对角化
      implicit real*8(a-z)
      integer::N
      real*8::A(N,N),tezheng(N)
      real*8::A1(N,N),R(N,N),RT(N,N),U(N,N),thi(N,N)
      integer::i,j,k,m,c,b,z,t
      integer::p,q,x,y
      real*8 sum
      do i=1,N
          do j=1,N
              A1(i,j)=A(i,j)
          end do
      end do
      k=0
      p=0
      m=1
      do while(m==1)
          m=0
          do i=1,N-1
              do j=i+1,N
                  R=0
                  do q=1,N
                      R(q,q)=1
                  end do
                  if(abs(A1(i,j))>tol) then
                      m=1
!         判断非对角矩阵元是否大于给出的阈值,如果是则建立旋转矩阵R来归零矩阵元
                      if(A1(i,i)==A1(j,j))then
                          R(i,i)=1/1.41421356
                          R(j,j)=1/1.41421356
                          R(i,j)=1/1.41421356
                          R(j,i)=-1/1.41421356
                      else
                          thi(i,j)=0.5*atan(2*A1(i,j)/(A1(i,i)-A1(j,j)))
                          R(i,i)=cos(thi(i,j))
                          R(j,j)=cos(thi(i,j))
                          R(i,j)=-sin(thi(i,j))
                          R(j,i)=sin(thi(i,j))
                      end if
                      do x=1,N
                          do y=1,N
                              RT(x,y)=R(y,x)
                          end do
                      end do
                      U=matmul(RT,A1)
                      A1=matmul(U,R)
                  end if
              end do
          end do
          print *,A1(9,9)
          p=p+1
          print *,p
          if (p==100) exit
      end do
      do i=1,N
          tezheng(i)=A1(i,i)
      end do
    end subroutine SOLVE
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 chaoszero253 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考博] 光量子物理方向 博士招生 1人(2026.09) +3 sandyworld 2026-05-15 3/150 2026-05-16 17:11 by zznnnj
[有机交流] 求有机合成大神指点三硫酸乙烯酯(CAS:2793408-99-6)的合成路线 30+3 Leekmid 2026-05-13 10/500 2026-05-16 16:37 by czyzsu
[公派出国] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +5 l7k6xnh0yc 2026-05-14 5/250 2026-05-16 16:35 by x28q7dxf75
[论文投稿] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +3 xx7gd5zq4e 2026-05-15 5/250 2026-05-16 12:24 by h3oerqvkv9
[硕博家园] 考博自荐 +3 科研狗111 2026-05-13 4/200 2026-05-16 11:45 by 科研狗111
[考博] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +4 l7k6xnh0yc 2026-05-14 4/200 2026-05-16 11:36 by h3oerqvkv9
[硕博家园] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +4 cjf4bx70cj 2026-05-14 6/300 2026-05-16 11:16 by h3oerqvkv9
[硕博家园] 申请博士 +3 呃?呃 2026-05-15 3/150 2026-05-16 11:01 by a4742549
[文学芳草园] 裁员滚滚,退居二线 +4 J_wei 2026-05-10 4/200 2026-05-16 10:52 by zh10246
[考博] 2026博士还有哪些学校有名额 +5 小王求读研 2026-05-15 6/300 2026-05-16 10:44 by a4742549
[硕博家园] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +4 l7k6xnh0yc 2026-05-14 5/250 2026-05-16 04:29 by k37jurhrau
[教师之家] 上海大学实验技术岗位非升即走 +5 嘻嘻哈哈乐呵呵 2026-05-15 5/250 2026-05-16 00:17 by caiyun
[文学芳草园] 窗边初夏的小雨 +8 阿美_Lml888 2026-05-09 11/550 2026-05-15 23:54 by WASM
[考博] 西南大学考核制博士 +4 lijunjie84 2026-05-11 7/350 2026-05-15 23:20 by 同仁堂教主
[基金申请] 精华III评审感受-评审感受-评审感受 +14 ferrarichen 2026-05-11 18/900 2026-05-15 11:12 by cmhchen
[考博] 26应届毕业生考博求助 +3 wo一定上岸 2026-05-13 3/150 2026-05-14 21:47 by 明海天涯
[有机交流] 求助2,4-二氯-5-嘧啶甲醛的合成方法 20+3 光吃不拉 2026-05-14 5/250 2026-05-14 20:15 by 一切都是空工
[基金申请] 请问大佬b0816评完了吗 +3 市民华南虎 2026-05-12 7/350 2026-05-14 07:41 by 市民华南虎
[论文投稿] 求助大佬sci投稿哪个好中 +3 江沅188 2026-05-12 4/200 2026-05-13 14:35 by 江沅188
[考博] 现在不知道怎么办,感觉很痛苦 +4 qweww 2026-05-11 5/250 2026-05-11 20:23 by Oversize
信息提示
请填处理意见