The Hamiltonian Monte Carlo algorithm (originally known as hybrid Monte Carlo) is a
Markov chain Monte Carlo
In statistics, Markov chain Monte Carlo (MCMC) methods comprise a class of algorithms for sampling from a probability distribution. By constructing a Markov chain that has the desired distribution as its equilibrium distribution, one can obtain ...
method for obtaining a sequence of
random samples which
converge to being
distributed Distribution may refer to:
Mathematics
*Distribution (mathematics), generalized functions used to formulate solutions of partial differential equations
*Probability distribution, the probability of a particular value or value range of a varia ...
according to a target probability distribution for which direct sampling is difficult. This sequence can be used to estimate
integrals with respect to the target distribution (
expected values).
Hamiltonian Monte Carlo corresponds to an instance of the
Metropolis–Hastings algorithm
In statistics and statistical physics, the Metropolis–Hastings algorithm is a Markov chain Monte Carlo (MCMC) method for obtaining a sequence of random samples from a probability distribution from which direct sampling is difficult. This seq ...
, with a
Hamiltonian dynamics evolution simulated using a
time-reversible and volume-preserving numerical integrator (typically the
leapfrog integrator) to propose a move to a new point in the state space. Compared to using a
Gaussian random walk proposal distribution in the Metropolis–Hastings algorithm, Hamiltonian Monte Carlo reduces the correlation between successive sampled states by proposing moves to distant states which maintain a high probability of acceptance due to the approximate
energy conserving properties of the simulated Hamiltonian dynamic when using a
symplectic integrator. The reduced correlation means fewer
Markov chain
A Markov chain or Markov process is a stochastic model describing a sequence of possible events in which the probability of each event depends only on the state attained in the previous event. Informally, this may be thought of as, "What happen ...
samples are needed to approximate integrals with respect to the target probability distribution for a given
Monte Carlo
Monte Carlo (; ; french: Monte-Carlo , or colloquially ''Monte-Carl'' ; lij, Munte Carlu ; ) is officially an administrative area of the Principality of Monaco, specifically the ward of Monte Carlo/Spélugues, where the Monte Carlo Casino i ...
error.
The algorithm was originally proposed by Simon Duane, Anthony Kennedy, Brian Pendleton and Duncan Roweth in 1987 for calculations in
lattice quantum chromodynamics. In 1996,
Radford M. Neal brought attention to the usefulness of the method for a broader class of statistical problems, in particular
artificial neural network
Artificial neural networks (ANNs), usually simply called neural networks (NNs) or neural nets, are computing systems inspired by the biological neural networks that constitute animal brains.
An ANN is based on a collection of connected units ...
s. The burden of having to supply
gradient
In vector calculus, the gradient of a scalar-valued differentiable function of several variables is the vector field (or vector-valued function) \nabla f whose value at a point p is the "direction and rate of fastest increase". If the gr ...
s of the respective
densities delayed the wider adoption of the method in statistics and other quantitative disciplines, until in the mid-2010s the developers of
Stan
Stan or STAN may refer to:
People
* Stan (given name), a list of people with the given name
** Stan Laurel (1890–1965), English comic actor, part of duo Laurel and Hardy
* Stan (surname), a Romanian surname
* Stan! (born 1964), American author ...
implemented HMC in combination with
automatic differentiation.
Algorithm
Suppose the target distribution to sample is
and a chain of samples
is required. The
Hamilton's equations are
:
and
:
where
and
are the
th component of the
position
Position often refers to:
* Position (geometry), the spatial location (rather than orientation) of an entity
* Position, a job or occupation
Position may also refer to:
Games and recreation
* Position (poker), location relative to the dealer
* ...
and
momentum
In Newtonian mechanics, momentum (more specifically linear momentum or translational momentum) is the product of the mass and velocity of an object. It is a vector quantity, possessing a magnitude and a direction. If is an object's mass ...
vector respectively and
is the Hamiltonian. Let
be a
mass matrix which is symmetric and positive definite, then the Hamiltonian is
:
where
is the
potential energy
In physics, potential energy is the energy held by an object because of its position relative to other objects, stresses within itself, its electric charge, or other factors.
Common types of potential energy include the gravitational potentia ...
. The potential energy for a target is given as
:
which comes from the
Boltzmann's factor.
The algorithm requires a positive integer for number of leap frog steps
and a positive number for the step size
. Suppose the chain is at
. Let
. First, a
random
In common usage, randomness is the apparent or actual lack of pattern or predictability in events. A random sequence of events, symbols or steps often has no order and does not follow an intelligible pattern or combination. Individual rando ...
Gaussian momentum
is drawn from
. Next, the particle will run under Hamiltonian dynamics for time
, this is done by solving the Hamilton's equations numerically using the
leap frog algorithm. The position and momentum vectors after time
using the leap frog algorithm are
:
:
:
These equations are to be applied to
and
times to obtain
and
.
The leap frog algorithm is an approximate solution to the motion of non-interacting classical particles. If exact, the solution will never change the initial randomly-generated energy distribution, as energy is conserved for each particle in the presence of a classical potential energy field. In order to reach a thermodynamic equilibrium distribution, particles must have some sort of interaction with, for example, a surrounding heat bath, so that the entire system can take on different energies with probabilities according to the Boltzmann distribution.
One way to move the system towards a thermodynamic equilibrium distribution is to change the state of the particles using the
Metropolis–Hastings. So first, one applies the leap frog step, then a Metropolis-Hastings step.
The transition from
to
is
:
where
:
This is repeated to obtain
.
No U-Turn Sampler
The No U-Turn Sampler (NUTS)
is an extension by controlling
automatically. Tuning
is critical. For example in the one dimensional
case, the potential is
which corresponds to the potential of a
simple harmonic oscillator. For
too large, the particle will oscillate and thus waste computational time. For
too small, the particle will behave like a random walk.
Loosely, NUTS runs the Hamiltonian dynamics both forwards and backwards in time randomly until a U-Turn condition is satisfied. When that happens, a random point from the path is chosen for the MCMC sample and the process is repeated from that new point.
In detail, a
binary tree is constructed to trace the path of the leap frog steps. To produce a MCMC sample, an iterative procedure is conducted. A slice variable
is sampled. Let
and
be the position and momentum of the forward particle respectively. Similarly,
and
for the backward particle. In each iteration, the binary tree selects at random uniformly to move the forward particle forwards in time or the backward particle backwards in time. Also for each iteration, the number of leap frog steps increase by a factor of 2. For example, in the first iteration, the forward particle moves forwards in time using 1 leap frog step. In the next iteration, the backward particle moves backwards in time using 2 leap frog steps.
The iterative procedure continues until the U-Turn condition is met, that is
:
or when the Hamiltonian becomes inaccurate
:
or
:
where, for example,
.
Once the U-Turn condition is met, the next MCMC sample,
, is obtained by sampling uniformly the leap frog path traced out by the binary tree
which satisfies
:
This is usually satisfied if the remaining HMC parameters are sensible.
See also
*
Dynamic Monte Carlo method In chemistry, dynamic Monte Carlo (DMC) is a Monte Carlo method for modeling the dynamic behaviors of molecules by comparing the rates of individual steps with random numbers. It is essentially the same as Kinetic Monte Carlo. Unlike the Metrop ...
*
Software for Monte Carlo molecular modeling
*
Stan
Stan or STAN may refer to:
People
* Stan (given name), a list of people with the given name
** Stan Laurel (1890–1965), English comic actor, part of duo Laurel and Hardy
* Stan (surname), a Romanian surname
* Stan! (born 1964), American author ...
*
Metropolis-adjusted Langevin algorithm
In computational statistics, the Metropolis-adjusted Langevin algorithm (MALA) or Langevin Monte Carlo (LMC) is a Markov chain Monte Carlo (MCMC) method for obtaining random samples – sequences of random observations – from a probability distr ...
References
Further reading
*
*
*
External links
*
* {{cite web , title=Markov chain Monte Carlo , work=Statistical Rethinking 2022 , first=Richard , last=McElreath , date= , via=
YouTube
YouTube is a global online video sharing and social media platform headquartered in San Bruno, California. It was launched on February 14, 2005, by Steve Chen, Chad Hurley, and Jawed Karim. It is owned by Google, and is the second most ...
, url=https://www.youtube.com/watch?v=Qqz5AJjyugM&list=PLDcUM9US4XdMROZ57-OIRtIK0aOynbgZN&index=9
Hamiltonian Monte Carlo from scratchOptimization and Monte Carlo Methods
Monte Carlo methods
Markov chain Monte Carlo