Non-adiabatic coupling matrix elements can be computed by finite differences for MCSCF
or CI
wavefunctions using the DDR
program. For state-averaged MCSCF
wavefunctions, they can also be computed analytically (cf. section difference gradients for SA-MCSCF).
Note that present numerical procedure has been much simplified relative to Molpro96
. No GEOM
and DISPL
input cards are needed any more, and the three necessary calculations can be done in any order.
In order to compute the coupling matrix elements by finite differences, one has to compute and store the wavefunctions at two (first-order algorithm) or three (second-order algorithm) slightly displaced geometries. The order of these calculations is arbitrary.
The typical strategy is as follows:
1.) Compute the wavefunction at the reference geometry. The wavefunctions for both states have to be stored using the SAVE
command of the CI
program. If the matrix elements are computed for MCSCF
wavefunctions, it is necessary to recompute the wavefunction with the CI
program, using the NOEXC
option. The transition density matrix is stored using the DM
directive of the CI program.
2.) Compute the wavefunctions at the (positively) displaced geometry and store the CI wavefunction in a second record.
3.) If the second-order (three-point) method is used, step (2) is repeated at a (negatively) displaced geometry.
4.) Compute the transition density matrices between the states at the reference geometry and the displaced geometr(ies). This is done with the TRANS
directive of the CI program.
5.) Finally, the DDR
program is used to assemble the matrix element. Using the first-order two-point method, only a single input line is needed:
DDR
, dr, orb1, orb2, trdm2
where dr is the geometry increment used as denominator in the finite difference method, orb1 is the record holding the orbitals of the reference geometry, orb2 is the record holding the orbitals of the displaced geometry, and trdm2 is the record holding the transition density matrix computed from the CI-vectors at R and R+DR.
If central differences (three points) are used, the input is as follows:
DDR
,2*dr
ORBITAL
,orb1,orb2,orb3
DENSITY
,trdm1,trdm2,trdm3
where dr, orb1, orb2 are as above, and orb3 is the record holding the orbitals at the negatively displaced geometry.
trdm1, trdm2, trdm3 are the records holding the transition densities $\gamma(R|R)$, $\gamma(R|R+DR)$, and $\gamma(R|R-DR)$, respectively.
If more than two states are computed simultaneously, the transition density matrices for all pairs of states will be stored in the same record. In that case, and also when there are just two states whose spatial symmetry is not 1, it is necessary to specify for which states the coupling is to be computed using the STATE
directive:
STATE
,state$_1$, state$_2$
where state$_i$ is of the form istate.isym (the symmetries of both states must be the same, and it is therefore sufficient to specify the symmetry of the first state).
As an example the input for first-order and second-order calculations is given below. The calculation is repeated for a range of geometries, and at the end of the calculation the results are printed using the TABLE
command.
In the calculation shown, the “diabatic” CASSCF orbitals are generated in the two CASSCF calculations at the displaced geometries by maximizing the overlap with the orbitals at the reference geometry. This is optional, and (within the numerical accuacy) does not influence the final results. However, the relative contributions of the orbital, overlap and CI contributions to the NACME are modified. If diabatic orbitals are used, which change as little as possible as function of geometry, the sum of overlap and orbital contribution is minimized, and to a very good approximation the NACME could be obtained from the CI-vectors alone.
***,lif non-adiabatic coupling basis,f=avdz,li=vdz !define basis r=[10.0,10.5,11.0,11.5,12.0] !define bond distances dr=0.01 !define increment geometry={li;f,li,rlif} !define geometry rlif=3 !first calculation at R=3 {hf;occ,4,1,1} !SCF {multi;closed,3; !CASSCF, 3 inactive orbitals wf,12,1;state,2; !Two 1A1 states orbital,2140.2} !dump orbitals to record 2140.2 do i=1,#r !loop over geometries rlif=r(i) !set bond distance {multi;closed,3; !CASSCF, 3 inactive orbitals wf,12,1;state,2; !Two 1A1 states orbital,2140.2} !Overwrite previous orbitals by present ones {ci;state,2;noexc; !CI for 2 states, no excitations save,6000.2; !save wavefunction to record 6000.2 dm,8000.2} !save (transition) densities to record 8000.2 rlif=r(i)+dr !increment bond distance by dr {multi;closed,3; !same CASSCF as above wf,12,1;state,2; !Two 1A1 states start,2140.2; !start with orbitals from reference geometry orbital,2141.2; !save orbitals to record 2141.2 diab,2140.2} !generate diabatic orbitals by maximizing the !overlap with the orbitals at the reference geometry {ci;state,2;noexc;save,6001.2} !CI for 2 states, wavefunction saved to record 6001.2 {ci;trans,6000.2,6001.2; !Compute overlap and transition density <R|R+DR> dm,8100.2} !Save transition density to record 8100.2 rlif=r(i)-dr !repeat at r-dr {multi;closed,3; !same CASSCF as above wf,12,1;state,2; !Two 1A1 states start,2140.2; !start with orbitals from reference geometry orbital,2142.2; !save orbitals to record 2142.2 diab,2140.2} !generate diabatic orbitals by maximizing the !overlap with the orbitals at the reference geometry {ci;state,2;noexc;save,6002.2} !CI for 2 states, wavefunction saved to record 6002.2 {ci;trans,6000.2,6002.2; !Compute overlap and transition density <R|R-DR> dm,8200.2} !Save transition density to record 8200.2 {ddr,dr,2140.2,2141.2,8100.2} !compute NACME using 2-point formula (forward difference) nacme1p(i)=nacme !store result in variable nacme1p {ddr,-dr,2140.2,2142.2,8200.2} !compute NACME using 2-point formula (backward difference) nacme1m(i)=nacme !store result in variable nacme1m {ddr,2*dr !compute NACME using 3-point formula orbital,2140.2,2141.2,2142.2; !orbital records for R, R+DR, R-DR density,8000.2,8100.2,8200.2} !transition density records for R, R+DR, R-DR nacme2(i)=nacme !store result in variable nacme2 end do !end of loop over differend bond distances nacmeav=(nacme1p+nacme1m)*0.5 !average the two results forward and backward differences table,r,nacme1p,nacme1m,nacmeav,nacme2 !print a table with results title,Non-adiabatic couplings for LiF !title for table
This calculation produces the following table:
Non-adiabatic couplings for LiF R NACME1P NACME1M NACMEAV NACME2 10.0 -0.22828936 -0.22328949 -0.22578942 -0.22578942 10.5 -0.51777034 -0.50728914 -0.51252974 -0.51252974 11.0 0.76672943 0.76125391 0.76399167 0.76399167 11.5 0.42565202 0.42750263 0.42657733 0.42657733 12.0 0.19199878 0.19246799 0.19223338 0.19223338
Note that the sign changes because of a phase change of one of the wavefunctions. In order to keep track of the sign, one has to inspect both the orbitals and the ci-vectors.
Please also see diabatic_orbitals.