Exercise: Comparing Fe Polymorphs

Overview

Now it's time to try some VASP calculations on your own. Our goal in this task will be to study bulk Fe. Specifically, we will use VASP to determine which is more stable: iron in the cubic phase or hexagonal phase. Try to do this yourself!
In order to complete this goal, you will need to:
    .1Create initial guess structures for both phases of bulk Fe.
    .2Relax both the atomic positions and cell shape/volume for each material to ensure they are at their local minimum energy configuration.
    .3Compare their energies to determine which is more stable and by how much.
I strongly encourage you to try this exercise yourself first! But when you get stuck or if you want you to compare your results, check out the walkthrough below.

Tasks

Fetch Initial Structures

Go to the  Materials Project  and download structures mp-13 (i.e. cubic Fe) and mp-136 (i.e. hexagonal Fe).
Normally, you would either construct the structure yourself or download the experimental crystal structure from a data repository. Here, we will use the Materials Project as a way to acquaint yourself with this powerful resource. The Materials Project contains DFT-computed data, so it actually answers our question already, but you can confirm for yourself now!

Input File Setup

Make the relevant VASP input files (i.e. INCAR, KPOINTS, POSCAR, POTCAR, submission script) for both materials, referring to  ✍️Input Files  for help. Some questions to get you critically thinking about how to approach this are included below:

INCAR

  • What value of ENCUT should you pick? Strictly speaking, you should run a "static" (i.e. single-point calculation) and do a convergence test to determine an appropriate value.
  • In practice, you can later use often try ~520 eV as a good starting point.
  • Warning: If you do try to converge ENCUT, do not do so while LASPH set to True. It won't work.
  • Picking the exchange-correlation functional is one of the most important parts of DFT. Here, let's use PBE to be roughly compatible with the Materials Project. What do you have to set in the INCAR to use PBE?
  • You want to run a geometry optimization. Which flags should you set to ensure that this is done?
  • Iron is known to be magnetic in its ground-state. You will need to run the calculation with spin-polarization. Which flags should you set? And what might be an appropriate guess for the initial magnetic moments?

KPOINTS

  • How many k-points should you use? Strictly speaking, you should run a "static" (i.e. single-point calculation) and do a convergence test to determine an appropriate value.
  • In practice, you can often try a density of ~100 normalized by volume via the kpoints_by_vol function as a good starting point.
  • Will you need to use the vasp_std or vasp_gam executable given your choice of k-points?

POSCAR

  • You'll get this from the Materials Project, as described above. Is it a primitive cell though? It might be worth checking so that you don't waste unecessary compute!

POTCAR

  • There are multiple types of pseudopotentials for Fe. What does  VASP recommend  as a good default? What does Fe vs. Fe_pv vs. Fe_sv mean anyway?

Results Analysis

When you successfully ran your calculations:
    .1What are the converged lattice constants for each material?
    .2What are their relative energies? Note: you will have to normalize them on a per-atom basis so that they are directly comparable!
    .3Which phase is more stable?
    .4How do your results compare to the Materials Project?

ASE

If you are learning to use the  Atomic Simulation Environment  ( ASE ), the following script can be used to carry out the same calculation in the YouTube video.
from ase.calculators.vasp import Vasp
from ase.io import read

# Read in the structure to make an Atoms object
atoms = read("MyStructure.cif")

# Set up the VASP calculator
calc = Vasp(
encut=520, # plane-wave kinetic energy cutoff (convergence parameter)
kpts=[10, 10, 10], # k-points in each dimension
xc="PBE", # exchange-correlation functional ("level of theory"); sets GGA = PE here
algo="fast", # SCF convergence algorithm
ediff=1e-5, # SCF convergence criterion (eV)
ismear=0, # smearing method (0 = Gaussian smearing)
sigma=0.05, # smearing width (eV)
lasph=True, # non-spherical corrections for 3d elements
prec="accurate", # high-precision calculations
ediffg=-0.03, # relaxation convergence criterion (eV/A)
ibrion=2, # relaxation algorithm (2 = conjugate-gradient)
isif=3, # relaxation degrees of freedom (3 = relax positions+cell shape+cell volume)
nsw=100, # maximum number of relaxation steps
lorbit=11, # print out magnetic moments
)

# Set the calculator for the Atoms object
atoms.calc = calc

# Set the initial magnetic moments (will auto-set ISPIN and MAGMOM)
atoms.set_initial_magnetic_moments([4.0, 4.0])

# Run the VASP calculation
atoms.get_potential_energy()