D4 dispersion model to evaluate C6 coefficients
Type | Visibility | Attributes | Name | Initial | |||
---|---|---|---|---|---|---|---|
real(kind=wp), | public, | allocatable | :: | aiw(:,:,:) |
Reference dynamic polarizibilities |
||
real(kind=wp), | public, | allocatable | :: | c6(:,:,:,:) |
Reference C6 coefficients |
||
real(kind=wp), | public, | allocatable | :: | cn(:,:) |
Reference coordination numbers |
||
real(kind=wp), | public, | allocatable | :: | en(:) |
Electronegativity |
||
real(kind=wp), | public, | allocatable | :: | eta(:) |
Chemical hardness |
||
real(kind=wp), | public | :: | ga |
Charge scaling height |
|||
real(kind=wp), | public | :: | gc |
Charge scaling steepness |
|||
integer, | public | :: | ncoup |
Number of atoms coupled to by pairwise parameters |
|||
integer, | public, | allocatable | :: | ngw(:,:) |
Number of Gaussian weights for each reference |
||
real(kind=wp), | public, | allocatable | :: | q(:,:) |
Reference partial charges |
||
real(kind=wp), | public, | allocatable | :: | r4r2(:) |
Expectation values for C8 extrapolation |
||
real(kind=wp), | public, | allocatable | :: | rcov(:) |
Covalent radii for coordination number |
||
integer, | public, | allocatable | :: | ref(:) |
Number of reference systems |
||
real(kind=wp), | public | :: | wf |
Weighting factor for CN interpolation |
|||
real(kind=wp), | public, | allocatable | :: | zeff(:) |
Effective nuclear charges |
Evaluate C6 coefficient
Calculate atomic dispersion coefficients and their derivatives w.r.t. the coordination numbers and atomic partial charges.
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
class(d4_model), | intent(in) | :: | self |
Instance of the dispersion model |
||
class(structure_type), | intent(in) | :: | mol |
Molecular structure data |
||
real(kind=wp), | intent(in) | :: | gwvec(:,:,:) |
Weighting function for the atomic reference systems |
||
real(kind=wp), | intent(in), | optional | :: | gwdcn(:,:,:) |
Derivative of the weighting function w.r.t. the coordination number |
|
real(kind=wp), | intent(in), | optional | :: | gwdq(:,:,:) |
Derivative of the weighting function w.r.t. the partial charge |
|
real(kind=wp), | intent(out) | :: | c6(:,:) |
C6 coefficients for all atom pairs. |
||
real(kind=wp), | intent(out), | optional | :: | dc6dcn(:,:) |
Derivative of the C6 w.r.t. the coordination number |
|
real(kind=wp), | intent(out), | optional | :: | dc6dq(:,:) |
Derivative of the C6 w.r.t. the partial charge |
Evaluate atomic polarizibilities
Calculate atomic polarizibilities and their derivatives w.r.t. the coordination numbers and atomic partial charges.
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
class(d4_model), | intent(in) | :: | self |
Instance of the dispersion model |
||
class(structure_type), | intent(in) | :: | mol |
Molecular structure data |
||
real(kind=wp), | intent(in) | :: | gwvec(:,:,:) |
Weighting function for the atomic reference systems |
||
real(kind=wp), | intent(in), | optional | :: | gwdcn(:,:,:) |
Derivative of the weighting function w.r.t. the coordination number |
|
real(kind=wp), | intent(in), | optional | :: | gwdq(:,:,:) |
Derivative of the weighting function w.r.t. the partial charge |
|
real(kind=wp), | intent(out) | :: | alpha(:) |
Static polarizibilities for all atoms. |
||
real(kind=wp), | intent(out), | optional | :: | dadcn(:) |
Derivative of the polarizibility w.r.t. the coordination number |
|
real(kind=wp), | intent(out), | optional | :: | dadq(:) |
Derivative of the polarizibility w.r.t. the partial charge |
Generate weights for all reference systems
Calculate the weights of the reference system and the derivatives w.r.t. coordination number for later use.
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
class(d4_model), | intent(in) | :: | self |
Instance of the dispersion model |
||
class(structure_type), | intent(in) | :: | mol |
Molecular structure data |
||
real(kind=wp), | intent(in) | :: | cn(:) |
Coordination number of every atom |
||
real(kind=wp), | intent(in) | :: | q(:) |
Partial charge of every atom |
||
real(kind=wp), | intent(out) | :: | gwvec(:,:,:) |
weighting for the atomic reference systems |
||
real(kind=wp), | intent(out), | optional | :: | gwdcn(:,:,:) |
derivative of the weighting function w.r.t. the coordination number |
|
real(kind=wp), | intent(out), | optional | :: | gwdq(:,:,:) |
derivative of the weighting function w.r.t. the charge scaling |
type, extends(dispersion_model) :: d4_model !> Weighting factor for CN interpolation real(wp) :: wf contains !> Generate weights for all reference systems procedure :: weight_references !> Evaluate C6 coefficient procedure :: get_atomic_c6 !> Evaluate atomic polarizibilities procedure :: get_polarizibilities end type d4_model