mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-07 03:43:20 +01:00
75 lines
2.4 KiB
Fortran
75 lines
2.4 KiB
Fortran
BEGIN_PROVIDER [ double precision , ao_value_at_nucl, (ao_num,nucl_num) ]
|
|
implicit none
|
|
BEGIN_DOC
|
|
! Values of the atomic orbitals at the nucleus
|
|
END_DOC
|
|
integer :: i,j,k
|
|
double precision :: x,y,z,expo,poly, r2
|
|
|
|
do k=1,nucl_num
|
|
do i=1,ao_num
|
|
ao_value_at_nucl(i,k) = 0.d0
|
|
x = nucl_coord(ao_nucl(i),1) - nucl_coord(k,1)
|
|
y = nucl_coord(ao_nucl(i),2) - nucl_coord(k,2)
|
|
z = nucl_coord(ao_nucl(i),3) - nucl_coord(k,3)
|
|
poly = x**(ao_power(i,1)) * y**(ao_power(i,2)) * z**(ao_power(i,3))
|
|
if (poly == 0.d0) cycle
|
|
|
|
r2 = (x*x) + (y*y) + (z*z)
|
|
do j=1,ao_prim_num(i)
|
|
expo = ao_expo_ordered_transp(j,i)*r2
|
|
if (expo > 40.d0) cycle
|
|
ao_value_at_nucl(i,k) = ao_value_at_nucl(i,k) + &
|
|
ao_coef_normalized_ordered_transp(j,i) * &
|
|
dexp(-expo)
|
|
enddo
|
|
ao_value_at_nucl(i,k) *= poly
|
|
enddo
|
|
enddo
|
|
END_PROVIDER
|
|
|
|
BEGIN_PROVIDER [ double precision, ao_ortho_value_at_nucl, (ao_num,nucl_num) ]
|
|
implicit none
|
|
BEGIN_DOC
|
|
! Values of the molecular orbitals at the nucleus
|
|
END_DOC
|
|
|
|
call dgemm('T','N',ao_num,nucl_num,ao_num,1.d0, &
|
|
ao_ortho_canonical_coef, size(ao_ortho_canonical_coef,1), &
|
|
ao_value_at_nucl, size(ao_value_at_nucl,1), &
|
|
0.d0, ao_ortho_value_at_nucl,size(ao_ortho_value_at_nucl,1))
|
|
END_PROVIDER
|
|
|
|
BEGIN_PROVIDER [ double precision, mo_value_at_nucl, (mo_tot_num,nucl_num) ]
|
|
implicit none
|
|
BEGIN_DOC
|
|
! Values of the molecular orbitals at the nucleus
|
|
END_DOC
|
|
|
|
call dgemm('T','N',mo_tot_num,nucl_num,ao_num,1.d0, &
|
|
mo_coef, size(mo_coef,1), &
|
|
ao_value_at_nucl, size(ao_value_at_nucl,1), &
|
|
0.d0, mo_value_at_nucl, size(mo_value_at_nucl,1))
|
|
END_PROVIDER
|
|
|
|
|
|
BEGIN_PROVIDER [ double precision , slater_value_at_nucl, (nucl_num,nucl_num) ]
|
|
implicit none
|
|
BEGIN_DOC
|
|
! Values of the Slater orbitals (1) at the nucleus (2)
|
|
END_DOC
|
|
integer :: i,j,k
|
|
double precision :: x,y,z,expo,poly, r
|
|
|
|
do k=1,nucl_num
|
|
do i=1,nucl_num
|
|
x = nucl_coord(i,1) - nucl_coord(k,1)
|
|
y = nucl_coord(i,2) - nucl_coord(k,2)
|
|
z = nucl_coord(i,3) - nucl_coord(k,3)
|
|
expo = slater_expo(i) * dsqrt((x*x) + (y*y) + (z*z))
|
|
slater_value_at_nucl(i,k) = dexp(-expo) * slater_normalization(i)
|
|
enddo
|
|
enddo
|
|
END_PROVIDER
|
|
|