Base classes for ebcc.ham.

ebcc.ham.base.BaseHamiltonian(mf, space, mo_coeff=None)

Bases: Namespace[Any], ABC

Base class for Hamiltonians.

Initialise the Hamiltonian.

Parameters:
  • mf (SCF) –

    Mean-field object.

  • space (tuple[SpaceType, ...]) –

    Space object for each index.

  • mo_coeff (Optional[tuple[CoeffType, ...]], default: None ) –

    Molecular orbital coefficients for each index.

Source code in ebcc/ham/base.py
def __init__(
    self,
    mf: SCF,
    space: tuple[SpaceType, ...],
    mo_coeff: Optional[tuple[CoeffType, ...]] = None,
) -> None:
    """Initialise the Hamiltonian.

    Args:
        mf: Mean-field object.
        space: Space object for each index.
        mo_coeff: Molecular orbital coefficients for each index.
    """
    Namespace.__init__(self)

    # Parameters:
    self.__dict__["mf"] = mf
    self.__dict__["space"] = space
    self.__dict__["mo_coeff"] = mo_coeff if mo_coeff is not None else (mf.mo_coeff,) * 4

ebcc.ham.base.BaseHamiltonian.__getitem__(key) abstractmethod

Just-in-time getter.

Parameters:
  • key (str) –

    Key to get.

Returns:
  • Any

    Slice of the Hamiltonian.

Source code in ebcc/ham/base.py
@abstractmethod
def __getitem__(self, key: str) -> Any:
    """Just-in-time getter.

    Args:
        key: Key to get.

    Returns:
        Slice of the Hamiltonian.
    """
    pass

ebcc.ham.base.BaseRHamiltonian(mf, space, mo_coeff=None)

Bases: BaseHamiltonian

Base class for restricted Hamiltonians.

Source code in ebcc/ham/base.py
def __init__(
    self,
    mf: SCF,
    space: tuple[SpaceType, ...],
    mo_coeff: Optional[tuple[CoeffType, ...]] = None,
) -> None:
    """Initialise the Hamiltonian.

    Args:
        mf: Mean-field object.
        space: Space object for each index.
        mo_coeff: Molecular orbital coefficients for each index.
    """
    Namespace.__init__(self)

    # Parameters:
    self.__dict__["mf"] = mf
    self.__dict__["space"] = space
    self.__dict__["mo_coeff"] = mo_coeff if mo_coeff is not None else (mf.mo_coeff,) * 4

ebcc.ham.base.BaseUHamiltonian(mf, space, mo_coeff=None)

Bases: BaseHamiltonian

Base class for unrestricted Hamiltonians.

Source code in ebcc/ham/base.py
def __init__(
    self,
    mf: SCF,
    space: tuple[SpaceType, ...],
    mo_coeff: Optional[tuple[CoeffType, ...]] = None,
) -> None:
    """Initialise the Hamiltonian.

    Args:
        mf: Mean-field object.
        space: Space object for each index.
        mo_coeff: Molecular orbital coefficients for each index.
    """
    Namespace.__init__(self)

    # Parameters:
    self.__dict__["mf"] = mf
    self.__dict__["space"] = space
    self.__dict__["mo_coeff"] = mo_coeff if mo_coeff is not None else (mf.mo_coeff,) * 4

ebcc.ham.base.BaseGHamiltonian(mf, space, mo_coeff=None)

Bases: BaseHamiltonian

Base class for general Hamiltonians.

Source code in ebcc/ham/base.py
def __init__(
    self,
    mf: SCF,
    space: tuple[SpaceType, ...],
    mo_coeff: Optional[tuple[CoeffType, ...]] = None,
) -> None:
    """Initialise the Hamiltonian.

    Args:
        mf: Mean-field object.
        space: Space object for each index.
        mo_coeff: Molecular orbital coefficients for each index.
    """
    Namespace.__init__(self)

    # Parameters:
    self.__dict__["mf"] = mf
    self.__dict__["space"] = space
    self.__dict__["mo_coeff"] = mo_coeff if mo_coeff is not None else (mf.mo_coeff,) * 4

ebcc.ham.base.BaseFock(mf, space, mo_coeff=None, g=None, shift=None, xi=None)

Bases: BaseHamiltonian

Base class for Fock matrices.

Initialise the Hamiltonian.

Parameters:
  • mf (SCF) –

    Mean-field object.

  • space (tuple[SpaceType, ...]) –

    Space object for each index.

  • mo_coeff (Optional[tuple[CoeffType, ...]], default: None ) –

    Molecular orbital coefficients for each index.

  • g (Optional[Namespace[Any]], default: None ) –

    Namespace containing blocks of the electron-boson coupling matrix.

  • shift (Optional[bool], default: None ) –

    Shift the boson operators such that the Hamiltonian is normal-ordered with respect to a coherent state. This removes the bosonic coupling to the static mean-field density, introducing a constant energy shift.

  • xi (Optional[NDArray[floating]], default: None ) –

    Shift in the bosonic operators to diagonalise the photon Hamiltonian.

Source code in ebcc/ham/base.py
def __init__(
    self,
    mf: SCF,
    space: tuple[SpaceType, ...],
    mo_coeff: Optional[tuple[CoeffType, ...]] = None,
    g: Optional[Namespace[Any]] = None,
    shift: Optional[bool] = None,
    xi: Optional[NDArray[floating]] = None,
) -> None:
    """Initialise the Hamiltonian.

    Args:
        mf: Mean-field object.
        space: Space object for each index.
        mo_coeff: Molecular orbital coefficients for each index.
        g: Namespace containing blocks of the electron-boson coupling matrix.
        shift: Shift the boson operators such that the Hamiltonian is normal-ordered with
            respect to a coherent state. This removes the bosonic coupling to the static
            mean-field density, introducing a constant energy shift.
        xi: Shift in the bosonic operators to diagonalise the photon Hamiltonian.
    """
    super().__init__(mf, space, mo_coeff=mo_coeff)

    # Boson parameters:
    self.__dict__["g"] = g
    self.__dict__["shift"] = shift
    self.__dict__["xi"] = xi

ebcc.ham.base.BaseERIs(mf, space, mo_coeff=None)

Bases: BaseHamiltonian

Base class for electronic repulsion integrals.

Source code in ebcc/ham/base.py
def __init__(
    self,
    mf: SCF,
    space: tuple[SpaceType, ...],
    mo_coeff: Optional[tuple[CoeffType, ...]] = None,
) -> None:
    """Initialise the Hamiltonian.

    Args:
        mf: Mean-field object.
        space: Space object for each index.
        mo_coeff: Molecular orbital coefficients for each index.
    """
    Namespace.__init__(self)

    # Parameters:
    self.__dict__["mf"] = mf
    self.__dict__["space"] = space
    self.__dict__["mo_coeff"] = mo_coeff if mo_coeff is not None else (mf.mo_coeff,) * 4

ebcc.ham.base.BaseElectronBoson(mf, g, space, mo_coeff=None)

Bases: BaseHamiltonian

Base class for electron-boson coupling matrices.

Initialise the Hamiltonian.

Parameters:
  • mf (SCF) –

    Mean-field object.

  • g (NDArray[floating]) –

    The electron-boson coupling matrix array.

  • space (tuple[SpaceType, ...]) –

    Space object for each index.

  • mo_coeff (Optional[tuple[CoeffType, ...]], default: None ) –

    Molecular orbital coefficients for each index.

Source code in ebcc/ham/base.py
def __init__(
    self,
    mf: SCF,
    g: NDArray[floating],
    space: tuple[SpaceType, ...],
    mo_coeff: Optional[tuple[CoeffType, ...]] = None,
) -> None:
    """Initialise the Hamiltonian.

    Args:
        mf: Mean-field object.
        g: The electron-boson coupling matrix array.
        space: Space object for each index.
        mo_coeff: Molecular orbital coefficients for each index.
    """
    super().__init__(mf, space, mo_coeff=mo_coeff)

    # Boson parameters:
    self.__dict__["g"] = g