All units in LAMMPS except lj
are supported. lj
is not supported.
The most commonly used units are metal
, since the internal units of distance, energy, force, and charge in DeePMD-kit are \AA
, eV
, eV / \AA
, and proton charge
, respectively. These units are consistent with the metal
units in LAMMPS.
If one wants to use other units like real
or si
, it is welcome to do so. There is no need to do the unit conversion mannualy. The unit conversion is done automatically by LAMMPS.
The only thing that one needs to take care is the unit of the output of compute deeptensor/atom
. Working with metal
units for compute deeptensor/atom
is totally fine, since there is no unit conversion. For other unit styles, we currently assume that the output of the compute deeptensor/atom
command has the unit of distance and have applied the unit conversion factor of distance. If a user wants to infer quantities with units other than distance, the user is encouraged to open a GitHub feature request, so that the unit conversion factor can be added.
If you are using the plugin mode, enable DeePMD-kit package in LAMMPS with plugin
command:
plugin load libdeepmd_lmp.so
After LAMMPS version patch_24Mar2022
, another way to load plugins is to set the environmental variable LAMMPS_PLUGIN_PATH
:
LAMMPS_PLUGIN_PATH=$deepmd_root/lib/deepmd_lmp
where $deepmd_root
is the directory to install C++ interface.
The built-in mode doesn't need this step.
The DeePMD-kit package provides the pair_style deepmd
pair_style deepmd models ... keyword value ...
- deepmd = style of this pair_style
- models = frozen model(s) to compute the interaction.
If multiple models are provided, then only the first model serves to provide energy and force prediction for each timestep of molecular dynamics,
and the model deviation will be computed among all models every
out_freq
timesteps. - keyword = out_file or out_freq or fparam or fparam_from_compute or aparam_from_compute or atomic or relative or relative_v or aparam or ttm
out_file value = filename filename = The file name for the model deviation output. Default is model_devi.out out_freq value = freq freq = Frequency for the model deviation output. Default is 100. fparam value = parameters parameters = one or more frame parameters required for model evaluation. fparam_from_compute value = id id = compute id used to update the frame parameter. aparam_from_compute value = id id = compute id used to update the atom parameter. atomic = no value is required. If this keyword is set, the force model deviation of each atom will be output. relative value = level level = The level parameter for computing the relative model deviation of the force relative_v value = level level = The level parameter for computing the relative model deviation of the virial aparam value = parameters parameters = one or more atomic parameters of each atom required for model evaluation ttm value = id id = fix ID of fix ttm
pair_style deepmd graph.pb
pair_style deepmd graph.pb fparam 1.2
pair_style deepmd graph_0.pb graph_1.pb graph_2.pb out_file md.out out_freq 10 atomic relative 1.0
pair_coeff * * O H
pair_style deepmd cp.pb fparam_from_compute TEMP
compute TEMP all temp
pair_style deepmd ener.pb aparam_from_compute 1
compute 1 all ke/atom
Evaluate the interaction of the system by using Deep Potential or Deep Potential Smooth Edition. It is noticed that deep potential is not a "pairwise" interaction, but a multi-body interaction.
This pair style takes the deep potential defined in a model file that usually has the .pb extension. The model can be trained and frozen by package DeePMD-kit, which can have either double or single float precision interface.
The model deviation evalulates the consistency of the force predictions from multiple models. By default, only the maximal, minimal and average model deviations are output. If the key atomic
is set, then the model deviation of force prediction of each atom will be output.
By default, the model deviation is output in absolute value. If the keyword relative
is set, then the relative model deviation of the force will be output, including values output by the keyword atomic
. The relative model deviation of the force on atom
where relative
.
If the keyword relative_v
is set, then the relative model deviation of the virial will be output instead of the absolute value, with the same definition of that of the force:
If the keyword fparam
is set, the given frame parameter(s) will be fed to the model.
If the keyword fparam_from_compute
is set, the global parameter(s) from compute command (e.g., temperature from compute temp command) will be fed to the model as the frame parameter(s).
If the keyword aparam_from_compute
is set, the atomic parameter(s) from compute command (e.g., per-atom translational kinetic energy from compute ke/atom command) will be fed to the model as the atom parameter(s).
If the keyword aparam
is set, the given atomic parameter(s) will be fed to the model, where each atom is assumed to have the same atomic parameter(s).
If the keyword ttm
is set, electronic temperatures from fix ttm command will be fed to the model as the atomic parameters.
Only a single pair_coeff
command is used with the deepmd style which specifies atom names. These are mapped to LAMMPS atom types (integers from 1 to Ntypes) by specifying Ntypes additional arguments after * *
in the pair_coeff
command.
If atom names are not set in the pair_coeff
command, the training parameter {ref}type_map <model/type_map>
will be used by default.
If a mapping value is specified as NULL
, the mapping is not performed. This can be used when a deepmd 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.
If the training parameter {ref}type_map <model/type_map>
is not set, atom names in the pair_coeff
command cannot be set. In this case, atom type indexes in type.raw
(integers from 0 to Ntypes-1) will map to LAMMPS atom types.
Spin is specified by keywords virtual_len
and spin_norm
. If the keyword virtual_len
is set, the distance between virtual atom and its corresponding real atom for each type of magnetic atoms will be fed to the model as the spin parameters. If the keyword spin_norm
is set, the magnitude of the magnetic moment for each type of magnetic atoms will be fed to the model as the spin parameters.
- The
deepmd
pair style is provided in the USER-DEEPMD package, which is compiled from the DeePMD-kit, visit the DeePMD-kit website for more information.
The DeePMD-kit package provides the compute deeptensor/atom
for computing atomic tensorial properties.
compute ID group-ID deeptensor/atom model_file
- ID: user-assigned name of the computation
- group-ID: ID of the group of atoms to compute
- deeptensor/atom: the style of this compute
- model_file: the name of the binary model file.
At this time, the training parameter {ref}type_map <model/type_map>
will be mapped to LAMMPS atom types.
compute dipole all deeptensor/atom dipole.pb
The result of the compute can be dumped to trajectory file by
dump 1 all custom 100 water.dump id type c_dipole[1] c_dipole[2] c_dipole[3]
- The
deeptensor/atom
compute is provided in the USER-DEEPMD package, which is compiled from the DeePMD-kit, visit the DeePMD-kit website for more information. - For the issue of using a unit style for
compute deeptensor/atom
, refer to the discussions in units of this page.
The reciprocal space part of the long-range interaction can be calculated by LAMMPS command kspace_style
. To use it with DeePMD-kit, one writes
pair_style deepmd graph.pb
pair_coeff * *
kspace_style pppm 1.0e-5
kspace_modify gewald 0.45
Please notice that the DeePMD does nothing to the direct space part of the electrostatic interaction, because this part is assumed to be fitted in the DeePMD model (the direct space cut-off is thus the cut-off of the DeePMD model). The splitting parameter gewald
is modified by the kspace_modify
command.
The DeePMD-kit also allows the computation of per-atom stress tensor defined as:
Where
In LAMMPS one can get the per-atom stress using the command centroid/stress/atom
:
compute ID group-ID centroid/stress/atom NULL virial
see LAMMPS doc page for more details on the meaning of the keywords.
:::{versionchanged} v2.2.3
v2.2.2 or previous versions passed per-atom stress (cvatom
) with the per-atom pressure tensor, which is inconsistent with LAMMPS's definition. LAMMPS defines per-atom stress as the negative of the per-atom pressure tensor. Such behavior is corrected in v2.2.3.
:::
In order of computing the 9-component per-atom stress
compute stress all centroid/stress/atom NULL virial
Thus c_stress
is an array with 9 components in the order xx,yy,zz,xy,xz,yz,yx,zx,zy
.
If you use this feature please cite D. Tisi, L. Zhang, R. Bertossa, H. Wang, R. Car, S. Baroni - arXiv preprint arXiv:2108.10850, 2021
Using a per-atom stress tensor one can, for example, compute the heat flux defined as:
to compute the heat flux with LAMMPS:
compute ke_ID all ke/atom
compute pe_ID all pe/atom
compute stress_ID group-ID centroid/stress/atom NULL virial
compute flux_ID all heat/flux ke_ID pe_ID stress_ID
compute ke all ke/atom
compute pe all pe/atom
compute stress all centroid/stress/atom NULL virial
compute flux all heat/flux ke pe stress
c_flux
is a global vector of length 6. The first three components are the
If you use these features please cite D. Tisi, L. Zhang, R. Bertossa, H. Wang, R. Car, S. Baroni - arXiv preprint arXiv:2108.10850, 2021