Syntax:
pair_style style keyword values
  rolling_friction values = 'cdt' or 'epsd' or 'epsd2' or 'off'
    cdt = activates constant directional rolling friction model
    epsd = activates elastic-plastic spring-dashpot model
    epsd2 = actiavtes an alternative version of the elastic-plastic spring-dashpot model
    off = no rolling friction model
  cohesion values = 'sjkr' or 'sjkr2' or'off'
    sjkr = activates simplified JKR cohesion model
    sjkr2 = activates variant of simplified JKR cohesion model
    off = no cohesion model
  tangential_damping values = 'on' or 'off'
    on = activates tangential damping
    off = no tangential damping
  viscous = 'stokes' or 'off'
    viscous = restitution coefficient varies with a local Stokes number of the particle
    off = no modification to the restitution coefficient
  absolute_damping values = 'on' or 'off'
    on = activates absolute damping (for hooke/history/simple only)
    off = deactivates absolute damping (for hooke/history/simple only) 
Examples:
pair_style gran/hooke/history pair_style gran/hertz/history rolling_friction cdt pair_style gran/hertz/history cohesion sjkr
LIGGGHTS vs. LAMMPS Info:
This LIGGGHTS command offers the following improvements vs. LAMMPS: The stiffness and damping coefficients k_n, k_t, gamma_n, gamma_t are now derived from the material properties. Also, a new model for macroscopic cohesion is introduced.
General description:
The gran styles use the following formula for the frictional force between two granular particles, when the distance r between two particles of radii Ri and Rj is less than their contact distance d = Ri + Rj. There is no force between the particles when r > d:
 
In the first term is the normal force between the two particles and the second term is the tangential force. The normal force has 2 terms, a contact force and a damping force. The tangential force also has 2 terms: a shear force and a damping force. The shear force is a "history" effect that accounts for the tangential displacement ("tangential overlap") between the particles for the duration of the time they are in contact. This term is included in pair styles hooke/history and hertz/history, but is not included in pair style hooke. Keyword tangential_damping can be used to eliminate the second part of the force in tangential direction. Additional keywords control model settings such as rolling_friction and cohesion.
The quantities in the equations are as follows:
Hertz/history:
For hertz/history, the Kn, Kt, gamma_n, and gamma_t coefficients are calculated as follows from the material properties:
 
Hooke and hooke/history:
For hooke and hooke/history, the k_n, k_t, gamma_n, and gamma_t coefficients are calculated as follows from the material properties:
 
Therby, the following definitions apply to two particles in contact:
 
To define those material properties, it is mandatory to use multiple fix property/global commands:
fix id all property/global youngsModulus peratomtype value_1 value_2 ...
    (value_i=value for Youngs Modulus of atom type i)
fix id all property/global poissonsRatio peratomtype value_1 value_2 ...
    (value_i=value for Poisson ratio of atom type i)
fix id all property/global coefficientRestitution peratomtypepair n_atomtypes value_11 value_12 .. value_21 value_22 .. .
    (value_ij=value for the coefficient of restitution between atom type i and j; n_atomtypes is the number of atom types you want to use in your simulation)
fix id all property/global coefficientFriction peratomtypepair n_atomtypes value_11 value_12 .. value_21 value_22 .. .
    (value_ij=value for the (static) coefficient of friction between atom type i and j; n_atomtypes is the number of atom types you want to use in your simulation) 
The "characteristic impact velocity" is only used for hooke styles:
fix id all property/global characteristicVelocity scalar value
    (value=value for characteristic impact velocity) 
Hertz/history/stiffness and hooke/history/stiffness:
For hooke/history/stiffness with absolute_damping = 'off' (which is default), the specified damping coefficient is multiplied by the effective mass. The forces are implemented as
 
For hooke/history/stiffness with absolute_damping = 'on', this multiplication is omitted and the forces become
 
For hertz/history/stiffness, the force implementation as
 
The k_n_specified, k_t_specified, gamma_n_specified, and gamma_t_specified coefficients are given by the user as follows from the material properties:
fix id all property/global kn peratomtypepair n_atomtypes value_11 value_12 .. value_21 value_22 .. .
    (value_ij=value for k_n between atom type i and j; n_atomtypes is the number of atom types you want to use in your simulation)
fix id all property/global kt peratomtypepair n_atomtypes value_11 value_12 .. value_21 value_22 .. .
    (value_ij=value for k_t between atom type i and j; n_atomtypes is the number of atom types you want to use in your simulation)
fix id all property/global gamman peratomtypepair n_atomtypes value_11 value_12 .. value_21 value_22 .. .
    (value_ij=value for gamma_n between atom type i and j; n_atomtypes is the number of atom types you want to use in your simulation)
fix id all property/global gammat peratomtypepair n_atomtypes value_11 value_12 .. value_21 value_22 .. .
    (value_ij=value for gamma_t between atom type i and j; n_atomtypes is the number of atom types you want to use in your simulation) 
For the hooke model, if the absolute damping implementation is used (absolute_damping = 'on'), the damping coefficients must be named gamman_abs and gammat_abs instead of gamman, gammat as follows:
fix id all property/global gamman_abs peratomtypepair n_atomtypes value_11 value_12 .. value_21 value_22 .. .
    (value_ij=value for gamma_n between atom type i and j; n_atomtypes is the number of atom types you want to use in your simulation)
fix id all property/global gammat_abs peratomtypepair n_atomtypes value_11 value_12 .. value_21 value_22 .. .
    (value_ij=value for gamma_t between atom type i and j; n_atomtypes is the number of atom types you want to use in your simulation) 
IMPORTANT NOTE: You have to use atom styles beginning from 1, e.g. 1,2,3,...
For all pair styles, the coefficient of friction cof is the upper limit of the tangential force through the Coulomb criterion Ft = cof *Fn, where Ft and Fn are the total tangential and normal force components in the formulas above. Thus in the Hookean case, the tangential force between 2 particles grows according to a tangential spring and dash-pot model until Ft/Fn = cof and is then held at Ft = Fn*cof until the particles lose contact. In the Hertzian case, a similar analogy holds, though the spring is no longer linear.
The optional rolling friction model (a constant directional torque model, see Ai et al) is activated via rolling_friction = 'cdt', and adds an additional torque contribution, equal to
torque_rf = rmu*k_n*delta_n*w_r_shear/mag(w_r_shear)*(R*).
w_r_shear is the projection of w_r into the shear plane, where w_r = w1-w2
If the rolling friction model is activated, the coefficient of rolling friction (rmu) must be defined as
fix id all property/global coefficientRollingFriction peratomtypepair n_atomtypes value_11 value_12 .. value_21 value_22 .. .
    (value_ij=value for the coefficient of rolling friction between atom type i and j; n_atomtypes is the number of atom types you want to use in your simulation) 
The command rolling_friction = 'epsd' activates an elastic-plastic spring-dashpot model (see Ai et al.) that adds an additional torque contribution, equal to
 
where the torque due to the spring M_rk is calculated as
 
Here k_r denotes the rolling stiffness and dtheta_r is the incremental relative rotation between the particles. The spring torque is limited by the full mobilisation torque M_rm that is determined by the normal force F_n and the coefficient of rolling friction (rmu) (compare the CDT model).
The viscous damping torque M_rd is implemented as
 
where in the current implementation the damping is disabled in case of full mobilisation (f = 0). The damping coefficient C_r may be expressed as:
 
Here I_i/j is the moment of inertia and m_i/j is the mass of the particles i and j, respectively. In addition to rmu (see CDT model), eta_r is the required material property that must be defined as
fix id all property/global coefficientRollingViscousDamping peratomtypepair n_atomtypes value_11 value_12 .. value_21 value_22 .. .
    (value_ij=value for the coefficient of rolling friction between atom type i and j; n_atomtypes is the number of atom types you want to use in your simulation) 
The command rolling_friction = 'epsd2' activates an alternative version of the 'epsd' model (see Iwashita and Oda). In contrast to the original model the rolling stiffness k_r is defined as
 
where k_t is the abovementioned tangential stiffness. Furthermore, the viscous damping torque M_rd is disabled at all.
A simple linear cohesion model can be activated by setting cohesion = 'sjkr' or 'sjkr2' (simplified Johnson-Kendall-Roberts model). If two particle are in contact, it adds an additional normal force tending to maintain the contact, which writes
F = k A,
where A is the particle contact area and k is the cohesion energy density in J/m3. For sjkr, the sphere-sphere contact area is calculated as (http://mathworld.wolfram.com/Sphere-SphereIntersection.html)
A = Pi/4 * ((dist-Ri-Rj)*(dist+Ri-Rj)*(dist-Ri+Rj)*(dist+Ri+Rj) )/(dist*dist)
where dist is the distance between the particle centers. For sjkr2, the sphere-sphere contact area is calculated as
A = 2*Pi * delta_n * (2R*)
If you are using the linear cohesion model, you must also define the cohesion energy density:
fix id all property/global cohesionEnergyDensity peratomtypepair n_atomtypes value_11 value_12 .. value_21 value_22 .. .
    (value_ij=value for the cohesion energy density (in Energy/Length3 units) between atom type i and j; n_atomtypes is the number of atom types you want to use in your simulation) 
IMPORTANT NOTE: The cohesion model has been derived for the Hertzian Style, it may note be appropriate for the Hookean styles.
Using option viscous = stokes adapts the coefficient of restitution as proposed by (Legendre), viscous = off performs no modification.
One has to provide the 3 peratomtypepair parameters via a fix property/global command needed for the viscous damping:
fix id all property/global FluidViscosity peratomtypepair n_atomtypes value_11 value_12 .. value_21 value_22 .. .
    (value_ij=value for fluid viscosity between atom type i and j; n_atomtypes is the number of atom types you want to use in your simulation)
fix id all property/global CriticalStokes peratomtypepair n_atomtypes value_11 value_12 .. value_21 value_22 .. .
    (value_ij=value for critical Stokes number between atom type i and j; n_atomtypes is the number of atom types you want to use in your simulation)
fix id all property/global MaximumRestitution peratomtypepair n_atomtypes value_11 value_12 .. value_21 value_22 .. .
    (value_ij=value for maximum coefficient of restitution between atom type i and j; n_atomtypes is the number of atom types you want to use in your simulation) 
For granular styles there are no additional coefficients to set for each pair of atom types via the pair_coeff command. All settings are global and are made via the pair_style command. However you must still use the pair_coeff for all pairs of granular atom types. For example the command
pair_coeff * *
should be used if all atoms in the simulation interact via a granular potential (i.e. one of the pair styles above is used). If a granular potential is used as a sub-style of pair_style hybrid, then specific atom types can be used in the pair_coeff command to determine which atoms interact via a granular potential.
Mixing, shift, table, tail correction, restart, rRESPA info:
The pair_modify mix, shift, table, and tail options are not relevant for granular pair styles.
These pair styles write their information to binary restart files, so a pair_style command does not need to be specified in an input script that reads a restart file.
IMPORTANT NOTE: The material properties are not written to restart files! Thus, if you restart a simulation, you have to re-define them (by using the fixes mentioned above).
These pair styles can only be used via the pair keyword of the run_style respa command. They do not support the inner, middle, outer keywords.
Restrictions:
These pair styles require that atoms store torque and angular velocity (omega) as defined by the atom_style. They also require a per-particle radius is stored. The granular atom style does all of this.
This pair style requires you to use the communicate vel yes option so that velocites are stored by ghost atoms.
Only unit system that are self-consistent (si, cgs, lj) can be used with this pair style.
Parameters are restricted to their physical range (e.g. FluidViscosity > 0) If using SI units, youngsModulus must be > 5e6 If using CGS units, youngsModulus must be > 5e5
Related commands:
Default:
rolling_friction = 'off' cohesion = 'off' tangential_damping = 'on' absolute_damping = 'off' store_force = 'no' viscous = 'off'
(Di Renzo) Alberto Di Renzo, Francesco Paolo Di Maio, CES, 59 (3), p 525–541 (2004).
(Ai) Jun Ai, Jian-Fei Chen, J. Michael Rotter, Jin Y. Ooi, Powder Technology, 206 (3), p 269-282 (2011).
(Brilliantov) Brilliantov, Spahn, Hertzsch, Poschel, Phys Rev E, 53, p 5382-5392 (1996).
(Silbert) Silbert, Ertas, Grest, Halsey, Levine, Plimpton, Phys Rev E, 64, p 051302 (2001).
(Zhang) Zhang and Makse, Phys Rev E, 72, p 011301 (2005).
(Legendre) Legendre, Daniel and Guiraud. Phys. Fluids 17, 097105 (2005).