10
0
mirror of https://github.com/LCPQ/quantum_package synced 2025-01-10 21:18:29 +01:00
quantum_package/plugins/FCIdump/fcidump.irp.f

61 lines
1.6 KiB
Fortran
Raw Normal View History

2015-01-19 10:41:58 +01:00
program fcidump
implicit none
2017-03-16 21:21:27 +01:00
character*(128) :: output
integer :: i_unit_output,getUnitAndOpen
output=trim(ezfio_filename)//'.FCIDUMP'
i_unit_output = getUnitAndOpen(output,'w')
2015-01-19 10:41:58 +01:00
integer :: i,j,k,l
2017-03-16 21:21:27 +01:00
integer :: i1,j1,k1,l1
integer :: i2,j2,k2,l2
2015-01-19 10:41:58 +01:00
integer*8 :: m
character*(2), allocatable :: A(:)
2017-03-16 21:21:27 +01:00
write(i_unit_output,*) '&FCI NORB=', n_act_orb, ', NELEC=', elec_num-n_core_orb*2, &
2015-01-19 10:41:58 +01:00
', MS2=', (elec_alpha_num-elec_beta_num), ','
2017-03-16 21:21:27 +01:00
allocate (A(n_act_orb))
2015-01-19 10:41:58 +01:00
A = '1,'
2017-03-16 21:21:27 +01:00
write(i_unit_output,*) 'ORBSYM=', (A(i), i=1,n_act_orb)
write(i_unit_output,*) 'ISYM=0,'
write(i_unit_output,*) '/'
2015-01-19 10:41:58 +01:00
deallocate(A)
integer(key_kind), allocatable :: keys(:)
double precision, allocatable :: values(:)
integer(cache_map_size_kind) :: n_elements, n_elements_max
PROVIDE mo_bielec_integrals_in_map
double precision :: get_mo_bielec_integral, integral
2017-03-16 21:21:27 +01:00
do l=1,n_act_orb
l1 = list_act(l)
do k=1,n_act_orb
k1 = list_act(k)
do j=l,n_act_orb
j1 = list_act(j)
do i=k,n_act_orb
i1 = list_act(i)
if (i1>=j1) then
integral = get_mo_bielec_integral(i1,j1,k1,l1,mo_integrals_map)
2015-01-19 10:41:58 +01:00
if (dabs(integral) > mo_integrals_threshold) then
2017-03-16 21:21:27 +01:00
write(i_unit_output,*) integral, i,k,j,l
2015-01-19 10:41:58 +01:00
endif
end if
enddo
enddo
enddo
enddo
2017-03-16 21:21:27 +01:00
do j=1,n_act_orb
j1 = list_act(j)
do i=j,n_act_orb
i1 = list_act(i)
integral = mo_mono_elec_integral(i1,j1) + core_fock_operator(i1,j1)
2015-01-19 10:41:58 +01:00
if (dabs(integral) > mo_integrals_threshold) then
2017-03-16 21:21:27 +01:00
write(i_unit_output,*) integral, i,j,0,0
2015-01-19 10:41:58 +01:00
endif
enddo
enddo
2017-03-16 21:21:27 +01:00
write(i_unit_output,*) core_energy, 0, 0, 0, 0
2015-01-19 10:41:58 +01:00
end