Molecule Class

Molecule class tht reads wavefunction information and computes various quantities.

class cugbasis.Molecule

Bases: pybind11_object

Attributes:
atcoords

Cartesian coordinates of the atomic centers.

atnums

Atomic number of atomic centers.

Methods

compute_density

Compute electron density ρ(r).

compute_electrostatic_potential

Compute the molecular electrostatic potential.

compute_empirical_gradient_expansion_ked

Compute the empirical gradient expansion approximation of kinetic energy density.

compute_general_gradient_expansion_ked

Compute the general gradient expansion approximation of kinetic energy density.

compute_general_ked

Compute the general(ish) kinetic energy density.

compute_general_kinetic_energy_density

Compute the general kinetic energy density on a grid of points.

compute_gradient

Compute the gradient of the electron density.

compute_gradient_expansion_ked

Compute the gradient expansion approximation of kinetic energy density

compute_hessian

Compute the Hessian of the electron density.

compute_laplacian

Compute the Laplacian of the electron density.

compute_molecular_orbitals

Compute Molecular Orbitals

compute_norm_of_vector

Compute the norm of a three-dimensional vector using GPU.

compute_positive_definite_kinetic_energy_density

Compute the positive definite kinetic energy density on a grid of points.

compute_reduced_density_gradient

Compute the reduced density gradient.

compute_schrodinger_ked

Compute the Schrödinger kinetic energy density.

compute_shannon_information_density

Compute the Shannon information density."

compute_thomas_fermi_ked

Compute the Thomas-Fermi kinetic energy density.

compute_weizsacker_ked

Compute the Weizsacker Kinetic energy density.

get_file_path

Get the wavefunction file path.

property atcoords

Cartesian coordinates of the atomic centers.

property atnums

Atomic number of atomic centers.

compute_density()

Compute electron density ρ(r).

Parameters:

points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

Returns:

The electron density evaluated on each point.

Return type:

ndarray(N,)

compute_electrostatic_potential()

Compute the molecular electrostatic potential.

Φ(r)=i=1NatomZA|rRA|ρ(r)|rr|dr,
Parameters:

points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

compute_empirical_gradient_expansion_ked()

Compute the empirical gradient expansion approximation of kinetic energy density.

τEGEA(r)=τTF(r)+15τW(r)+162ρ(r)
Parameters:

points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

compute_general_gradient_expansion_ked()

Compute the general gradient expansion approximation of kinetic energy density.

τGGE(r)=τTF(r)+ατW(r)+β2ρ(r)
Parameters:
  • points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

  • alpha (float) – Constant parameter.

  • beta (float) – Constant parameter.

compute_general_ked()

Compute the general(ish) kinetic energy density.

τG(r,α)=τPD(r)+14(α1)2ρ(r),

where a is a constant parameter. When a=0, then it is the ‘Schrödinger’ kinetic energy, when a=1, then it is the positive-definite kinetic energy.

Parameters:
  • points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

  • alpha (float) – The constant parameter.

compute_general_kinetic_energy_density()

Compute the general kinetic energy density on a grid of points.

tα(r)=t+(r)+α2ρ(r)

where t+(r) is the positive definite kinetic energy density and 2 is the Laplacian.

Parameters:
  • points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

  • alpha (float) – Constant parameter.

compute_gradient()

Compute the gradient of the electron density.

ρ(r)=(ρx,ρy,ρz),
Parameters:

points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

Returns:

The gradient of the electron density evaluated on each point.

Return type:

ndarray(N, 3)

compute_gradient_expansion_ked()

Compute the gradient expansion approximation of kinetic energy density

τGEA(r)=τTF(r)+19τW(r)+162ρ(r)
Parameters:

points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

compute_hessian()

Compute the Hessian of the electron density.

Parameters:

points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

Returns:

The Hessian of the electron density evaluated on each point.

Return type:

ndarray(N, 3, 3)

compute_laplacian()

Compute the Laplacian of the electron density.

2ρ(r)=(ρx)2+(ρy)2+(ρz)2
Parameters:

points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

compute_molecular_orbitals()

Compute Molecular Orbitals

Parameters:

points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

Returns:

The M molecular orbitals evaluated on each point.

Return type:

ndarray(M, N)

compute_norm_of_vector()

Compute the norm of a three-dimensional vector using GPU.

Parameters:

points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

compute_positive_definite_kinetic_energy_density()

Compute the positive definite kinetic energy density on a grid of points.

τPD(r)=12i=1N|ϕi(r)|2,

where ϕi is the molecular orbitals. In the QTAIM community, this is denoted as G(r).

Parameters:

points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

compute_reduced_density_gradient()

Compute the reduced density gradient.

s(r)=12(3π2)1/3|ρ(r)|ρ(r)4/3.

Note it may be more efficient to compute each component individually, then using Numpy to compute this quanity.

Parameters:

points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

compute_schrodinger_ked()

Compute the Schrödinger kinetic energy density.

This is the general(sh) kinetic energy density when a=0:

K(r)=τPD(r)142ρ(r),

In the QTAIM community, this is denoted as K(r).

Parameters:

points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

compute_shannon_information_density()

Compute the Shannon information density.”

s(r)=ρ(r)logρ(r),

where the integral gives the Shannon entropy of the electron density.

Parameters:

points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

compute_thomas_fermi_ked()

Compute the Thomas-Fermi kinetic energy density.

τTF(r)=310(3π)2/3ρ(r)5/3
Parameters:

points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

compute_weizsacker_ked()

Compute the Weizsacker Kinetic energy density.

τW(r)=|ρ(r)|28ρ(r)
Parameters:

points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

get_file_path()

Get the wavefunction file path.

class cugbasis.Promolecule

Bases: pybind11_object

Attributes:
atcoords

Cartesian coordinates of the atomic centers.

atnums

Atomic number of atomic centers.

promol_coeffs

Get the coefficients as a dictionary with keys element_parameter_type (e.g.

promol_exps

Get the exponents as a dictionary with keys element_parameter_type (e.g.

Methods

compute_density

Compute promolecular density ρ(r).

compute_esp

Compute the electrostatic potential on ρ(r).

property atcoords

Cartesian coordinates of the atomic centers.

property atnums

Atomic number of atomic centers.

compute_density()

Compute promolecular density ρ(r).

ρ(r)=A[iciαπ3/2eαrA2+jdj2α5/23π3/2rA2eαrA2],

where A is an atom, ci,dj are the s-type, p-type coefficients respectively. Note this is normalized. Please see the paper “An information-theoretic approach to basis-set fitting of electron densities and other non-negative functions”.

Parameters:

points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

Returns:

The promolecular density evaluated on each point.

Return type:

ndarray(N,)

compute_esp()

Compute the electrostatic potential on ρ(r).

Φ(r)=i=1NatomZA|rRA|ρ(r)|rr|dr,

where ZA is the atomic number of atom A.

Parameters:

points (ndarray(N, 3)) – Cartesian coordinates of N points in three-dimensions.

Returns:

The promolecular electrostatic potential evaluated on each point.

Return type:

ndarray(N,)

property promol_coeffs

Get the coefficients as a dictionary with keys element_parameter_type (e.g. f_coeffs_p).

property promol_exps

Get the exponents as a dictionary with keys element_parameter_type (e.g. f_coeffs_p).