CCpy is a research-level Python package for performing nonrelativistic and spin-free scalar relativistic electronic structure calculations for molecular systems using methods based on the ground-state coupled-cluster (CC) theory and its equation-of-motion (EOM) extension to electronic excited, attached, and ionized states. CCpy employs a hybrid Python-Fortran programming approach made possible with the f2py package, which allows one to compile Fortran code into shared object libraries containing subroutines that are callable from Python and interoperable with Numpy arrays.
CCpy provides easy-to-use interfaces to both PySCF and GAMESS for obtaining the mean-field (typically Hartree-Fock) reference state and associated transformed one- and two-electron integrals in the molecular orbital basis that are used to set up the correlated CC calculations. A general interface that can be used to initialize CCpy calculations using reference state information and one- and two-electron integrals provided by an FCIDUMP file is also included.
CCpy is distributed as an official extension module of PySCF (see https://pyscf.org/install.html#extension-modules).
Below, we list the computational options that are currently available in CCpy (see the dropdown menus below along with the `tests` directory for sample input scripts). All implementations in CCpy are based on the spin-integrated spinorbital formulation and are compatible with RHF/ROHF and UHF references, unless otherwise indicated.
MP2
Second-order MBPT energy correction. Compatible with RHF and UHF only.
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
geometry = [["O", (0.0, 0.0, -0.0180)],
["H", (0.0, 3.030526, -2.117796)],
["H", (0.0, -3.030526, -2.117796)]]
mol = gto.M(
atom=geometry,
basis="cc-pvdz",
charge=0,
spin=0,
symmetry="C2V",
cart=False,
unit="Bohr",
)
mf = scf.RHF(mol)
mf.kernel()
# Load CCpy driver from PySCF
driver = Driver.from_pyscf(mf, nfrozen=0)
# Run MP2 calculation
driver.run_mbpt(method="mp2")
MP3
Third-order MBPT energy correction. Compatible with RHF and UHF only.
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
geometry = [["O", (0.0, 0.0, -0.0180)],
["H", (0.0, 3.030526, -2.117796)],
["H", (0.0, -3.030526, -2.117796)]]
mol = gto.M(
atom=geometry,
basis="cc-pvdz",
charge=0,
spin=0,
symmetry="C2V",
cart=False,
unit="Bohr",
)
mf = scf.RHF(mol)
mf.kernel()
# Load CCpy driver from PySCF
driver = Driver.from_pyscf(mf, nfrozen=0)
# Run MP3 calculation
driver.run_mbpt(method="mp3")
CCD
The CC with doubles (CCD) method truncates the cluster operator as T = T2. It has iterative computational costs that scale as no2nu4, where no is the number of correlated occupied orbitals and nu is the number of correlated unoccupied orbitals. Due to the importance of pair correlations in the many-electron problem, the CCD approximation was first introduced in Prof. Čížek's landmark 1966 paper under the name coupled-pair many-electron theory, or CPMET. Although CCD is often superceeded by the more accurate CC with singles and doubles (CCSD) method, which has the same computational scaling, CCD is still relevant to modern CC calculations within the context of correlating orbital-optimized reference functions, as in Brückner CCD.
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
# build molecule using PySCF and run SCF calculation
mol = gto.M(
atom=[["O", (0.0, 0.0, -0.0180)],
["H", (0.0, 3.030526, -2.117796)],
["H", (0.0, -3.030526, -2.117796)]],
basis="cc-pvdz",
charge=0,
spin=0,
symmetry="C2V",
cart=False,
unit="Bohr",
)
mf = scf.RHF(mol)
mf.kernel()
# get the CCpy driver object using PySCF meanfield
driver = Driver.from_pyscf(mf, nfrozen=1)
# set calculation parameters
driver.options["energy_convergence"] = 1.0e-07 # (in hartree)
driver.options["amp_convergence"] = 1.0e-07
driver.options["maximum_iterations"] = 80
# run CCD calculation
driver.run_cc(method="ccd")
- J. Čížek, J. Chem. Phys. 45, 4256 (1966).
CCSD
The CC with singles and doubles (CCSD) method approximates the cluster operator as T = T1 + T2. It is the most commonly used truncation level in the CC hierarchy and often forms the starting point for more sophisticated treatments of many-electron correlation effects. CCSD has iterative computational costs that scale as no2nu4, where no is the number of correlated occupied orbitals and nu is the number of correlated unoccupied orbitals.
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
# build molecule using PySCF and run SCF calculation
mol = gto.M(
atom=[["O", (0.0, 0.0, -0.0180)],
["H", (0.0, 3.030526, -2.117796)],
["H", (0.0, -3.030526, -2.117796)]],
basis="cc-pvdz",
charge=0,
spin=0,
symmetry="C2V",
cart=False,
unit="Bohr",
)
mf = scf.RHF(mol)
mf.kernel()
# get the CCpy driver object using PySCF meanfield
driver = Driver.from_pyscf(mf, nfrozen=1)
# set calculation parameters
driver.options["energy_convergence"] = 1.0e-07 # (in hartree)
driver.options["amp_convergence"] = 1.0e-07
driver.options["maximum_iterations"] = 80
# run CCSD calculation
driver.run_cc(method="ccsd")
- G. D. Purvis and R. J. Bartlett, J. Chem. Phys. 76, 1910 (1982).
- J. M. Cullen and M. C. Zerner, J. Chem. Phys. 77, 4088 (1982).
- G. E. Scuseria, A. C. Scheiner, T. J. Lee, J. E. Rice, and H. F. Schaefer, J. Chem. Phys. 86, 2881 (1987).
- P. Piecuch and J. Paldus, Int. J. Quantum Chem. 36, 429 (1989).
CCSDT
The CC with singles, doubles, and triples (CCSDT) method approximates the cluster operator as T = T1 + T2 + T3. CCSDT is a high-level method capable of providing nearly exact results for closed-shell molecules as well as chemically accurate energetics for single bond breaking and a variety of open-shell systems. CCSDT has iterative computational costs that scale as no3nu5, where no is the number of correlated occupied orbitals and nu is the number of correlated unoccupied orbitals.
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
# build molecule using PySCF and run SCF calculation
mol = gto.M(
atom=[["O", (0.0, 0.0, -0.0180)],
["H", (0.0, 3.030526, -2.117796)],
["H", (0.0, -3.030526, -2.117796)]],
basis="cc-pvdz",
charge=0,
spin=0,
symmetry="C2V",
cart=False,
unit="Bohr",
)
mf = scf.RHF(mol)
mf.kernel()
# get the CCpy driver object using PySCF meanfield
driver = Driver.from_pyscf(mf, nfrozen=1)
# set calculation parameters
driver.options["energy_convergence"] = 1.0e-07 # (in hartree)
driver.options["amp_convergence"] = 1.0e-07
driver.options["maximum_iterations"] = 80
# run CCSDT calculation
driver.run_cc(method="ccsdt")
- M. R. Hoffmann and H. F. Schaefer, Adv. Quantum Chem. 18, 207 (1986).
- J. Noga and R. J. Bartlett, J. Chem. Phys. 86, 7041 (1987).
- G. E. Scuseria and H. F. Schaefer, Chem. Phys. Lett. 152, 382 (1988).
- J. D. Watts and R. J. Bartlett, J. Chem. Phys. 93, 6104 (1990).
CCSDTQ
The CC with singles, doubles, triples, and quadruples (CCSDTQ) method approximates the cluster operator as T = T1 + T2 + T3 + T4. CCSDTQ is a very high-level method and is often capable of providing near-exact energetics for most problems of chemical interest, as long as the number of strongly correlated electrons is not too large (for methods designed to treat genuine strong correlations, see the approximate coupled-pair, or ACP approaches). CCSDTQ has iterative computational costs that scale as no4nu6, where no is the number of correlated occupied orbitals and nu is the number of correlated unoccupied orbitals.
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
# build molecule using PySCF and run SCF calculation
mol = gto.M(
atom=[["O", (0.0, 0.0, -0.0180)],
["H", (0.0, 3.030526, -2.117796)],
["H", (0.0, -3.030526, -2.117796)]],
basis="cc-pvdz",
charge=0,
spin=0,
symmetry="C2V",
cart=False,
unit="Bohr",
)
mf = scf.RHF(mol)
mf.kernel()
# get the CCpy driver object using PySCF meanfield
driver = Driver.from_pyscf(mf, nfrozen=1)
# set calculation parameters
driver.options["energy_convergence"] = 1.0e-07 # (in hartree)
driver.options["amp_convergence"] = 1.0e-07
driver.options["maximum_iterations"] = 80
# run CCSDTQ calculation
driver.run_cc(method="ccsdtq")
- N. Oliphant and L. Adamowicz, J. Chem. Phys. 95, 6645 (1991).
- S. A. Kucharski and R. J. Bartlett, Theor. Chem. Acc. 80, 387 (1991).
- S. A. Kucharski and R. J. Bartlett, J. Chem. Phys. 97, 4282 (1992).
- P. Piecuch and L. Adamowicz, J. Chem. Phys. 100, 5792 (1994).
CCSD(T)
The CCSD(T) method corrects the CCSD energy for the correlation effects due to T3 clusters using formulas derived using many-body perturbation theory (MBPT). In particular, the CCSD(T) correction includes the leading 4th-order energy correction for T3 along with 5th-order contribution due to disconnected triples. The inclusion of the latter term distinguishes CCSD(T) from its CCSD[T] precedessor. CCSD(T) has noniterative computational costs that scale as no3n44, where no is the number of correlated occupied orbitals and nu is the number of correlated unoccupied orbitals.
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
# build molecule using PySCF and run SCF calculation
mol = gto.M(
atom=[["O", (0.0, 0.0, -0.0180)],
["H", (0.0, 3.030526, -2.117796)],
["H", (0.0, -3.030526, -2.117796)]],
basis="cc-pvdz",
charge=0,
spin=0,
symmetry="C2V",
cart=False,
unit="Bohr",
)
mf = scf.RHF(mol)
mf.kernel()
# get the CCpy driver object using PySCF meanfield
driver = Driver.from_pyscf(mf, nfrozen=1)
# set calculation parameters
driver.options["energy_convergence"] = 1.0e-07 # (in hartree)
driver.options["amp_convergence"] = 1.0e-07
driver.options["maximum_iterations"] = 80
# run CCSD calculation
driver.run_cc(method="ccsd")
# perform CCSD(T) correction
driver.run_ccp3(method="ccsd(t)")
- K. Raghavachari, G. W. Trucks, J. A. Pople, and M. Head-Gordon, Chem. Phys. Lett. 157, 479 (1989).
- J. F. Stanton, Chem. Phys. Lett. 281, 130 (1997).
- S. A. Kucharski and R. J. Bartlett, J. Chem. Phys. 108, 5243 (1998).
- T. D. Crawford and J. F. Stanton, Int. J. Quantum Chem. 70, 601 (1998).
CR-CC(2,3)
The CR-CC(2,3) approach is a nonperturbative and noniterative correction to the CCSD energetics that accounts for the correlation effects due to T3 clusters using formulas derived from the biorthogonal moment energy expansions of CC theory. In particular, CR-CC(2,3) represents the most robust scheme to noniteratively include the effects of connected triples on top of CCSD, and it is capable of providing an accurate description of closed-shell molecules in addition to commonly encountered multireference problems, such as single bond breaking and open-shell radical and diradical species, which are generally beyond the scope of perturbative methods like CCSD(T). The CR-CC(2,3) triples correction uses noniterative steps that scale as no3n44, where no is the number of correlated occupied orbitals and nu is the number of correlated unoccupied orbitals, however, due to the precise form of the expressions defining the CR-CC(2,3) triples correction, it is approximately twice as expensive as its CCSD(T) counterpart. One must also solve the companion left-CCSD system of linear equations (roughly as expensive as CCSD) prior to computing the CR-CC(2,3) correction.
The CR-CC(2,3) calculation returns four distinct energetics, labelled as CR-CC(2,3)X, for X = A, B, C, and D, where each variant A-D corresponds to a different treatment of the energy denominators entering the formula for the CR-CC(2,3) triples correction. The variant CR-CC(2,3)A uses the simplest Møller-Plesset form of the energy denominator and is equivalent to the method called CCSD(2)T. Meanwhile, the CR-CC(2,3)D result, which employs the full Epstein-Nesbet energy denominator, is generally most accurate and often reported as the CR-CC(2,3) energy (or by its former name, CR-CCSD(T)L).
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
# build molecule using PySCF and run SCF calculation
mol = gto.M(
atom=[["O", (0.0, 0.0, -0.0180)],
["H", (0.0, 3.030526, -2.117796)],
["H", (0.0, -3.030526, -2.117796)]],
basis="cc-pvdz",
charge=0,
spin=0,
symmetry="C2V",
cart=False,
unit="Bohr",
)
mf = scf.RHF(mol)
mf.kernel()
# get the CCpy driver object using PySCF meanfield
driver = Driver.from_pyscf(mf, nfrozen=1)
# set calculation parameters
driver.options["energy_convergence"] = 1.0e-07 # (in hartree)
driver.options["amp_convergence"] = 1.0e-07
driver.options["maximum_iterations"] = 80
# run CCSD calculation
driver.run_cc(method="ccsd")
# build CCSD similarity-transformed Hamiltonian (this overwrites original MO integrals)
driver.run_hbar(method="ccsd")
# run companion left-CCSD calculation
driver.run_leftcc(method="left_ccsd")
# run CR-CC(2,3) triples correction
driver.run_ccp3(method="crcc23")
- P. Piecuch and M. Włoch, J. Chem. Phys. 123, 224105 (2005).
- P. Piecuch, M. Włoch, J. R. Gour, and A. Kinal, Chem. Phys. Lett 418, 467 (2006).
- M. Włoch, M. D. Lodriguito, P. Piecuch, and J. R. Gour, Mol. Phys. 104, 2149 (2006), 104, 2991 (2006) [Erratum].
- M. Włoch, J. R. Gour, and P. Piecuch, J. Phys. Chem. A. 111, 11359 (2007).
- P. Piecuch, J. R. Gour, and M. Włoch, Int. J. Quantum Chem. 108, 2128 (2008).
CC3
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
# build molecule using PySCF and run SCF calculation
mol = gto.M(
atom=[["O", (0.0, 0.0, -0.0180)],
["H", (0.0, 3.030526, -2.117796)],
["H", (0.0, -3.030526, -2.117796)]],
basis="cc-pvdz",
charge=0,
spin=0,
symmetry="C2V",
cart=False,
unit="Bohr",
)
mf = scf.RHF(mol)
mf.kernel()
# get the CCpy driver object using PySCF meanfield
driver = Driver.from_pyscf(mf, nfrozen=1)
# set calculation parameters
driver.options["energy_convergence"] = 1.0e-07 # (in hartree)
driver.options["amp_convergence"] = 1.0e-07
driver.options["maximum_iterations"] = 80
# run CC3 calculation
driver.run_cc(method="cc3")
- J. Chem. Phys. 106, 1808 (1997); doi: 10.1063/1.473322
- J. Chem. Phys. 103, 7429–7441 (1995); doi: 10.1063/1.470315
- J. Chem. Phys. 122, 054110 (2005); doi: 10.1063/1.1835953
CCSDt
The active-orbital-based CCSDt calculation
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
from ccpy.utilities.pspace import get_active_triples_pspace
# build molecule using PySCF and run SCF calculation
mol = gto.M(
atom=[["F", (0.0, 0.0, -2.66816)],
["F", (0.0, 0.0, 2.66816)]],
basis="cc-pvdz",
charge=0,
spin=0,
symmetry="D2H",
cart=True,
unit="Bohr",
)
mf = scf.RHF(mol)
mf.kernel()
# get the CCpy driver object using PySCF meanfield
driver = Driver.from_pyscf(mf, nfrozen=1)
# set the active space
driver.set_active_space(nact_occupied=5, nact_unoccupied=8)
# get triples entering P space corresponding to the CCSDt truncation scheme
t3_excitations = get_active_triples_pspace(driver.system,
driver.system.reference_symmetry,
num_active=1)
# set calculation parameters
driver.options["energy_convergence"] = 1.0e-07 # (in hartree)
driver.options["amp_convergence"] = 1.0e-07
driver.options["maximum_iterations"] = 80
# Run CC(P) calculation equivalent to CCSDt
driver.run_ccp(method="ccsdt_p", t3_excitations=t3_excitations)
The above CC(P)-based approach offers two advantages: (i) it can take advantage of
the Abelian point group symmetry of a molecule by restricting the CC calculation to
include only those triply excited cluster amplitudes belonging to a particular irrep,
as specified by the keyword target_irrep
and (ii) it can be used to perform other
types of active-orbital-based CCSDt calculations based on restricting num_active
occupied/unoccupied indices to the active set. The standard choice of
num_active=1
results in the usual CCSDt method, however num_active=2
and
num_active=3
result in the CCSDt(II) and CCSDt(III) approaches introduced in Ref. [X].
CC(t;3)
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
from ccpy.utilities.pspace import get_active_triples_pspace
# build molecule using PySCF and run SCF calculation
mol = gto.M(
atom=[["F", (0.0, 0.0, -2.66816)],
["F", (0.0, 0.0, 2.66816)]],
basis="cc-pvdz",
charge=0,
spin=0,
symmetry="D2H",
cart=True,
unit="Bohr",
)
mf = scf.RHF(mol)
mf.kernel()
# get the CCpy driver object using PySCF meanfield
driver = Driver.from_pyscf(mf, nfrozen=1)
# set the active space
driver.set_active_space(nact_occupied=5, nact_unoccupied=8)
# get triples entering P space corresponding to the CCSDt truncation scheme
t3_excitations = get_active_triples_pspace(driver.system,
driver.system.reference_symmetry)
# set calculation parameters
driver.options["energy_convergence"] = 1.0e-07 # (in hartree)
driver.options["amp_convergence"] = 1.0e-07
driver.options["maximum_iterations"] = 80
# Run CC(P) calculation equivalent to CCSDt
driver.run_ccp(method="ccsdt_p", t3_excitations=t3_excitations)
# build CCSD-like similarity-transformed Hamiltonian (this overwrites original MO integrals)
driver.run_hbar(method="ccsd")
# run companion left-CCSD-like calculation
driver.run_leftcc(method="left_ccsd")
# run CC(t;3) triples correction
driver.run_ccp3(method="ccp3", t3_excitations=t3_excitations)
As in the case of the CCSDt calculations, the general CC(P) approach allows one to perform alternative active-orbital-based truncation schemes of the CCSDt(II) and CCSDt(III) types in addition to the standard CCSDt method. The corresponding CC(P;Q) corrections result in the CC(t;3)(II), CC(t;3)(III), and CC(t;3) approaches, respectively.
CIPSI-driven CC(P;Q) aimed at converging CCSDT
from pathlib import Path
import numpy as np
from ccpy.drivers.driver import Driver
from ccpy.utilities.pspace import get_pspace_from_cipsi
TEST_DATA_DIR = str(Path(__file__).parents[1].absolute() / "data")
def test_cipsi_ccpq_h2o():
driver = Driver.from_gamess(
logfile=TEST_DATA_DIR + "/h2o/h2o-Re.log",
onebody=TEST_DATA_DIR + "/h2o/onebody.inp",
twobody=TEST_DATA_DIR + "/h2o/twobody.inp",
nfrozen=0,
)
civecs = TEST_DATA_DIR + "/h2o/civecs-10k.dat"
_, t3_excitations, _ = get_pspace_from_cipsi(civecs, driver.system, nexcit=3)
driver.run_ccp(method="ccsdt_p", t3_excitations=t3_excitations)
driver.run_hbar(method="ccsdt_p", t3_excitations=t3_excitations)
driver.run_leftccp(method="left_ccsdt_p", t3_excitations=t3_excitations)
driver.run_ccp3(method="ccp3", state_index=0, t3_excitations=t3_excitations)
- K. Gururangan, J. E. Deustua, J. Shen, and P. Piecuch, J. Chem. Phys. 155, 174114 (2021)
(see https://doi.org/10.1063/5.0064400; cf. also https://doi.org/10.48550/arXiv.2107.10994)
Adaptive CC(P;Q) aimed at converging CCSDT
import numpy as np
from pyscf import scf, gto
from ccpy.drivers.driver import Driver
from ccpy.drivers.adaptive import AdaptDriver
def test_adaptive_f2():
geometry = [["F", (0.0, 0.0, -2.66816)], ["F", (0.0, 0.0, 2.66816)]]
mol = gto.M(
atom=geometry,
basis="cc-pvdz",
charge=0,
spin=0,
symmetry="D2H",
cart=True,
unit="Bohr",
)
mf = scf.RHF(mol)
mf.kernel()
percentages = [0.0, 1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0, 9.0, 10.0]
driver = Driver.from_pyscf(mf, nfrozen=2)
driver.system.print_info()
driver.options["RHF_symmetry"] = False
adaptdriver = AdaptDriver(driver, percentage=percentages)
adaptdriver.options["energy_tolerance"] = 1.0e-08
adaptdriver.options["two_body_approx"] = True
adaptdriver.run()
- K. Gururangan and P. Piecuch, J. Chem. Phys. 159, 084108 (2023)
(see https://doi.org/10.1063/5.0162873; cf. also https://doi.org/10.48550/arXiv.2306.09638)
CC4
Approximate CC method with quadruples. Currently compatible with RHF references only.
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
# build molecule using PySCF and run SCF calculation
mol = gto.M(
atom=[["O", (0.0, 0.0, -0.0180)],
["H", (0.0, 3.030526, -2.117796)],
["H", (0.0, -3.030526, -2.117796)]],
basis="cc-pvdz",
charge=0,
spin=0,
symmetry="C2V",
cart=False,
unit="Bohr",
)
mf = scf.RHF(mol)
mf.kernel()
# get the CCpy driver object using PySCF meanfield
driver = Driver.from_pyscf(mf, nfrozen=1)
# set calculation parameters
driver.options["energy_convergence"] = 1.0e-07 # (in hartree)
driver.options["amp_convergence"] = 1.0e-07
driver.options["maximum_iterations"] = 80
# run CC4 calculation
driver.run_cc(method="cc4")
CIPSI-driven ec-CC-II and ec-CC-II3
from pathlib import Path
import numpy as np
from ccpy.drivers.driver import Driver
from ccpy.utilities.pspace import get_pspace_from_cipsi
TEST_DATA_DIR = str(Path(__file__).parents[1].absolute() / "data")
def test_eccc23_h2o():
driver = Driver.from_gamess(
logfile=TEST_DATA_DIR + "/h2o/h2o-Re.log",
onebody=TEST_DATA_DIR + "/h2o/onebody.inp",
twobody=TEST_DATA_DIR + "/h2o/twobody.inp",
nfrozen=0,
)
civecs = TEST_DATA_DIR + "/h2o/civecs-10k.dat"
_, t3_excitations, _ = get_pspace_from_cipsi(civecs, driver.system, nexcit=3)
driver.run_eccc(method="eccc2", ci_vectors_file=civecs)
driver.run_hbar(method="ccsd")
driver.run_leftcc(method="left_ccsd")
driver.run_ccp3(method="ccp3", state_index=0, t3_excitations=t3_excitations)
- I. Magoulas, K. Gururangan, P. Piecuch, J. E. Deustua, and J. Shen, J. Chem. Theory Comput. 17, 4006 (2021)
(see https://doi.org/10.1021/acs.jctc.1c00181; cf. also https://doi.org/10.48550/arXiv.2102.10143)
- ACCD
- ACCSD
- ACCSDt
- ACC(2,3)
- ACC(t;3)
- EOMCCSD
- CR-EOMCC(2,3) and its size-intensive δ-CR-EOMCC(2,3) extension
- EOMCCSD(T)(a)*
- EOM-CC3
- EOMCCSDt
- Excited-state CC(t;3)
- Adaptive CC(P;Q) aimed at converging EOMCCSDT
- EOMCCSDT
- SF-EOMCCSD
- SF-EOMCC(2,3)
- IP-EOMCCSD(2h-1p)
- IP-EOMCCSD(T)(a)*
- Active-space IP-EOMCCSD(3h-2p){No} (also known as IP-EOMCCSDt)
- IP-EOMCCSD(3h-2p)
- IP-EOMCCSDT
- EA-EOMCCSD(2p-1h)
- EA-EOMCCSD(T)(a)*
Active-space EA-EOMCCSD(3p-2h){Nu} (also known as EA-EOMCCSDt)
The active-space EA-EOMCCSDt approach obtains the ground and excited states of an (N+1)-electron target system using a full inclusion of 1p and 2p1h excitations and an active-orbital-based treatment of 3p2h correlations on top the CCSD description of the underlying N-electron reference species.
This example performs EA-EOMCCSDt calculations with an active space spanned by 2 unoccupied RHF orbitals to determine the C ^{2}Sigma+ state of the CH radical, as described with an aug-cc-pVDZ basis set, studied in Ref. [3].
from pyscf import gto, scf
from ccpy import Driver, get_active_3p2h_pspace
def test_eaeom3a_ch():
# Define CH geometry corresponding to the equilibrium in the C ^{2}Sigma+ state
mol = gto.M(atom='''C 0. 0. 0.
H 0. 0. 1.1143''',
basis="aug-cc-pvdz",
symmetry="C2V",
spin=0,
charge=1,
cart=False,
unit="angstrom")
# Run RHF for closed-shell CH+
mf = scf.RHF(mol)
mf.kernel()
# Get CCPy driver from PySCF mf
driver = Driver.from_pyscf(mf, nfrozen=1)
driver.system.print_info()
# Run CCSD
driver.run_cc(method="ccsd")
driver.run_hbar(method="ccsd")
# Locate the C ^{2}Sigma+ state of CH using an 1p + active 2p1h guess, where the 2p1h
# space is spanned by the highest 3 occupied and lowest 3 unoccupied RHF orbitals
# The state indices correspond as follows:
# state_index 1 -> C ^{2}Sigma+
driver.run_guess(method="eacisd",
nact_occupied=3,
nact_unoccupied=3,
roots_per_irrep={"A1": 3},
multiplicity=-1)
# Define the list of active 3p2h excitations |ijkAbc> obtained using 2 unoccupied active orbitals
driver.system.set_active_space(nact_occupied=0, nact_unoccupied=2)
r3_excitations = get_active_3p2h_pspace(driver.system, target_irrep="A1")
# Run the EA-EOMCCSDt calculation [via the general EA-EOMCC(P) solver]
driver.run_eaeomccp(method="eaeom3_p", state_index=1, r3_excitations=r3_excitations)
- J. R. Gour, P. Piecuch, and M. Włoch, J. Chem. Phys. 123, 134113 (2005).
- J. R. Gour, P. Piecuch, and M. Włoch, Int. J. Quantum Chem. 106, 2854 (2006).
- J. R. Gour and P. Piecuch, J. Chem. Phys. 125, 234107 (2006).
EA-EOMCCSD(3p-2h)
The EA-EOMCCSD(3p-2h) approach obtains the ground and excited states of an (N+1)-electron target system by treating the 1p, 2p1h, and 3p2h correlations on top the CCSD description of the underlying N-electron reference species.
This example performs EA-EOMCCSD(3p-2h) calculations to determine the C ^{2}Sigma+ state of the CH radical, as described with an aug-cc-pVDZ basis set, studied in Ref. [3].
from pyscf import gto, scf
from ccpy import Driver
def test_eaeom3_ch():
# Define CH geometry corresponding to the equilibrium in the C ^{2}Sigma+ state
mol = gto.M(atom='''C 0. 0. 0.
H 0. 0. 1.1143''',
basis="aug-cc-pvdz",
symmetry="C2V",
spin=0,
charge=1,
cart=False,
unit="angstrom")
# Run RHF for closed-shell CH+
mf = scf.RHF(mol)
mf.kernel()
# Get CCPy driver from PySCF mf
driver = Driver.from_pyscf(mf, nfrozen=1)
driver.system.print_info()
# Run CCSD
driver.run_cc(method="ccsd")
driver.run_hbar(method="ccsd")
# Locate the C ^{2}Sigma+ state of CH using an 1p + active 2p1h guess, where the 2p1h
# space is spanned by the highest 3 occupied and lowest 3 unoccupied RHF orbitals
# The state indices correspond as follows:
# state_index 1 -> C ^{2}Sigma+
driver.run_guess(method="eacisd",
nact_occupied=3,
nact_unoccupied=3,
roots_per_irrep={"A1": 3},
multiplicity=-1)
driver.run_eaeomcc(method="eaeom3", state_index=[1])
- J. R. Gour, P. Piecuch, and M. Włoch, J. Chem. Phys. 123, 134113 (2005).
- J. R. Gour, P. Piecuch, and M. Włoch, Int. J. Quantum Chem. 106, 2854 (2006).
- J. R. Gour and P. Piecuch, J. Chem. Phys. 125, 234107 (2006).
EA-EOMCCSDT
The EA-EOMCCSDT approach, introduced in Ref. [1], obtains the ground and excited states of an (N+1)-electron target system by treating the 1p, 2p1h, and 3p2h correlations on top the CCSDT description of the underlying N-electron reference species.
This example performs EA-EOMCCSDT calculations to determine the electron attachment energies of the carbon dimer studied in Ref. [1].
from pyscf import gto, scf
from ccpy import Driver
def test_eaeomccsdt_c2():
geom = [["C", (0.0, 0.0, 0.0)],
["C", (0.0, 0.0, 1.243)]]
mol = gto.M(atom=geom,
basis="cc-pvdz",
charge=0,
symmetry="D2H",
cart=False,
spin=0,
unit="Angstrom")
mf = scf.RHF(mol)
mf.kernel()
driver = Driver.from_pyscf(mf, nfrozen=2)
driver.system.print_info()
#
driver.run_cc(method="ccsdt")
driver.run_hbar(method="ccsdt")
#
driver.run_guess(method="eacisd", nact_occupied=0, nact_unoccupied=0,
multiplicity=-1, roots_per_irrep={"AG": 7}, use_symmetry=False)
driver.run_eaeomcc(method="eaeomccsdt", state_index=[0])
- M. Musiał and R. J. Bartlett, J. Chem. Phys 119, 1901 (2003).
DEA-EOMCCSD(3p-1h)
The DEA-EOMCCSD(3p-1h) approach obtains the ground and excited states of an (N+2)-electron target system by treating the 2p and 3p1h correlations on top the CCSD description of the underlying N-electron reference species.
This example performs DEA-EOMCCSD(3p-1h) calculations to determine the triplet ground state and the lowest-lying singlet state of the methylene biradical.
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
def test_deaeom3_ch2():
# Define the undelrying closed-shell methylene dication in PySCF
mol = gto.M(atom=[["C", (0.0, 0.0, 0.0)],
["H", (0.0, 1.644403, -1.32213)],
["H", (0.0, -1.644403, -1.32213)]],
basis="6-31g",
charge=2,
symmetry="C2V",
cart=True,
spin=0,
unit="Bohr")
# Run the RHF
mf = scf.RHF(mol)
mf.kernel()
driver = Driver.from_pyscf(mf, nfrozen=0)
driver.system.print_info()
# Run CCSD calculation
driver.run_cc(method="ccsd")
driver.run_hbar(method="ccsd")
# Locate the triplet ground state and lowest singlet excited state of methylene
# using a basic 2p (`deacis`) guess in an active space spanned by the 5 lowest
# unoccupied orbitals. The electronic states of methylene are labelled as follows:
# state_index 0 -> X ^{3}B1
# state_index 1 -> a ^{1}A1
driver.run_guess(method="deacis", multiplicity=-1, nact_unoccupied=5, roots_per_irrep={"A1": 6})
# Perform the DEA-EOMCCSD(3p-1h) calculation
driver.run_deaeomcc(method="deaeom3", state_index=[0, 1])
- M. Musiał, S. A. Kucharski, and R. J. Bartlett, J. Chem. Theory Comput. 7, 3088 (2011).
- A. O. Ajala, J. Shen, and P. Piecuch, J. Phys. Chem. A 121, 3469 (2017).
- J. Shen and P. Piecuch, J. Chem. Phys. 138, 194102 (2013).
- J. Shen and P. Piecuch, Mol. Phys. 112, 868 (2014).
- J. Shen and P. Piecuch, Mol. Phys. 119, e1966534 (2021).
- S. Gulania, E. F. Kjønstad, J. F. Stanton, H. Koch, and A. I. Krylov, J. Chem. Phys. 154, 114115 (2021).
DEA-EOMCCSD(4p-2h)
The DEA-EOMCCSD(4p-2h) approach obtains the ground and excited states of an (N+2)-electron target system by treating the 2p, 3p1h, and 4p2h correlations on top the CCSD description of the underlying N-electron reference species.
This example performs DEA-EOMCCSD(4p-2h) calculations to determine the triplet ground state and the lowest-lying singlet state of the methylene biradical.
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
def test_deaeom4_ch2():
# Define the undelrying closed-shell methylene dication in PySCF
mol = gto.M(atom=[["C", (0.0, 0.0, 0.0)],
["H", (0.0, 1.644403, -1.32213)],
["H", (0.0, -1.644403, -1.32213)]],
basis="6-31g",
charge=2,
symmetry="C2V",
cart=True,
spin=0,
unit="Bohr")
# Run the RHF
mf = scf.RHF(mol)
mf.kernel()
driver = Driver.from_pyscf(mf, nfrozen=0)
driver.system.print_info()
# Run CCSD calculation
driver.run_cc(method="ccsd")
driver.run_hbar(method="ccsd")
# Locate the triplet ground state and lowest singlet excited state of methylene
# using a basic 2p (`deacis`) guess in an active space spanned by the 5 lowest
# unoccupied orbitals. The electronic states of methylene are labelled as follows:
# state_index 0 -> X ^{3}B1
# state_index 1 -> a ^{1}A1
driver.run_guess(method="deacis", multiplicity=-1, nact_unoccupied=5, roots_per_irrep={"A1": 6})
# Perform the DEA-EOMCCSD(4p-2h) calculation
driver.run_deaeomcc(method="deaeom4", state_index=[0, 1])
- A. O. Ajala, J. Shen, and P. Piecuch, J. Phys. Chem. A 121, 3469 (2017).
- J. Shen and P. Piecuch, J. Chem. Phys. 138, 194102 (2013).
- J. Shen and P. Piecuch, Mol. Phys. 112, 868 (2014).
- J. Shen and P. Piecuch, Mol. Phys. 119, e1966534 (2021)
DIP-EOMCCSD(3h-1p)
The DIP-EOMCCSD(3h-1p) approach, introduced in Refs. [1,2] below, obtains the ground and excited states of an (N-2)-electron target system by treating the 2h and 3h1p correlations on top the CCSD description of the underlying N-electron reference species.
This example performs DIP-EOMCCSD(3h-1p) calculations to determine the DIPs of the chlorine molecule, as described using a cc-pVDZ basis set, corresponding to the states listed in Table III of the paper K. Gururangan, A. K. Dutta, and P. Piecuch, "Double Ionization Potential Equation-of-Motion Coupled-Cluster Approach with Full Inclusion of 4-Hole–2-Particle Excitations and Three-Body Clusters", available at https://doi.org/10.48550/arXiv.2412.10688.
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
def test_dipeom3_cl2():
# Define the geometry [R(Cl-Cl) = 1.987 angstrom]
geom = [["Cl", (0.0, 0.0, 0.0)],
["Cl", (0.0, 0.0, 1.987)]]
# Set up the RHF calculation using PySCF
mol = gto.M(atom=geom, basis="cc-pvdz", symmetry="D2H", unit="Angstrom", cart=False, charge=0)
mf = scf.RHF(mol)
mf = mf.x2c() # Use SFX2C-1e treatment of scalar relativity
mf.kernel()
# Create the CCpy driver out of PySCF meanfield
driver = Driver.from_pyscf(mf, nfrozen=10)
driver.system.print_info()
# Run CCSD for neutral Cl2
driver.run_cc(method="ccsd")
driver.run_hbar(method="ccsd")
# Locate selected states of (Cl2)^{2+} located using 2h (`dipcis`) guess
# The state indices correlate to electronic states of (Cl2)^{2+} as follows:
# state_index 0 -> X ^{3}Sigma_g-
# state_index 1 -> a ^{1}Delta_g
# state_index 2 -> b ^{1}Sigma_g+
# state_index 3 -> c ^{1}Sigma_u-
driver.run_guess(method="dipcis",
multiplicity=-1,
nact_occupied=driver.system.noccupied_alpha,
roots_per_irrep={"A1": 10},
use_symmetry=False)
# Run DIP-EOMCCSD(3h-1p) calculation for selected states
driver.run_dipeomcc(method="dipeom3", state_index=[0, 1, 3, 4])
- M. Wladyslawski and M. Nooijen, in Low-Lying Potential Energy Surfaces, ACS Symposium Series, Vol. 828, edited by M. R. Hoffmann and K. G. Dyall (American Chemical Society, Washington, D.C., 2002) pp. 65–92.
- M. Nooijen, Int. J. Mol. Sci. 3, 656 (2002).
- M. Musia l, A. Perera, and R. J. Bartlett, J. Chem. Phys. 134, 114108 (2011).
- T. Kuś and A. I. Krylov, J. Chem. Phys. 135, 084109 (2011).
- T. Kuś and A. I. Krylov, J. Chem. Phys. 136, 244109 (2012).
- J. Shen and P. Piecuch, J. Chem. Phys. 138, 194102 (2013).
- J. Shen and P. Piecuch, Mol. Phys. 112, 868 (2014).
DIP-EOMCCSD(4h-2p)
The DIP-EOMCCSD(4h-2p) approach, introduced in Refs. [1,2] below, obtains the ground and excited states of an (N-2)-electron target system by treating the 2h, 3h1p, and 4h2p correlations on top the CCSD description of the underlying N-electron reference species.
This example performs DIP-EOMCCSD(4h-2p) calculations to determine the DIPs of the chlorine molecule, as described using a cc-pVDZ basis set, corresponding to the states listed in Table III of the paper K. Gururangan, A. K. Dutta, and P. Piecuch, "Double Ionization Potential Equation-of-Motion Coupled-Cluster Approach with Full Inclusion of 4-Hole–2-Particle Excitations and Three-Body Clusters", available at https://doi.org/10.48550/arXiv.2412.10688.
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
def test_dipeom4_cl2():
# Define the geometry [R(Cl-Cl) = 1.987 angstrom]
geom = [["Cl", (0.0, 0.0, 0.0)],
["Cl", (0.0, 0.0, 1.987)]]
# Set up the RHF calculation using PySCF
mol = gto.M(atom=geom, basis="cc-pvdz", symmetry="D2H", unit="Angstrom", cart=False, charge=0)
mf = scf.RHF(mol)
mf = mf.x2c() # Use SFX2C-1e treatment of scalar relativity
mf.kernel()
# Create the CCpy driver out of PySCF meanfield
driver = Driver.from_pyscf(mf, nfrozen=10)
driver.system.print_info()
# Run CCSD for neutral Cl2
driver.run_cc(method="ccsd")
driver.run_hbar(method="ccsd")
# Locate selected states of (Cl2)^{2+} using 2h (`dipcis`) guess
# The state indices correlate to electronic states of (Cl2)^{2+} as follows:
# state_index 0 -> X ^{3}Sigma_g-
# state_index 1 -> a ^{1}Delta_g
# state_index 2 -> b ^{1}Sigma_g+
# state_index 3 -> c ^{1}Sigma_u-
driver.run_guess(method="dipcis",
multiplicity=-1,
nact_occupied=driver.system.noccupied_alpha,
roots_per_irrep={"A1": 10},
use_symmetry=False)
# Run DIP-EOMCCSD(4h-2p) calculation for selected states
driver.run_dipeomcc(method="dipeom4", state_index=[0, 1, 3, 4])
- J. Shen and P. Piecuch, J. Chem. Phys. 138, 194102 (2013).
- J. Shen and P. Piecuch, Mol. Phys. 112, 868 (2014).
DIP-EOMCCSD(T)(a)(4h-2p)
The DIP-EOMCCSD(T)(a)(4h-2p) approach, introduced in Ref. [1] below, obtains the ground and excited states of an (N-2)-electron target system by treating the 2h, 3h1p, and 4h2p correlations on top the CCSD(T)(a) description of the underlying N-electron reference species.
This example performs DIP-EOMCCSD(T)(a)(4h-2p) calculations to determine the DIPs of the chlorine molecule, as described using a cc-pVDZ basis set, corresponding to the states listed in Table III of Ref. [1].
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
def test_dipeomccsdta_cl2():
# Define the geometry [R(Cl-Cl) = 1.987 angstrom]
geom = [["Cl", (0.0, 0.0, 0.0)],
["Cl", (0.0, 0.0, 1.987)]]
# Set up the RHF calculation using PySCF
mol = gto.M(atom=geom, basis="cc-pvdz", symmetry="D2H", unit="Angstrom", cart=False, charge=0)
mf = scf.RHF(mol)
mf = mf.x2c() # Use SFX2C-1e treatment of scalar relativity
mf.kernel()
# Create the CCpy driver out of PySCF meanfield
driver = Driver.from_pyscf(mf, nfrozen=10)
driver.system.print_info()
# Run CCSD for neutral Cl2
driver.run_cc(method="ccsd")
driver.run_hbar(method="ccsd")
# Locate selected states of (Cl2)^{2+} using 2h (`dipcis`) guess
# The state indices correlate to electronic states of (Cl2)^{2+} as follows:
# state_index 0 -> X ^{3}Sigma_g-
# state_index 1 -> a ^{1}Delta_g
# state_index 2 -> b ^{1}Sigma_g+
# state_index 3 -> c ^{1}Sigma_u-
driver.run_guess(method="dipcis",
multiplicity=-1,
nact_occupied=driver.system.noccupied_alpha,
roots_per_irrep={"A1": 10},
use_symmetry=False)
# Run DIP-EOMCCSDT(T)(a)(4h-2p) calculation for selected states
driver.run_dipeomcc(method="dipeomccsdta", state_index=[0, 1, 3, 4])
- K. Gururangan, A. K. Dutta, and P. Piecuch, “Double Ionization Potential Equation-of-Motion Coupled-Cluster Approach with Full Inclusion of 4-Hole-2-Particle Excitations and Three-Body Clusters,” (2024), arXiv:2412.10688.
DIP-EOMCCSDT(4h-2p)
The DIP-EOMCCSDT(4h-2p) approach, introduced in Ref. [1] below, obtains the ground and excited states of an (N-2)-electron target system by treating the 2h, 3h1p, and 4h2p correlations on top the CCSDT description of the underlying N-electron reference species.
This example performs DIP-EOMCCSDT(4h-2p) calculations to determine the DIPs of the chlorine molecule, as described using a cc-pVDZ basis set, corresponding to the states listed in Table III Ref. [1].
from pyscf import gto, scf
from ccpy.drivers.driver import Driver
def test_dipeomccsdt_cl2():
# Define the geometry [R(Cl-Cl) = 1.987 angstrom]
geom = [["Cl", (0.0, 0.0, 0.0)],
["Cl", (0.0, 0.0, 1.987)]]
# Set up the RHF calculation using PySCF
mol = gto.M(atom=geom, basis="cc-pvdz", symmetry="D2H", unit="Angstrom", cart=False, charge=0)
mf = scf.RHF(mol)
mf = mf.x2c() # Use SFX2C-1e treatment of scalar relativity
mf.kernel()
# Create the CCpy driver out of PySCF meanfield
driver = Driver.from_pyscf(mf, nfrozen=10)
driver.system.print_info()
# Run CCSDT for neutral Cl2
driver.run_cc(method="ccsdt")
driver.run_hbar(method="ccsdt")
# Locate selected states of (Cl2)^{2+} using 2h (`dipcis`) guess
# The state indices correlate to electronic states of (Cl2)^{2+} as follows:
# state_index 0 -> X ^{3}Sigma_g-
# state_index 1 -> a ^{1}Delta_g
# state_index 2 -> b ^{1}Sigma_g+
# state_index 3 -> c ^{1}Sigma_u-
driver.run_guess(method="dipcis",
multiplicity=-1,
nact_occupied=driver.system.noccupied_alpha,
roots_per_irrep={"A1": 10},
use_symmetry=False)
# Run DIP-EOMCCSDT(4h-2p) calculation for selected states
driver.run_dipeomcc(method="dipeomccsdt", state_index=[0, 1, 3, 4])
- K. Gururangan, A. K. Dutta, and P. Piecuch, “Double Ionization Potential Equation-of-Motion Coupled-Cluster Approach with Full Inclusion of 4-Hole-2-Particle Excitations and Three-Body Clusters,” (2024), arXiv:2412.10688.
CCpy is currently run and tested on Linux and Mac OS devices. Linux users (including WSL users) can choose to install a pre-compiled version of CCpy from the PyPI server (simplest option) or download the source code and install it manually. For now, Mac OS users must download and install the source code (wheels for Mac OS will be uploaded to PyPI in the near future).
For Linux machines, latest distribution copy of CCpy that is available on PyPI can be obtained by running
pip install coupled-cluster-py
Note: The distribution version of CCpy on PyPI is not necessarily the latest version of CCpy. To have access to the latest version of CCpy, including the most recently developed methods [DIP-EOMCCSDT(4h-2p) and DIP-EOMCCSD(T)(a)(4h-2p)], you should download and install CCpy via source code (see below).
In order to install CCpy from source, we recommend creating a new environment for CCpy by running
conda create --name=ccpy_env python=3.12
You need reasonably up-to-date Fortran/C compilers as well as openblas
, cmake
, and pkgconfig
.
If you already have these packages installed, then you can skip this step. Otherwise, local copies
of these packages can be obtained within the Conda environment using
conda install -c conda-forge gfortran
conda install openblas
conda install pkgconfig cmake
Now, we are ready to install CCpy.
git clone https://github.com/piecuch-group/ccpy.git
Next, enter the ccpy
directory
cd ccpy
Dependencies are listed in requirements-dev.txt
. You can install all of them via
pip install -r requirements-dev.txt
Run the following command to install CCpy in editable mode (via --editable
). This way, the
Meson backend will automatically update the package with any changes you make to either Python
or Fortran/C code without any additional compilation steps. Additional details about developing
within CCpy can be found on the online documentation page.
pip install --no-build-isolation --verbose --editable .
Note: If Meson is having issues with finding openblas
, make sure that the environment variable
PKG_CONFIG_PATH
points to the directory that includes the openblas.pc
file. This should be
located within openblas/lib
, or something similar.
Karthik Gururangan
Doctoral student, Department of Chemistry, Michigan State University
e-mail: gururang@msu.edu
(lead developer)
Dr. J. Emiliano Deustua
COO and Co-founder, Examol
(co-developer)
Professor Piotr Piecuch
University Distinguished Professor and MSU Research Foundation Professor, Department of Chemistry, Michigan State University
Adjunct Professor, Department of Physics and Astronomy, Michigan State University
e-mail: piecuch@chemistry.msu.edu
(co-developer and principal investigator)
Additional contributors: Tiange Deng (doctoral student, Department of Chemistry, Michigan State University; ACCD and ACCSD options).
We acknowledge support from the Chemical Sciences, Geosciences and Biosciences Division, Office of Basic Energy Sciences, Office of Science, U.S. Department of Energy (Grant No. DE-FG02-01ER15228 to Piotr Piecuch).
CCpy is an open-source code under the GPLv3 license developed and maintained by the Piecuch Group at Michigan State University.