私が投稿しているコードは最小限の例ではないことをお許しください。コードをさらに削減しようとすると、見せたい状況が崩れます。私は初心者で、ここで何が起こっているのか理解できません。
Write-Statement "WTF" まで下にスクロールしてください。
効果番号 1: stdout に「ctemp」を与える Write ステートメントの出力は、「WTF」を与える以前の書き込みステートメントに依存します。コードを実行し、「WTF」の部分をコメントアウトして、再度実行します。どうすればいいの?
効果番号 2: stdout に書き込まれるはずの ctemp は、matmul-calculation で最後に定義されます。代わりに、この結果を 1 でいっぱいの行列 (現在はコメントアウトされている) で上書きすると、出力は以前の WTF-Write-Statement に依存しなくなります。
私は途方に暮れていて、これには論理が見えません。何が起こっている?ありがとう。
編集: 要求に応じて、取得する異なる出力を指定します。
WITH 書き込みステートメント:
WTF 0.40000000E+01 0.00000000E+00 0.20000000E+01 0.10000000E+01 0.10000000E+01 0.20000000E+01 0.20000000E+01 0.30000000E+01
書き込みステートメントなし:
0.22583338E+01 -0.17920885E+01 0.13104573E+01 -0.21149418E+01 0.28983440E+01 0.24774309E+01 0.37416662E+01 0.47920885E+01
コンパイラ:
インテル(R) Fortran インテル(R) 64 コンパイラー XE (インテル(R) 64 で動作するアプリケーション用)、バージョン 12.0.3.174 ビルド 20110309
program testlapack
implicit none
integer, parameter :: dp = selected_real_kind(15, 307)
integer :: n, ndim, k, j, i
complex(dp) :: cunit, czero, cone
complex(dp), allocatable :: H(:,:) !Input Hamiltonian
complex(dp), allocatable :: EigVec(:,:) !Eigenvector matrix
complex(dp), allocatable :: InvEigVec(:,:) !Inverted eigenvector matrix
complex(dp), allocatable :: EigVal(:) !Eigenvalue vector
complex(dp), allocatable :: ctemp(:,:) !Temporary array
complex(dp), allocatable :: ctemp2(:,:) !Temporary array
!Lapack arrays and variables
integer :: info, lwork
complex(dp), allocatable :: work(:)
real(dp), allocatable :: rwork(:)
integer,allocatable :: ipiv(:)
ndim=2
lwork=ndim*ndim
allocate(H(ndim,ndim))
allocate(EigVec(ndim,ndim))
allocate(EigVal(ndim))
allocate(InvEigVec(ndim,ndim))
allocate(ctemp2(ndim,ndim))
H = reshape((/ (4,0), (1,2), (2,1), (2,3) /), shape(H))
allocate(ctemp(ndim,ndim))
ctemp(:,:) = H(:,:)
allocate(work(lwork),rwork(2*ndim))
call zgeev('N', 'V', ndim, ctemp, ndim, EigVal, InvEigVec, ndim, EigVec, ndim, work, lwork, rwork, info)
if(info/=0)write(*,*) "Warning: zgeev info=", info
deallocate(work,rwork)
deallocate(ctemp)
InvEigVec(:,:)=EigVec(:,:)
lwork = 3*ndim
allocate(ipiv(ndim))
allocate(work(lwork))
call zgetrf(ndim,ndim,InvEigVec,ndim,ipiv,info)
if(info/=0)write(*,*) "Warning: zgetrf info=", info ! LU decomposition
call zgetri(ndim,InvEigVec,ndim,ipiv,work,lwork,info)
if(info/=0)write(*,*) "Warning: zgetri info=", info ! Inversion by LU decomposition (Building of InvEigVec)
deallocate(work)
deallocate(ipiv)
write(*,*) "WTF"
allocate(ctemp(ndim,ndim))
do i=1,ndim
ctemp(i,i) = EigVal(i)
end do
ctemp2 = matmul(ctemp, InvEigVec)
ctemp = matmul(EigVec,ctemp2)
! ctemp = reshape((/ (1,1), (1,1), (1,1), (1,1) /), shape(H))
do i=1, ndim
do j=1, ndim
write(*, '(2e17.8)', advance='NO') real(ctemp(i,j)), aimag(ctemp(i,j))
end do
Write(128,*)
end do
deallocate(H)
deallocate(EigVal)
deallocate(EigVec)
deallocate(InvEigVec)
deallocate(ctemp)
deallocate(ctemp2)
end program testlapack