Base D3 dispersion model to evaluate C6 coefficients
Type | Visibility | Attributes | Name | Initial | |||
---|---|---|---|---|---|---|---|
real(kind=wp), | public, | allocatable | :: | c6(:,:,:,:) |
Reference C6 coefficients |
||
real(kind=wp), | public, | allocatable | :: | cn(:,:) |
Reference coordination numbers |
||
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, | allocatable | :: | rvdw(:,:) |
Van-der-Waals radii for damping function |
||
real(kind=wp), | public, | allocatable | :: | wf |
Weighting factor for CN interpolation |
Evaluate C6 coefficient
Calculate atomic dispersion coefficients and their derivatives w.r.t. the coordination number.
Type | Intent | Optional | Attributes | Name | ||
---|---|---|---|---|---|---|
class(d3_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(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 |
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(d3_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(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 |
type :: d3_model !> Covalent radii for coordination number real(wp), allocatable :: rcov(:) !> Van-der-Waals radii for damping function real(wp), allocatable :: rvdw(:, :) !> Expectation values for C8 extrapolation real(wp), allocatable :: r4r2(:) !> Weighting factor for CN interpolation real(wp), allocatable :: wf !> Number of reference systems integer, allocatable :: ref(:) !> Reference coordination numbers real(wp), allocatable :: cn(:, :) !> Reference C6 coefficients real(wp), allocatable :: c6(:, :, :, :) contains !> Generate weights for all reference systems procedure :: weight_references !> Evaluate C6 coefficient procedure :: get_atomic_c6 end type d3_model