VibrationalBasis#
- class VibrationalBasis(num_modals, *, threshold=1e-06)[source]#
Bases:
ABC
The Vibrational basis base class.
This class defines the interface which any vibrational basis must implement. A basis must be applied to the vibrational integrals in order to map them into a second-quantization form.
The following attributes can be set via the initializer but can also be read and updated once the
VibrationalBasis
object has been constructed.- num_modals#
the number of modals into which each mode gets expanded in second-quantization.
- Parameters:
Methods
- abstract eval_integral(mode, modal_1, modal_2, power, kinetic_term=False)[source]#
The integral evaluation method of this basis.
- Parameters:
mode (int) – the index of the mode.
modal_1 (int) – the index of the first modal.
modal_2 (int) – the index of the second modal.
power (int) – the exponent of the coordinate.
kinetic_term (bool) – if this is True, the method should compute the integral of the kinetic term of the vibrational Hamiltonian, :math:
d^2/dQ^2
.
- Returns:
The evaluated integral for the specified coordinate or
None
if this integral value falls below the threshold.- Raises:
ValueError – if an unsupported parameter is supplied.
- Return type:
complex | None
- map(coefficient, modes)[source]#
Maps the provided coefficient and mode index to this second-quantization basis.
This applies the actual basis and expands each mode into the number of modals with which the basis instance was initialized.
- Parameters:
- Yields:
Pairs of integral values and indices. The indices are now three times as long as the initially provided modes index. The reason for that is that each mode index gets expanded into three indices, denoting the
(mode, modal_1, modal_2)
indices.- Return type: