pair_style polymorphic command

Syntax

pair_style polymorphic

style = polymorphic

Examples

pair_style polymorphic
pair_coeff * * FeCH_BOP_I.poly Fe C H
pair_coeff * * TlBr_msw.poly Tl Br
pair_coeff * * CuTa_eam.poly Cu Ta
pair_coeff * * GaN_tersoff.poly Ga N
pair_coeff * * GaN_sw.poly Ga N

Description

The polymorphic pair style computes a 3-body free-form potential (Zhou3) for the energy E of a system of atoms as

E=12i=1i=Nj=1j=N[(1δij)UIJ(rij)(1ηij)FIJ(Xij)VIJ(rij)]Xij=k=i1,kjiNWIK(rik)GJIK(cosθjik)PJIK(Δrjik)Δrjik=rijξIJrik

where I, J, K represent species of atoms i, j, and k, i1,...,iN represents a list of i‘s neighbors, δij is a Dirac constant (i.e., δij=1 when i=j, and δij=0 otherwise), ηij is similar constant that can be set either to ηij=δij or ηij=1δij depending on the potential type, UIJ(rij), VIJ(rij), WIK(rik) are pair functions, GJIK(cosθjik) is an angular function, PJIK(Δrjik) is a function of atomic spacing differential Δrjik=rijξIJrik with ξIJ being a pair-dependent parameter, and FIJ(Xij) is a function of the local environment variable Xij. This generic potential is fully defined once the constants ηij and ξIJ, and the six functions UIJ(rij), VIJ(rij), WIK(rik), GJIK(cosθjik), PJIK(Δrjik), and FIJ(Xij) are given. Here LAMMPS uses a global parameter η to represent ηij. When η=1, ηij=1δij, otherwise ηij=δij. Additionally, η=3 indicates that the function PJIK(Δr) depends on species I, J and K, otherwise PJIK(Δr)=PIK(Δr) only depends on species I and K. Note that these six functions are all one dimensional, and hence can be provided in a tabular form. This allows users to design different potentials solely based on a manipulation of these functions. For instance, the potential reduces to a Stillinger-Weber potential (SW) if we set

ηij=δij(η=2 or η=0),ξIJ=0UIJ(r)=AIJϵIJ(σIJr)q[BIJ(σIJr)pq1]exp(σIJraIJσIJ)VIJ(r)=λIJϵIJexp(γIJσIJraIJσIJ)FIJ(X)=XPJIK(Δr)=PIK(Δr)=1WIJ(r)=λIJϵIJexp(γIJσIJraIJσIJ)GJIK(cosθ)=(cosθ+13)2

The potential reduces to a Tersoff potential (Tersoff or Albe) if we set

ηij=δij(η=2 or η=0),ξIJ=1UIJ(r)=De,IJSIJ1exp[βIJ2SIJ(rre,IJ)]fc,IJ(r)VIJ(r)=SIJDe,IJSIJ1exp[βIJ2SIJ(rre,IJ)]fc,IJ(r)FIJ(X)=(1+X)12PJIK(Δr)=PIK(Δr)=exp(2μIKΔr)WIJ(r)=fc,IJ(r)GJIK(cosθ)=γIK[1+cIK2dIK2cIK2dIK2+(hIK+cosθ)2]

where

fc,IJ(r)={1,rRIJDIJ12+12cos[π(r+DIJRIJ)2DIJ],RIJDIJ<r<RIJ+DIJ0,rRIJ+DIJ

The potential reduces to a modified Stillinger-Weber potential (Zhou3) if we set

ηij=δij(η=2 or η=0),ξIJ=0UIJ(r)=φR,IJ(r)φA,IJ(r)VIJ(r)=uIJ(r)FIJ(X)=XPJIK(Δr)=PIK(Δr)=1WIJ(r)=uIJ(r)GJIK(cosθ)=gJIK(cosθ)

The potential reduces to a Rockett-Tersoff potential (Wang3) if we set

ηij=δij(η=2 or η=0),ξIJ=1UIJ(r)=AIJexp(λ1,IJr)fc,IJ(r)fca,IJ(r)VIJ(r)={BIJexp(λ2,IJr)fc,IJ(r)+AIJexp(λ1,IJr)fc,IJ(r)[1fca,IJ(r)]}FIJ(X)=[1+(βIJX)nIJ]12nIJPJIK(Δr)=PIK(Δr)=exp(λ3,IKΔr3)WIJ(r)=fc,IJ(r)GJIK(cosθ)=1+cIK2dIK2cIK2dIK2+(hIK+cosθ)2

where fca,IJ(r) is similar to the fc,IJ(r) defined above:

fca,IJ(r)={1,rRa,IJDa,IJ12+12cos[π(r+Da,IJRa,IJ)2Da,IJ],Ra,IJDa,IJ<r<Ra,IJ+Da,IJ0,rRa,IJ+Da,IJ

The potential becomes the embedded atom method (Daw) if we set

ηij=1δij(η=1),ξIJ=0UIJ(r)=ϕIJ(r)VIJ(r)=1FII(X)=2FI(X)PJIK(Δr)=PIK(Δr)=1WIJ(r)=fJ(r)GJIK(cosθ)=1

In the embedded atom method case, ϕIJ(r) is the pair energy, FI(X) is the embedding energy, X is the local electron density, and fJ(r) is the atomic electron density function.

The potential reduces to another type of Tersoff potential (Zhou4) if we set

ηij=δij(η=3),ξIJ=1UIJ(r)=De,IJSIJ1exp[βIJ2SIJ(rre,IJ)]fc,IJ(r)TIJ(r)+VZBL,IJ(r)[1TIJ(r)]VIJ(r)=SIJDe,IJSIJ1exp[βIJ2SIJ(rre,IJ)]fc,IJ(r)TIJ(r)FIJ(X)=(1+X)12PJIK(Δr)=ωJIKexp(αJIKΔr)WIJ(r)=fc,IJ(r)GJIK(cosθ)=γJIK[1+cJIK2dJIK2cJIK2dJIK2+(hJIK+cosθ)2]TIJ(r)=11+exp[bf,IJ(rrf,IJ)]VZBL,IJ(r)=14.4ZIZJrk=14μkexp[νk(ZI0.23+ZJ0.23)r]

where fc,IJ(r) is the same as defined above. This Tersoff potential differs from the one above because the PJIK(Δr) function is now dependent on all three species I, J, and K.

If the tabulated functions are created using the parameters of Stillinger-Weber, Tersoff, and EAM potentials, the polymorphic pair style will produce the same global properties (energies and stresses) and the same forces as the sw, tersoff, and eam pair styles. The polymorphic pair style also produces the same per-atom properties (energies and stresses) as the corresponding tersoff and eam pair styles. However, due to a different partitioning of global properties to per-atom properties, the polymorphic pair style will produce different per-atom properties (energies and stresses) as the sw pair style. This does not mean that polymorphic pair style is different from the sw pair style. It just means that the definitions of the atom energies and atom stresses are different.

Only a single pair_coeff command is used with the polymorphic pair style which specifies a potential file 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:

  • filename

  • N element names = mapping of polymorphic potential elements to atom types

See the pair_coeff page for alternate ways to specify the path for the potential file. Several files for polymorphic potentials are included in the potentials directory of the LAMMPS distribution. They have a “poly” suffix.

As an example, imagine the GaN_tersoff.poly file has tabulated functions for Ga-N tersoff potential. If your LAMMPS simulation has 4 atom types and you want the first 3 to be Ga, and the fourth to be N, you would use the following pair_coeff command:

pair_coeff * * GaN_tersoff.poly Ga Ga Ga N

The first two arguments must be * * to span all pairs of LAMMPS atom types. The first three Ga arguments map LAMMPS atom types 1,2,3 to the Ga element in the polymorphic file. The final N argument maps LAMMPS atom type 4 to the N element in the polymorphic file. If a mapping value is specified as NULL, the mapping is not performed. This can be used when an polymorphic 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.

Potential files in the potentials directory of the LAMMPS distribution have a “.poly” suffix. At the beginning of the files, an unlimited number of lines starting with ‘#’ are used to describe the potential and are ignored by LAMMPS. The next line lists two numbers:

ntypes eta

Here ntypes represent total number of species defined in the potential file, η=1 reduces to embedded atom method, η=3 assumes a three species dependent PJIK(Δr) function, and all other values of η assume a two species dependent PJK(Δr) function. The value of ntypes must equal the total number of different species defined in the pair_coeff command. The next ntypes lines each lists two numbers and a character string representing atomic number, atomic mass, and name of the species of the ntypes elements:

atomic-number atomic-mass element-name(1)
atomic-number atomic-mass element-name(2)
...
atomic-number atomic-mass element-name(ntypes)

The next line contains four numbers:

nr ntheta nx xmax

Here nr is total number of tabular points for radial functions U, V, W, P, ntheta is total number of tabular points for the angular function G, nx is total number of tabular points for the function F, xmax is a maximum value of the argument of function F. Note that the pair functions UIJ(r), VIJ(r), WIJ(r) are uniformly tabulated between 0 and cutoff distance of the IJ pair, GJIK(cosθ) is uniformly tabulated between -1 and 1, PJIK(Δr) is uniformly tabulated between -rcmax and rcmax where rcmax is the maximum cutoff distance of all pairs, and FIJ(X) is uniformly tabulated between 0 and xmax. Linear extrapolation is assumed if actual simulations exceed these ranges.

The next ntypes*(ntypes+1)/2 lines contain two numbers:

cut xi(1)
cut xi(2)
...
cut xi(ntypes*(ntypes+1)/2)

Here cut means the cutoff distance of the pair functions, “xi” is ξ as defined in the potential functions above. The ntypes*(ntypes+1)/2 lines are related to the pairs according to the sequence of first ii (self) pairs, i = 1, 2, …, ntypes, and then ij (cross) pairs, i = 1, 2, …, ntypes-1, and j = i+1, i+2, …, ntypes (i.e., the sequence of the ij pairs follows 11, 22, …, 12, 13, 14, …, 23, 24, …).

In the final blocks of the potential file, U, V, W, P, G, and F functions are listed sequentially. First, U functions are given for each of the ntypes*(ntypes+1)/2 pairs according to the sequence described above. For each of the pairs, nr values are listed. Next, similar arrays are given for V and W functions. If P functions depend only on pair species, i.e., η3, then P functions are also listed the same way the next. If P functions depend on three species, i.e., η=3, then P functions are listed for all the ntypes*ntypes*ntypes IJK triplets in a natural sequence I from 1 to ntypes, J from 1 to ntypes, and K from 1 to ntypes (i.e., IJK = 111, 112, 113, …, 121, 122, 123 …, 211, 212, …). Next, G functions are listed for all the ntypes*ntypes*ntypes IJK triplets similarly. For each of the G functions, ntheta values are listed. Finally, F functions are listed for all the ntypes*(ntypes+1)/2 pairs in the same sequence as described above. For each of the F functions, nx values are listed.

Mixing, shift, table, tail correction, restart, rRESPA info

This pair style does not support the pair_modify shift, table, and tail options.

This pair style does not write their 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.


Restrictions

If using create_atoms command, atomic masses must be defined in the input script. If using read_data, atomic masses must be defined in the atomic structure data file.

This pair style is part of the MANYBODY package. It is only enabled if LAMMPS was built with that package. See the Build package page for more info.

This pair potential requires the newton setting to be “on” for pair interactions.

The potential files provided with LAMMPS (see the potentials directory) are parameterized for metal units. You can use any LAMMPS units, but you would need to create your own potential files.