1
0
mirror of https://github.com/TREX-CoE/fparser.git synced 2025-01-06 19:33:15 +01:00

determinant file read successfully

This commit is contained in:
Ravindra Shinde 2021-03-03 15:53:47 +01:00
parent ff575f7a93
commit 61f7711ffd
4 changed files with 50 additions and 54 deletions

View File

@ -35,6 +35,7 @@ PROGRAM iochamp
real(dp) :: float_value real(dp) :: float_value
character(len=20) :: real_format = '(A, T20, F14.8)' character(len=20) :: real_format = '(A, T20, F14.8)'
character(len=20) :: int_format = '(A, T20, I8)' character(len=20) :: int_format = '(A, T20, I8)'
character(len=80) :: string_format = '(A, T40, A)'
! for determinants sections ! for determinants sections
integer :: nelectrons, nexcitation, iostat integer :: nelectrons, nexcitation, iostat
@ -52,26 +53,29 @@ PROGRAM iochamp
! Get the directory where the pooled data is kept ! Get the directory where the pooled data is kept
path_pool = fdf_string('pool', './') path_pool = fdf_string('pool', './')
write(6,'(A)') 'pool directory location :: ', path_pool write(6,fmt=string_format) 'pool directory location :: ', path_pool
! Get all the filenames from which the data is to be read ! Get all the filenames from which the data is to be read
file_molecule = fdf_load_filename('molecule', 'default.xyz')
write(6,fmt=string_format) 'filename molecule :: ', trim(file_molecule)
file_pseudo = fdf_load_filename('pseudopot', 'default.psp') file_pseudo = fdf_load_filename('pseudopot', 'default.psp')
write(6,'(A)') 'filename pseuodpotential :: ', file_pseudo write(6,fmt=string_format) 'filename pseuodpotential :: ', trim(file_pseudo)
file_basis = fdf_load_filename('basis', 'default.bas') file_basis = fdf_load_filename('basis', 'default.bas')
write(6,'(A)') 'filename basis :: ', file_basis write(6,fmt=string_format) 'filename basis :: ', trim(file_basis)
file_determinants = fdf_load_filename('determinants', 'default.det') file_determinants = fdf_load_filename('determinants', 'default.det')
write(6,'(A)') 'filename determinants :: ', file_determinants write(6,fmt=string_format) 'filename determinants :: ', trim(file_determinants)
file_orbitals = fdf_load_filename('orbitals', 'default.orb') file_orbitals = fdf_load_filename('orbitals', 'default.orb')
write(6,'(A)') 'filename orbitals :: ', file_orbitals write(6,fmt=string_format) 'filename orbitals :: ', trim(file_orbitals)
file_jastrow = fdf_load_filename('jastrow', 'default.jas') file_jastrow = fdf_load_filename('jastrow', 'default.jas')
write(6,'(A)') 'filename jastrow :: ', file_jastrow write(6,fmt=string_format) 'filename jastrow :: ',trim(file_jastrow)
file_jastrow_deriv = fdf_load_filename('jastrow_deriv', 'default.jasder') file_jastrow_deriv = fdf_load_filename('jastrow_deriv', 'default.jasder')
write(6,'(A)') 'filename jastrow derivatives :: ', file_jastrow_deriv write(6,fmt=string_format) 'filename jastrow derivatives :: ', trim(file_jastrow_deriv)
! &optwf ioptwf 1 ioptci 1 ioptjas 1 ioptorb 1 ! &optwf ioptwf 1 ioptci 1 ioptjas 1 ioptorb 1
@ -403,59 +407,50 @@ PROGRAM iochamp
write(6,*) '------------------------------------------------------' write(6,*) '------------------------------------------------------'
if (fdf_block('determinants', bfdf)) then if (.not. fdf_block('determinants', bfdf)) then
! External file reading ! External file reading
write(6,*) 'Beginning of external file determinant block ' write(6,*) 'Reading the determinants block from an external file '
ia = 1 ia = 1
! call io_status() ! call io_status()
! call fdf_printfdf() ! print*, "printing label ", bfdf%label , trim(bfdf%mark%pline%line)
print*, "printing label ", bfdf%label , trim(bfdf%mark%pline%line)
! print*, "pline obtained", (fdf_bline(bfdf, pline))
print*, "pline obtained", (fdf_bline(bfdf, pline)) open (unit=11,file=file_determinants, iostat=iostat, action='read' )
open (unit=11,file='TZ_1M_500.det', iostat=iostat, action='read' )
read(11,*) temp1, temp2, nelectrons, temp3, nalpha read(11,*) temp1, temp2, nelectrons, temp3, nalpha
write(*,'(a,1x,i3,1x,i3)') "write after read1", nelectrons, nalpha
read(11,*) temp1, ndeterminants, nexcitation read(11,*) temp1, ndeterminants, nexcitation
allocate(det_coeff(ndeterminants)) if (.not. allocated(det_coeff)) allocate(det_coeff(ndeterminants))
write(*,'(a,1x,i3, 1x, i3)') "write after read2", ndeterminants, nexcitation
read(11,*) (det_coeff(i), i=1,ndeterminants) read(11,*) (det_coeff(i), i=1,ndeterminants)
write(fmt,*) '(', ndeterminants, '(f11.8,1x))' write(fmt,*) '(', ndeterminants, '(f11.8,1x))'
write(*,fmt) (det_coeff(i), i=1,ndeterminants) write(*,fmt) (det_coeff(i), i=1,ndeterminants)
! write(*,'(<ndeterminants>(f11.8, 1x))') (det_coeff(i), i=1,ndeterminants) ! for Intel Fortran ! write(*,'(<ndeterminants>(f11.8, 1x))') (det_coeff(i), i=1,ndeterminants) ! for Intel Fortran
close(11)
if(fdf_bsearch(pline, "&electrons")) then
nelectrons = integers(pline, 1)
nalpha = integers(pline, 2)
nbeta = nelectrons - nalpha nbeta = nelectrons - nalpha
! allocate the orbital mapping array
if (.not. allocated(iworbd)) allocate(iworbd(nelectrons, ndeterminants))
write(*,*) "total number of electrons ", nelectrons write(*,*) "total number of electrons ", nelectrons
write(*,*) " number of alpha electrons ", nalpha write(*,*) " number of alpha electrons ", nalpha
write(*,*) " number of beta electrons ", nalpha write(*,*) " number of beta electrons ", nbeta
if (.not. allocated(det_alpha)) allocate(det_alpha(nalpha))
if (.not. allocated(det_beta)) allocate(det_beta(nbeta))
endif
if(fdf_bsearch(pline, "determinants")) then do i = 1, ndeterminants
ndeterminants = fdf_bintegers(pline, 1) read(11,*) (iworbd(j,i), j=1,nelectrons)
nexcitation = fdf_bintegers(pline, 2) enddo
write(*,*) "total number of determinants ", ndeterminants
write(*,*) " number of excitations ", nexcitation write(fmt,*) '(i4,1x)'
if (.not. allocated(det_coeff)) allocate(det_coeff(ndeterminants)) do i = 1, ndeterminants
endif write(*,'(<nelectrons>(i4, 1x))') (iworbd(j,i), j=1,nelectrons)
enddo
read(11,*) temp1
if (temp1 == "end" ) write(*,*) "Determinant File read successfully "
na = nintegers(pline)
write(*,'(2(a,i0),a)') 'number of integers: ', na, ' integers'
write(*,'(tr5,a,<nalpha>(tr1,i0))') 'list: ', det_alpha(1:nalpha)
close(11)
! endif
! enddo
endif endif
write(6,'(A)') write(6,'(A)')

View File

@ -86,6 +86,7 @@ MODULE keywords
public :: nctype, ntypes_atom ! number of atom/center types public :: nctype, ntypes_atom ! number of atom/center types
public :: ncent, natoms, ncenters, ncentres ! number of atoms/centers public :: ncent, natoms, ncenters, ncentres ! number of atoms/centers
public :: iwctype ! specify atom-type for each atom public :: iwctype ! specify atom-type for each atom
public :: znuc, znuclear, atomic_number ! nuclear charge public :: znuc, znuclear, atomic_number ! nuclear charge
public :: cent !atom_coords ! atom positions public :: cent !atom_coords ! atom positions
public :: ndet, ndeterminants ! number of determinants in wavefunction public :: ndet, ndeterminants ! number of determinants in wavefunction
@ -152,6 +153,7 @@ MODULE keywords
character(len=132) :: file_input, file_output character(len=132) :: file_input, file_output
character(len=132) :: file_basis character(len=132) :: file_basis
character(len=132) :: file_pseudo character(len=132) :: file_pseudo
character(len=132) :: file_molecule
character(len=132) :: file_orbitals character(len=132) :: file_orbitals
character(len=132) :: file_determinants character(len=132) :: file_determinants
character(len=132) :: file_jastrow character(len=132) :: file_jastrow
@ -250,6 +252,7 @@ MODULE keywords
integer, pointer :: natoms => ncent, ncenters => ncent, ncentres => ncent integer, pointer :: natoms => ncent, ncenters => ncent, ncentres => ncent
integer :: iwctype integer :: iwctype
integer, allocatable :: iworbd(:,:) ! to store orbital mapping in determinants
integer, target :: znuc integer, target :: znuc
integer, pointer :: znuclear => znuc, atomic_number => znuc integer, pointer :: znuclear => znuc, atomic_number => znuc
@ -268,7 +271,6 @@ MODULE keywords
real(dp), allocatable :: cdet(:) real(dp), allocatable :: cdet(:)
! integer, pointer :: det_coeffs => cdet ! issues in performance ! integer, pointer :: det_coeffs => cdet ! issues in performance
integer :: iworbd
integer, target :: ianalyt_lap integer, target :: ianalyt_lap
integer, pointer :: analytic_laplacian => ianalyt_lap integer, pointer :: analytic_laplacian => ianalyt_lap

View File

@ -7,10 +7,10 @@ basis BFD-T-normf0
%include global.fdf %include global.fdf
%block molecule < caffeine.xyz %block molecule < caffeine.xyz
%block determinants < sample.det
load molecule caffeine.xyz
load determinants TZ_1M_500.det load basis BFD-T-normf0.bas
load determinants "TZ_1M_500.det"
optimize_wavefunction 1 optimize_wavefunction 1

View File

@ -1,7 +1,8 @@
title A Sample QMC input file parsed by libfdf interfaced to CHAMP title A Sample QMC input file parsed by libfdf interfaced to CHAMP
pool ./pool pool ./pool
molecule caffeine.xyz
pseudopot default.psp # default value pseudopot default.psp # default value
basis default.bas # default value basis BFD-T-normf0.bas
determinants TZ_1M_500.det determinants TZ_1M_500.det
orbitals default.orb # default value orbitals default.orb # default value
jastrow default.jas # default value jastrow default.jas # default value
@ -57,5 +58,3 @@ etrial -408.1744362 eV
H 3.2249 1.5791 0.8255 H 3.2249 1.5791 0.8255
H 2.6431 2.5130 -0.5793 H 2.6431 2.5130 -0.5793
%endblock molecule %endblock molecule
%block determinants
&electrons nelec 22 nup 11