Particle filter

Particle filters, or sequential Monte Carlo methods, are a set of Monte Carlo algorithms used to find approximate solutions for filtering problems for nonlinear state-space systems, such as signal processing and Bayesian statistical inference. The filtering problem consists of estimating the internal states in dynamical systems when partial observations are made and random perturbations are present in the sensors as well as in the dynamical system. The objective is to compute the posterior distributions of the states of a Markov process, given the noisy and partial observations. The term "particle filters" was first coined in 1996 by Pierre Del Moral about mean-field interacting particle methods used in fluid mechanics since the beginning of the 1960s. The term "Sequential Monte Carlo" was coined by Jun S. Liu and Rong Chen in 1998.

Particle filtering uses a set of particles (also called samples) to represent the posterior distribution of a stochastic process given the noisy and/or partial observations. The state-space model can be nonlinear and the initial state and noise distributions can take any form required. Particle filter techniques provide a well-established methodology for generating samples from the required distribution without requiring assumptions about the state-space model or the state distributions. However, these methods do not perform well when applied to very high-dimensional systems.

Particle filters update their prediction in an approximate (statistical) manner. The samples from the distribution are represented by a set of particles; each particle has a likelihood weight assigned to it that represents the probability of that particle being sampled from the probability density function. Weight disparity leading to weight collapse is a common issue encountered in these filtering algorithms. However, it can be mitigated by including a resampling step before the weights become uneven. Several adaptive resampling criteria can be used including the variance of the weights and the relative entropy concerning the uniform distribution. In the resampling step, the particles with negligible weights are replaced by new particles in the proximity of the particles with higher weights.

From the statistical and probabilistic point of view, particle filters may be interpreted as mean-field particle interpretations of Feynman-Kac probability measures. These particle integration techniques were developed in molecular chemistry and computational physics by Theodore E. Harris and Herman Kahn in 1951, Marshall N. Rosenbluth and Arianna W. Rosenbluth in 1955, and more recently by Jack H. Hetherington in 1984. In computational physics, these Feynman-Kac type path particle integration methods are also used in Quantum Monte Carlo, and more specifically Diffusion Monte Carlo methods. Feynman-Kac interacting particle methods are also strongly related to mutation-selection genetic algorithms currently used in evolutionary computation to solve complex optimization problems.

The particle filter methodology is used to solve Hidden Markov Model (HMM) and nonlinear filtering problems. With the notable exception of linear-Gaussian signal-observation models (Kalman filter) or wider classes of models (Benes filter ), Mireille Chaleyat-Maurel and Dominique Michel proved in 1984 that the sequence of posterior distributions of the random states of a signal, given the observations (a.k.a. optimal filter), has no finite recursion. Various other numerical methods based on fixed grid approximations, Markov Chain Monte Carlo techniques, conventional linearization, extended Kalman filters, or determining the best linear system (in the expected cost-error sense) are unable to cope with large-scale systems, unstable processes, or insufficiently smooth nonlinearities.

Particle filters and Feynman-Kac particle methodologies find application in signal and image processing, Bayesian inference, machine learning, risk analysis and rare event sampling, engineering and robotics, artificial intelligence, bioinformatics, phylogenetics, computational science, economics and mathematical finance, molecular chemistry, computational physics, pharmacokinetics, quantitative risk and insurance and other fields.

Heuristic-like algorithms
From a statistical and probabilistic viewpoint, particle filters belong to the class of branching/genetic type algorithms, and mean-field type interacting particle methodologies. The interpretation of these particle methods depends on the scientific discipline. In Evolutionary Computing, mean-field genetic type particle methodologies are often used as heuristic and natural search algorithms (a.k.a. Metaheuristic). In computational physics and molecular chemistry, they are used to solve Feynman-Kac path integration problems or to compute Boltzmann-Gibbs measures, top eigenvalues, and ground states of Schrödinger operators. In Biology and Genetics, they represent the evolution of a population of individuals or genes in some environment.

The origins of mean-field type evolutionary computational techniques can be traced back to 1950 and 1954 with Alan Turing's work on genetic type mutation-selection learning machines and the articles by Nils Aall Barricelli at the Institute for Advanced Study in Princeton, New Jersey. The first trace of particle filters in statistical methodology dates back to the mid-1950s; the 'Poor Man's Monte Carlo', that was proposed by Hammersley et al., in 1954, contained hints of the genetic type particle filtering methods used today. In 1963, Nils Aall Barricelli simulated a genetic type algorithm to mimic the ability of individuals to play a simple game. In evolutionary computing literature, genetic-type mutation-selection algorithms became popular through the seminal work of John Holland in the early 1970s, particularly his book published in 1975.

In Biology and Genetics, the Australian geneticist Alex Fraser also published in 1957 a series of papers on the genetic type simulation of artificial selection of organisms. The computer simulation of the evolution by biologists became more common in the early 1960s, and the methods were described in books by Fraser and Burnell (1970) and Crosby (1973). Fraser's simulations included all of the essential elements of modern mutation-selection genetic particle algorithms.

From the mathematical viewpoint, the conditional distribution of the random states of a signal given some partial and noisy observations is described by a Feynman-Kac probability on the random trajectories of the signal weighted by a sequence of likelihood potential functions. Quantum Monte Carlo, and more specifically Diffusion Monte Carlo methods can also be interpreted as a mean-field genetic type particle approximation of Feynman-Kac path integrals. The origins of Quantum Monte Carlo methods are often attributed to Enrico Fermi and Robert Richtmyer who developed in 1948 a mean-field particle interpretation of neutron-chain reactions, but the first heuristic-like and genetic type particle algorithm (a.k.a. Resampled or Reconfiguration Monte Carlo methods) for estimating ground state energies of quantum systems (in reduced matrix models) is due to Jack H. Hetherington in 1984. One can also quote the earlier seminal works of Theodore E. Harris and Herman Kahn in particle physics, published in 1951, using mean-field but heuristic-like genetic methods for estimating particle transmission energies. In molecular chemistry, the use of genetic heuristic-like particle methodologies (a.k.a. pruning and enrichment strategies) can be traced back to 1955 with the seminal work of Marshall N. Rosenbluth and Arianna W. Rosenbluth.

The use of genetic particle algorithms in advanced signal processing and Bayesian inference is more recent. In January 1993, Genshiro Kitagawa developed a "Monte Carlo filter", a slightly modified version of this article appeared in 1996. In April 1993, Gordon et al., published in their seminal work an application of genetic type algorithm in Bayesian statistical inference. The authors named their algorithm 'the bootstrap filter', and demonstrated that compared to other filtering methods, their bootstrap algorithm does not require any assumption about that state space or the noise of the system. Independently, the ones by Pierre Del Moral and Himilcon Carvalho, Pierre Del Moral, André Monin, and Gérard Salut on particle filters published in the mid-1990s. Particle filters were also developed in signal processing in early 1989-1992 by P. Del Moral, J.C. Noyer, G. Rigal, and G. Salut in the LAAS-CNRS in a series of restricted and classified research reports with STCAN (Service Technique des Constructions et Armes Navales), the IT company DIGILOG, and the LAAS-CNRS (the Laboratory for Analysis and Architecture of Systems) on RADAR/SONAR and GPS signal processing problems.

Mathematical foundations
From 1950 to 1996, all the publications on particle filters, and genetic algorithms, including the pruning and resample Monte Carlo methods introduced in computational physics and molecular chemistry, present natural and heuristic-like algorithms applied to different situations without a single proof of their consistency, nor a discussion on the bias of the estimates and genealogical and ancestral tree-based algorithms.

The mathematical foundations and the first rigorous analysis of these particle algorithms are due to Pierre Del Moral in 1996. The article also contains proof of the unbiased properties of a particle approximation of likelihood functions and unnormalized conditional probability measures. The unbiased particle estimator of the likelihood functions presented in this article is used today in Bayesian statistical inference.

Dan Crisan, Jessica Gaines, and Terry Lyons, as well as Dan Crisan, Pierre Del Moral, and Terry Lyons, created branching-type particle techniques with various population sizes around the end of the 1990s. P. Del Moral, A. Guionnet, and L. Miclo   made more advances in this subject in 2000. Pierre Del Moral and Alice Guionnet proved the first central limit theorems in 1999, and Pierre Del Moral and Laurent Miclo proved them in 2000. The first uniform convergence results concerning the time parameter for particle filters were developed at the end of the 1990s by Pierre Del Moral and Alice Guionnet. The first rigorous analysis of genealogical tree-ased particle filter smoothers is due to P. Del Moral and L. Miclo in 2001

The theory on Feynman-Kac particle methodologies and related particle filter algorithms was developed in 2000 and 2004 in the books. These abstract probabilistic models encapsulate genetic type algorithms, particle, and bootstrap filters, interacting Kalman filters (a.k.a. Rao–Blackwellized particle filter ), importance sampling and resampling style particle filter techniques, including genealogical tree-based and particle backward methodologies for solving filtering and smoothing problems. Other classes of particle filtering methodologies include genealogical tree-based models, backward Markov particle models, adaptive mean-field particle models, island-type particle models,  particle Markov chain Monte Carlo methodologies,  Sequential Monte Carlo samplers   and Sequential Monte Carlo Approximate Bayesian Computation methods and Sequential Monte Carlo ABC based Bayesian Bootstrap.

Objective
A particle filter's goal is to estimate the posterior density of state variables given observation variables. The particle filter is intended for use with a hidden Markov Model, in which the system includes both hidden and observable variables. The observable variables (observation process) are linked to the hidden variables (state-process) via a known functional form. Similarly, the probabilistic description of the dynamical system defining the evolution of the state variables is known.

A generic particle filter estimates the posterior distribution of the hidden states using the observation measurement process. With respect to a state-space such as the one below:


 * $$\begin{array}{cccccccccc}

X_0&\to &X_1&\to &X_2&\to&X_3&\to &\cdots&\text{signal}\\ \downarrow&&\downarrow&&\downarrow&&\downarrow&&\cdots&\\ Y_0&&Y_1&&Y_2&&Y_3&&\cdots&\text{observation} \end{array}$$ the filtering problem is to estimate sequentially the values of the hidden states $$X_k$$, given the values of the observation process $$Y_0,\cdots,Y_k,$$ at any time step k.

All Bayesian estimates of $$X_k$$ follow from the posterior density $$p(x_k|y_0,y_1,...,y_k)$$. The particle filter methodology provides an approximation of these conditional probabilities using the empirical measure associated with a genetic type particle algorithm. In contrast, the Markov Chain Monte Carlo or importance sampling approach would model the full posterior $$p(x_0,x_1,...,x_k|y_0,y_1,...,y_k)$$.

The Signal-Observation model
Particle methods often assume $$X_k$$ and the observations $$Y_k$$ can be modeled in this form:


 * $$X_0, X_1, \cdots$$ is a Markov process on $$\mathbb R^{d_x}$$ (for some $$d_x\geqslant 1$$) that evolves according to the transition probability density $$p(x_k|x_{k-1})$$. This model is also often written in a synthetic way as
 * $$X_k|X_{k-1}=x_k \sim p(x_k|x_{k-1})$$
 * with an initial probability density $$p(x_0)$$.

An example of system with these properties is:
 * The observations $$Y_0, Y_1, \cdots$$ take values in some state space on $$\mathbb{R}^{d_y}$$ (for some $$d_y\geqslant 1$$) and are conditionally independent provided that $$X_0, X_1, \cdots$$ are known. In other words, each $$Y_k$$ only depends on $$X_k$$. In addition, we assume conditional distribution for $$Y_k$$ given $$X_k=x_k$$ are absolutely continuous, and in a synthetic way we have
 * $$Y_k|X_k=y_k \sim p(y_k|x_k)$$


 * $$X_k = g(X_{k-1}) + W_{k-1}$$
 * $$Y_k = h(X_k) + V_k$$

where both $$W_k$$ and $$V_k$$ are mutually independent sequences with known probability density functions and g and h are known functions. These two equations can be viewed as state space equations and look similar to the state space equations for the Kalman filter. If the functions g and h in the above example are linear, and if both $$W_k$$ and $$V_k$$ are Gaussian, the Kalman filter finds the exact Bayesian filtering distribution. If not, Kalman filter-based methods are a first-order approximation (EKF) or a second-order approximation (UKF in general, but if the probability distribution is Gaussian a third-order approximation is possible).

The assumption that the initial distribution and the transitions of the Markov chain are continuous for the Lebesgue measure can be relaxed. To design a particle filter we simply need to assume that we can sample the transitions $$X_{k-1} \to X_k$$ of the Markov chain $$X_k,$$ and to compute the likelihood function $$x_k\mapsto p(y_k|x_k)$$ (see for instance the genetic selection mutation description of the particle filter given below). The continuous assumption on the Markov transitions of $$X_k$$ is only used to derive in an informal (and rather abusive) way different formulae between posterior distributions using the Bayes' rule for conditional densities.

Approximate Bayesian computation models
In certain problems, the conditional distribution of observations, given the random states of the signal, may fail to have a density; the latter may be impossible or too complex to compute. In this situation, an additional level of approximation is necessitated. One strategy is to replace the signal $$X_k$$ by the Markov chain $$\mathcal X_k=\left(X_k,Y_k\right)$$ and to introduce a virtual observation of the form


 * $$\mathcal Y_k=Y_k+\epsilon \mathcal V_k\quad\mbox{for some parameter}\quad\epsilon\in [0,1]$$

for some sequence of independent random variables $$\mathcal V_k$$ with known probability density functions. The central idea is to observe that


 * $$\text{Law}\left(X_k|\mathcal Y_0=y_0,\cdots, \mathcal Y_k=y_k\right)\approx_{\epsilon\downarrow 0} \text{Law}\left(X_k|Y_0=y_0,\cdots, Y_k=y_k\right)$$

The particle filter associated with the Markov process $$\mathcal X_k=\left(X_k,Y_k\right)$$ given the partial observations $$\mathcal Y_0=y_0,\cdots, \mathcal Y_k=y_k,$$ is defined in terms of particles evolving in $$\mathbb R^{d_x+d_y}$$ with a likelihood function given with some obvious abusive notation by $$p(\mathcal Y_k|\mathcal X_k)$$. These probabilistic techniques are closely related to Approximate Bayesian Computation (ABC). In the context of particle filters, these ABC particle filtering techniques were introduced in 1998 by P. Del Moral, J. Jacod and P. Protter. They were further developed by P. Del Moral, A. Doucet and A. Jasra.

The nonlinear filtering equation
Bayes' rule for conditional probability gives:


 * $$p(x_0, \cdots, x_k|y_0,\cdots,y_k) =\frac{p(y_0,\cdots,y_k|x_0, \cdots, x_k) p(x_0,\cdots,x_k)}{p(y_0,\cdots,y_k)}$$

where


 * $$\begin{align}

p(y_0,\cdots,y_k) &=\int p(y_0,\cdots,y_k|x_0,\cdots, x_k) p(x_0,\cdots,x_k) dx_0\cdots dx_k \\ p(y_0,\cdots, y_k|x_0,\cdots ,x_k) &=\prod_{l=0}^{k} p(y_l|x_l) \\ p(x_0,\cdots, x_k) &=p_0(x_0)\prod_{l=1}^{k} p(x_l|x_{l-1}) \end{align}$$

Particle filters are also an approximation, but with enough particles they can be much more accurate. The nonlinear filtering equation is given by the recursion

with the convention $$p(x_0|y_0,\cdots,y_{k-1})=p(x_0)$$ for k = 0. The nonlinear filtering problem consists in computing these conditional distributions sequentially.

Feynman-Kac formulation
We fix a time horizon n and a sequence of observations $$Y_0=y_0,\cdots,Y_n=y_n$$, and for each k = 0, ..., n we set:


 * $$G_k(x_k)=p(y_k|x_k).$$

In this notation, for any bounded function F on the set of trajectories of $$X_k$$ from the origin k = 0 up to time k = n, we have the Feynman-Kac formula


 * $$\begin{align}

\int F(x_0,\cdots,x_n) p(x_0,\cdots,x_n|y_0,\cdots,y_n) dx_0\cdots dx_n &= \frac{\int F(x_0,\cdots,x_n) \left\{\prod\limits_{k=0}^{n} p(y_k|x_k)\right\}p(x_0,\cdots,x_n) dx_0\cdots dx_n}{\int \left\{\prod\limits_{k=0}^{n} p(y_k|x_k)\right\}p(x_0,\cdots,x_n) dx_0\cdots dx_n}\\ &=\frac{E\left(F(X_0,\cdots,X_n)\prod\limits_{k=0}^{n} G_k(X_k)\right)}{E\left(\prod\limits_{k=0}^{n} G_k(X_k)\right)} \end{align}$$

Feynman-Kac path integration models arise in a variety of scientific disciplines, including in computational physics, biology, information theory and computer sciences. Their interpretations are dependent on the application domain. For instance, if we choose the indicator function $$G_n(x_n)=1_A(x_n)$$ of some subset of the state space, they represent the conditional distribution of a Markov chain given it stays in a given tube; that is, we have:


 * $$E\left(F(X_0,\cdots,X_n) | X_0\in A, \cdots, X_n\in A\right) =\frac{E\left(F(X_0,\cdots,X_n)\prod\limits_{k=0}^{n} G_k(X_k)\right)}{E\left(\prod\limits_{k=0}^{n} G_k(X_k)\right)}$$

and
 * $$P\left(X_0\in A,\cdots, X_n\in A\right)=E\left(\prod\limits_{k=0}^{n} G_k(X_k)\right)$$

as soon as the normalizing constant is strictly positive.

A Genetic type particle algorithm
Initially, such an algorithm starts with N independent random variables $$\left(\xi^i_0\right)_{1\leqslant i\leqslant N}$$ with common probability density $$p(x_0)$$. The genetic algorithm selection-mutation transitions


 * $$\xi_k:=\left(\xi^i_{k}\right)_{1\leqslant i\leqslant N}\stackrel{\text{selection}}{\longrightarrow} \widehat{\xi}_k:=\left(\widehat{\xi}^i_{k}\right)_{1\leqslant i\leqslant N}\stackrel{\text{mutation}}{\longrightarrow} \xi_{k+1}:=\left(\xi^i_{k+1}\right)_{1\leqslant i\leqslant N}$$

mimic/approximate the updating-prediction transitions of the optimal filter evolution ($$):


 * During the selection-updating transition we sample N (conditionally) independent random variables $$\widehat{\xi}_k:=\left(\widehat{\xi}^i_{k}\right)_{1\leqslant i\leqslant N}$$ with common (conditional) distribution
 * $$\sum_{i=1}^N \frac{p(y_k|\xi^i_k)}{\sum_{j=1}^Np(y_k|\xi^j_k)} \delta_{\xi^i_k}(dx_k)$$

where $$\delta_a$$ stands for the Dirac measure at a given state a.


 * During the mutation-prediction transition, from each selected particle $$\widehat{\xi}^i_k$$ we sample independently a transition
 * $$\widehat{\xi}^i_k \longrightarrow\xi^i_{k+1} \sim p(x_{k+1}|\widehat{\xi}^i_k), \qquad i=1,\cdots,N.$$

In the above displayed formulae $$p(y_k|\xi^i_k)$$ stands for the likelihood function $$x_k\mapsto p(y_k|x_k)$$ evaluated at $$x_k=\xi^i_k$$, and $$p(x_{k+1}|\widehat{\xi}^i_k)$$ stands for the conditional density $$p(x_{k+1}|x_k)$$ evaluated at $$x_k=\widehat{\xi}^i_k$$.

At each time k, we have the particle approximations


 * $$\widehat{p}(dx_k|y_0,\cdots,y_k):=\frac{1}{N} \sum_{i=1}^N \delta_{\widehat{\xi}^i_k} (dx_k) \approx_{N\uparrow\infty} p(dx_k|y_0,\cdots,y_k) \approx_{N\uparrow\infty}

\sum_{i=1}^N \frac{p(y_k|\xi^i_k)}{\sum_{i=1}^N p(y_k|\xi^j_k)} \delta_{\xi^i_k}(dx_k)$$

and


 * $$\widehat{p}(dx_k|y_0,\cdots,y_{k-1}):=\frac{1}{N}\sum_{i=1}^N \delta_{\xi^i_k}(dx_k) \approx_{N\uparrow\infty} p(dx_k|y_0,\cdots,y_{k-1})$$

In Genetic algorithms and Evolutionary computing community, the mutation-selection Markov chain described above is often called the genetic algorithm with proportional selection. Several branching variants, including with random population sizes have also been proposed in the articles.

Monte Carlo principles
Particle methods, like all sampling-based approaches (e.g., Markov Chain Monte Carlo), generate a set of samples that approximate the filtering density


 * $$p(x_k|y_0, \cdots, y_k).$$

For example, we may have N samples from the approximate posterior distribution of $$X_k$$, where the samples are labeled with superscripts as:


 * $$\widehat{\xi}_k^1, \cdots, \widehat{\xi}_k^{N}.$$

Then, expectations with respect to the filtering distribution are approximated by

with


 * $$\widehat{p}(dx_k|y_0,\cdots,y_k)=\frac{1}{N}\sum_{i=1}^N \delta_{\widehat{\xi}^i_k}(dx_k)$$

where $$\delta_a$$ stands for the Dirac measure at a given state a. The function f, in the usual way for Monte Carlo, can give all the moments etc. of the distribution up to some approximation error. When the approximation equation ($$) is satisfied for any bounded function f we write


 * $$p(dx_k|y_0,\cdots,y_k):=p(x_k|y_0,\cdots,y_k) dx_k \approx_{N\uparrow\infty} \widehat{p}(dx_k|y_0,\cdots,y_k)=\frac{1}{N}\sum_{i=1}^N \delta_{\widehat{\xi}^{i}_k}(dx_k)$$

Particle filters can be interpreted as a genetic type particle algorithm evolving with mutation and selection transitions. We can keep track of the ancestral lines


 * $$\left(\widehat{\xi}^{i}_{0,k}, \widehat{\xi}^{i}_{1,k},\cdots,\widehat{\xi}^{i}_{k-1,k},\widehat{\xi}^i_{k,k}\right)$$

of the particles $$i=1,\cdots,N$$. The random states $$\widehat{\xi}^{i}_{l,k}$$, with the lower indices l=0,...,k, stands for the ancestor of the individual $$\widehat{\xi}^{i}_{k,k}=\widehat{\xi}^i_k$$ at level l=0,...,k. In this situation, we have the approximation formula

with the empirical measure


 * $$\widehat{p}(d(x_0,\cdots,x_k)|y_0,\cdots,y_k):=\frac{1}{N}\sum_{i=1}^N \delta_{\left(\widehat{\xi}^{i}_{0,k},\widehat{\xi}^{i}_{1,k},\cdots,\widehat{\xi}^{i}_{k,k}\right)}(d(x_0,\cdots,x_k))$$

Here F stands for any founded function on the path space of the signal. In a more synthetic form ($$) is equivalent to


 * $$\begin{align}

p(d(x_0,\cdots,x_k)|y_0,\cdots,y_k)&:=p(x_0,\cdots,x_k|y_0,\cdots,y_k) \, dx_0\cdots dx_k \\ &\approx_{N\uparrow\infty} \widehat{p}(d(x_0,\cdots,x_k)|y_0,\cdots,y_k) \\ &:=\frac{1}{N}\sum_{i=1}^N \delta_{\left(\widehat{\xi}^{i}_{0,k}, \cdots,\widehat{\xi}^{i}_{k,k}\right)}(d(x_0,\cdots,x_k)) \end{align}$$

Particle filters can be interpreted in many different ways. From the probabilistic point of view they coincide with a mean-field particle interpretation of the nonlinear filtering equation. The updating-prediction transitions of the optimal filter evolution can also be interpreted as the classical genetic type selection-mutation transitions of individuals. The sequential importance resampling technique provides another interpretation of the filtering transitions coupling importance sampling with the bootstrap resampling step. Last, but not least, particle filters can be seen as an acceptance-rejection methodology equipped with a recycling mechanism.

The general probabilistic principle
The nonlinear filtering evolution can be interpreted as a dynamical system in the set of probability measures of the form $$\eta_{n+1}=\Phi_{n+1}\left(\eta_{n}\right)$$ where $$\Phi_{n+1}$$ stands for some mapping from the set of probability distribution into itself. For instance, the evolution of the one-step optimal predictor $$ \eta_n(dx_n) =p(x_n|y_0,\cdots,y_{n-1})dx_n$$

satisfies a nonlinear evolution starting with the probability distribution $$\eta_0(dx_0)=p(x_0)dx_0$$. One of the simplest ways to approximate these probability measures is to start with N independent random variables $$\left(\xi^i_0\right)_{1\leqslant i\leqslant N}$$ with common probability distribution $$\eta_0(dx_0)=p(x_0)dx_0$$. Suppose we have defined a sequence of N random variables $$\left(\xi^i_n\right)_{1\leqslant i\leqslant N}$$ such that


 * $$\frac{1}{N}\sum_{i=1}^N \delta_{\xi^i_n}(dx_n) \approx_{N\uparrow\infty} \eta_n(dx_n)$$

At the next step we sample N (conditionally) independent random variables $$\xi_{n+1}:=\left(\xi^i_{n+1}\right)_{1\leqslant i\leqslant N}$$ with common law.


 * $$\Phi_{n+1}\left(\frac{1}{N}\sum_{i=1}^N \delta_{\xi^i_n}\right) \approx_{N\uparrow\infty} \Phi_{n+1}\left(\eta_{n}\right)=\eta_{n+1}$$

A particle interpretation of the filtering equation
We illustrate this mean-field particle principle in the context of the evolution of the one step optimal predictors

For k = 0 we use the convention $$p(x_0|y_0,\cdots,y_{-1}):=p(x_0)$$.

By the law of large numbers, we have


 * $$\widehat{p}(dx_0)=\frac{1}{N}\sum_{i=1}^N \delta_{\xi^{i}_0}(dx_0)\approx_{N\uparrow\infty} p(x_0)dx_0$$

in the sense that


 * $$\int f(x_0)\widehat{p}(dx_0)=\frac{1}{N}\sum_{i=1}^N f(\xi^i_0)\approx_{N\uparrow\infty} \int f(x_0)p(dx_0)dx_0$$

for any bounded function $$f$$. We further assume that we have constructed a sequence of particles $$\left(\xi^i_k\right)_{1\leqslant i\leqslant N}$$ at some rank k such that


 * $$\widehat{p}(dx_k|y_0,\cdots,y_{k-1}):=\frac{1}{N}\sum_{i=1}^N \delta_{\xi^{i}_k}(dx_k)\approx_{N\uparrow\infty}~p(x_k~|~y_0,\cdots,y_{k-1})dx_k$$

in the sense that for any bounded function $$f$$ we have


 * $$\int f(x_k)\widehat{p}(dx_k|y_0,\cdots,y_{k-1})=\frac{1}{N}\sum_{i=1}^N f(\xi^i_k)\approx_{N\uparrow\infty} \int f(x_k)p(dx_k|y_0,\cdots,y_{k-1})dx_k$$

In this situation, replacing by the empirical measure  in the evolution equation of the one-step optimal filter stated in ($$) we find that


 * $$p(x_{k+1}|y_0,\cdots,y_k)\approx_{N\uparrow\infty} \int p(x_{k+1}|x'_{k}) \frac{p(y_k|x_k') \widehat{p}(dx'_k|y_0,\cdots,y_{k-1})}{ \int p(y_k|x_k) \widehat{p}(dx_k|y_0,\cdots,y_{k-1})}$$

Notice that the right hand side in the above formula is a weighted probability mixture


 * $$\int p(x_{k+1}|x'_{k}) \frac{p(y_k|x_k') \widehat{p}(dx'_k|y_0,\cdots,y_{k-1})}{\int p(y_k|x_k) \widehat{p}(dx_k|y_0,\cdots,y_{k-1})}=\sum_{i=1}^N \frac{p(y_k|\xi^i_k)}{\sum_{i=1}^N p(y_k|\xi^j_k)} p(x_{k+1}|\xi^i_k)=:\widehat{q}(x_{k+1}|y_0,\cdots,y_k)$$

where $$p(y_k|\xi^i_k)$$ stands for the density $$p(y_k|x_k)$$ evaluated at $$x_k=\xi^i_k$$, and $$p(x_{k+1}|\xi^i_k)$$ stands for the density $$p(x_{k+1}|x_k)$$ evaluated at $$x_k=\xi^i_k$$ for $$i=1,\cdots,N.$$

Then, we sample N independent random variable $$\left(\xi^i_{k+1}\right)_{1\leqslant i\leqslant N}$$ with common probability density $$\widehat{q}(x_{k+1}|y_0,\cdots,y_k)$$ so that


 * $$\widehat{p}(dx_{k+1}|y_0,\cdots,y_{k}):=\frac{1}{N}\sum_{i=1}^N \delta_{\xi^{i}_{k+1}}(dx_{k+1})\approx_{N\uparrow\infty} \widehat{q}(x_{k+1}|y_0,\cdots,y_{k}) dx_{k+1} \approx_{N\uparrow\infty} p(x_{k+1}|y_0,\cdots,y_{k})dx_{k+1}$$

Iterating this procedure, we design a Markov chain such that


 * $$\widehat{p}(dx_k|y_0,\cdots,y_{k-1}):=\frac{1}{N}\sum_{i=1}^N \delta_{\xi^i_k}(dx_k) \approx_{N\uparrow\infty} p(dx_k|y_0,\cdots,y_{k-1}):=p(x_k|y_0,\cdots,y_{k-1}) dx_k$$

Notice that the optimal filter is approximated at each time step k using the Bayes' formulae


 * $$p(dx_{k}|y_0,\cdots,y_{k}) \approx_{N\uparrow\infty} \frac{p(y_{k}|x_{k}) \widehat{p}(dx_{k}|y_0,\cdots,y_{k-1})}{\int p(y_{k}|x'_{k})\widehat{p}(dx'_{k}|y_0,\cdots,y_{k-1})}=\sum_{i=1}^N \frac{p(y_k|\xi^i_k)}{\sum_{j=1}^Np(y_k|\xi^j_k)}~\delta_{\xi^i_k}(dx_k)$$

The terminology "mean-field approximation" comes from the fact that we replace at each time step the probability measure $$p(dx_k|y_0,\cdots,y_{k-1})$$ by the empirical approximation $$\widehat{p}(dx_k|y_0,\cdots,y_{k-1})$$. The mean-field particle approximation of the filtering problem is far from being unique. Several strategies are developed in the books.

Some convergence results
The analysis of the convergence of particle filters was started in 1996 and in 2000 in the book and the series of articles. More recent developments can be found in the books, When the filtering equation is stable (in the sense that it corrects any erroneous initial condition), the bias and the variance of the particle particle estimates


 * $$I_k(f):=\int f(x_k) p(dx_k|y_0,\cdots,y_{k-1}) \approx_{N\uparrow\infty} \widehat{I}_k(f):=\int f(x_k) \widehat{p}(dx_k|y_0,\cdots,y_{k-1})$$

are controlled by the non asymptotic uniform estimates


 * $$\sup_{k\geqslant 0}\left\vert E\left(\widehat{I}_k(f)\right)-I_k(f)\right\vert\leqslant \frac{c_1}{N}$$
 * $$\sup_{k\geqslant 0}E\left(\left[\widehat{I}_k(f)-I_k(f)\right]^2\right)\leqslant \frac{c_2}{N}$$

for any function f bounded by 1, and for some finite constants $$c_1,c_2.$$ In addition, for any $$x\geqslant 0$$:


 * $$\mathbf{P} \left ( \left| \widehat{I}_k(f)-I_k(f)\right|\leqslant c_1 \frac{x}{N}+c_2 \sqrt{\frac{x}{N}}\land \sup_{0\leqslant k\leqslant n}\left| \widehat{I}_k(f)-I_k(f)\right|\leqslant c \sqrt{\frac{x\log(n)}{N}} \right ) > 1-e^{-x}$$

for some finite constants $$c_1, c_2$$ related to the asymptotic bias and variance of the particle estimate, and some finite constant c. The same results are satisfied if we replace the one step optimal predictor by the optimal filter approximation.

Genealogical tree based particle smoothing
Tracing back in time the ancestral lines


 * $$\left(\widehat{\xi}^i_{0,k},\widehat{\xi}^i_{1,k},\cdots,\widehat{\xi}^i_{k-1,k},\widehat{\xi}^i_{k,k}\right), \quad \left(\xi^i_{0,k},\xi^i_{1,k},\cdots,\xi^i_{k-1,k},\xi^i_{k,k}\right)$$

of the individuals $$\widehat{\xi}^i_{k}\left(=\widehat{\xi}^i_{k,k}\right)$$ and $$\xi^i_{k}\left(={\xi}^i_{k,k}\right)$$ at every time step k, we also have the particle approximations


 * $$\begin{align}

\widehat{p}(d(x_0,\cdots,x_k)|y_0,\cdots,y_k) &:=\frac{1}{N}\sum_{i=1}^N \delta_{\left(\widehat{\xi}^i_{0,k},\cdots,\widehat{\xi}^i_{0,k}\right)}(d(x_0,\cdots,x_k)) \\ &\approx_{N\uparrow\infty} p(d(x_0,\cdots,x_k)|y_0,\cdots,y_k) \\ &\approx_{N\uparrow\infty} \sum_{i=1}^N \frac{p(y_k|\xi^i_{k,k})}{\sum_{j=1}^Np(y_k|\xi^j_{k,k})} \delta_{\left(\xi^i_{0,k},\cdots,\xi^i_{0,k}\right)}(d(x_0,\cdots,x_k)) \\ & \ \\ \widehat{p}(d(x_0,\cdots,x_k)|y_0,\cdots,y_{k-1}) &:=\frac{1}{N}\sum_{i=1}^N \delta_{\left(\xi^i_{0,k},\cdots,\xi^i_{k,k}\right)}(d(x_0,\cdots,x_k)) \\ &\approx_{N\uparrow\infty} p(d(x_0,\cdots,x_k)|y_0,\cdots,y_{k-1}) \\ &:=p(x_0,\cdots,x_k|y_0,\cdots,y_{k-1}) dx_0,\cdots,dx_k \end{align}$$

These empirical approximations are equivalent to the particle integral approximations


 * $$\begin{align}

\int F(x_0,\cdots,x_n) \widehat{p}(d(x_0,\cdots,x_k)|y_0,\cdots,y_k) &:=\frac{1}{N}\sum_{i=1}^N F\left(\widehat{\xi}^i_{0,k},\cdots,\widehat{\xi}^i_{0,k}\right) \\ &\approx_{N\uparrow\infty} \int F(x_0,\cdots,x_n) p(d(x_0,\cdots,x_k)|y_0,\cdots,y_k) \\ &\approx_{N\uparrow\infty} \sum_{i=1}^N \frac{p(y_k|\xi^i_{k,k})}{\sum_{j=1}^N p(y_k|\xi^j_{k,k})} F\left(\xi^i_{0,k}, \cdots,\xi^i_{k,k} \right) \\ & \ \\ \int F(x_0,\cdots,x_n) \widehat{p}(d(x_0,\cdots,x_k)|y_0,\cdots,y_{k-1}) &:=\frac{1}{N} \sum_{i=1}^N F\left(\xi^i_{0,k},\cdots,\xi^i_{k,k}\right) \\ &\approx_{N\uparrow\infty} \int F(x_0,\cdots,x_n) p(d(x_0,\cdots,x_k)|y_0,\cdots,y_{k-1}) \end{align}$$

for any bounded function F on the random trajectories of the signal. As shown in the evolution of the genealogical tree coincides with a mean-field particle interpretation of the evolution equations associated with the posterior densities of the signal trajectories. For more details on these path space models, we refer to the books.

Unbiased particle estimates of likelihood functions
We use the product formula


 * $$p(y_0,\cdots,y_n)=\prod_{k=0}^n p(y_k|y_0,\cdots,y_{k-1})$$

with


 * $$p(y_k|y_0,\cdots,y_{k-1})=\int p(y_k|x_k) p(dx_k|y_0,\cdots,y_{k-1})$$

and the conventions $$p(y_0|y_0,\cdots,y_{-1})=p(y_0)$$ and $$p(x_0|y_0,\cdots,y_{-1})=p(x_0),$$ for k = 0. Replacing $$p(x_k|y_0,\cdots,y_{k-1})dx_k$$ by the empirical approximation


 * $$\widehat{p}(dx_k|y_0,\cdots,y_{k-1}):=\frac{1}{N}\sum_{i=1}^N \delta_{\xi^i_k}(dx_k) \approx_{N\uparrow\infty} p(dx_k|y_0,\cdots,y_{k-1})$$

in the above displayed formula, we design the following unbiased particle approximation of the likelihood function


 * $$p(y_0,\cdots,y_n) \approx_{N\uparrow\infty} \widehat{p}(y_0,\cdots,y_n)=\prod_{k=0}^n \widehat{p}(y_k|y_0,\cdots,y_{k-1}) $$

with


 * $$\widehat{p}(y_k|y_0,\cdots,y_{k-1})=\int p(y_k|x_k) \widehat{p}(dx_k|y_0,\cdots,y_{k-1})=\frac{1}{N}\sum_{i=1}^N p(y_k|\xi^i_k)$$

where $$p(y_k|\xi^i_k)$$ stands for the density $$p(y_k|x_k)$$ evaluated at $$x_k=\xi^i_k$$. The design of this particle estimate and the unbiasedness property has been proved in 1996 in the article. Refined variance estimates can be found in and.

Backward particle smoothers
Using Bayes' rule, we have the formula


 * $$p(x_0,\cdots,x_n|y_0,\cdots,y_{n-1}) = p(x_n | y_0,\cdots,y_{n-1}) p(x_{n-1}|x_n, y_0,\cdots,y_{n-1} ) \cdots p(x_1|x_2,y_0,y_1) p(x_0|x_1,y_0)$$

Notice that


 * $$ \begin{align}

p(x_{k-1}|x_{k},(y_0,\cdots,y_{k-1})) &\propto p(x_{k}|x_{k-1})p(x_{k-1}|(y_0,\cdots,y_{k-1})) \\ p(x_{k-1}|(y_0,\cdots,y_{k-1}) &\propto p(y_{k-1}|x_{k-1})p(x_{k-1}|(y_0,\cdots,y_{k-2}) \end{align}$$

This implies that


 * $$p(x_{k-1}|x_k, (y_0,\cdots,y_{k-1}))=\frac{p(y_{k-1}|x_{k-1})p(x_{k}|x_{k-1})p(x_{k-1}|y_0,\cdots,y_{k-2})}{\int p(y_{k-1}|x'_{k-1})p(x_{k}|x'_{k-1})p(x'_{k-1}|y_0,\cdots,y_{k-2}) dx'_{k-1}}$$

Replacing the one-step optimal predictors $$p(x_{k-1}|(y_0,\cdots,y_{k-2}))dx_{k-1}$$ by the particle empirical measures


 * $$\widehat{p}(dx_{k-1}|(y_0,\cdots,y_{k-2}))=\frac{1}{N}\sum_{i=1}^N \delta_{\xi^i_{k-1}}(dx_{k-1}) \left(\approx_{N\uparrow\infty} p(dx_{k-1}|(y_0,\cdots,y_{k-2})):={p}(x_{k-1}|(y_0,\cdots,y_{k-2})) dx_{k-1}\right)$$

we find that


 * $$\begin{align}

p(dx_{k-1}| x_{k},(y_0,\cdots,y_{k-1})) &\approx_{N\uparrow\infty} \widehat{p}(dx_{k-1}|x_{k},(y_0,\cdots,y_{k-1})) \\ &:= \frac{p(y_{k-1}|x_{k-1}) p(x_{k}|x_{k-1}) \widehat{p}(dx_{k-1}|y_0,\cdots,y_{k-2})}{\int p(y_{k-1}|x'_{k-1})~p(x_{k}| x'_{k-1}) \widehat{p}(dx'_{k-1}|y_0,\cdots,y_{k-2})}\\ &= \sum_{i=1}^{N} \frac{p(y_{k-1}|\xi^i_{k-1}) p(x_{k}|\xi^i_{k-1})}{\sum_{j=1}^{N} p(y_{k-1}|\xi^j_{k-1}) p(x_{k}|\xi^j_{k-1})} \delta_{\xi^i_{k-1}}(dx_{k-1}) \end{align}$$

We conclude that


 * $$p(d(x_0,\cdots,x_n)|(y_0,\cdots,y_{n-1})) \approx_{N\uparrow\infty} \widehat{p}_{backward}(d(x_0,\cdots,x_n)|(y_0,\cdots,y_{n-1}))$$

with the backward particle approximation


 * $$\begin{align}

\widehat{p}_{backward} (d(x_0,\cdots,x_n)|(y_0,\cdots,y_{n-1})) = \widehat{p}(dx_n|(y_0,\cdots,y_{n-1})) \widehat{p}(dx_{n-1}|x_n,(y_0,\cdots,y_{n-1})) \cdots \widehat{p}(dx_1|x_2,(y_0,y_1)) \widehat{p}(dx_0|x_1,y_0) \end{align}$$

The probability measure


 * $$\widehat{p}_{backward}(d(x_0,\cdots,x_n)|(y_0,\cdots,y_{n-1}))$$

is the probability of the random paths of a Markov chain $$\left(\mathbb X^{\flat}_{k,n}\right)_{0\leqslant k\leqslant n}$$running backward in time from time k=n to time k=0, and evolving at each time step k in the state space associated with the population of particles $$\xi^i_k, i=1,\cdots,N.$$
 * Initially (at time k=n) the chain $$\mathbb X^{\flat}_{n,n}$$ chooses randomly a state with the distribution
 * $$\widehat{p}(dx_{n}|(y_0,\cdots,y_{n-1}))=\frac{1}{N}\sum_{i=1}^N \delta_{\xi^i_{n}}(dx_{n})$$


 * From time k to the time (k-1), the chain starting at some state $$\mathbb X^{\flat}_{k,n}=\xi^i_k$$ for some $$ i=1,\cdots,N$$ at time k moves at time (k-1) to a random state $$\mathbb{X}^{\flat}_{k-1,n}$$ chosen with the discrete weighted probability


 * $$\widehat{p}(dx_{k-1}|\xi^i_{k},(y_0,\cdots,y_{k-1}))= \sum_{j=1}^N\frac{p(y_{k-1}|\xi^j_{k-1}) p(\xi^i_{k}|\xi^j_{k-1})}{\sum_{l=1}^Np(y_{k-1}|\xi^l_{k-1}) p(\xi^i_{k}|\xi^l_{k-1})}~\delta_{\xi^j_{k-1}}(dx_{k-1})$$

In the above displayed formula, $$\widehat{p}(dx_{k-1}|\xi^i_{k},(y_0,\cdots,y_{k-1}))$$ stands for the conditional distribution $$\widehat{p}(dx_{k-1}|x_k, (y_0,\cdots,y_{k-1}))$$ evaluated at $$x_k=\xi^i_{k}$$. In the same vein, $$p(y_{k-1}|\xi^j_{k-1})$$ and $$p(\xi^i_k|\xi^j_{k-1})$$ stand for the conditional densities $$p(y_{k-1}|x_{k-1})$$ and $$p(x_k|x_{k-1})$$ evaluated at $$x_k=\xi^i_{k}$$ and $$x_{k-1}=\xi^j_{k-1}.$$ These models allows to reduce integration with respect to the densities $$p((x_0,\cdots,x_n)|(y_0,\cdots,y_{n-1}))$$ in terms of matrix operations with respect to the Markov transitions of the chain described above. For instance, for any function $$f_k$$ we have the particle estimates


 * $$\begin{align}

\int p(d(x_0,\cdots,x_n)&|(y_0,\cdots,y_{n-1}))f_k(x_k) \\ &\approx_{N\uparrow\infty} \int \widehat{p}_{backward}(d(x_0,\cdots,x_n)| (y_0,\cdots,y_{n-1})) f_k(x_k) \\ &=\int \widehat{p}(dx_n| (y_0,\cdots,y_{n-1})) \widehat{p}(dx_{n-1}|x_n,(y_0,\cdots,y_{n-1})) \cdots \widehat{p}(dx_k| x_{k+1},(y_0,\cdots,y_k)) f_k(x_k) \\ &=\underbrace{\left[\tfrac{1}{N},\cdots,\tfrac{1}{N}\right]}_{N \text{ times}}\mathbb{M}_{n-1} \cdots\mathbb M_{k} \begin{bmatrix} f_k(\xi^1_k)\\ \vdots\\ f_k(\xi^N_k) \end{bmatrix} \end{align}$$

where


 * $$\mathbb M_k= (\mathbb M_k(i,j))_{1\leqslant i,j\leqslant N}: \qquad \mathbb M_k(i,j)=\frac{p(\xi^i_{k}|\xi^j_{k-1})~p(y_{k-1}|\xi^j_{k-1})}{\sum\limits_{l=1}^{N} p(\xi^i_{k}|\xi^l_{k-1}) p(y_{k-1}|\xi^l_{k-1})}$$

This also shows that if


 * $$\overline{F}(x_0,\cdots,x_n):=\frac{1}{n+1}\sum_{k=0}^n f_k(x_k)$$

then


 * $$\begin{align}

\int \overline{F}(x_0,\cdots,x_n) p(d(x_0,\cdots,x_n)|(y_0,\cdots,y_{n-1})) &\approx_{N\uparrow\infty} \int \overline{F}(x_0,\cdots,x_n) \widehat{p}_{backward}(d(x_0,\cdots,x_n)|(y_0,\cdots,y_{n-1})) \\ &=\frac{1}{n+1} \sum_{k=0}^n \underbrace{\left[\tfrac{1}{N},\cdots,\tfrac{1}{N}\right]}_{N \text{ times}}\mathbb M_{n-1}\mathbb M_{n-2}\cdots\mathbb{M}_k \begin{bmatrix} f_k(\xi^1_k)\\ \vdots\\ f_k(\xi^N_k) \end{bmatrix} \end{align}$$

Some convergence results
We shall assume that filtering equation is stable, in the sense that it corrects any erroneous initial condition.

In this situation, the particle approximations of the likelihood functions are unbiased and the relative variance is controlled by


 * $$E\left(\widehat{p}(y_0,\cdots,y_n)\right)= p(y_0,\cdots,y_n), \qquad E\left(\left[\frac{\widehat{p}(y_0,\cdots,y_n)}{p(y_0,\cdots,y_n)}-1\right]^2\right)\leqslant \frac{cn}{N},$$

for some finite constant c. In addition, for any $$x\geqslant 0$$:


 * $$\mathbf{P} \left ( \left\vert \frac{1}{n}\log{\widehat{p}(y_0,\cdots,y_n)}-\frac{1}{n}\log{p(y_0,\cdots,y_n)}\right\vert \leqslant c_1 \frac{x}{N}+c_2 \sqrt{\frac{x}{N}} \right ) > 1-e^{-x} $$

for some finite constants $$c_1, c_2$$ related to the asymptotic bias and variance of the particle estimate, and for some finite constant c.

The bias and the variance of the particle particle estimates based on the ancestral lines of the genealogical trees


 * $$\begin{align}

I^{path}_k(F) &:=\int F(x_0,\cdots,x_k) p(d(x_0,\cdots,x_k)|y_0,\cdots,y_{k-1}) \\ &\approx_{N\uparrow\infty} \widehat{I}^{path}_k(F) \\ &:=\int F(x_0,\cdots,x_k) \widehat{p}(d(x_0,\cdots,x_k)|y_0,\cdots,y_{k-1}) \\ &=\frac{1}{N}\sum_{i=1}^N F\left(\xi^i_{0,k},\cdots,\xi^i_{k,k}\right) \end{align}$$

are controlled by the non asymptotic uniform estimates


 * $$\left| E\left(\widehat{I}^{path}_k(F)\right)-I_k^{path}(F)\right|\leqslant \frac{c_1 k}{N}, \qquad E\left(\left[\widehat{I}^{path}_k(F)-I_k^{path}(F)\right]^2\right)\leqslant \frac{c_2 k}{N},$$

for any function F bounded by 1, and for some finite constants $$c_1, c_2.$$ In addition, for any $$x\geqslant 0$$:


 * $$\mathbf{P} \left ( \left| \widehat{I}^{path}_k(F)-I_k^{path}(F)\right | \leqslant c_1 \frac{kx}{N}+c_2 \sqrt{\frac{kx}{N}} \land \sup_{0\leqslant k\leqslant n}\left| \widehat{I}_k^{path}(F)-I^{path}_k(F)\right| \leqslant c \sqrt{\frac{xn\log(n)}{N}} \right ) > 1-e^{-x}$$

for some finite constants $$c_1, c_2$$ related to the asymptotic bias and variance of the particle estimate, and for some finite constant c. The same type of bias and variance estimates hold for the backward particle smoothers. For additive functionals of the form


 * $$\overline{F}(x_0,\cdots,x_n):=\frac{1}{n+1}\sum_{0\leqslant k\leqslant n}f_k(x_k)$$

with


 * $$I^{path}_n(\overline{F}) \approx_{N\uparrow\infty} I^{\flat, path}_n(\overline{F}):=\int \overline{F}(x_0,\cdots,x_n) \widehat{p}_{backward}(d(x_0,\cdots,x_n)|(y_0,\cdots,y_{n-1}))$$

with functions $$f_k$$ bounded by 1, we have


 * $$\sup_{n\geqslant 0}{\left\vert E\left(\widehat{I}^{\flat,path}_n(\overline{F})\right)-I_n^{path}(\overline{F})\right\vert} \leqslant \frac{c_1}{N}$$

and


 * $$E\left(\left[\widehat{I}^{\flat,path}_n(F)-I_n^{path}(F)\right]^2\right)\leqslant \frac{c_2}{nN}+ \frac{c_3}{N^2}$$

for some finite constants $$c_1,c_2,c_3.$$ More refined estimates including exponentially small probability of errors are developed in.

Monte Carlo filter and bootstrap filter
Sequential importance Resampling (SIR), Monte Carlo filtering (Kitagawa 1993 ), bootstrap filtering algorithm (Gordon et al. 1993 ) and single distribution resampling (Bejuri W.M.Y.B et al. 2017 ), are also commonly applied filtering algorithms, which approximate the filtering probability density $$p(x_k|y_0,\cdots,y_k)$$ by a weighted set of N samples


 * $$ \left \{ \left (w^{(i)}_k,x^{(i)}_k \right ) \ : \ i\in\{1,\cdots,N\} \right \}.$$

The importance weights $$w^{(i)}_k$$ are approximations to the relative posterior probabilities (or densities) of the samples such that


 * $$\sum_{i=1}^N w^{(i)}_k = 1.$$

Sequential importance sampling (SIS) is a sequential (i.e., recursive) version of importance sampling. As in importance sampling, the expectation of a function f can be approximated as a weighted average


 * $$ \int f(x_k) p(x_k|y_0,\dots,y_k) dx_k \approx \sum_{i=1}^N w_k^{(i)} f(x_k^{(i)}).$$

For a finite set of samples, the algorithm performance is dependent on the choice of the proposal distribution


 * $$\pi(x_k|x_{0:k-1},y_{0:k})\, $$.

The "optimal" proposal distribution is given as the target distribution
 * $$\pi(x_k|x_{0:k-1},y_{0:k}) = p(x_k|x_{k-1},y_{k})=\frac{p(y_k|x_k)}{\int p(y_k|x_k)p(x_k|x_{k-1})dx_k}~p(x_k|x_{k-1}).$$

This particular choice of proposal transition has been proposed by P. Del Moral in 1996 and 1998. When it is difficult to sample transitions according to the distribution $$ p(x_k|x_{k-1},y_{k})$$ one natural strategy is to use the following particle approximation


 * $$\begin{align}

\frac{p(y_k|x_k)}{\int p(y_k|x_k)p(x_k|x_{k-1})dx_k} p(x_k|x_{k-1})dx_k &\simeq_{N\uparrow\infty} \frac{p(y_k|x_k)}{\int p(y_k|x_k)\widehat{p}(dx_k|x_{k-1})} \widehat{p}(dx_k|x_{k-1}) \\ &= \sum_{i=1}^N \frac{p(y_k|X^i_k(x_{k-1}))}{\sum_{j=1}^N p(y_k|X^j_k(x_{k-1}))} \delta_{X^i_k(x_{k-1})}(dx_k) \end{align}$$

with the empirical approximation


 * $$ \widehat{p}(dx_k|x_{k-1})= \frac{1}{N}\sum_{i=1}^{N} \delta_{X^i_k(x_{k-1})}(dx_k)~\simeq_{N\uparrow\infty} p(x_k|x_{k-1})dx_k $$

associated with N (or any other large number of samples) independent random samples $$X^i_k(x_{k-1}), i=1,\cdots,N $$with the conditional distribution of the random state $$X_k$$ given $$X_{k-1}=x_{k-1}$$. The consistency of the resulting particle filter of this approximation and other extensions are developed in. In the above display $$\delta_a$$ stands for the Dirac measure at a given state a.

However, the transition prior probability distribution is often used as importance function, since it is easier to draw particles (or samples) and perform subsequent importance weight calculations:
 * $$\pi(x_k|x_{0:k-1},y_{0:k}) = p(x_k|x_{k-1}).$$

Sequential Importance Resampling (SIR) filters with transition prior probability distribution as importance function are commonly known as bootstrap filter and condensation algorithm.

Resampling is used to avoid the problem of the degeneracy of the algorithm, that is, avoiding the situation that all but one of the importance weights are close to zero. The performance of the algorithm can be also affected by proper choice of resampling method. The stratified sampling proposed by Kitagawa (1993 ) is optimal in terms of variance.

A single step of sequential importance resampling is as follows:


 * 1) For $$i=1,\cdots,N$$ draw samples from the proposal distribution
 * $$x^{(i)}_k \sim \pi(x_k|x^{(i)}_{0:k-1},y_{0:k})$$


 * 2) For $$i=1,\cdots,N$$ update the importance weights up to a normalizing constant:
 * $$\hat{w}^{(i)}_k = w^{(i)}_{k-1} \frac{p(y_k|x^{(i)}_k) p(x^{(i)}_k|x^{(i)}_{k-1})} {\pi(x_k^{(i)}|x^{(i)}_{0:k-1},y_{0:k})}.$$
 * Note that when we use the transition prior probability distribution as the importance function,
 * $$ \pi(x_k^{(i)}|x^{(i)}_{0:k-1},y_{0:k}) = p(x^{(i)}_k|x^{(i)}_{k-1}),$$
 * this simplifies to the following :
 * $$ \hat{w}^{(i)}_k = w^{(i)}_{k-1} p(y_k|x^{(i)}_k), $$


 * 3) For $$i=1,\cdots,N$$ compute the normalized importance weights:
 * $$w^{(i)}_k = \frac{\hat{w}^{(i)}_k}{\sum_{j=1}^N \hat{w}^{(j)}_k}$$


 * 4) Compute an estimate of the effective number of particles as
 * $$\hat{N}_\mathit{eff} = \frac{1}{\sum_{i=1}^N\left(w^{(i)}_k\right)^2} $$
 * This criterion reflects the variance of the weights. Other criteria can be found in the article, including their rigorous analysis and central limit theorems.


 * 5) If the effective number of particles is less than a given threshold $$\hat{N}_\mathit{eff} < N_{thr}$$, then perform resampling:
 * a) Draw N particles from the current particle set with probabilities proportional to their weights. Replace the current particle set with this new one.
 * b) For $$i=1,\cdots,N$$ set $$w^{(i)}_k = 1/N.$$

The term "Sampling Importance Resampling" is also sometimes used when referring to SIR filters, but the term Importance Resampling is more accurate because the word "resampling" implies that the initial sampling has already been done.

Sequential importance sampling (SIS)

 * Is the same as sequential importance resampling, but without the resampling stage.

"Direct version" algorithm
The "direct version" algorithm is rather simple (compared to other particle filtering algorithms) and it uses composition and rejection. To generate a single sample x at k from $$p_{x_k|y_{1:k}}(x|y_{1:k})$$:
 * 1) Set n = 0 (This will count the number of particles generated so far)


 * 2) Uniformly choose an index i from the range $$\{1,..., N\}$$


 * 3) Generate a test $$\hat{x}$$ from the distribution $$p(x_k|x_{k-1})$$ with $$ x_{k-1}=x_{k-1|k-1}^{(i)}$$


 * 4) Generate the probability of $$\hat{y}$$ using $$\hat{x}$$ from $$p(y_k|x_k),~\mbox{with}~x_k=\hat{x}$$ where $$y_k$$ is the measured value


 * 5) Generate another uniform u from $$[0, m_k]$$ where $$m_k = \sup_{x_k} p(y_k|x_k) $$


 * 6) Compare u and $$p\left(\hat{y}\right)$$


 * 6a) If u is larger then repeat from step 2


 * 6b) If u is smaller then save $$\hat{x}$$ as $$x_{k|k}^{(i)}$$ and increment n


 * 7) If n == N then quit

The goal is to generate P "particles" at k using only the particles from $$k-1$$. This requires that a Markov equation can be written (and computed) to generate a $$x_k$$ based only upon $$x_{k-1}$$. This algorithm uses the composition of the P particles from $$k-1$$ to generate a particle at k and repeats (steps 2–6) until P particles are generated at k.

This can be more easily visualized if x is viewed as a two-dimensional array. One dimension is k and the other dimension is the particle number. For example, $$x(k,i)$$ would be the ith particle at $$k$$ and can also be written $$x_k^{(i)}$$ (as done above in the algorithm). Step 3 generates a potential $$x_k$$ based on a randomly chosen particle ($$x_{k-1}^{(i)}$$) at time $$k-1$$ and rejects or accepts it in step 6. In other words, the $$x_k$$ values are generated using the previously generated $$x_{k-1}$$.

Applications
Particle filters and Feynman-Kac particle methodologies find application in several contexts, as an effective mean for tackling noisy observations or strong nonlinearities, such as:
 * Bayesian inference, machine learning, risk analysis and rare event sampling
 * Bioinformatics
 * Computational science
 * Economics, financial mathematics and mathematical finance: particle filters can perform simulations which are needed to compute the high-dimensional and/or complex integrals related to problems such as dynamic stochastic general equilibrium models in macro-economics and option pricing
 * Engineering
 * Infectious disease epidemiology where they have been applied to a number of epidemic forecasting problems, for example predicting seasonal influenza epidemics
 * Fault detection and isolation: in observer-based schemas a particle filter can forecast expected sensors output enabling fault isolation
 * Molecular chemistry and computational physics
 * Pharmacokinetics
 * Phylogenetics
 * Robotics, artificial intelligence: Monte Carlo localization is a de facto standard in mobile robot localization
 * Signal and image processing: visual localization, tracking, feature recognition

Other particle filters

 * Auxiliary particle filter
 * Cost Reference particle filter
 * Exponential Natural Particle Filter
 * Feynman-Kac and mean-field particle methodologies
 * Gaussian particle filter
 * Gauss–Hermite particle filter
 * Hierarchical/Scalable particle filter
 * Nudged particle filter
 * Particle Markov-Chain Monte-Carlo, see e.g. pseudo-marginal Metropolis–Hastings algorithm.
 * Rao–Blackwellized particle filter
 * Regularized auxiliary particle filter
 * Rejection-sampling based optimal particle filter
 * Unscented particle filter