Example: CO absorption on a Cu slab: fragment option and densityplot¶
#! /bin/sh
# This example illustrates the usage of fragments in a BAND calculation for
# analysis purposes. It takes two runs to do the DOS analysis in a fragment
# basis, and an extra two runs to get the deformation density with respect to
# the fragment densities.
# The setup involves first the computation of the free CO overlayer, which is to
# be adsorbed on a Cu surface. To suppress (most of the) interactions between
# the CO molecules, i.e. to effectively get the molecular CO, the KSpace
# parameter is set to 1 (= no dispersion), and the lattice parameters are set so
# large that the CO molecules are far apart. The standard result file RUNKF is
# saved under the name 'CO.results/band.rkf'.
# ----------------------------- CO molecule --------------------------
AMS_JOBNAME=CO $ADFBIN/ams <<eor
Task SinglePoint
System
  ! CO molecules far apart
  Atoms [Bohr]
    C   0 0 0
    O   0 0 2.18
  End
  
  Lattice [Bohr]
    25.0  0.0   0.0
    0.0   25.0  0.0
  End
End
Engine Band
  Title The CO fragment
  Print AtomicChargesDetails
  Comment
   Technical  
     Zero order k space integration
   Features
     Lattice   : 2D, large lattice vectors
     Unit cell : 2 atoms, 1x1, quasi molecular
     Basis     : NO+STO w/ core
  End
  Print Eigens
  Kspace 
    Quality GammaOnly  ! neglect dispersion
  End 
  Basis
    Type DZ
    Core Large
  End
  DOS
     Enabled True
     Energies 300 
  End
EndEngine
eor
# Now we can use the result file to do a DOS analysis for CO on a copper surface
# treating the molecule as a fragment. With Fragment%Labels we assign names to
# the different symmetry orbitals. The Density-of-States analysis details are
# given with the keys DOS (energy grid, result file with DOS data) and,
# optionally, GrossPopulations and OverlapPopulations.
# ----------------------------- CO + Cu slab --------------------------
AMS_JOBNAME=COCu $ADFBIN/ams <<eor
Task SinglePoint
System
  Lattice [Bohr]
    4.822 0.0   0.0
    0.0   4.822 0.0
  End
  Atoms [Bohr]
    C   0     0     3.44
    O   0     0     5.62
    Cu  0.0   0.0   0.0
  End
End
Engine Band
  Title Cu slab with CO adsorbed
  Print AtomicChargesDetails
  Comment
   Technical  
     Quadratic K space integration (low)
   Features
     Lattice   : 2D
     Unit cell : 3 atoms, 1x1
     Basis     : NO+STO w/ core
     Options   : Molecular fragment
                 Analysis: DOS, PDOS, COOP
  End        
  KSpace 
    Symmetric KInteg=3
  End
  ! fragment specification
  Fragment 
    filename CO.results/band.rkf
    atommapping
      1 1
      2 2
    End
    Labels ! let us give them some labels
      2Sigma
      2Sigma*
      1Pi_x
      1Pi_y
      3Sigma
      1Pi_x*
      1Pi_y*
      3Sigma*
    End
  End
  ! use fragment basis in dos
  DosBas
    Fragment 1
  End
  DOS   ! Analysis
    Enabled   True
    File      pdos.CO_Cu
    Energies  500
    Min      -0.750
    Max       0.300
  End
  GrossPopulations
    3 2    ! All metal d states
    Sum     ! ALl metal sp states
      3 0
      3 1
    EndSum
    Frag 1   ! All CO states
    Sum   ! CO 1pi
      FragFun 1 5
      FragFun 1 6
    EndSum
    FragFun 1 7  ! CO 5-sigma
  End
  OverlapPopulations
    Left   ! Metal d with CO
      3 2
    Right
      Frag 1
  End
  Basis
    Type DZ
    Core Large
  End
EndEngine
eor
# After this run we copy the computed DOS data from the DOS result file to
# standard output. We also save the restart file for later use.
echo ""
echo "Contents of DOS file"
cat pdos.CO_Cu
# Next we want to know the deformation density with respect to the two
# fragments: 1) The CO molecule and 2) the bare Cu surface. We haven't done the
# bare Cu surface yet, so that is what happens next.
# ----------------------------- Cu slab --------------------------
AMS_JOBNAME=Cu $ADFBIN/ams <<eor
Task SinglePoint
System
  Lattice [Bohr]
    4.822 0.0 0.0
    0.0   4.822 0.0
  End
  Atoms [Bohr]
    Cu  0.0   0.0   0.0
  End
End
Engine Band 
  Title Cu slab
  Print AtomicChargesDetails
  Comment
   Technical  
     Quadratic K space integration (low)
   Features
     Lattice   : 2D
     Unit cell : 3 atoms, 1x1
     Basis     : NO+STO w/ core
     Options   : 
  End
  Kspace 
    Symmetric KInteg=3
  End
  Basis
    Type DZ
    Core Large
  End
  DOS
     Enabled True
     Energies 300 
  End
EndEngine
eor
# Now we are all set to do our final calculation. We have the two fragment files
# CO.results/band.rkf and Cu.results/band.rkf, and the restart file COCu.results/band.rkf. Next we want to know
# the deformation density with respect to the two fragments: 1) The CO molecule
# and 2) the bare Cu surface. The visualization options like OrbitalPlot and
# Densityplot require a regular set of points (a grid). Here is how it works
# ----------------------------- CO + Cu slab restart --------------------------
NSCM=1
export NSCM
AMS_JOBNAME=Final $ADFBIN/ams <<eor
Task SinglePoint
System
  Lattice [Bohr]
    4.822 0.0 0.0
    0.0   4.822 0.0
  End
  Atoms [Bohr]
    C   0     0     3.44
    O   0     0     5.62
    Cu  0.0   0.0   0.0
  End
End
Engine Band
  Title Cu slab with CO adsorbed (restart density plot)
  Print AtomicChargesDetails
  debug BlockPropertyModule
  Kspace 
    Symmetric KInteg=3
  End
  Restart
    File COCu.results/band.rkf
    DensityPlot
  End
  Grid
    Type Coarse
  End
  DensityPlot
    rho(deformation/fit) !FITDENSITY_deformation_scf
  End
  ! fragment specification
  Fragment 
    filename CO.results/band.rkf
    atommapping
    1 1
    2 2
    End
  End
  Fragment 
    filename Cu.results/band.rkf
    atommapping
      1 3
    End
  End
  Basis
    Type DZ
    Core Large
  End
  DOS
     Enabled True
     Energies 300 
  End
EndEngine
eor
# This particular restart options does not work in parallel, hence the '-n 1' on
# the first line.The result of the last run is a file named TAPE41. Normally you
# would save that to COCu.t41
# mv TAPE41 COCu.t41 and view it with ADFview. On the TAPE41 file are now three
# fields shown in ADFview as
# FITDENSITY_deformation_scf FITDENSITY_deformation_scf_frag1
# FITDENSITY_deformation_scf_frag2 being the deformation density of CO+Cu with
# respect to the atoms, and the same for the two fragments CO and the Cu slab.
# In ADFview you can add the fields of the two fragments, and then create
# another field that holds the difference.
NSCM=1
export NSCM
echo ""
echo "Begin TOC of tape41"
$ADFBIN/dmpkf -n 1 Final.results/FILE_BLOCKPROPERTIES --toc
echo "End TOC of tape41"