Syntax:
pair_style bop keyword ...
table = BOP potential file has tabulated form save = pre-compute and save some values sigmaoff = assume a_sigma = 0
Examples:
pair_style bop pair_coeff * * ../potentials/CdTe_bop Cd Te pair_style bop table save pair_coeff * * ../potentials/CdTe.bop.table Cd Te Te communicate single cutoff 14.70
Description:
The bop pair style computes Bond-Order Potentials (BOP) based on quantum mechanical theory incorporating both sigma and pi bondings. By analytically deriving the BOP from quantum mechanical theory its transferability to different phases can approach that of quantum mechanical methods. This particlular BOP is extremely effective at modeling III-V and II-VI compounds such as GaAs and CdTe. This potential is similar to the original BOP developed by Pettifor (Pettifor_1, Pettifor_2, Pettifor_3) and later updated by Murdick, Zhou, and Ward (Murdick, Ward).
The BOP potential consists of three terms:
where phi_ij(r_ij) is a short-range two-body function representing the repulsion between a pair of ion cores, beta_(sigma,ij)(r_ij) and beta_(sigma,ij)(r_ij) are respectively sigma and pi bond ingtegrals, THETA_(sigma,ij) and THETA_(pi,ij) are sigma and pi bond-orders, and U_prom is the promotion energy for sp-valent systems.
The detailed formulas for this potential are given in Ward (Ward); here we provide only a brief description.
The repulsive energy phi_ij(r_ij) and the bond integrals beta_(sigma,ij)(r_ij) and beta_(phi,ij)(r_ij) are functions of the interatomic distance r_ij between atom i and j. Each of these potentials has a smooth cutoff at a radius of r_(cut,ij). These smooth cutoffs ensure stable behavior at situations with high sampling near the cutoff such as melts and surfaces.
The bond-orders can be viewed as environment-dependent local variables that are ij bond specific. The maximum value of the sigma bond-order (THETA_sigma) is 1, while that of the pi bond-order (THETA_pi) is 2, attributing to a maximum value of the total bond-order (THETA_sigma+THETA_pi) of 3. The sigma and pi bond-orders reflect the ubiquitous single-, double-, and triple- bond behavior of chemistry. Their analytical expressions can be derived from tight- binding theory by recursively expanding an inter-site Green's function as a continued fraction. To accurately represent the bonding with a computationally efficient potential formulation suitable for MD simulations, the derived BOP only takes (and retains) the first two levels of the recursive representations for both the sigma and the pi bond-orders. Bond-order terms can be understood in terms of molecular orbital hopping paths based upon the Cyrot-Lackmann theorem (Pettifor_1). The sigma bond-order with a half-full valence band filling. This pi bond-order expression also contains also contains a three-member ring term that allows implementation of an asymmetric density of states, which helps to either stabilize or destabilize close-packed structures. The pi bond-order includes hopping paths of length 4. This enables the incorporation of dihedral angles effects.
The cutoffs for the various interactions are defined in the BOP potential file.
IMPORTANT NOTE: You must use the communicate cutoff command to insure ghost atoms are acquired at a distance 3x further than the largest BOP cutoff (for a particular pair of elements). E.g. if the BOP cutoff is 4.9 Angstroms, then the ghost atom communication needs to be 14.7 Angstroms or greater as in the example above. This is because the BOP formulation uses neighbors of neighbors of neighbors to enumerate all the required many-body interactions. LAMMPS will generate an error if you do not use an appropriate setting for the communicate cutoff command.
Several options can be specified as keywords with the pair_style command.
The table keyword tells LAMMPS what format the BOP potential file is in. The default is a non-tabulated form. If the table keyword is used, the file is in a tabulated form containing pre-tabulated pair functions for phi_ij(r_ij), beta_(sigma,ij)(r_ij), and beta_(pi,ij)(r_ij). This allows you to use your own functional form for various interactions.
The save keyword gives you the option to calculate and store in advance a set of distances, angles, and derivatives of angles. The default is to not do this, but to calculate the various quantities on-the-fly each time they are needed. The former may be faster, but takes more memory. The latter requires less memory, but may be slower. It is best to test this option to see if it makes a difference on your machine for the specific problem you are modeling.
The sigmaoff keyword optimizes the BOP equations for the case of a_sigma = 0. For some published BOP potentials, a_sigma = 0 and several terms in the BOP equationas drop out. If this is the case, specifying sigmaoff will typically speed up the BOP pair style.
Only a single pair_coeff command is used with the bop style which specifies a BOP potential file, with parameters for all needed elements. These are mapped to LAMMPS atom types by specifying N additional arguments after the filename in the pair_coeff command, where N is the number of LAMMPS atom types:
See the pair_coeff doc page for alternate ways to specify the path for the potential file.
As an example, imagine the CdTe.bop file has BOP values for Cd and Te. If your LAMMPS simulation has 4 atoms types and you want the 1st 3 to be Cd, and the 4th to be Te, you would use the following pair_coeff command:
pair_coeff * * CdTe Cd Cd Cd Te
The 1st 2 arguments must be * * so as to span all LAMMPS atom types. The first three Cd arguments map LAMMPS atom types 1,2,3 to the Cd element in the BOP file. The final Te argument maps LAMMPS atom type 4 to the Te element in the BOP file. If a mapping value is specified as NULL, the mapping is not performed. This can be used when a bop potential is used as part of the hybrid pair style. The NULL values are placeholders for atom types that will be used with other potentials.
BOP files in the potentials directory of the LAMMPS distribution have a ".bop" or ".bop.table" suffix, depending on whether they are of the non-tabulated or tabulated form, as described above.
The parameters/coefficients format for the both kinds of BOP files are given below with variables matching the formulation of Ward (Ward). Each header line containing a ":" is preceded by a blank line.
The first two lines are followed by N lines containing the atomic number and mass of each element.
Non-tabulated potential file format:
Following the definition of the elements is the block of global variables for spline and quadratic fits of THETA_(S,ij) and its components THETA_0, THETA_1, and S.
The next block contains constants for the environment depend promotional energy for sp-valent systems, each of which are species dependent. Refer to Pettifor (Pettifor_3) for constant definitions. As well as one species dependent parameter p_pi.
Following the ptrs header there are N lines for e_1-e_N containing (A_ij)^(mu*nu), delta^mu, p_pi
The next block contains constants for the pair interactions.
Following the header the block contains a series of constants for the number of pair interaction types, the block will be broken up into parameters for e_i-e_j with i=0->N, j=i->N. Each single interaction section for this block will contain (see Ward for parameter definitions):
The next block contains tris.
Following the header there is a line for each three body interaction types as e_j-e_i-e_k with i->N, j->N, k=j->N
This would be the end of the potential parameter file without pre- tabulated data.
Tabulated potential file format:
The parameters/coefficients format for the BOP potentials input file containing pre-tabulated functions of is given below with variables matching the formulation of Ward (Ward).
The first two lines are followed by N lines containing the atomic number and mass of each element THETA_0 and THETA_1 (see Ward).
Following the definition of the elements several global variables for the tabulated functions are given.
Following this N lines for e_1-e_N containing p_pi.
The next section contains several pair constants for the number of interaction types e_i-e_j, with i=1->N, j=i->N
The next section contains a line for each three body interaction type e_j-e_i-e_k with i=0->N, j=0->N, k=j->N
The next section contains a block for each interaction type for the phi_ij(r_ij). Each block has nr entries with 5 entries per line.
The next section contains a block for each interaction type for the beta_(sigma,ij)(r_ij). Each block has nr entries with 5 entries per line.
The next section contains a block for each interaction type for beta_(pi,ij)(r_ij). Each block has nr entries with 5 entries per line.
The next section contains a block for each interaction type for the THETA_(S,ij)((THETA_(sigma,ij))^(1/2), f_(sigma,ij)). Each block has nBOt entries with 5 entries per line.
The next section contains a block of N lines for e_1-e_N
The last section contains more constants for e_i-e_j interactions with i=0->N, j=i->N
Mixing, shift, table tail correction, restart:
This pair style does not support the pair_modify mix, shift, table, and tail options.
This pair style does not write its information to binary restart files, since it is stored in potential files. Thus, you need to re-specify the pair_style and pair_coeff commands in an input script that reads a restart file.
This pair style can only be used via the pair keyword of the run_style respa command. It does not support the inner, middle, outer keywords.
Restrictions:
These pair styles are part of the MANYBODY package. They are only enabled if LAMMPS was built with that package (which it is by default). See the Making LAMMPS section for more info.
These pair potentials require the newtion setting to be "on" for pair interactions.
The CdTe.bop and GaAs.bop potential files provided with LAMMPS (see the potentials directory) are parameterized for metal units. You can use the BOP potential with any LAMMPS units, but you would need to create your own BOP potential file with coefficients listed in the appropriate units if your simulation does not use "metal" units.
Related commands:
Default:
non-tabulated potential file, a_0 is non-zero.
(Pettifor_1) D.G. Pettifor and I.I. Oleinik, Phys. Rev. B, 59, 8487 (1999).
(Pettifor_2) D.G. Pettifor and I.I. Oleinik, Phys. Rev. Lett., 84, 4124 (2000).
(Pettifor_3) D.G. Pettifor and I.I. Oleinik, Phys. Rev. B, 65, 172103 (2002).
(Murdick) D.A. Murdick, X.W. Zhou, H.N.G. Wadley, D. Nguyen-Manh, R. Drautz, and D.G. Pettifor, Phys. Rev. B, 73, 45206 (2006).
(Ward) D.K. Ward, X.W. Zhou, B.M. Wong, F.P. Doty, and J.A. Zimmerman, Phys. Rev. B, 85,115206 (2012).