1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
|
! Copyright (C) 2016 J. K. Dewhurst, S. Sharma and E. K. U. Gross.
! This file is distributed under the terms of the GNU General Public License.
! See the file COPYING for license details.
subroutine zfmtpack(tpack,nr,nri,zfmt1,zfmt2)
use modmain
implicit none
! arguments
logical, intent(in) :: tpack
integer, intent(in) :: nr,nri
complex(8), intent(in) :: zfmt1(*)
complex(8), intent(out) :: zfmt2(*)
! local variables
integer ir,i,j,k
i=1
j=1
if (tpack) then
do ir=1,nri
call zcopy(lmmaxi,zfmt1(i),1,zfmt2(j),1)
i=i+lmmaxo
j=j+lmmaxi
end do
else
do ir=1,nri
call zcopy(lmmaxi,zfmt1(i),1,zfmt2(j),1)
i=i+lmmaxi
k=j+lmmaxi
j=j+lmmaxo
zfmt2(k:j-1)=0.d0
end do
end if
k=lmmaxo*(nr-nri)
call zcopy(k,zfmt1(i),1,zfmt2(j),1)
return
end subroutine
|