10
0
mirror of https://github.com/LCPQ/quantum_package synced 2024-11-07 22:53:57 +01:00
quantum_package/src/Ezfio_files/output.irp.f

103 lines
2.8 KiB
Fortran
Raw Normal View History

2014-04-11 01:53:15 +02:00
BEGIN_PROVIDER [ double precision, output_wall_time_0 ]
&BEGIN_PROVIDER [ double precision, output_cpu_time_0 ]
2014-04-03 01:50:22 +02:00
implicit none
2014-04-11 01:53:15 +02:00
BEGIN_DOC
! Initial CPU and wall times when printing in the output files
2014-04-03 01:50:22 +02:00
END_DOC
2014-04-11 01:53:15 +02:00
call cpu_time(output_wall_time_0)
call wall_time(output_wall_time_0)
2014-04-03 01:50:22 +02:00
END_PROVIDER
2014-04-11 01:53:15 +02:00
BEGIN_SHELL [ /bin/bash ]
2015-06-08 14:49:10 +02:00
for NAME in $(\ls -d ${QP_ROOT}/src/*/)
2014-04-11 01:53:15 +02:00
do
NAME=$(basename ${NAME})
2014-04-11 01:53:15 +02:00
cat << EOF
BEGIN_PROVIDER [ integer, output_$NAME ]
implicit none
BEGIN_DOC
! Output file for $NAME
END_DOC
2015-04-20 15:41:19 +02:00
PROVIDE output_wall_time_0 output_cpu_time_0 ezfio_filename
2015-05-11 19:41:56 +02:00
! integer :: getUnitAndOpen
! call ezfio_set_output_empty(.False.)
IRP_IF COARRAY
if (this_image() == 1) then
2015-01-09 23:52:44 +01:00
output_$NAME = 6 !getUnitAndOpen(trim(ezfio_filename)//'/output/'//'$NAME.rst','a')
else
output_$NAME = getUnitAndOpen('/dev/null','w')
endif
IRP_ELSE
2015-01-09 23:52:44 +01:00
output_$NAME = 6 !getUnitAndOpen(trim(ezfio_filename)//'/output/'//'$NAME.rst','a')
IRP_ENDIF
2014-04-11 01:53:15 +02:00
write(output_$NAME,'(A)') &
'--------------------------------------------------------------------------------'
END_PROVIDER
EOF
done
END_SHELL
subroutine write_time(iunit)
implicit none
BEGIN_DOC
! Write a time stamp in the output for chronological reconstruction
END_DOC
integer, intent(in) :: iunit
double precision :: wt, ct
call cpu_time(ct)
call wall_time(wt)
write(iunit,*)
write(iunit,'(A,F15.6,A,F15.6,A)') &
'.. >>>>> [ WALL TIME: ', wt-output_wall_time_0, &
' s ] [ CPU TIME: ', ct-output_cpu_time_0, ' s ] <<<<< ..'
write(iunit,*)
end
subroutine write_double(iunit,value,label)
implicit none
BEGIN_DOC
! Write a double precision value in output
END_DOC
integer, intent(in) :: iunit
double precision :: value
character*(*) :: label
2014-06-25 14:58:58 +02:00
character*(64), parameter :: f = '(A50,G24.16)'
2014-04-11 01:53:15 +02:00
character*(50) :: newlabel
write(newlabel,'(A,A)') '* ',trim(label)
write(iunit,f) newlabel, value
end
2014-04-03 01:50:22 +02:00
2014-04-11 01:53:15 +02:00
subroutine write_int(iunit,value,label)
implicit none
BEGIN_DOC
! Write an integer value in output
END_DOC
integer, intent(in) :: iunit
integer :: value
character*(*) :: label
character*(64), parameter :: f = '(A50,I16)'
character*(50) :: newlabel
write(newlabel,'(A,A)') '* ',trim(label)
write(iunit,f) newlabel, value
end
2014-04-03 01:50:22 +02:00
2014-07-29 14:23:33 +02:00
subroutine write_bool(iunit,value,label)
implicit none
BEGIN_DOC
! Write an logical value in output
END_DOC
integer, intent(in) :: iunit
logical :: value
character*(*) :: label
character*(64), parameter :: f = '(A50,L1)'
character*(50) :: newlabel
write(newlabel,'(A,A)') '* ',trim(label)
write(iunit,f) newlabel, value
end