10
1
mirror of https://github.com/pfloos/quack synced 2024-12-26 14:23:38 +01:00
QuAcK/src/eDFT/read_options.f90

138 lines
2.9 KiB
Fortran
Raw Normal View History

subroutine read_options(method,x_rung,x_DFA,c_rung,c_DFA,SGn,nEns,wEns,aCC_w1,aCC_w2, &
maxSCF,thresh,DIIS,max_diis,guess_type,ortho_type)
2019-03-13 11:07:31 +01:00
! Read DFT options
implicit none
include 'parameters.h'
! Local variables
integer :: I
! Output variables
character(len=8),intent(out) :: method
2019-03-13 11:07:31 +01:00
integer,intent(out) :: x_rung,c_rung
character(len=12),intent(out) :: x_DFA, c_DFA
2019-03-13 11:07:31 +01:00
integer,intent(out) :: SGn
integer,intent(out) :: nEns
double precision,intent(out) :: wEns(maxEns)
double precision,intent(out) :: aCC_w1(3)
double precision,intent(out) :: aCC_w2(3)
2019-03-13 11:07:31 +01:00
integer,intent(out) :: maxSCF
double precision,intent(out) :: thresh
logical,intent(out) :: DIIS
integer,intent(out) :: max_diis
integer,intent(out) :: guess_type
integer,intent(out) :: ortho_type
! Local variables
character(len=1) :: answer
! Open file with method specification
2020-03-15 14:33:53 +01:00
open(unit=1,file='input/dft')
2019-03-13 11:07:31 +01:00
! Default values
2020-03-15 08:23:01 +01:00
method = 'GOK-RKS'
2019-03-13 11:07:31 +01:00
x_rung = 1
c_rung = 1
x_DFA = 'RS51'
c_DFA = 'RVWN5'
2019-03-13 11:07:31 +01:00
SGn = 0
wEns(:) = 0d0
2020-03-15 08:23:01 +01:00
! Restricted or unrestricted calculation
read(1,*)
read(1,*) method
2019-03-13 11:07:31 +01:00
! EXCHANGE: read rung of Jacob's ladder
2020-03-17 11:29:20 +01:00
read(1,*)
read(1,*)
read(1,*)
read(1,*)
read(1,*)
2019-03-13 11:07:31 +01:00
read(1,*)
read(1,*) x_rung,x_DFA
! CORRELATION: read rung of Jacob's ladder
2020-03-17 11:29:20 +01:00
read(1,*)
read(1,*)
read(1,*)
read(1,*)
read(1,*)
2019-03-13 11:07:31 +01:00
read(1,*)
read(1,*) c_rung,c_DFA
! Read SG-n grid
read(1,*)
read(1,*) SGn
! Read number of states in ensemble
read(1,*)
read(1,*) nEns
if(nEns.gt.maxEns) then
write(*,*) ' Number of states in ensemble too big!! '
stop
endif
write(*,*)'----------------------------------------------------------'
write(*,'(A33,I3)')' Number of states in ensemble = ',nEns
write(*,*)'----------------------------------------------------------'
write(*,*)
! Read ensemble weights
read(1,*)
read(1,*) (wEns(I),I=2,nEns)
wEns(1) = 1d0 - sum(wEns)
write(*,*)'----------------------------------------------------------'
write(*,*)' Ensemble weights '
write(*,*)'----------------------------------------------------------'
call matout(nEns,1,wEns)
write(*,*)
! Read parameters for weight-dependent functional
read(1,*)
read(1,*) (aCC_w1(I),I=1,3)
read(1,*) (aCC_w2(I),I=1,3)
write(*,*)'----------------------------------------------------------'
write(*,*)' Ensemble weights '
write(*,*)'----------------------------------------------------------'
call matout(nEns,1,wEns)
write(*,*)
2019-03-13 11:07:31 +01:00
! Read KS options
maxSCF = 64
thresh = 1d-6
DIIS = .false.
max_diis = 5
guess_type = 1
ortho_type = 1
read(1,*)
read(1,*) maxSCF,thresh,answer,max_diis,guess_type,ortho_type
if(answer == 'T') DIIS = .true.
if(.not.DIIS) max_diis = 1
! Close file with options
2020-03-15 14:33:53 +01:00
close(unit=1)
2019-03-13 11:07:31 +01:00
end subroutine read_options