This lesson shows how to calculate physical properties related to strain, for an insulator and a metal :
This lesson should take about two hours.
Before beginning, you might consider working in a different subdirectory
                 as for the other lessons.
Why not create "Work_elast" in ~abinit/tests/tutorespfn/Input ? 
                    
You should copy the files ~abinit/tests/tutorespfn/Input/telast_1.files and telast_1.in into Work_elast. You may wish to start the calculation (less than one minute on a standard 3GHz machine) before you read the following. You should open your input file telast_1.in with an editor and examine it as you read this discussion.
The hypothetical wurtzite structure for AlAs retains the tetrahedral coordination
                 of the atoms of the actual zincblende structure of AlAs,
but    has    a  hexagonal       lattice.  It was chosen for this lesson
because    the atomic     positions   are   not completely determined by
symmetry.   Both the atomic     positions  and the   lattice constants should
be optimized     before beginning     response-function      calculations,
especially those     related to strain   properties.   While GS   structural
  optimization  was   treated in lessons   1-3, we are introducing  a few
new features   here,  and you should look at  the following new input  variables
which will   be  discussed below:
                    
There are two datasets specified in telast_1.in. First, let us examine the common input data. We specify a starting guess for acell , and give an accurate decimal specification for rprim . The definition of the atom types and atoms follows lesson RF1 . The reduced atomic positions xred are a starting approximation, and will be replaced by our converged results in the remaining input files, as will acell .
We will work with a fixed plane wave cutoff ecut (=6 Ha), but introduce ecutsm (=0.5 Ha)as in lesson 3 to smear the cutoff, which produces smoothly varying stresses as the lattice parameters are optimized. We will keep the same value of ecutsm for the response-function calculations as well, since changing it from the optimization run value could reintroduce non-zero forces and stresses. For the k-point grid, we must explicitly specify shiftk since the default value results in a grid shifted so as to break hexagonal symmetry. The RF strain calculations check this, and will exit with an error message if the grid does not have the proper symmetry. The self-consistency procedures follow lesson RF1 .
Dataset 1 optimizes the atomic positions keeping the lattice parameters fixed, setting ionmov =2 as in lesson 1 . The optimization steps proceed until the maximum force component on any atom is less than tolmxf . It is always advised to relax the forces before beginning the lattice parameter optimization. Dataset 2 optimizes the lattice parameters with optcell =2 as in lesson 3 . However, lesson 3 treated cubic Si, and the atom positions in reduced coordinates remained fixed. In the present, more general case, the reduced atomic coordinates must be reoptimized as the lattice parameters are optimized. Note that it is necessary to include getxred = -1 so that the second dataset is initialized with the relaxed coordinates . Coordinate and lattice parameter optimizations actually take place simultaneously, with the computed stresses at each step acting as forces on the lattice parameters. We have introduced strfact which scales the stresses so that they may be compared with the same tolmxf convergence test that is applied to the forces. The default value of 100 is probably a good choice for many systems, but you should be aware of what is happening.
From the hexagonal symmetry, we know that the positions of the atoms in
                the a-b basal plane are fixed.  However, a uniform translation
     along      the    c axis of all the atoms leaves the structure invariant.
       Only  the    relative    displacement of the Al and As planes along
 the    c axis is physically    relevant.     We will fix the Al positions
 to be   at reduced  c-axis coordinates    0 and  1/2  (these are related
by symmetry)    by introducing  
                      natfix
                                  and 
            iatfix
                                  to constrain the structural optimization.
  This   is  really    just   for   cosmetic   purposes, since letting them
  all slide   an arbitrary    amount   (as   they otherwise   would) won't
 change any results.    However,    you probably    wouldn't want to  publish
 the results that way,  so we may    as well develop    good habits.
                    
Now we shall examine the results of the structural optimization run. As always, we should first examine the log file to make sure the run has terminated cleanly. There are a number of warnings, but none of them are apparently serious. Next, let us edit the output file, telast_1.out. The first thing to look for is to see whether Abinit recognized the symmetry of the system. In setting up a new data file, it's easy to make mistakes, so this is a valuable check. We see
DATASET 1 : space group P6_3 m c (#186); Bravais hP (primitive hexag.)
which is correct. Next, we confirm that the structural optimization converged. The following lines from dataset 1 and dataset2 tell us that things are OK:
At Broyd/MD step 4, gradients are converged :
max grad (force/stress) = 1.0674E-08 < tolmxf= 1.0000E-06 ha/bohr (free atoms)
At Broyd/MD step 11, gradients are converged :
max grad (force/stress) = 7.8147E-08 < tolmxf= 1.0000E-06 ha/bohr (free atoms)
We can also confirm that the stresses are relaxed:
Cartesian components of stress tensor (hartree/bohr^3)
sigma(1 1)= -3.76644862E-10 sigma(3 2)= 0.00000000E+00
sigma(2 2)= -3.76644714E-10 sigma(3 1)= 0.00000000E+00
sigma(3 3)= 7.81298436E-10 sigma(2 1)= 0.00000000E+00
Now would be a good time to copy telast_2.in and telast_2.files into your working directory, since we will use the present output to start the next run. Locate the optimized lattice parameters and reduced atomic coordinates near the end of telast_1.out:
acell2 7.5389648144E+00 7.5389648144E+00 1.2277795374E+01 Bohr
xred2 3.3333333333E-01 6.6666666667E-01 0.0000000000E+00
6.6666666667E-01 3.3333333333E-01 5.0000000000E-01
3.3333333333E-01 6.6666666667E-01 3.7608588373E-01
6.6666666667E-01 3.3333333333E-01 8.7608588373E-01
With your editor, copy and paste these into telast_2.in at the indicated
   places              in the "Common input data" area.  Be sure to change
 acell2  and   xred2         to acell and xred since these common values will
 apply  to all  datasets      in   the next set of calculations.
                    
We will now compute second derivatives of the total energy (2DTE's) with respect to all the perturbations we need to compute elastic and piezoelectric properties. You may want to review sections 0 and the first paragraph of section 1 of the respfn_help file which you studied in lesson RF1. We will introduce only one new input variable for the strain perturbation,
The treatment of strain as a perturbation has some subtle aspects. It would be a good idea to read Metric tensor formulation of strain in density-functional perturbation theory, by D. R. Hamann, Xifan Wu, Karin M. Rabe, and David Vanderbilt, Phys. Rev. B 71, 035117 (2005) , especially Sec. II and Sec. IV. We will do all the RF calculations you learned in lesson RF1 together with strain, so you should review the variables
It would be a good idea to copy telast_2.files into Work_elast and start the calculation while you read (less than 2 minutes on a standard 3GHz machine). Look at telast_2.in in your editor to follow the discussion, and double check that you have copied acell and xred as discussed in the last section.
This has been set up as a self-contained calculation with three datasets. The first is simply a GS run to obtain the GS wave functions we will need for the response function (RF) calculations. We have removed the convergence test from the common input data to remind ourselves that different tests are needed for different datasets. We set a tight limit on the convergence of the self-consistent potential with tolvrs . Since we have specified nband =8, all the bands are occupied and the potential test also assures us that all the wave functions are well converged. This issue will come up again in section 6 . We could have used the output wave functions telast_1o_DS2_WFK as input for our RF calculations and skipped dataset 1, but redoing the GS calculation takes relatively little time for this simple system .
Dataset 2 involves the calculation of the derivatives of the wave functions
               with respect to the Brillouin-zone wave vector, the so-called
   ddk    wave     functions.    Recall that these are auxiliary quantities
  needed   to compute     the response   to the
       electric  field perturbation
        and introduced in lesson RF1                  .  It   would be a
 good   idea to review the relevant parts  of  
                         section    1
                                of the respfn_help file.  Examining this
section     of  telast_2.in,     note     that  electric field as well as
strain are    uniform  perturbations,      only  are   defined  for 
         qpt
                                = 0 0 0.  
               rfelfd
                                = 2 specifies that we want the ddk calculation
   to  be  performed,      which    requires  
            iscf
                                = -3.  The ddk wave functions will be used
 to  calculate      both   the     piezoelectric  tensor and the Born effective
  charges, and    in general   we   need   them for   k derivatives
 in all three (reduced)     directions,     
            rfdir
                                = 1 1 1.  Since there is no potential self-consistency
       in  the   ddk     calculations, we must specify convergence in terms
  of   the  wave  function     residuals  using 
                 tolwfr
                               .
                    
Finally, dataset 3 performs the actual calculations of the needed 2DTE's for the elastic and piezoelectric tensors. Setting rfphon = 1 turns on the atomic displacement perturbation, which we need for all atoms ( rfatpol = 1 4) and all directions ( rfdir = 1 1 1). Abinit will calculate first-order wave functions for each atom and direction in turn, and use those to calculate 2DTE's with respect to all pairs of atomic displacements and with respect to one atomic displacement and one component of electric field. These quantities, the interatomic force constants (at gamma) and the Born effective charges will be used later to compute the atomic relaxation contribution to the elastic and piezoelectric tensor.
First-order wave functions for the strain perturbation are computed next. Setting rfstrs = 3 specifies that we want both uniaxial and shear strains to be treated, and rfdir = 1 1 1 cycles through strains xx, yy, and zz for uniaxial and yz, xz, and xy for shear. We note that while other perturbations in Abinit are treated in reduced coordinates, strain is better dealt with in Cartesian coordinates for reasons discussed in the reference cited above. These wave functions are used to compute three types of 2DTE's. Derivatives with respect to two strain components give us the so-called rigid-ion elastic tensor. Derivatives with respect to one strain and one electric field component give us the rigid-ion piezoelectric tensor. Finally, derivatives with respect to one strain and one atomic displacement yield the internal-strain force-response tensor, an intermediate quantity that will be necessary to compute the atomic relaxation corrections to the rigid-ion quantities. As in lesson RF1, we specify convergence in terms of the residual of the potential (here the first-order potential) using tolvrs .
Your run should have completed by now. Abinit should have created quite a few files.
First, take a look at the end of the telast_2.log file to make sure the run has completed without error. You might wish to take a look at the WARNING's, but they all appear to be harmless. Next, edit your telast_2.out file. Searching backwards for ETOT you will find
iter 2DEtotal(Ha) deltaE(Ha) residm vres2
-ETOT 1 2.3955210936959 -6.519E+00 6.313E-01 4.126E+02
ETOT 2 1.3034866746082 -1.092E+00 4.874E-04 4.710E+00
ETOT 3 1.2898922627828 -1.359E-02 1.856E-05 3.514E-01
ETOT 4 1.2891989643464 -6.933E-04 2.648E-07 1.382E-02
ETOT 5 1.2891785442295 -2.042E-05 8.156E-09 1.945E-04
ETOT 6 1.2891783810507 -1.632E-07 6.814E-11 4.395E-05
ETOT 7 1.2891783087573 -7.229E-08 2.750E-11 3.704E-06
ETOT 8 1.2891783033031 -5.454E-09 2.224E-12 1.001E-07
ETOT 9 1.2891783031248 -1.783E-10 7.592E-14 6.584E-10
ETOT 10 1.2891783031235 -1.276E-12 1.112E-15 4.697E-11
At SCF step 10 vres2 = 4.70E-11 < tolvrs= 1.00E-10 =>converged.
Abinit is solving a set of Schroedinger-like equations for the first-order wave functions, and these functions minimize a variational expression for the 2DTE. (Technically, they are called self-consistent Sternheimer equations.) The energy convergence looks similar to that of GS calculations. The fact that vres2, the residual of the self-consistent first-order potential, has reached tolvrs well within nstep (40) iterations indicates that the 2DTE calculation for this perturbation (xy strain) has converged . It would pay to examine a few more cases for different perturbations (unless you have looked through all the warnings in the log).
Another convergence item to examine in your .out file is
Seventeen components of 2nd-order total energy (hartree) are
1,2,3: 0th-order hamiltonian combined with 1st-order wavefunctions
kin0= 9.10477366E+00 eigvalue= 3.11026172E-01 local= -3.66858410E+00
4,5,6,7: 1st-order hamiltonian combined with 1st and 0th-order wfs
loc psp = -8.91644866E+00 Hartree= 4.33575581E+00 xc= -6.58530125E-01
kin1= -8.62111357E+00
8,9,10: eventually, occupation + non-local contributions
edocc= 0.00000000E+00 enl0= 6.43290213E-01 enl1= -1.55388913E-01
1-10 gives the relaxation energy (to be shifted if some occ is /=2.0)
erelax= -7.62521951E+00
11,12,13 Non-relaxation contributions : frozen-wavefunctions and Ewald
fr.hart= -1.18530360E-01 fr.kin= 5.20015318E+00 fr.loc= 4.18792396E-01
14,15,16 Non-relaxation contributions : frozen-wavefunctions and Ewald
fr.nonl= 2.94970653E-01 fr.xc= 9.41457939E-02 Ewald= 3.02486615E+00
17 Non-relaxation contributions : pseudopotential core energy
pspcore= 0.00000000E+00
Resulting in :
2DEtotal= 0.1289178303E+01 Ha. Also 2DEtotal= 0.350803264954E+02 eV
(2DErelax= -7.6252195079E+00 Ha. 2DEnonrelax= 8.9143978110E+00 Ha)
( non-var. 2DEtotal : 1.2891783532E+00 Ha)
This detailed breakdown of the contributions to 2DTE is probably of limited interest, but you should compare "2DEtotal" and "non-var. 2DEtotal" from the last three lines. While the first-order wave function for the present perturbation minimizes a variational expression for the second derivative with respect to this perturbation as we just saw, the various 2DTE given as elastic tensors, etc. in the output and in the DDB file are all computed using non-variational expressions. Using the non-variational expressions, mixed second derivatives with respect to the present perturbation and all other perturbations of interest can be computed directly from the present first-order wave functions. The disadvantage is that the non-variational result has errors which are linearly proportional to convergence errors in the GS and first-order wave functions. Since errors in the variational 2DEtotal are second-order in wave-function convergence errors, comparing this to the non-variational result for the diagonal second derivative will give an idea of the accuracy of the latter and perhaps indicate the need for tighter convergence tolerances for both the GS and RF wave functions. This is discussed in X. Gonze and C. Lee, Phys. Rev. B 55, 10355 (1997) , Sec. II. For an atomic-displacement perturbation, the corresponding breakdown of the 2DTE is headed "Thirteen components."
Now let us take a look at the results we want, the various 2DTE's. They begin
==> Compute Derivative Database <==
2nd-order matrix (non-cartesian coordinates, masses not included,
asr not included )
cartesian coordinates for strain terms (1/ucvol factor
for elastic tensor components not included)
j1 j2 matrix element
dir pert dir pert real part imaginary part
1 1 1 1 5.4508667670 0.0000000000
1 1 2 1 -2.7254333834 0.0000000000
1 1 3 1 0.0000000000 0.0000000000
.....
These are the "raw" 2DTE's, in reduced coordinates for atom-displacement
               and electric-field perturbations, but Cartesian coordinates
 for    strain perturbations.    This       same results with the same organization
     appear in the file telast_2_DS3_DDB        which   will be used later
 as  input   for automated analysis and converted       to more  useful notation
   and units  by anaddb.  A breakout of various  types     of  2DTE's follows
   (all converted  to Cartesian coordinates and in atomic units): 
                    
Dynamical matrix, in cartesian coordinates,
if specified in the inputs, asr has been imposed
j1 j2 matrix element
dir pert dir pert real part imaginary part
1 1 1 1 0.0959051953 0.0000000000
1 1 2 1 0.0000000000 0.0000000000
1 1 3 1 0.0000000000 0.0000000000
.....
This contains the interatomic force constant data that will be used later to include atomic relaxation effects. "asr" refers to the acoustic sum rule, which basically is a way of making sure that forces sum to zero when an atom is displaced.
Effective charges, in cartesian coordinates,
(from phonon response)
if specified in the inputs, asr has been imposed
j1 j2 matrix element
dir pert dir pert real part imaginary part
1 6 1 1 1.8290468197 0.0000000000
2 6 1 1 0.0000000000 0.0000000000
3 6 1 1 0.0000000000 0.0000000000
.....
The Born effective charges will be used to find the atomic relaxation contributions of the piezoelectric tensor.
Rigid-atom elastic tensor , in cartesian coordinates,
j1 j2 matrix element
dir pert dir pert real part imaginary part
1 7 1 7 0.0056418398 0.0000000000
1 7 2 7 0.0013753713 0.0000000000
1 7 3 7 0.0007168444 0.0000000000
.....
The rigid-atom elastic tensor is the 2DTE with respect to a pair of strains. We recall that "pert" = natom+3 and natom+4 for unaxial and shear strains, respectively.
Internal strain coupling parameters, in cartesian coordinates,
zero average net force deriv. has been imposed
j1 j2 matrix element
dir pert dir pert real part imaginary part
1 1 1 7 0.1249319229 0.0000000000
1 1 2 7 -0.1249319273 0.0000000000
1 1 3 7 0.0000000000 0.0000000000
.....
These 2DTE's with respect to one strain and one atomic displacement are needed for atomic relaxation corrections to both the elastic tensor and piezoelectric tensor. While this set of parameters is of limited direct interest, it should be examined in cases when you think that high symmetry may eliminate the need for these corrections. You are probably wrong, and any non-zero term indicates a correction.
Rigid-atom proper piezoelectric tensor, in cartesian coordinates,
j1 j2 matrix element
dir pert dir pert real part imaginary part
1 6 1 7 0.0000000000 0.0000000000
1 6 2 7 0.0000000000 0.0000000000
1 6 3 7 0.0000000000 0.0000000000
Finally, we have the piezoelectric tensor, the 2DTE with respect to one
               strain and one uniform electric field component.  (Yes,
  there    are non-zero elements.)
                    
In this section, we will run the program anaddb, which analyzes DDB files
               generated in prior RF calculations.  You should copy telast_3.in
   and  telast_3.files          in your Work_elast directory.  You should
now   go to the 
          anaddb help file
                              , and read the short introduction.  The bulk
 of  the   material     in  this     help file is contained in the description
  of the   variables.     You  should     read the descriptions of
                    
Elastic Tensor(clamped ion)(unit:10^2GP):
1.6598864 0.4046482 0.2109029 0.0000000 0.0000000 0.0000002
0.4046481 1.6598863 0.2109029 0.0000000 0.0000000 0.0000002
0.2109030 0.2109030 1.8258574 0.0000000 0.0000000 0.0000002
0.0000000 0.0000000 0.0000000 0.4081819 0.0000000 0.0000000
0.0000000 0.0000000 0.0000000 0.0000000 0.4081822 0.0000000
0.0000000 0.0000000 0.0000000 0.0000000 0.0000000 0.6276191
Elastic Tensor(relaxed ion)(unit:10^2GP):
(at fixed electric field boundary condition)
1.3526230 0.5445033 0.3805291 0.0000000 0.0000000 0.0000002
0.5445032 1.3526228 0.3805291 0.0000000 0.0000000 0.0000002
0.3805292 0.3805293 1.4821105 0.0000000 0.0000000 0.0000002
0.0000000 0.0000000 0.0000000 0.3055073 0.0000000 0.0000000
0.0000000 0.0000000 0.0000000 0.0000000 0.3055072 0.0000000
0.0000000 0.0000000 0.0000000 0.0000000 0.0000000 0.4040599
Proper piezoelectric constants(clamped ion)(unit:c/m^2)
0.00000000 0.00000000 0.38490082
0.00000000 0.00000000 0.38490078
0.00000000 0.00000000 -0.73943037
0.00000000 0.43548809 0.00000000
0.43548801 0.00000000 0.00000000
0.00000000 0.00000000 0.00000000
Proper piezoelectric constants(relaxed ion)(unit:c/m^2)
0.00000000 -0.00000002 -0.01187139
0.00000000 0.00000002 -0.01187157
0.00000000 0.00000000 0.06462740
0.00000000 -0.04828794 0.00000000
-0.04828881 0.00000000 0.00000000
0.00000001 -0.00000001 0.00000000
Dataset 1:
At SCF step 21 vres2 = 4.14E-19 < tolvrs= 1.00E-18 =>converged.
Dataset 2:
At SCF step 1 vres2 = 8.54E-20 < tolvrs= 1.00E-18 =>converged.
Since dataset 2 has better convergence, we will use this and the dataset 4 results, choosing those in GPa units,
- sigma(1 1)= -2.11921106E-03 sigma(3 2)= 0.00000000E+00
- sigma(3 3)= -1.82392096E-02 sigma(2 1)= 0.00000000E+00
- sigma(1 1)= 2.09884071E-03 sigma(3 2)= 0.00000000E+00
- sigma(3 3)= 1.82778626E-02 sigma(2 1)= 0.00000000E+00
Let us now compute the numerical derivative of sigma(3 3)and compare to our RF result. Recalling that our dimensionless strains were ±0.0001, we find 182.5853 GPa. This compares very well with the value 182.58574 GPa, the 3,3 element of the Rigid-ion elastic tensor we found from our anaddb calculation in 3 . (Recall that our strain and stress were both 3 3 or z z or Voigt 3.) Similarly, the numerical derivative of sigma(1 1)is 21.09025 GPa, compared to 21.09030 GPa, the 3,1 elastic-tensor element.
The good agreement we found from this simple numerical differentiation required that we had accurately relaxed the lattice so that the stress of the unstrained structure was very small. Similar numerical-derivative comparisons for systems with finite stress are more complicated, as discussed in notes by A. R. Oganov . Numerical-derivative comparisons for the relaxed-ion results are extremely challenging since they require relaxing atomic forces to exceedingly small limits.
Now let us examine the electric polarizations found in datasets 2 and 4, focusing on the C/m^2 results,
Polarization -1.578184222E-11 C/m^2
Polarization 1.578180951E-11 C/m^2
Polarization -2.979936117E-01 C/m^2
Polarization -1.577713293E-11 C/m^2
Polarization 1.577662674E-11 C/m^2
Polarization -2.981427295E-01 C/m^2
While not labeled as such, these are the Cartesian x, y, and z components, respectively, and the x and y components are zero within numerical accuracy as they must be from symmetry. Numerical differentiation of the z component yields -0.745589 C/m^2. This is to be compared with the z,3 element of our rigid-ion piezoelectric tensor from 3 , -0.73943037 C/m^2, and the two results do not compare as well as we might wish.
What is wrong? There are two possibilities. The first is that the RF calculation produces the proper piezoelectric tensor, while numerical differentiation of the polarization produces the improper piezoelectric tensor. This is a subtle point, for which you are referred to D. Vanderbilt, J. Phys. Chem. Solids 61, 147 (2000) . The improper-to-proper transformation only effects certain tensor elements, however, and for our particular combination of crystal symmetry and choice of strain there is no correction. The second possibility is the subject of the next section.
                    
Our GS calculation of the polarization in 4 used, in effect, a finite-difference approximation to ddk wave functions, while our RF calculations in 2 used analytic results based on the RF approach. Since the k grid determined by ngkpt = 4 4 4 and nshiftk = 1 is rather coarse, this is a probable source of discrepancy. Since this issue was noted previously in connection with the calculation of Born effective charges by Na Sai, K. M. Rabe, and D. Vanderbilt, Phys. Rev. B 66, 104108 (2002) , Abinit has incorporated the ability to use finite-difference ddk wave functions from GS calculations in RF calculations of electric-field-related 2DTE's. Copy telast_5.in and telast_5.files into Work_elast, and edit telast_5.in.
You should compare this with our previous RF data, telast_2.in, and note that dataset1 and the Common data (after entering relaxed structural results) are essentially identical. Dataset 2 has been replaced by a non-self-consistent GS calculation with berryopt = -2 specified to perform the finite-difference ddk wave function calculation. (The finite-difference first-order wave functions are implicit but not actually calculated in the GS polarization calculation.) We have restricted rfdir to 0 0 1 since we are only interested in the 3,3 piezoelectric constant. Now compare dataset 3 with that in telast_2.in. Can you figure out what we have dropped and why? Run the telast_5 calculation, which will only take about a minute with our simplifications.
Now edit telast_5.out, looking for the piezoelectric tensor,
Rigid-atom proper piezoelectric tensor, in cartesian coordinates,
j1 j2 matrix element
dir pert dir pert real part imaginary part
3 6 3 7 -0.0130314055 0.0000000000
The fully RF calculation in 2
                         in fact will converge much more rapidly with 
k      sample    than   the   partial-finite-difference  method introduced
here.    Is   it worthwhile   to have  learned how to do this?  We believe
 that  is always   pays to have  alternative   ways to test results, and
besides,    this didn't   take much time.   (Have you   found the conversion
factor  on  your own yet?)
                    
                    
C_11 C_12 C_44 acell
ngkpt=3*6 0.0037773594 0.0022583552 0.0013453703 7.5710952267
ngkpt=3*8 0.0042004471 0.0020423400 0.0013076775 7.5693986688
ngkpt=3*10 0.0042034439 0.0020343450 0.0012956781 7.5694820863
We can immediately see that the lattice constant converges considerably more rapidly with k sample than the elastic constants. For ngkpt =3*6, acell is converged to 0.02%, while the C's have 5-10% errors. For ngkpt =3*8, the C's are converged to better than 1%, much better for the largest, C11, which should be acceptable.
As in lesson 4, the ngkpt convergence is controlled by tsmear . The smaller the broadening, the denser the k sample that is needed to get a smooth variation of occupancy, and presumably stress, with strain. While we will not explore tsmear convergence in this lesson, you may wish to do so on your own. We believe that the value tsmear = 0.02 in telast_6.in gives results within 1% of the fully-converged small-broadening limit.
We find that occopt =3, standard Fermi-Dirac broadening, gives much better convergence of the C's than "cold smearing." Changing occopt to 4 in telast_6.in, the option used in lesson 4, the C's show no sign of convergence. At ngkpt=3*16, errors are still ~5%. The reasons that this supposedly superior smoothing function performs so poorly in this context is a future research topic. The main thing to be learned is that checking convergence with respect to all relevant parameters is always the user's responsibility. Simple systems that include the main physical features of a complex system of interest will usually suffice for this testing. Don't get caught publishing a result that another researcher refutes on convergence grounds, and don't blame such a mistake on Abinit!
Finally, we conclude the lesson with a comparison with experiment.  Converting
        the C's to standard units (Ha/Bohr^3 = 2.94210119E+04 GPa) and using
   zero-temperature     extrapolated experimental results from P. M.
 Sutton,  Phys. Rev. 91,   816 (1953), we find
                
C_11(GPa) C_12(GPa) C_44(GPa)Is this good agreement? There isn't much literature on DFT calculations of full sets of elastic constants. Many calculations of the bulk modulus (K=(C11+2C 12 )/3 in the cubic case) typically are within 10% of experiment for the LDA. Running telast_6 with ixc=11, the Perdew-Burke-Enzerhof GGA, increases the calculated C's by 1-2%, and wouldn't be expected to make a large difference for a nearly-free-electron metal.
Calculated 123.7 59.9 38.1
Experiment (T=0) 123.0 70.8 30.9
           
               This ABINIT tutorial is now finished...