1
0
mirror of https://github.com/TREX-CoE/fparser.git synced 2025-01-05 11:00:40 +01:00

coordinates block read properly

This commit is contained in:
Ravindra Shinde 2021-02-10 00:29:00 +01:00
parent bcb87047b8
commit 8e4a092b2e
2 changed files with 123 additions and 86 deletions

View File

@ -1,6 +1,3 @@
!============================================================
!= Sample program using the f90 FDF module : September 2007 =
!============================================================
! !
! Shows FDF capabilities.. ! Shows FDF capabilities..
! !
@ -10,8 +7,8 @@ PROGRAM iochamp
implicit none implicit none
!--------------------------------------------------------------- Local Variables !--------------------------------------------------------------- Local Variables
integer, parameter :: maxa = 100 integer, parameter :: maxa = 100
logical :: doit, debug, check logical :: doit, debug, check, val
character(len=72) :: fname, axis, status, filename, title, molecule_name character(len=72) :: fname, axis, status, filename, title, molecule_name, key
character(2) :: symbol(maxa) character(2) :: symbol(maxa)
integer(sp) :: i, j, ia, na, external_entry integer(sp) :: i, j, ia, na, external_entry
integer(sp) :: isa(maxa) integer(sp) :: isa(maxa)
@ -21,11 +18,12 @@ PROGRAM iochamp
real(dp) :: listr(maxa) real(dp) :: listr(maxa)
type(block_fdf) :: bfdf type(block_fdf) :: bfdf
type(parsed_line), pointer :: pline type(parsed_line), pointer :: pline
!type(fdf_file) :: fdffile
integer :: nextorb, nblk_max, nopt_iter, max_iteration, max_iter integer :: nextorb, nblk_max, nopt_iter, max_iteration, max_iter
real(dp) :: energy_tol real(dp) :: energy_tol
real(dp) :: sr_tau, sr_eps, sr_adiag real(dp) :: sr_tau, sr_eps, sr_adiag
character(len=15) :: real_format = '(A, T20, F8.5)' character(len=15) :: real_format = '(A, T20, F8.5)'
character(len=15) :: int_format = '(A, T20, I6)' character(len=15) :: int_format = '(A, T20, I8)'
!------------------------------------------------------------------------- BEGIN !------------------------------------------------------------------------- BEGIN
@ -72,44 +70,45 @@ PROGRAM iochamp
write(6,'(A, L2)') 'Debug:', debug write(6,'(A, L2)') 'Debug:', debug
! mixed types in one line (for example, reading a number with units) ! mixed types in one line (for example, reading a number with units)
cutoff = fdf_physical('Energy_Cutoff', 8.d0, 'Ry') cutoff = fdf_physical('Energy_Cutoff', 8.d0, 'Ry')
write(6,fmt=real_format) 'Energy CutOff:', cutoff, " eV" write(6,fmt=real_format) 'Energy CutOff:', cutoff, " eV"
phonon_energy = fdf_physical('phonon-energy', 0.01d0, 'eV') phonon_energy = fdf_physical('phonon-energy', 0.01d0, 'eV')
write(6,*) 'Phonon Energy:', phonon_energy write(6,fmt=real_format) 'Phonon Energy:', phonon_energy
! ! to check if a certain flag is defined or not ! block containing other key-value pairs (currently not working)
! check = fdf_defined('optimization_flags')
! write(6,*) 'optimization flags block defined', check
! if (fdf_block('optimization_flags', bfdf)) then ! if (fdf_block('optimization_flags', bfdf)) then
! ! Forward reading ! ia = 1
! do while(fdf_bline(bfdf, pline)) ! do while((fdf_bline(bfdf, pline)) .and. (ia .le. na))
! doit = fdf_bboolean(pline, 1) ! ! doit = fdf_bboolean(pline, 1)
! write(*,*) "inside opt block", doit ! doit = fdf_boolean("optimize_wavefunction", .true.)
! enddo ! write(6,*) 'optimize_wavefunction', doit
! doit = fdf_boolean('optimize_ci', .true.)
! write(6,*) 'optimize_ci', doit
! doit = fdf_boolean('optimize_jastrow', .true.)
! write(6,*) 'optimize_jastrow:', doit
! doit = fdf_boolean('optimize_orbitals', .true.)
! write(6,*) 'optimize_orbitals:', doit
! enddo
! endif ! endif
doit = fdf_boolean("opt.optimize_wavefunction", .true.)
write(6,*) 'optimize_wavefunction', doit
! if (fdf_block('optimization_flags', bfdf)) then doit = fdf_boolean('opt.optimize_ci', .true.)
! doit = fdf_bboolean(pline, 1) write(6,*) 'optimize_ci', doit
! write(6,*) 'optimize_wavefunction', doit
! doit = fdf_boolean('optimize_ci', .true.) doit = fdf_boolean('opt.optimize_jastrow', .true.)
! write(6,*) 'optimize_ci', doit write(6,*) 'optimize_jastrow:', doit
! doit = fdf_boolean('optimize_jastrow', .true.)
! write(6,*) 'optimize_jastrow:', doit
! doit = fdf_boolean('optimize_orbitals', .true.)
! write(6,*) 'optimize_orbitals:', doit
! endif
doit = fdf_boolean('opt.optimize_orbitals', .true.)
write(6,*) 'optimize_orbitals:', doit
@ -118,36 +117,51 @@ PROGRAM iochamp
write(6,*) 'Examples: maximum_iter =', max_iter write(6,*) 'Examples: maximum_iter =', max_iter
if (fdf_defined('molecule')) then
write(6,*) "molecule block has been defined :: molecule's geometry in angstrom units"
molecule_name = fdf_string('molecule', 'h2o.xyz')
write(6,*) 'Name of xyz file:', molecule_name
check = fdf_defined('molecule')
write(6,*) 'molecule block has been defined', check
if (fdf_block('Other-Block', bfdf)) then
write(6,*) "inside molecule block"
fname = fdf_string('molecule.xyz', 'h2o.xyz')
write(6,*) 'Name of xyz file:', fname
write(6,*) 'Coordinates:'
na = fdf_bintegers(pline, 1)
write(6,*) 'Number of atoms =', na
molecule_name = fdf_bnames(pline, 1)
write(6,*) 'Name of the molecule =', molecule_name
ia = 1 ia = 1
do while((fdf_bline(bfdf, pline)) .and. (ia .le. na)) do while(fdf_bline(bfdf, pline))
symbol(ia) = fdf_bnames(pline, 1) symbol(ia) = fdf_bnames(pline, 1)
do i= 1, 3 do i= 1, 3
xa(i,ia) = fdf_breals(pline, i) xa(i,ia) = fdf_breals(pline, i)
enddo
ia = ia + 1
enddo enddo
ia = ia + 1
enddo
na = ia - 1
endif
write(6,*) 'Coordinates from an external file:'
do ia = 1, na
write(6,'(A, 4x, 3F10.6)') symbol(ia), (xa(i,ia),i=1,3)
enddo
! Molecule coordinate block begins here
if (fdf_block('Coordinates', bfdf)) then
ia = 1
do while(fdf_bline(bfdf, pline))
symbol(ia) = fdf_bnames(pline, 1)
do i= 1, 3
xa(i,ia) = fdf_breals(pline, i)
enddo
ia = ia + 1
enddo
na = ia - 1
endif endif
write(6,*) 'Coordinates:' write(6,*) 'Coordinates:'
do ia= 1, na do ia = 1, na
write(6,'(3F10.6,I5)') (xa(i,ia),i=1,3), symbol(ia) write(6,'(A, 4x, 3F10.6)') symbol(ia), (xa(i,ia),i=1,3)
enddo enddo
! Molecule coordinate block ends here
if (fdf_block('Other-Block', bfdf)) then if (fdf_block('Other-Block', bfdf)) then

View File

@ -1,39 +1,5 @@
title "A Sample QMC input file parsed by libfdf interfaced to CHAMP" title "A Sample QMC input file parsed by libfdf interfaced to CHAMP"
%block general
pool_directory pool
pseudopotential BFD
basis BFD-T-normf0
%endblock
%block sample
max_iteration 3
Energy_Cutoff 500.0 eV
float_value 3.14e10
filename 'sample read input.txt'
phonon-energy 344 cm**-1
%endblock
molecule caffeine.xyz
%include pool/BFD-T.bfinfo
# Comments start with a '#' Can be included anywhere
#%include TZ_1M_500.det
#%include jastrow_good_b3lyp.0
%block optimization_flags
optimize_wavefunction true
optimize_ci T
optimize_jastrow yes
optimize_orbitals 0
%endblock
nextorb 280 nextorb 280
nblk_max 200 nblk_max 200
nopt_iter 2 nopt_iter 2
@ -44,4 +10,61 @@ sr_adiag 0.05
energy_tol 0.0 energy_tol 0.0
opt.optimize_wavefunction no
opt.optimize_ci No
opt.optimize_jastrow yes
opt.optimize_orbitals False
# The sub blocks currently does not parse.
%block general
pool_directory pool
pseudopotential BFD
basis BFD-T-normf0
%endblock
%block mixed
max_iteration 3
Energy_Cutoff 500.0 eV
float_value 3.14e10
filename 'sample read input.txt'
phonon-energy 344 cm**-1
%endblock
# Read molecule's geometry directly from the xyz file
# molecule caffeine.xyz
# An alternative way to provide coordinates
%block Coordinates
C 0.00000 1.40272 0.00000
H 0.00000 2.49029 0.00000
C -1.21479 0.70136 0.00000
H -2.15666 1.24515 0.00000
C -1.21479 -0.70136 0.00000
H -2.15666 -1.24515 0.00000
C 0.00000 -1.40272 0.00000
H 0.00000 -2.49029 0.00000
C 1.21479 -0.70136 0.00000
H 2.15666 -1.24515 0.00000
C 1.21479 0.70136 0.00000
H 2.15666 1.24515 0.00000
%endblock
# %include pool/BFD-T.bfinfo
### To be implemented (large file reading support, possibly hdf5 files)
#%include TZ_1M_500.det
#%include jastrow_good_b3lyp.0