Extensions#

Due to its flexibility and modular nature, many extensions have been developed based on PySCF. As a courtesy, repositories for some of these extensions are hosted by the PySCF organization’s GitHub. However, the PySCF organization provides no support for these extensions, nor a guarantee of future compatibility. Questions should be addressed to the authors of the extension, and issues can be raised on the GitHub repository of the extension.

Once an extension module has been correctly installed (see How to install extensions), you can use it as a regular submodule of PySCF, e.g.,

import pyscf
from pyscf.semiempirical import MINDO3
mol = pyscf.M(atom='N 0 0 0; N 0 0 1')
MINDO3(mol).run()

A list of PySCF extensions is given below.

Project

URL

cas_ac0

https://github.com/CQCL/pyscf-ac0

cornell-shci

https://github.com/pyscf/cornell-shci

ccpy

https://github.com/piecuch-group/ccpy

cppe

https://github.com/maxscheurer/cppe

dftd3

https://github.com/pyscf/dftd3

dispersion

https://github.com/pyscf/dispersion

dmrgscf

https://github.com/pyscf/dmrgscf

doci

https://github.com/pyscf/doci

fciqmc

https://github.com/pyscf/fciqmc

forge

https://github.com/pyscf/pyscf-forge

icmpspt

https://github.com/pyscf/icmpspt

mbd

https://github.com/pyscf/mbd

naive-hci

https://github.com/pyscf/naive-hci

nao

https://github.com/pyscf/nao

properties

https://github.com/pyscf/properties

pyqmc

https://github.com/WagnerGroup/pyqmc

qsdopt

https://github.com/pyscf/qsdopt

rt

https://github.com/pyscf/rt

semiempirical

https://github.com/pyscf/semiempirical

shciscf

https://github.com/pyscf/shciscf

zquatev

https://github.com/sunqm/zquatev

tblis

https://github.com/pyscf/pyscf-tblis

How to install extensions#

Many extension modules (e.g., the semiempirical module) can be installed using pip’s extra dependency mechanism,

pip install pyscf[semiempirical]

Although not recommended, all extension modules can be installed,

pip install pyscf[all]

How to install extensions (advanced)#

Based on the technique of namespace packages specified in PEP 420, PySCF has developed a couple of methods to install the extension modules.

Pip command#

For pip version newer than 19.0, projects hosted on GitHub can be installed on the command line,

pip install git+https://github.com/pyscf/semiempirical

A particular release on GitHub can be installed with the release URL you can look up on GitHub,

pip install https://github.com/pyscf/semiempirical/archive/v0.1.0.tar.gz

Pip command for local paths#

If you wish to load an extension module developed in a local directory, you can use the local install mode of pip. Use of a Python virtual environment is recommended to avoid polluting the system default Python runtime environment, for example,

python -m venv /home/abc/pyscf-local-env
source /home/abc/pyscf-local-env/bin/activate
git clone https://github.com/pyscf/semiempirical /home/abc/semiempirical
pip install -e /home/abc/semiempirical

Environment variable PYSCF_EXT_PATH#

You can place the location of each extension module (or a file that contains these locations) in this environment variable. The PySCF library will parse the paths defined in this environment variable, and load the relevant submodules. For example,

git clone https://github.com/pyscf/semiempirical /home/abc/semiempirical
git clone https://github.com/pyscf/doci /home/abc/doci
git clone https://github.com/pyscf/dftd3 /home/abc/dftd3
echo /home/abc/doci > /home/abc/.pyscf_ext_modules
echo /home/abc/dftd3 >> /home/abc/.pyscf_ext_modules
export PYSCF_EXT_PATH=/home/abc/semiempirical:/home/abc/.pyscf_ext_modules

Using this definition of PYSCF_EXT_PATH, the three extension submodules (semiempirical, doci, dftd3) are loaded when PySCF is imported, and you don’t have to use a Python virtual environment.