Physics:Bennett acceptance ratio

From HandWiki
Short description: Algorithm for estimating the difference in free energy between two systems

The Bennett acceptance ratio method (BAR) is an algorithm for estimating the difference in free energy between two systems (usually the systems will be simulated on the computer). It was suggested by Charles H. Bennett in 1976.[1]


Take a system in a certain super (i.e. Gibbs) state. By performing a Metropolis Monte Carlo walk it is possible to sample the landscape of states that the system moves between, using the equation

[math]\displaystyle{ p(\text{State}_x \rightarrow \text{State}_y) = \min \left(e ^ { - \beta \, \Delta U} , 1 \right) = M(\beta \, \Delta U) }[/math]

where ΔUU(Statey) − U(Statex) is the difference in potential energy, β = 1/kT (T is the temperature in kelvins, while k is the Boltzmann constant), and [math]\displaystyle{ M(x) \equiv \min(e^{-x} , 1) }[/math] is the Metropolis function. The resulting states are then sampled according to the Boltzmann distribution of the super state at temperature T. Alternatively, if the system is dynamically simulated in the canonical ensemble (also called the NVT ensemble), the resulting states along the simulated trajectory are likewise distributed. Averaging along the trajectory (in either formulation) is denoted by angle brackets [math]\displaystyle{ \left\langle \cdots \right\rangle }[/math].

Suppose that two super states of interest, A and B, are given. We assume that they have a common configuration space, i.e., they share all of their micro states, but the energies associated to these (and hence the probabilities) differ because of a change in some parameter (such as the strength of a certain interaction). The basic question to be addressed is, then, how can the Helmholtz free energy change (ΔF = FB − FA) on moving between the two super states be calculated from sampling in both ensembles? The kinetic energy part in the free energy is equal between states so can be ignored. Also the Gibbs free energy corresponds to the NpT ensemble.

The general case

Bennett shows that for every function f satisfying the condition [math]\displaystyle{ f(x)/f(-x) \equiv e^{-x} }[/math] (which is essentially the detailed balance condition), and for every energy offset C, one has the exact relationship

[math]\displaystyle{ e ^ { - \beta (\Delta F - C)} = \frac{\left\langle f\left(\beta (U_\text{B} - U_\text{A} - C)\right) \right\rangle_\text{A}}{\left\langle f\left(\beta (U_\text{A} - U_\text{B} + C)\right) \right\rangle_\text{B}} }[/math]

where UA and UB are the potential energies of the same configurations, calculated using potential function A (when the system is in superstate A) and potential function B (when the system is in the superstate B) respectively.

The basic case

Substituting for f the Metropolis function defined above (which satisfies the detailed balance condition), and setting C to zero, gives

[math]\displaystyle{ e ^ { - \beta \Delta F} = \frac{\left\langle M\left(\beta (U_\text{B} - U_\text{A})\right) \right\rangle_\text{A}}{\left\langle M\left(\beta (U_\text{A} - U_\text{B})\right) \right\rangle_\text{B}} }[/math]

The advantage of this formulation (apart from its simplicity) is that it can be computed without performing two simulations, one in each specific ensemble. Indeed, it is possible to define an extra kind of "potential switching" Metropolis trial move (taken every fixed number of steps), such that the single sampling from the "mixed" ensemble suffices for the computation.

The most efficient case

Bennett explores which specific expression for ΔF is the most efficient, in the sense of yielding the smallest standard error for a given simulation time. He shows that the optimal choice is to take

  1. [math]\displaystyle{ f(x) \equiv \frac{1}{1 + e^x} }[/math], which is essentially the Fermi–Dirac distribution (satisfying indeed the detailed balance condition).
  2. [math]\displaystyle{ C \approx \Delta F }[/math]. This value, of course, is not known (it is exactly what one is trying to compute), but it can be approximately chosen in a self-consistent manner.

Some assumptions needed for the efficiency are the following:

  1. The densities of the two super states (in their common configuration space) should have a large overlap. Otherwise, a chain of super states between A and B may be needed, such that the overlap of each two consecutive super states is adequate.
  2. The sample size should be large. In particular, as successive states are correlated, the simulation time should be much larger than the correlation time.
  3. The cost of simulating both ensembles should be approximately equal - and then, in fact, the system is sampled roughly equally in both super states. Otherwise, the optimal expression for C is modified, and the sampling should devote equal times (rather than equal number of time steps) to the two ensembles.

Multistate Bennett acceptance ratio

The multistate Bennett acceptance ratio (MBAR) is a generalization of the Bennett acceptance ratio that calculates the (relative) free energies of several multi states. It essentially reduces to the BAR method when only two super states are involved.

Relation to other methods

The perturbation theory method

This method, also called Free energy perturbation (or FEP), involves sampling from state A only. It requires that all the high probability configurations of super state B are contained in high probability configurations of super state A, which is a much more stringent requirement than the overlap condition stated above.

The exact (infinite order) result

[math]\displaystyle{ e ^ { - \beta \Delta F} = \left\langle e ^{ - \beta (U_\text{B} - U_\text{A})} \right\rangle_\text{A} }[/math]


[math]\displaystyle{ \Delta F = -kT \cdot \log \left\langle e ^{\beta (U_\text{A} - U_\text{B})} \right\rangle_\text{A} }[/math]

This exact result can be obtained from the general BAR method, using (for example) the Metropolis function, in the limit [math]\displaystyle{ C \rightarrow -\infty }[/math]. Indeed, in that case, the denominator of the general case expression above tends to 1, while the numerator tends to [math]\displaystyle{ e^{\beta C} \left\langle e^{-\beta (U_\text{B} - U_\text{A})} \right\rangle_\text{A} }[/math]. A direct derivation from the definitions is more straightforward, though.

The second order (approximate) result

Assuming that [math]\displaystyle{ U_\text{B} - U_\text{A} \ll kT }[/math] and Taylor expanding the second exact perturbation theory expression to the second order, one gets the approximation

[math]\displaystyle{ \Delta F \approx \left\langle U_\text{B} - U_\text{A} \right\rangle_\text{A} - \frac{\beta}{2} \left( \left\langle (U_\text{B} - U_\text{A})^2 \right\rangle_\text{A} - \left(\left\langle (U_\text{B} - U_\text{A}) \right\rangle_\text{A}\right)^2 \right) }[/math]

Note that the first term is the expected value of the energy difference, while the second is essentially its variance.

The first order inequalities

Using the convexity of the log function appearing in the exact perturbation analysis result, together with Jensen's inequality, gives an inequality in the linear level; combined with the analogous result for the B ensemble one gets the following version of the Gibbs-Bogoliubov inequality:

[math]\displaystyle{ \langle U_\text{B} - U_\text{A} \rangle_\text{B} \le \Delta F \le \langle U_\text{B} - U_\text{A} \rangle_\text{A} }[/math]

Note that the inequality agrees with the negative sign of the coefficient of the (positive) variance term in the second order result.

The thermodynamic integration method

writing the potential energy as depending on a continuous parameter, [math]\displaystyle{ U_\text{A} = U(\lambda = 0), U_\text{B} = U(\lambda = 1), }[/math]

one has the exact result [math]\displaystyle{ \frac{\partial F(\lambda)}{\partial \lambda} = \left\langle \frac{\partial U(\lambda)}{\partial \lambda} \right\rangle_\lambda }[/math] This can either be directly verified from definitions or seen from the limit of the above Gibbs-Bogoliubov inequalities when [math]\displaystyle{ \text{A} = \lambda^+, \text{B} = \lambda^- }[/math]. we can therefore write

[math]\displaystyle{ \Delta F = \int_0^1 \left\langle \frac{\partial U(\lambda)}{\partial \lambda} \right\rangle \, d\lambda }[/math]

which is the thermodynamic integration (or TI) result. It can be approximated by dividing the range between states A and B into many values of λ at which the expectation value is estimated, and performing numerical integration.


The Bennett acceptance ratio method is implemented in modern molecular dynamics systems, such as Gromacs. Python-based code for MBAR and BAR is available for download at [2].

See also


  1. Charles H. Bennett (1976) Efficient estimation of free energy differences from Monte Carlo data. Journal of Computational Physics 22 : 245–268 [1]

External links