External calculators¶
Many external calculators can be used with ASE, including GPAW, Abinit, Vasp, Siesta, Quantum ESPRESSO, Asap, LAMMPS and many more, see Supported calculators for the full list.
Setting up an external calculator with ASE¶
This tutorial will cover how to set up a basic calculation in ASE, using an external calculator.
We will be using the Vasp
class in this example, other calculators can be used in a similar manner. For details please refer to the documentation of the specific calculators Supported calculators.
Important: ASE does not provide code or a license for VASP, and these must be acquired elsewhere. ASE only creates an interface with VASP, so that you can use the ASE provided tools together with VASP.
Setting up¶
The first step, is to tell ASE how to execute VASP, and where to find the pseudopotentials. You will need to have two environment variables defined:
$ export ASE_VASP_COMMAND="mpiexec $HOME/vasp/bin/vasp_std"
$ export VASP_PP_PATH=$HOME/vasp/mypps
The first environment variable ASE_VASP_COMMAND
is the default way to execute VASP, and should be defined in the same way, that you could normally execute a VASP run. Here we assume that the VASP executable, vasp_std
, is located in $HOME/vasp/bin
. Note, that if you want to execute VASP in parallel, this call should also include the MPI executable, which in this case is mpiexec
.
The second variable, VASP_PP_PATH
, is the path to the VASP pseudopotentials.
An additional (optional) variable for the vdw_kernel.bindat
file, which is required when doing van der Waals calculations, where luse_vdw=True
.
$ export ASE_VASP_VDW=$HOME/<path-to-vdw_kernel.bindat-folder>
Note, that this should target the folder, and not the file itself.
Your first run¶
Now that ASE knows how to execute VASP, we can try setting up a simple calculation. First we set up an atoms object
from ase.build import molecule
atoms = molecule('N2')
atoms.center(vacuum=5)
To perform a VASP DFT calculation, we now set up a calculator object.
from ase.calculators.vasp import Vasp
calc = Vasp(xc='pbe', # Select exchange-correlation functional
encut=400, # Plane-wave cutoff
kpts=(1, 1, 1)) # k-points
atoms.calc = calc
en = atoms.get_potential_energy() # This call will start the calculation
print('Potential energy: {:.2f} eV'.format(en))
Which results in the following output:
Potential energy: -16.59 eV
The flow of how ASE interfaces with VASP, is that ASE handles writing the input files, which are required for the run, and then executes the ASE_VASP_COMMAND
, i.e. executes VASP.
Once the VASP run is complete, ASE then reads all of the relevant files, in this case the OUTCAR
, vasprun.xml
and CONTCAR
, and stores properties in the calculator object.
For more information on the capabilities of the VASP calculators, please refer to VASP. For other calculators, please refer to the Calculators page.