Bernoulli process

In probability and statistics, a Bernoulli process (named after Jacob Bernoulli) is a finite or infinite sequence of binary random variables, so it is a discrete-time stochastic process that takes only two values, canonically 0 and 1. The component Bernoulli variables Xi are identically distributed and independent. Prosaically, a Bernoulli process is a repeated coin flipping, possibly with an unfair coin (but with consistent unfairness). Every variable Xi in the sequence is associated with a Bernoulli trial or experiment. They all have the same Bernoulli distribution. Much of what can be said about the Bernoulli process can also be generalized to more than two outcomes (such as the process for a six-sided die); this generalization is known as the Bernoulli scheme.

The problem of determining the process, given only a limited sample of Bernoulli trials, may be called the problem of checking whether a coin is fair.

Definition
A Bernoulli process is a finite or infinite sequence of independent random variables X1, X2, X3, ..., such that


 * for each i, the value of Xi is either 0 or 1;
 * for all values of $i$, the probability p that Xi = 1 is the same.

In other words, a Bernoulli process is a sequence of independent identically distributed Bernoulli trials.

Independence of the trials implies that the process is memoryless. Given that the probability p is known, past outcomes provide no information about future outcomes. (If p is unknown, however, the past informs about the future indirectly, through inferences about p.)

If the process is infinite, then from any point the future trials constitute a Bernoulli process identical to the whole process, the fresh-start property.

Interpretation
The two possible values of each Xi are often called "success" and "failure". Thus, when expressed as a number 0 or 1, the outcome may be called the number of successes on the ith "trial".

Two other common interpretations of the values are true or false and yes or no. Under any interpretation of the two values, the individual variables Xi may be called Bernoulli trials with parameter p.

In many applications time passes between trials, as the index i increases. In effect, the trials X1, X2, ... Xi, ... happen at "points in time" 1, 2, ..., i, .... That passage of time and the associated notions of "past" and "future" are not necessary, however. Most generally, any Xi and Xj in the process are simply two from a set of random variables indexed by {1, 2, ..., n}, the finite cases, or by {1, 2, 3, ...}, the infinite cases.

One experiment with only two possible outcomes, often referred to as "success" and "failure", usually encoded as 1 and 0, can be modeled as a Bernoulli distribution. Several random variables and probability distributions beside the Bernoullis may be derived from the Bernoulli process:


 * The number of successes in the first n trials, which has a binomial distribution B(n, p)
 * The number of failures needed to get r successes, which has a negative binomial distribution NB(r, p)
 * The number of failures needed to get one success, which has a geometric distribution NB(1, p), a special case of the negative binomial distribution

The negative binomial variables may be interpreted as random waiting times.

Formal definition
The Bernoulli process can be formalized in the language of probability spaces as a random sequence of independent realisations of a random variable that can take values of heads or tails. The state space for an individual value is denoted by $$2=\{H,T\} .$$

Borel algebra
Consider the countably infinite direct product of copies of $$2=\{H,T\}$$. It is common to examine either the one-sided set $$\Omega=2^\mathbb{N}=\{H,T\}^\mathbb{N}$$ or the two-sided set $$\Omega=2^\mathbb{Z}$$. There is a natural topology on this space, called the product topology. The sets in this topology are finite sequences of coin flips, that is, finite-length strings of H and T (H stands for heads and T stands for tails), with the rest of (infinitely long) sequence taken as "don't care". These sets of finite sequences are referred to as cylinder sets in the product topology. The set of all such strings forms a sigma algebra, specifically, a Borel algebra. This algebra is then commonly written as $$(\Omega, \mathcal{B})$$ where the elements of $$\mathcal{B}$$ are the finite-length sequences of coin flips (the cylinder sets).

Bernoulli measure
If the chances of flipping heads or tails are given by the probabilities $$\{p,1-p\}$$, then one can define a natural measure on the product space, given by $$P=\{p, 1-p\}^\mathbb{N}$$ (or by $$P=\{p, 1-p\}^\mathbb{Z}$$ for the two-sided process). In another word, if a discrete random variable X has a Bernoulli distribution with parameter p, where 0 ≤ p ≤ 1, and its probability mass function is given by


 * $$pX(1)=P(X=1)=p$$ and $$pX(0)=P(X=0)=1-p$$.

We denote this distribution by Ber(p).

Given a cylinder set, that is, a specific sequence of coin flip results $$[\omega_1, \omega_2,\cdots\omega_n]$$ at times $$1,2,\cdots,n$$, the probability of observing this particular sequence is given by


 * $$P([\omega_1, \omega_2,\cdots ,\omega_n])= p^k (1-p)^{n-k}$$

where k is the number of times that H appears in the sequence, and n−k is the number of times that T appears in the sequence. There are several different kinds of notations for the above; a common one is to write
 * $$P(X_1=x_1, X_2=x_2,\cdots, X_n=x_n)= p^k (1-p)^{n-k}$$

where each $$X_i$$ is a binary-valued random variable with $$x_i=[\omega_i=H]$$ in Iverson bracket notation, meaning either $$1$$ if $$\omega_i=H$$ or $$0$$ if $$\omega_i=T$$. This probability $$P$$ is commonly called the Bernoulli measure.

Note that the probability of any specific, infinitely long sequence of coin flips is exactly zero; this is because $$\lim_{n\to\infty}p^n=0$$, for any $$0\le p<1$$. A probability equal to 1 implies that any given infinite sequence has measure zero. Nevertheless, one can still say that some classes of infinite sequences of coin flips are far more likely than others, this is given by the asymptotic equipartition property.

To conclude the formal definition, a Bernoulli process is then given by the probability triple $$(\Omega, \mathcal{B}, P)$$, as defined above.

Law of large numbers, binomial distribution and central limit theorem
Let us assume the canonical process with $$ H $$ represented by $$ 1 $$ and $$ T $$ represented by $$ 0 $$. The law of large numbers states that the average of the sequence, i.e., $$ \bar{X}_{n}:=\frac{1}{n}\sum_{i=1}^{n}X_{i} $$, will approach the expected value almost certainly, that is, the events which do not satisfy this limit have zero probability. The expectation value of flipping heads, assumed to be represented by 1, is given by $$p$$. In fact, one has
 * $$\mathbb{E}[X_i]=\mathbb{P}([X_i=1])=p,$$

for any given random variable $$X_i$$ out of the infinite sequence of Bernoulli trials that compose the Bernoulli process.

One is often interested in knowing how often one will observe H in a sequence of n coin flips. This is given by simply counting: Given n successive coin flips, that is, given the set of all possible strings of length n, the number N(k,n) of such strings that contain k occurrences of H is given by the binomial coefficient
 * $$N(k,n) = {n \choose k}=\frac{n!}{k! (n-k)!}$$

If the probability of flipping heads is given by p, then the total probability of seeing a string of length n with k heads is
 * $$\mathbb{P}([S_n=k]) = {n\choose k} p^k (1-p)^{n-k}, $$

where $$ S_n=\sum_{i=1}^{n}X_i $$. The probability measure thus defined is known as the Binomial distribution.

As we can see from the above formula that, if n=1, the Binomial distribution will turn into a Bernoulli distribution. So we can know that the Bernoulli distribution is exactly a special case of Binomial distribution when n equals to 1.

Of particular interest is the question of the value of $$S_{n}$$ for a sufficiently long sequences of coin flips, that is, for the limit $$n\to\infty$$. In this case, one may make use of Stirling's approximation to the factorial, and write
 * $$n! = \sqrt{2\pi n} \;n^n e^{-n}

\left(1 + \mathcal{O}\left(\frac{1}{n}\right)\right)$$

Inserting this into the expression for P(k,n), one obtains the Normal distribution; this is the content of the central limit theorem, and this is the simplest example thereof.

The combination of the law of large numbers, together with the central limit theorem, leads to an interesting and perhaps surprising result: the asymptotic equipartition property. Put informally, one notes that, yes, over many coin flips, one will observe H exactly p fraction of the time, and that this corresponds exactly with the peak of the Gaussian. The asymptotic equipartition property essentially states that this peak is infinitely sharp, with infinite fall-off on either side. That is, given the set of all possible infinitely long strings of H and T occurring in the Bernoulli process, this set is partitioned into two: those strings that occur with probability 1, and those that occur with probability 0. This partitioning is known as the Kolmogorov 0-1 law.

The size of this set is interesting, also, and can be explicitly determined: the logarithm of it is exactly the entropy of the Bernoulli process. Once again, consider the set of all strings of length n. The size of this set is $$2^n$$. Of these, only a certain subset are likely; the size of this set is $$2^{nH}$$ for $$H\le 1$$. By using Stirling's approximation, putting it into the expression for P(k,n), solving for the location and width of the peak, and finally taking $$n\to\infty$$ one finds that


 * $$H=-p\log_2 p - (1-p)\log_2(1-p)$$

This value is the Bernoulli entropy of a Bernoulli process. Here, H stands for entropy; not to be confused with the same symbol H standing for heads.

John von Neumann posed a question about the Bernoulli process regrading the possibility of a given process being isomorphic to another, in the sense of the isomorphism of dynamical systems. The question long defied analysis, but was finally and completely answered with the Ornstein isomorphism theorem. This breakthrough resulted in the understanding that the Bernoulli process is unique and universal; in a certain sense, it is the single most random process possible; nothing is 'more' random than the Bernoulli process (although one must be careful with this informal statement; certainly, systems that are mixing are, in a certain sense, "stronger" than the Bernoulli process, which is merely ergodic but not mixing. However, such processes do not consist of independent random variables: indeed, many purely deterministic, non-random systems can be mixing).

Dynamical systems
The Bernoulli process can also be understood to be a dynamical system, as an example of an ergodic system and specifically, a measure-preserving dynamical system, in one of several different ways. One way is as a shift space, and the other is as an odometer. These are reviewed below.

Bernoulli shift
One way to create a dynamical system out of the Bernoulli process is as a shift space. There is a natural translation symmetry on the product space $$\Omega=2^\mathbb{N}$$ given by the shift operator
 * $$T(X_0, X_1, X_2, \cdots) = (X_1, X_2, \cdots)$$

The Bernoulli measure, defined above, is translation-invariant; that is, given any cylinder set $$\sigma\in\mathcal{B}$$, one has
 * $$P(T^{-1}(\sigma))=P(\sigma)$$

and thus the Bernoulli measure is a Haar measure; it is an invariant measure on the product space.

Instead of the probability measure $$P:\mathcal{B}\to\mathbb{R}$$, consider instead some arbitrary function $$f:\mathcal{B}\to\mathbb{R}$$. The pushforward
 * $$f\circ T^{-1}$$

defined by $$\left(f\circ T^{-1}\right)(\sigma) = f(T^{-1}(\sigma))$$ is again some function $$\mathcal{B}\to\mathbb{R}.$$ Thus, the map $$T$$ induces another map $$\mathcal{L}_T$$ on the space of all functions $$\mathcal{B}\to\mathbb{R}.$$ That is, given some $$f:\mathcal{B}\to\mathbb{R}$$, one defines
 * $$\mathcal{L}_T f = f \circ T^{-1}$$

The map $$\mathcal{L}_T$$ is a linear operator, as (obviously) one has $$\mathcal{L}_T(f+g)= \mathcal{L}_T(f) + \mathcal{L}_T(g)$$ and $$\mathcal{L}_T(af)= a\mathcal{L}_T(f)$$ for functions $$f,g$$ and constant $$a$$. This linear operator is called the transfer operator or the Ruelle–Frobenius–Perron operator. This operator has a spectrum, that is, a collection of eigenfunctions and corresponding eigenvalues. The largest eigenvalue is the Frobenius–Perron eigenvalue, and in this case, it is 1. The associated eigenvector is the invariant measure: in this case, it is the Bernoulli measure. That is, $$\mathcal{L}_T(P)= P.$$

If one restricts $$\mathcal{L}_T$$ to act on polynomials, then the eigenfunctions are (curiously) the Bernoulli polynomials! This coincidence of naming was presumably not known to Bernoulli.

The 2x mod 1 map
[[Image:Exampleergodicmap.svg|thumb|The map T : [0,1) → [0,1), $$x \mapsto 2x \bmod 1$$ preserves the [[Lebesgue measure]].]]

The above can be made more precise. Given an infinite string of binary digits $$b_0, b_1, \cdots$$ write
 * $$y=\sum_{n=0}^\infty \frac{b_n}{2^{n+1}}.$$

The resulting $$y$$ is a real number in the unit interval $$0\le y\le 1.$$ The shift $$T$$ induces a homomorphism, also called $$T$$, on the unit interval. Since $$T(b_0, b_1, b_2, \cdots) = (b_1, b_2, \cdots),$$ one can see that $$T(y)=2y\bmod 1.$$ This map is called the dyadic transformation; for the doubly-infinite sequence of bits $$\Omega=2^\mathbb{Z},$$ the induced homomorphism is the Baker's map.

Consider now the space of functions in $$y$$. Given some $$f(y)$$ one can find that
 * $$\left[\mathcal{L}_T f\right](y) = \frac{1}{2}f\left(\frac{y}{2}\right)+\frac{1}{2}f\left(\frac{y+1}{2}\right)$$

Restricting the action of the operator $$\mathcal{L}_T$$ to functions that are on polynomials, one finds that it has a discrete spectrum given by
 * $$\mathcal{L}_T B_n= 2^{-n}B_n$$

where the $$B_n$$ are the Bernoulli polynomials. Indeed, the Bernoulli polynomials obey the identity
 * $$\frac{1}{2}B_n\left(\frac{y}{2}\right)+\frac{1}{2}B_n\left(\frac{y+1}{2}\right) = 2^{-n}B_n(y)$$

The Cantor set
Note that the sum
 * $$y=\sum_{n=0}^\infty \frac{b_n}{3^{n+1}}$$

gives the Cantor function, as conventionally defined. This is one reason why the set $$\{H,T\}^\mathbb{N}$$ is sometimes called the Cantor set.

Odometer
Another way to create a dynamical system is to define an odometer. Informally, this is exactly what it sounds like: just "add one" to the first position, and let the odometer "roll over" by using carry bits as the odometer rolls over. This is nothing more than base-two addition on the set of infinite strings. Since addition forms a group (mathematics), and the Bernoulli process was already given a topology, above, this provides a simple example of a topological group.

In this case, the transformation $$T$$ is given by
 * $$T\left(1,\dots,1,0,X_{k+1},X_{k+2},\dots\right) = \left(0,\dots,0,1,X_{k+1},X_{k+2},\dots \right).$$

It leaves the Bernoulli measure invariant only for the special case of $$p=1/2$$ (the "fair coin"); otherwise not. Thus, $$T$$ is a measure preserving dynamical system in this case, otherwise, it is merely a conservative system.

Bernoulli sequence
The term Bernoulli sequence is often used informally to refer to a realization of a Bernoulli process. However, the term has an entirely different formal definition as given below.

Suppose a Bernoulli process formally defined as a single random variable (see preceding section). For every infinite sequence x of coin flips, there is a sequence of integers


 * $$\mathbb{Z}^x = \{n\in \mathbb{Z} : X_n(x) = 1 \} \, $$

called the Bernoulli sequence associated with the Bernoulli process. For example, if x represents a sequence of coin flips, then the associated Bernoulli sequence is the list of natural numbers or time-points for which the coin toss outcome is heads.

So defined, a Bernoulli sequence $$\mathbb{Z}^x$$ is also a random subset of the index set, the natural numbers $$\mathbb{N}$$.

Almost all Bernoulli sequences $$\mathbb{Z}^x$$ are ergodic sequences.

Randomness extraction
From any Bernoulli process one may derive a Bernoulli process with p = 1/2 by the von Neumann extractor, the earliest randomness extractor, which actually extracts uniform randomness.

Basic von Neumann extractor
Represent the observed process as a sequence of zeroes and ones, or bits, and group that input stream in non-overlapping pairs of successive bits, such as (11)(00)(10)... . Then for each pair,
 * if the bits are equal, discard;
 * if the bits are not equal, output the first bit.

This table summarizes the computation. For example, an input stream of eight bits 10011011 would by grouped into pairs as (10)(01)(10)(11). Then, according to the table above, these pairs are translated into the output of the procedure: (1)(0)(1) (=101).

In the output stream 0 and 1 are equally likely, as 10 and 01 are equally likely in the original, both having probability p(1−p) = (1−p)p. This extraction of uniform randomness does not require the input trials to be independent, only uncorrelated. More generally, it works for any exchangeable sequence of bits: all sequences that are finite rearrangements are equally likely.

The von Neumann extractor uses two input bits to produce either zero or one output bits, so the output is shorter than the input by a factor of at least 2. On average the computation discards proportion p2 + (1 − p)2 of the input pairs(00 and 11), which is near one when p is near zero or one, and is minimized at 1/4 when p = 1/2 for the original process (in which case the output stream is 1/4 the length of the input stream on average).

Von Neumann (classical) main operation pseudocode:

Iterated von Neumann extractor
This decrease in efficiency, or waste of randomness present in the input stream, can be mitigated by iterating the algorithm over the input data. This way the output can be made to be "arbitrarily close to the entropy bound".

The iterated version of the von Neumann algorithm, also known as advanced multi-level strategy (AMLS), was introduced by Yuval Peres in 1992. It works recursively, recycling "wasted randomness" from two sources: the sequence of discard-non-discard, and the values of discarded pairs (0 for 00, and 1 for 11). It relies on the fact that, given the sequence already generated, both of those sources are still exchangeable sequences of bits, and thus eligible for another round of extraction. While such generation of additional sequences can be iterated infinitely to extract all available entropy, an infinite amount of computational resources is required, therefore the number of iterations is typically fixed to a low value – this value either fixed in advance, or calculated at runtime.

More concretely, on an input sequence, the algorithm consumes the input bits in pairs, generating output together with two new sequences:

(If the length of the input is odd, the last bit is completely discarded.) Then the algorithm is applied recursively to each of the two new sequences, until the input is empty.

Example: The input stream from above, 10011011, is processed this way:

From the step of 1 on, the input becomes the new sequence1 of the last step to move on in this process. The output is therefore (101)(1)(0) (=10110), so that from the eight bits of input five bits of output were generated, as opposed to three bits through the basic algorithm above. The constant output of exactly 2 bits per round (compared with a variable 0 to 1 bits in classical VN) also allows for constant-time implementations which are resistant to timing attacks.

Von Neumann–Peres (iterated) main operation pseudocode: Another tweak was presented in 2016, based on the observation that the Sequence2 channel doesn't provide much throughput, and a hardware implementation with a finite number of levels can benefit from discarding it earlier in exchange for processing more levels of Sequence1.