Arbitrary floating-point types
Since DFTK is completely generic in the floating-point type in its routines, there is no reason to perform the computation using double-precision arithmetic (i.e.Float64
). Other floating-point types such as Float32
(single precision) are readily supported as well. On top of that we already reported[HLC2020] calculations in DFTK using elevated precision from DoubleFloats.jl or interval arithmetic using IntervalArithmetic.jl. In this example, however, we will concentrate on single-precision computations with Float32
.
The setup of such a reduced-precision calculation is basically identical to the regular case, since Julia automatically compiles all routines of DFTK at the precision, which is used for the lattice vectors. Apart from setting up the model with an explicit cast of the lattice vectors to Float32
, there is thus no change in user code required:
using DFTK
using PseudoPotentialData
using AtomsBuilder
# Use AtomsBuilder to setup silicon lattice and cast model to Float32
pseudopotentials = PseudoFamily("cp2k.nc.sr.lda.v0_1.largecore.gth")
model = model_DFT(bulk(:Si); functionals=LDA(), pseudopotentials)
basis = PlaneWaveBasis(convert(Model{Float32}, model), Ecut=7, kgrid=[4, 4, 4])
# Run the SCF
scfres = self_consistent_field(basis, tol=1e-3);
n Energy log10(ΔE) log10(Δρ) Diag Δtime
--- --------------- --------- --------- ---- ------
1 -7.900588035583 -0.70 4.6 56.5ms
2 -7.905044555664 -2.35 -1.52 1.0 36.7ms
3 -7.905212402344 -3.78 -2.52 1.2 37.8ms
4 -7.905243873596 -4.50 -2.84 2.5 46.8ms
5 -7.905244827271 -6.02 -3.01 1.1 37.7ms
To check the calculation has really run in Float32, we check the energies and density are expressed in this floating-point type:
scfres.energies
Energy breakdown (in Ha):
Kinetic 3.1034999
AtomicLocal -2.1992576
AtomicNonlocal 1.7305341
Ewald -8.3994751
PspCorrection -0.2947882
Hartree 0.5533737
Xc -2.3991311
total -7.905244827271
eltype(scfres.energies.total)
Float32
eltype(scfres.ρ)
Float32
For more unusual floating-point types (like IntervalArithmetic or DoubleFloats), which are not directly supported in the standard LinearAlgebra
and FFTW
libraries one additional step is required: One needs to explicitly enable the generic versions of standard linear-algebra operations like cholesky
or qr
or standard fft
operations, which DFTK requires. THis is done by loading the GenericLinearAlgebra
package in the user script (i.e. just add ad using GenericLinearAlgebra
next to your using DFTK
call).
- HLC2020M. F. Herbst, A. Levitt, E. Cancès. A posteriori error estimation for the non-self-consistent Kohn-Sham equations ArXiv 2004.13549