2023-07-17 13:35:24 +02:00
|
|
|
subroutine read_methods(doRHF,doUHF,doRMOM,doUMOM,doKS, &
|
2022-12-01 09:42:23 +01:00
|
|
|
doMP2,doMP3, &
|
2021-11-10 14:47:26 +01:00
|
|
|
doCCD,dopCCD,doDCD,doCCSD,doCCSDT, &
|
|
|
|
do_drCCD,do_rCCD,do_crCCD,do_lCCD, &
|
|
|
|
doCIS,doCIS_D,doCID,doCISD,doFCI, &
|
2023-07-12 23:16:37 +02:00
|
|
|
dophRPA,dophRPAx,docrRPA,doppRPA, &
|
2021-11-10 14:47:26 +01:00
|
|
|
doG0F2,doevGF2,doqsGF2, &
|
|
|
|
doG0F3,doevGF3, &
|
2022-11-29 12:11:09 +01:00
|
|
|
doG0W0,doevGW,doqsGW,doSRGqsGW, &
|
2021-11-10 14:47:26 +01:00
|
|
|
doufG0W0,doufGW, &
|
2023-07-03 23:15:07 +02:00
|
|
|
doG0T0pp,doevGTpp,doqsGTpp, &
|
|
|
|
doG0T0eh,doevGTeh,doqsGTeh)
|
2019-03-19 10:13:33 +01:00
|
|
|
|
|
|
|
! Read desired methods
|
|
|
|
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
! Input variables
|
|
|
|
|
2023-07-17 13:35:24 +02:00
|
|
|
logical,intent(out) :: doRHF,doUHF,doRMOM,doUMOM,doKS
|
2022-12-01 09:42:23 +01:00
|
|
|
logical,intent(out) :: doMP2,doMP3
|
2021-11-10 14:47:26 +01:00
|
|
|
logical,intent(out) :: doCCD,dopCCD,doDCD,doCCSD,doCCSDT
|
|
|
|
logical,intent(out) :: do_drCCD,do_rCCD,do_crCCD,do_lCCD
|
2021-03-08 17:00:05 +01:00
|
|
|
logical,intent(out) :: doCIS,doCIS_D,doCID,doCISD,doFCI
|
2023-07-12 23:16:37 +02:00
|
|
|
logical,intent(out) :: dophRPA,dophRPAx,docrRPA,doppRPA
|
2021-03-05 22:34:48 +01:00
|
|
|
logical,intent(out) :: doG0F2,doevGF2,doqsGF2,doG0F3,doevGF3
|
2022-11-29 12:11:09 +01:00
|
|
|
logical,intent(out) :: doG0W0,doevGW,doqsGW,doSRGqsGW,doufG0W0,doufGW
|
2023-07-03 23:15:07 +02:00
|
|
|
logical,intent(out) :: doG0T0pp,doevGTpp,doqsGTpp
|
|
|
|
logical,intent(out) :: doG0T0eh,doevGTeh,doqsGTeh
|
2019-03-19 10:13:33 +01:00
|
|
|
|
|
|
|
! Local variables
|
|
|
|
|
2022-11-29 12:11:09 +01:00
|
|
|
character(len=1) :: answer1,answer2,answer3,answer4,answer5,answer6
|
2019-03-19 10:13:33 +01:00
|
|
|
|
|
|
|
! Open file with method specification
|
|
|
|
|
|
|
|
open(unit=1,file='input/methods')
|
|
|
|
|
|
|
|
! Set all the booleans to false
|
|
|
|
|
2023-07-17 13:35:24 +02:00
|
|
|
doRHF = .false.
|
|
|
|
doUHF = .false.
|
|
|
|
doRMOM = .false.
|
|
|
|
doUMOM = .false.
|
|
|
|
doKS = .false.
|
2019-03-19 10:13:33 +01:00
|
|
|
|
|
|
|
doMP2 = .false.
|
|
|
|
doMP3 = .false.
|
|
|
|
|
|
|
|
doCCD = .false.
|
2021-11-10 14:47:26 +01:00
|
|
|
dopCCD = .false.
|
2020-12-04 13:26:08 +01:00
|
|
|
doDCD = .false.
|
2019-03-19 10:13:33 +01:00
|
|
|
doCCSD = .false.
|
|
|
|
doCCSDT = .false.
|
|
|
|
|
2020-03-21 22:50:43 +01:00
|
|
|
do_drCCD = .false.
|
|
|
|
do_rCCD = .false.
|
2021-11-10 14:47:26 +01:00
|
|
|
do_crCCD = .false.
|
2020-03-21 22:50:43 +01:00
|
|
|
do_lCCD = .false.
|
2020-01-14 14:44:01 +01:00
|
|
|
|
2019-10-05 23:32:17 +02:00
|
|
|
doCIS = .false.
|
2020-10-01 23:05:23 +02:00
|
|
|
doCIS_D = .false.
|
2020-04-20 12:28:19 +02:00
|
|
|
doCID = .false.
|
|
|
|
doCISD = .false.
|
2021-03-08 17:00:05 +01:00
|
|
|
doFCI = .false.
|
2020-04-20 12:28:19 +02:00
|
|
|
|
2023-07-12 23:16:37 +02:00
|
|
|
dophRPA = .false.
|
|
|
|
dophRPAx = .false.
|
|
|
|
docrRPA = .false.
|
|
|
|
doppRPA = .false.
|
2019-03-19 10:13:33 +01:00
|
|
|
|
2020-03-19 10:21:18 +01:00
|
|
|
doG0F2 = .false.
|
|
|
|
doevGF2 = .false.
|
2021-03-05 22:34:48 +01:00
|
|
|
doqsGF2 = .false.
|
2020-03-19 10:21:18 +01:00
|
|
|
doG0F3 = .false.
|
|
|
|
doevGF3 = .false.
|
2019-03-19 10:13:33 +01:00
|
|
|
|
2022-11-29 12:11:09 +01:00
|
|
|
doG0W0 = .false.
|
|
|
|
doevGW = .false.
|
|
|
|
doqsGW = .false.
|
|
|
|
doSRGqsGW = .false.
|
|
|
|
doufG0W0 = .false.
|
|
|
|
doufGW = .false.
|
2019-10-16 18:14:47 +02:00
|
|
|
|
2023-07-03 23:15:07 +02:00
|
|
|
doG0T0pp = .false.
|
|
|
|
doevGTpp = .false.
|
|
|
|
doqsGTpp = .false.
|
|
|
|
doG0T0eh = .false.
|
|
|
|
doevGTeh = .false.
|
|
|
|
doqsGTeh = .false.
|
2019-03-19 10:13:33 +01:00
|
|
|
|
|
|
|
! Read mean-field methods
|
|
|
|
|
|
|
|
read(1,*)
|
2023-07-17 13:35:24 +02:00
|
|
|
read(1,*) answer1,answer2,answer3,answer4,answer5
|
|
|
|
if(answer1 == 'T') doRHF = .true.
|
|
|
|
if(answer2 == 'T') doUHF = .true.
|
|
|
|
if(answer3 == 'T') doRMOM = .true.
|
|
|
|
if(answer4 == 'T') doUMOM = .true.
|
|
|
|
if(answer5 == 'T') doKS = .true.
|
2019-03-19 10:13:33 +01:00
|
|
|
|
|
|
|
! Read MPn methods
|
|
|
|
|
|
|
|
read(1,*)
|
2022-12-01 09:42:23 +01:00
|
|
|
read(1,*) answer1,answer2
|
2019-03-19 10:13:33 +01:00
|
|
|
if(answer1 == 'T') doMP2 = .true.
|
|
|
|
if(answer2 == 'T') doMP3 = .true.
|
|
|
|
|
|
|
|
! Read CC methods
|
|
|
|
|
|
|
|
read(1,*)
|
2021-11-10 14:47:26 +01:00
|
|
|
read(1,*) answer1,answer2,answer3,answer4,answer5
|
|
|
|
if(answer1 == 'T') doCCD = .true.
|
|
|
|
if(answer2 == 'T') dopCCD = .true.
|
|
|
|
if(answer3 == 'T') doDCD = .true.
|
|
|
|
if(answer4 == 'T') doCCSD = .true.
|
|
|
|
if(answer5 == 'T') doCCSDT = .true.
|
2020-03-24 14:55:22 +01:00
|
|
|
|
|
|
|
! Read weird CC methods
|
|
|
|
read(1,*)
|
|
|
|
read(1,*) answer1,answer2,answer3,answer4
|
2020-03-26 16:57:46 +01:00
|
|
|
if(answer1 == 'T') do_drCCD = .true.
|
|
|
|
if(answer2 == 'T') do_rCCD = .true.
|
2021-11-10 14:47:26 +01:00
|
|
|
if(answer3 == 'T') do_crCCD = .true.
|
|
|
|
if(answer4 == 'T') do_lCCD = .true.
|
2019-03-19 10:13:33 +01:00
|
|
|
|
|
|
|
! Read excited state methods
|
|
|
|
|
|
|
|
read(1,*)
|
2021-03-08 17:00:05 +01:00
|
|
|
read(1,*) answer1,answer2,answer3,answer4,answer5
|
2019-10-05 23:32:17 +02:00
|
|
|
if(answer1 == 'T') doCIS = .true.
|
2020-10-01 23:05:23 +02:00
|
|
|
if(answer2 == 'T') doCIS_D = .true.
|
|
|
|
if(answer3 == 'T') doCID = .true.
|
|
|
|
if(answer4 == 'T') doCISD = .true.
|
2021-03-08 17:00:05 +01:00
|
|
|
if(answer5 == 'T') doFCI = .true.
|
2020-10-01 23:05:23 +02:00
|
|
|
if(doCIS_D) doCIS = .true.
|
2020-04-20 12:28:19 +02:00
|
|
|
|
|
|
|
read(1,*)
|
2021-11-10 14:47:26 +01:00
|
|
|
read(1,*) answer1,answer2,answer3,answer4
|
2023-07-12 23:16:37 +02:00
|
|
|
if(answer1 == 'T') dophRPA = .true.
|
|
|
|
if(answer2 == 'T') dophRPAx = .true.
|
|
|
|
if(answer3 == 'T') docrRPA = .true.
|
|
|
|
if(answer4 == 'T') doppRPA = .true.
|
2019-03-19 10:13:33 +01:00
|
|
|
|
|
|
|
! Read Green function methods
|
|
|
|
|
|
|
|
read(1,*)
|
2021-03-05 22:34:48 +01:00
|
|
|
read(1,*) answer1,answer2,answer3,answer4,answer5
|
2020-03-19 10:21:18 +01:00
|
|
|
if(answer1 == 'T') doG0F2 = .true.
|
|
|
|
if(answer2 == 'T') doevGF2 = .true.
|
2021-03-05 22:34:48 +01:00
|
|
|
if(answer3 == 'T') doqsGF2 = .true.
|
|
|
|
if(answer4 == 'T') doG0F3 = .true.
|
|
|
|
if(answer5 == 'T') doevGF3 = .true.
|
2019-03-19 10:13:33 +01:00
|
|
|
|
|
|
|
! Read GW methods
|
|
|
|
|
|
|
|
read(1,*)
|
2022-11-29 12:11:09 +01:00
|
|
|
read(1,*) answer1,answer2,answer3,answer4,answer5,answer6
|
|
|
|
if(answer1 == 'T') doG0W0 = .true.
|
|
|
|
if(answer2 == 'T') doevGW = .true.
|
|
|
|
if(answer3 == 'T') doqsGW = .true.
|
|
|
|
if(answer4 == 'T') doSRGqsGW = .true.
|
|
|
|
if(answer5 == 'T') doufG0W0 = .true.
|
|
|
|
if(answer6 == 'T') doufGW = .true.
|
2019-03-19 10:13:33 +01:00
|
|
|
|
2019-10-16 18:14:47 +02:00
|
|
|
! Read GT methods
|
|
|
|
|
|
|
|
read(1,*)
|
2023-07-03 23:15:07 +02:00
|
|
|
read(1,*) answer1,answer2,answer3,answer4,answer5,answer6
|
|
|
|
if(answer1 == 'T') doG0T0pp = .true.
|
|
|
|
if(answer2 == 'T') doevGTpp = .true.
|
|
|
|
if(answer3 == 'T') doqsGTpp = .true.
|
|
|
|
if(answer4 == 'T') doG0T0eh = .true.
|
|
|
|
if(answer5 == 'T') doevGTeh = .true.
|
|
|
|
if(answer6 == 'T') doqsGTeh = .true.
|
2019-10-16 18:14:47 +02:00
|
|
|
|
2019-03-19 10:13:33 +01:00
|
|
|
! Close file with geometry specification
|
|
|
|
|
|
|
|
close(unit=1)
|
|
|
|
|
2023-07-18 14:59:18 +02:00
|
|
|
end subroutine
|