Constrained molecular dynamics is performed using the SHAKE[1] algorithm.
In this algorithm, the Lagrangian for the system
is extended as follows:
data:image/s3,"s3://crabby-images/0f571/0f5712f183d0ddcb4914312eab34e424a98c86fc" alt="{\displaystyle
\mathcal{L}^*(\mathbf{q,\dot{q}}) = \mathcal{L}(\mathbf{q,\dot{q}}) +
\sum_{i=1}^{r} \lambda_i \sigma_i(q),
}"
where the summation is over r geometric constraints,
is the Lagrangian for the extended system, and λi is a Lagrange multiplier associated with a geometric constraint σi:
data:image/s3,"s3://crabby-images/0a383/0a3831412bbb65544e1ad5c422ed8345c71d15a0" alt="{\displaystyle
\sigma_i(q) = \xi_i({q})-\xi_i \;
}"
with ξi(q) being a geometric parameter and ξi is the value of ξi(q) fixed during the simulation.
In the SHAKE algorithm, the Lagrange multipliers λi are determined in the iterative procedure:
- Perform a standard MD step (leap-frog algorithm):
data:image/s3,"s3://crabby-images/7f62f/7f62f47c3cb9bb3cbfa50a04adf143c3ee4bd848" alt="{\displaystyle
v^{t+{\Delta}t/2}_i = v^{t-{\Delta}t/2}_i + \frac{a^{t}_i}{m_i} {\Delta}t
}"
data:image/s3,"s3://crabby-images/af3c5/af3c5303f7c1aabde6ac4df07d99b6e5c942efda" alt="{\displaystyle
q^{t+{\Delta}t}_i = q^{t}_i + v^{t+{\Delta}t/2}_i{\Delta}t
}"
- Use the new positions q(t+Δt) to compute Lagrange multipliers for all constraints:
data:image/s3,"s3://crabby-images/16d72/16d7273d7c327c34822e9bf93f4a5b634c25894c" alt="{\displaystyle
{\lambda}_k= \frac{1}{{\Delta}t^2} \frac{\sigma_k(q^{t+{\Delta}t})}{\sum_{i=1}^N m_i^{-1} \bigtriangledown_i{\sigma}_k(q^{t}) \bigtriangledown_i{\sigma}_k(q^{t+{\Delta}t})}
}"
- Update the velocities and positions by adding a contribution due to restoring forces (proportional to λk):
data:image/s3,"s3://crabby-images/6dcec/6dcecf265431249a85389f43758d2545b32733d0" alt="{\displaystyle
v^{t+{\Delta}t/2}_i = v^{t-{\Delta}t/2}_i + \left( a^{t}_i-\sum_k \frac{{\lambda}_k}{m_i} \bigtriangledown_i{\sigma}_k(q^{t}) \right ) {\Delta}t
}"
data:image/s3,"s3://crabby-images/af3c5/af3c5303f7c1aabde6ac4df07d99b6e5c942efda" alt="{\displaystyle
q^{t+{\Delta}t}_i = q^{t}_i + v^{t+{\Delta}t/2}_i{\Delta}t
}"
- repeat steps 2-4 until either |σi(q)| are smaller than a predefined tolerance (determined by SHAKETOL), or the number of iterations exceeds SHAKEMAXITER.
References