PSI4 provides a wide variety of quantum chemical methods using state-of-the-art numerical methods and algorithms. Several parts of the code feature shared-memory parallelization to run efficiently on multi-core machines (see Sec. Threading). An advanced parser written in Python allows the user input to have a very simple style for routine computations, but it can also automate very complex tasks with ease.
In this section, we provide an overview of some of the features of PSI4 along with the prerequisite steps for running calculations. Sec. Tutorial provides a brief tutorial to help new users get started. Section Psithon offers further details into the structure of PSI4 input files, and how Python can be mixed with quantum chemistry directives in PSI4. Section Psithon Functions provides more detail on the Python functions provided by PSI4 and discusses some of the higher-level functions such as counterpoise correction, complete-basis-set extrapolation, and running computations on an entire database of molecules at a time. Later sections deal with the different types of computations which can be done using PSI4 (e.g., Hartree–Fock, MP2, coupled-cluster) and general procedures such as geometry optimization and vibrational frequency analysis. The Appendix includes a complete description of all possible input keywords for each module, as well as tables of available basis sets and a listing of the sample input files available under psi4/samples.
The user is urged to examine this directory of sample inputs, as most common types of computations are represented there. For the latest PSI4 documentation, check www.psicode.org.
The following citation should be used in any publication utilizing the PSI4 program package:
Depending on the particular modules used, the user may also wish to cite some of the following references for theoretical, algorithmic, or implementation contributions specific to PSI4 (in addition to appropriate references for the underlying theory):
DCFT
ADC(2)
PR-CIS(D) and PR-ADC(2)
CI
CC
Mk-MRCCSD
Mk-MRCCSD(T)
Mk-MRCCSDT(-n)
Mk-MRPT2
SAPT (General)
All capabilities of the SAPT module are based on Symmetry Adapted Perturbation Theory. A good review article for this method is as follows:
The particular implementation and algorithms for various orders of SAPT available in PSI4 are provided below.
SAPT0
SAPT2, SAPT2+, SAPT2+(3), SAPT2+3
Using Natural Orbitals in SAPT
The latest version of the PSI4 program package may be obtained at www.psicode.org. The source code is available as a gzipped tar archive (named, for example, psi4.X.tar.gz, and binaries may be available for certain architectures. For detailed installation and testing instructions, please refer to the installation instructions at the PSI4 website above or to the file psi4/INSTALL distributed with the package. Additional compilation hints may be found at Psi Compiling.
The majority of PSI4 was developed on Mac and Linux machines. In principle, it should work on any Unix system; however, we have not tested extensively on systems other than Mac and Linux. There is not a Windows version of PSI4.
PSI4 has been successfully compiled using Intel, GCC, and Clang compilers. For the Intel compilers, use versions 11 or 12.1 (we have had trouble with version 12.0).
PSI4 can perform ab initio computations employing basis sets of contrated Gaussian-type functions of virtually arbitrary orbital quantum number. Many parts of PSI4 can recognize and exploit the largest Abelian subgroup of the molecular point group. Table Methods displays the range of theoretical methods available in PSI4. For more details, see Tables Energy, Energy (DFT), Energy (MRCC), Gradient, and Frequency.
Method | Energy | Gradient | Reference | Parallelism |
---|---|---|---|---|
SCF | Y | Y [4] | RHF/ROHF/UHF | threaded |
DF-SCF | Y | Y [4] | RHF/ROHF/UHF | threaded |
DCFT | Y | Y | UHF | partially threaded |
SAPT | Y | — | RHF | threaded |
MP2 | Y | Y [2] | RHF/ROHF/UHF | threaded [3] |
DF-MP2 | Y | — | RHF | threaded |
ADC(2) | Y | — | RHF/ROHF | threaded [3] |
CI(n) | Y | — | RHF/ROHF | threaded (pthreads) |
RAS-CI | Y | — | RHF/ROHF | threaded (pthreads) |
MP(n) | Y | — | RHF/ROHF | threaded (pthreads) |
ZAPT(n) | Y | — | RHF/ROHF | threaded (pthreads) |
CC2 | Y | — | RHF/ROHF/UHF | threaded [3] |
CCSD | Y | Y | RHF/ROHF/UHF | threaded [3] |
CCSD(T) | Y | Y [1] | RHF/ROHF/UHF | threaded (pthreads) |
CC3 | Y | — | RHF/ROHF/UHF | threaded (pthreads) |
EOM-CCSD | Y | Y | RHF/ROHF/UHF | threaded [3] |
Mk-MRCCSD | Y | N | RHF/ROHF/TCSCF | threaded [3] |
Mk-MRCCSD(T) | Y | N | RHF/ROHF/TCSCF | threaded [3] |
Mk-MRPT2 | Y | N | RHF/ROHF/TCSCF | threaded [3] |
Geometry optimization (currently restricted to true minima on the potential energy surface) can be performed using either analytic gradients or energy points. Likewise, vibrational frequencies can be computed by analytic second derivatives, by finite differences of analytic gradients, or by finite differences of energies. PSI4 can also compute an extensive list of one-electron properties.
The PSI4 package is distributed for free and without any guarantee of reliability, accuracy, or suitability for any particular purpose. No obligation to provide technical support is expressed or implied. As time allows, the developers will attempt to answer inquiries directed to crawdad@vt.edu. For bug reports, specific and detailed information, with example inputs, would be appreciated. Questions or comments regarding this user’s manual may be sent to sherrill@gatech.edu.
Footnotes
[1] | UHF-CCSD(T) gradients only, as of beta2 |
[2] | RHF reference only. DF-MP2 is recommended as a faster alternative. |
[3] | (1, 2, 3, 4, 5, 6, 7, 8) threading through BLAS routines only |
[4] | (1, 2) DFT gradients only implemented for SCF type DF. LRC-DFT gradients not implemented yet. |