2020-07-02 15:40:30 +02:00
|
|
|
subroutine read_options(method,x_rung,x_DFA,c_rung,c_DFA,SGn,nEns,wEns,aCC_w1,aCC_w2, &
|
2020-08-02 13:09:30 +02:00
|
|
|
maxSCF,thresh,DIIS,max_diis,guess_type,ortho_type,doNcentered,ncent,occnum,Cx_choice)
|
2019-03-13 11:07:31 +01:00
|
|
|
|
|
|
|
! Read DFT options
|
|
|
|
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
include 'parameters.h'
|
|
|
|
|
|
|
|
! Local variables
|
|
|
|
|
2020-08-01 11:45:17 +02:00
|
|
|
integer :: I,J
|
2019-03-13 11:07:31 +01:00
|
|
|
|
|
|
|
! Output variables
|
|
|
|
|
2020-06-23 15:59:19 +02:00
|
|
|
character(len=8),intent(out) :: method
|
2019-03-13 11:07:31 +01:00
|
|
|
integer,intent(out) :: x_rung,c_rung
|
2020-07-02 15:40:30 +02:00
|
|
|
character(len=12),intent(out) :: x_DFA, c_DFA
|
2019-03-13 11:07:31 +01:00
|
|
|
integer,intent(out) :: SGn
|
2020-08-02 13:09:30 +02:00
|
|
|
integer,intent(out) :: nEns, doNcentered
|
2019-03-13 11:07:31 +01:00
|
|
|
double precision,intent(out) :: wEns(maxEns)
|
2020-07-02 15:40:30 +02:00
|
|
|
double precision,intent(out) :: aCC_w1(3)
|
|
|
|
double precision,intent(out) :: aCC_w2(3)
|
2020-08-04 12:30:52 +02:00
|
|
|
double precision,intent(inout):: occnum(nspin,2,maxEns)
|
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
|
2020-08-01 11:45:17 +02:00
|
|
|
double precision,intent(in) :: ncent
|
2020-08-02 13:09:30 +02:00
|
|
|
integer,intent(out) :: Cx_choice
|
2019-03-13 11:07:31 +01:00
|
|
|
|
|
|
|
! 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
|
2020-03-16 23:28:56 +01:00
|
|
|
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(*,*)
|
|
|
|
|
2020-08-01 11:45:17 +02:00
|
|
|
! Read ensemble weights for unphysical (integer number of electrons) left or right N-centered ensembles:
|
|
|
|
! (alpha,0) or (0,alpha) in input
|
|
|
|
! read(1,*)
|
|
|
|
! read(1,*) (wEns(I),I=2,nEns)
|
|
|
|
! wEns(2) = (ncent/(ncent-1.d0))*wEns(2)
|
|
|
|
! wEns(3) = (ncent/(ncent+1.d0))*wEns(3)
|
|
|
|
! wEns(1) = 1d0 - ((ncent-1.d0)/ncent)*wEns(2) - ((ncent+1.d0)/ncent)*wEns(3) ! for N-centered
|
|
|
|
|
|
|
|
! Read ensemble weights for real physical (fractional number of electrons) ensemble (w1,w2)
|
2019-03-13 11:07:31 +01:00
|
|
|
read(1,*)
|
|
|
|
read(1,*) (wEns(I),I=2,nEns)
|
2020-08-02 13:09:30 +02:00
|
|
|
read(1,*)
|
|
|
|
read(1,*) doNcentered
|
|
|
|
if (doNcentered==0) then
|
|
|
|
wEns(1) = 1d0 - wEns(2) - wEns(3)
|
|
|
|
else
|
|
|
|
wEns(2) = (ncent/(ncent-1.d0))*wEns(2)
|
|
|
|
wEns(3) = (ncent/(ncent+1.d0))*wEns(3)
|
|
|
|
wEns(1) = 1d0 - ((ncent-1.d0)/ncent)*wEns(2) - ((ncent+1.d0)/ncent)*wEns(3) ! for N-centered
|
|
|
|
end if
|
2019-03-13 11:07:31 +01:00
|
|
|
write(*,*)'----------------------------------------------------------'
|
|
|
|
write(*,*)' Ensemble weights '
|
|
|
|
write(*,*)'----------------------------------------------------------'
|
|
|
|
call matout(nEns,1,wEns)
|
|
|
|
write(*,*)
|
2020-07-02 15:40:30 +02:00
|
|
|
|
|
|
|
! Read parameters for weight-dependent functional
|
|
|
|
read(1,*)
|
|
|
|
read(1,*) (aCC_w1(I),I=1,3)
|
|
|
|
read(1,*) (aCC_w2(I),I=1,3)
|
2020-08-02 13:09:30 +02:00
|
|
|
! Read choice of exchange coefficient
|
|
|
|
read(1,*)
|
|
|
|
read(1,*) Cx_choice
|
2020-07-02 15:40:30 +02:00
|
|
|
|
2020-07-02 22:15:29 +02:00
|
|
|
write(*,*)'----------------------------------------------------------'
|
|
|
|
write(*,*)' parameters for w1-dependant exchange functional coefficient '
|
|
|
|
write(*,*)'----------------------------------------------------------'
|
|
|
|
call matout(3,1,aCC_w1)
|
|
|
|
write(*,*)
|
|
|
|
|
|
|
|
write(*,*)'----------------------------------------------------------'
|
|
|
|
write(*,*)' parameters for w2-dependant exchange functional coefficient '
|
|
|
|
write(*,*)'----------------------------------------------------------'
|
|
|
|
call matout(3,1,aCC_w2)
|
2020-07-02 15:40:30 +02:00
|
|
|
write(*,*)
|
2020-08-01 11:45:17 +02:00
|
|
|
|
|
|
|
! Read occupation numbers for orbitals nO and nO+1
|
|
|
|
read(1,*)
|
2020-08-04 12:30:52 +02:00
|
|
|
do J=1,nEns
|
2020-08-01 11:45:17 +02:00
|
|
|
read(1,*) (occnum(1,I,J),I=1,2)
|
|
|
|
read(1,*) (occnum(2,I,J),I=1,2)
|
|
|
|
end do
|
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
|