mirror of
https://gitlab.com/scemama/qmcchem.git
synced 2025-01-03 10:05:39 +01:00
added context
This commit is contained in:
parent
7591af6ca9
commit
b33952fcec
56
src/QMCkl/qmckl_context.irp.f
Normal file
56
src/QMCkl/qmckl_context.irp.f
Normal file
@ -0,0 +1,56 @@
|
||||
BEGIN_PROVIDER [ integer*8, qmckl_ctx ]
|
||||
use qmckl
|
||||
implicit none
|
||||
BEGIN_DOC
|
||||
! Context for the QMCKL library
|
||||
END_DOC
|
||||
qmckl_ctx = qmckl_context_create()
|
||||
integer :: rc
|
||||
|
||||
! Nuclei
|
||||
rc = 0
|
||||
rc = rc + qmckl_set_nucleus_num (qmckl_ctx, int(nucl_num,8))
|
||||
rc = rc + qmckl_set_nucleus_coord (qmckl_ctx, 'T', dble(nucl_coord(1:nucl_num,1:3)))
|
||||
rc = rc + qmckl_set_nucleus_charge(qmckl_ctx, dble(nucl_charge))
|
||||
if (rc /= QMCKL_SUCCESS) stop -1
|
||||
|
||||
rc = rc + qmckl_set_nucleus_num (qmckl_ctx, int(nucl_num,8))
|
||||
rc = rc + qmckl_set_nucleus_coord (qmckl_ctx, 'T', dble(nucl_coord(1:nucl_num,1:3)))
|
||||
rc = rc + qmckl_set_nucleus_charge(qmckl_ctx, dble(nucl_charge))
|
||||
if (rc /= QMCKL_SUCCESS) stop -1
|
||||
|
||||
! Basis
|
||||
rc = rc + qmckl_set_ao_basis_type(qmckl_ctx, 'G')
|
||||
rc = rc + qmckl_set_ao_basis_shell_num(qmckl_ctx, shell_num)
|
||||
rc = rc + qmckl_set_ao_basis_prim_num(qmckl_ctx, prim_num)
|
||||
rc = rc + qmckl_set_ao_basis_nucleus_index(qmckl_ctx, nucleus_index-1_8)
|
||||
rc = rc + qmckl_set_ao_basis_nucleus_shell_num(qmckl_ctx, nucleus_shell_num)
|
||||
rc = rc + qmckl_set_ao_basis_shell_ang_mom(qmckl_ctx, shell_ang_mom)
|
||||
rc = rc + qmckl_set_ao_basis_shell_prim_num(qmckl_ctx, shell_prim_num)
|
||||
rc = rc + qmckl_set_ao_basis_shell_prim_index(qmckl_ctx, shell_prim_index-1_8)
|
||||
rc = rc + qmckl_set_ao_basis_shell_factor(qmckl_ctx, shell_factor)
|
||||
rc = rc + qmckl_set_ao_basis_exponent(qmckl_ctx, prim_expo)
|
||||
rc = rc + qmckl_set_ao_basis_coefficient(qmckl_ctx, prim_coef)
|
||||
rc = rc + qmckl_set_ao_basis_prim_factor(qmckl_ctx, prim_factor)
|
||||
rc = rc + qmckl_set_ao_basis_ao_num(qmckl_ctx, int(ao_num,8))
|
||||
rc = rc + qmckl_set_ao_basis_ao_factor(qmckl_ctx, ao_factor)
|
||||
if (rc /= QMCKL_SUCCESS) stop -2
|
||||
|
||||
! Electrons
|
||||
rc = rc + qmckl_set_electron_num(qmckl_ctx, int(elec_alpha_num,8), int(elec_beta_num,8))
|
||||
rc = rc + qmckl_set_electron_walk_num(qmckl_ctx, int(walk_num,8))
|
||||
rc = rc + qmckl_set_electron_coord(qmckl_ctx, 'T', dble(elec_coord_full(1:elec_num,1:3,1:walk_num)))
|
||||
if (rc /= QMCKL_SUCCESS) stop -3
|
||||
ao_elec = 1
|
||||
TOUCH ao_elec
|
||||
|
||||
END_PROVIDER
|
||||
|
||||
BEGIN_PROVIDER [ integer, qmckl_precision ]
|
||||
use qmckl
|
||||
implicit none
|
||||
BEGIN_DOC
|
||||
! Precision used in QMCKL
|
||||
END_DOC
|
||||
qmckl_precision = qmckl_get_numprec_precision(qmckl_ctx)
|
||||
END_PROVIDER
|
Loading…
Reference in New Issue
Block a user