..
: PyBEST: Pythonic Black-box Electronic Structure Tool
: Copyright (C) 2016-- The PyBEST Development Team
:
: This file is part of PyBEST.
:
: PyBEST is free software; you can redistribute it and/or
: modify it under the terms of the GNU General Public License
: as published by the Free Software Foundation; either version 3
: of the License, or (at your option) any later version.
:
: PyBEST is distributed in the hope that it will be useful,
: but WITHOUT ANY WARRANTY; without even the implied warranty of
: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
: GNU General Public License for more details.
:
: You should have received a copy of the GNU General Public License
: along with this program; if not, see
: --
.. _user_eom_long:
The EOM module with various CC reference functions
##################################################
Before proceeding, please read the Quick Guide on all available EOM-CC methods :ref:`here `.
Since most of the EOM-CC flavors implemented in PyBEST offer similar functionality,
we will group them in different subsections depending on the supported features of
the EOM-CC method in question. Specifically, we distinguish between modules that
1. support only the Davidson diagonalization of the EOM Hamiltonian.
2. support both exact and Davidson diagonalization of the EOM Hamiltonian.
In addition, the :py:class:`~pybest.io.iodata.IOData` container attributes
mentioned in the Quick Guide above, the :py:class:`~pybest.ee_eom.eom_base.REOMCC`
containers include the following information
:orb_a: A copy of the orbitals used in the CC reference calculation.
:olp: The overlap integrals used in the CC reference calculation.
.. _eom_exact_diagonalization:
Exact diagonalization
=====================
Due to their simplicity, the effective Hamiltonian of EOM-CCS, EOM-pCCD, EOM-pCCD+S,
and EOM-pCCD-CCS can be explicitly constructed and exactly diagonalized. If you wish
to solve for the eigenvalues and eigenvalues iteratively, you can specify the Davidson
diagonalizer using the corresponding ``davidson`` keyword argument.
For instance, if you target the excited states of large systems, the exact diagonalization
might be prohibitive. For very large systems, we thus recommend to keep the default setting and exploit the
Davidson diagonalizer,
.. literalinclude:: ../src/pybest/data/examples/eom/reompccd_water_cc-pvdz.py
:lines: 64-
If you, however, want to use exact diagonalization, you can do this by
setting the ``davidson`` keyword argument to ``False``.
.. note::
The ``davidson`` keyword argument works for all
:py:class:`~pybest.ee_eom.eom_base.REOMCC` modules in PyBEST.
.. _eom_keywords:
Summary of keyword arguments
============================
The :py:class:`~pybest.ee_eom.eom_base.REOMCC` module supports various keyword
arguments that allow us to steer the optimization of excited states (excitation
energies and the eigenvectors of the targeted states).
In the following, all supported keyword
arguments are listed together with their default values. Please note that for
most cases, the default values should be sufficient to reach convergence.
:indextrans: (str) 4-index transformation. The choice between ``cupy``, ``tensordot``
(default) and ``einsum``. ``tensordot`` is faster than ``einsum``.
If ``DenseLinalgFactory`` is used, the memory requirement scales roughly
as :math:`3N^4`. Due to the storage of the two-electron integrals,
the total amount of memory increases to :math:`4N^4`
.. note::
If Cupy is not available or unsuccessful, ``td`` is selected instead.
:nroot: (int) The number of targeted (excited) states, excluding the ground state
(default ``1``).
:davidson: (boolean) Type of solver used. If set to ``True`` PyBEST's
internal Davidson method for diagonalizing is employed, where only the lowest
``nroot`` states are optimized. If set to ``False``, only the
lowest ``nroot`` are returned and printed (default ``True``).
.. note::
For very large systems switching ``davidson`` to ``True``
might save memory. For small- and medium-sized systems, an
exact diagonalization is typically of similar cost due to the
simplicity of the model.
:threshold: (float) Printing threshold for the eigenvectors. If a (row)
element of ``civ_ee`` is larger than the threshold in absolute
value, the corresponding excitation contribution is printed
(default ``0.1``).
:tco: (str | None) The flavor of tensor contraction operations used.
Either ``cupy``, ``td`` or ``einsum`` (default ``None``).
.. note::
PyBEST takes the most efficient tensor contraction operations
for specific contractions. By default, selected operations are
exported to the GPU using Cupy. If Cupy is not available, ``td``
is selected. ``einsum`` is taken if all other flavors are unsupported.
We do not recommend changing the default unless you know what you
are doing.
Some keyword arguments are only working together with the ``davidson`` solver.
If exact diagonalization is used, they have no effect. These arguments include:
:tolerance: (float) optimization threshold for each excitation energy
(default ``1e-6``).
:tolerancev: (float) optimization threshold for each excited state eigenvector
(default ``1e-4``).
:maxiter: (int) maximum number of total Davidson diagonalization steps
(default ``200``).
:nguessv: (int) total number of guess vectors (default ``(nroots-1)*4+1``,
that is, 4 vectors per excited state).
:maxvectors: (int) maximum number of Davidson vectors. If additional vectors
are added, a subspace collapse is performed (default ``(nroots-1)*10``,
that is, 10 vectors per excited state).
:todisk: (boolean) if set to ``True`` all intermediates are stored to disk.
This reduces memory requirements. However, due to the intensive
I/O operations, the code is slowed down significantly
(default ``False``).