Error function
Template:Short description Template:Use dmy dates Script error: No such module "Distinguish". In mathematics, the error function (also called the Gauss error function), often denoted by erfScript error: No such module "Check for unknown parameters"., is a function defined as:[1] Template:Infobox mathematical function
The integral here is a complex contour integral which is path-independent because is holomorphic on the whole complex plane . In many applications, the function argument is a real number, in which case the function value is also real.
In some old texts,[2] the error function is defined without the factor of . This nonelementary integral is a sigmoid function that occurs often in probability, statistics, and partial differential equations.
In statistics, for non-negative real values of Template:Mvar, the error function has the following interpretation: for a real random variable Template:Mvar that is normally distributed with mean 0 and standard deviation , erf(x)Script error: No such module "Check for unknown parameters". is the probability that Template:Mvar falls in the range Template:Closed-closed.
Two closely related functions are the complementary error function is defined as
and the imaginary error function is defined as
where Template:Mvar is the imaginary unit.
Name
The name "error function" and its abbreviation erfScript error: No such module "Check for unknown parameters". were proposed by J. W. L. Glaisher in 1871 on account of its connection with "the theory of probability, and notably the theory of errors".[3] The error function complement was also discussed by Glaisher in a separate publication in the same year.[4] For the "law of facility" of errors whose density is given by (the normal distribution), Glaisher calculates the probability of an error lying between Template:Mvar and Template:Mvar as
Applications
When the results of a series of measurements are described by a normal distribution with standard deviation Template:Mvar and expected value 0, then erf (Template:Sfrac)Script error: No such module "Check for unknown parameters". is the probability that the error of a single measurement lies between −aScript error: No such module "Check for unknown parameters". and +aScript error: No such module "Check for unknown parameters"., for positive Template:Mvar. This is useful, for example, in determining the bit error rate of a digital communication system.
The error and complementary error functions occur, for example, in solutions of the heat equation when boundary conditions are given by the Heaviside step function.
The error function and its approximations can be used to estimate results that hold with high probability or with low probability. Given a random variable X ~ Norm[μ,σ]Script error: No such module "Check for unknown parameters". (a normal distribution with mean Template:Mvar and standard deviation Template:Mvar) and a constant L > μScript error: No such module "Check for unknown parameters"., it can be shown via integration by substitution:
where Template:Mvar and Template:Mvar are certain numeric constants. If Template:Mvar is sufficiently far from the mean, specifically μ − L ≥ σ
- REDIRECT Template:Radic
Template:Rcat shellScript error: No such module "Check for unknown parameters"., then:
so the probability goes to 0 as k → ∞Script error: No such module "Check for unknown parameters"..
The probability for Template:Mvar being in the interval Template:Closed-closed can be derived as
Properties
Script error: No such module "Multiple image".
The property erf (−z) = −erf(z)Script error: No such module "Check for unknown parameters". means that the error function is an odd function. This directly results from the fact that the integrand e−t2Script error: No such module "Check for unknown parameters". is an even function (the antiderivative of an even function which is zero at the origin is an odd function and vice versa).
Since the error function is an entire function which takes real numbers to real numbers, for any complex number Template:Mvar: where denotes the complex conjugate of .
The integrand f = exp(−z2)Script error: No such module "Check for unknown parameters". and f = erf(z)Script error: No such module "Check for unknown parameters". are shown in the complex Template:Mvar-plane in the figures at right with domain coloring.
The error function at +∞Script error: No such module "Check for unknown parameters". is exactly 1 (see Gaussian integral). At the real axis, erf zScript error: No such module "Check for unknown parameters". approaches unity at z → +∞Script error: No such module "Check for unknown parameters". and −1 at z → −∞Script error: No such module "Check for unknown parameters".. At the imaginary axis, it tends to ±i∞Script error: No such module "Check for unknown parameters"..
Taylor series
The error function is an entire function; it has no singularities (except that at infinity) and its Taylor expansion always converges. For x >> 1Script error: No such module "Check for unknown parameters"., however, cancellation of leading terms makes the Taylor expansion unpractical.
The defining integral cannot be evaluated in closed form in terms of elementary functions (see Liouville's theorem), but by expanding the integrand e−z2Script error: No such module "Check for unknown parameters". into its Maclaurin series and integrating term by term, one obtains the error function's Maclaurin series as: which holds for every complex number Template:Mvar. The denominator terms are sequence A007680 in the OEIS.
It is a special case of Kummer's function:
For iterative calculation of the above series, the following alternative formulation may be useful: because Template:SfracScript error: No such module "Check for unknown parameters". expresses the multiplier to turn the Template:Mvarth term into the (k + 1)Script error: No such module "Check for unknown parameters".th term (considering Template:Mvar as the first term).
The imaginary error function has a very similar Maclaurin series, which is: which holds for every complex number Template:Mvar.
Derivative and integral
The derivative of the error function follows immediately from its definition: From this, the derivative of the imaginary error function is also immediate: Higher order derivatives are given by where Template:Mvar are the physicists' Hermite polynomials.[5]
An antiderivative of the error function, obtainable by integration by parts, is An antiderivative of the imaginary error function, also obtainable by integration by parts, is
Bürmann series
An expansion,[6] which converges more rapidly for all real values of Template:Mvar than a Taylor expansion, is obtained by using Hans Heinrich Bürmann's theorem:[7] where sgnScript error: No such module "Check for unknown parameters". is the sign function. By keeping only the first two coefficients and choosing c1 = Template:SfracScript error: No such module "Check for unknown parameters". and c2 = −Template:SfracScript error: No such module "Check for unknown parameters"., the resulting approximation shows its largest relative error at x = ±1.40587Script error: No such module "Check for unknown parameters"., where it is less than 0.0034361:
Inverse functions
Given a complex number Template:Mvar, there is not a unique complex number Template:Mvar satisfying erf(w) = zScript error: No such module "Check for unknown parameters"., so a true inverse function would be multivalued. However, for −1 < x < 1Script error: No such module "Check for unknown parameters"., there is a unique real number denoted erf−1(x)Script error: No such module "Check for unknown parameters". satisfying
The inverse error function is usually defined with domain Template:Open-open, and it is restricted to this domain in many computer algebra systems. However, it can be extended to the disk Template:Abs < 1Script error: No such module "Check for unknown parameters". of the complex plane, using the Maclaurin series[8] where c0 = 1Script error: No such module "Check for unknown parameters". and
So we have the series expansion (common factors have been canceled from numerators and denominators): (After cancellation the numerator and denominator values in Template:Oeis and Template:Oeis respectively; without cancellation the numerator terms are values in Template:Oeis.) The error function's value at ±∞Script error: No such module "Check for unknown parameters". is equal to ±1Script error: No such module "Check for unknown parameters"..
For Template:Abs < 1Script error: No such module "Check for unknown parameters"., we have erf(erf−1(z)) = zScript error: No such module "Check for unknown parameters"..
The inverse complementary error function is defined as For real Template:Mvar, there is a unique real number erfi−1(x)Script error: No such module "Check for unknown parameters". satisfying erfi(erfi−1(x)) = xScript error: No such module "Check for unknown parameters".. The inverse imaginary error function is defined as erfi−1(x)Script error: No such module "Check for unknown parameters"..[9]
For any real x, Newton's method can be used to compute erfi−1(x)Script error: No such module "Check for unknown parameters"., and for −1 ≤ x ≤ 1Script error: No such module "Check for unknown parameters"., the following Maclaurin series converges: where ckScript error: No such module "Check for unknown parameters". is defined as above.
Asymptotic expansion
A useful asymptotic expansion of the complementary error function (and therefore also of the error function) for large real Template:Mvar is where (2n − 1)!!Script error: No such module "Check for unknown parameters". is the double factorial of (2n − 1)Script error: No such module "Check for unknown parameters"., which is the product of all odd numbers up to (2n − 1)Script error: No such module "Check for unknown parameters".. This series diverges for every finite Template:Mvar, and its meaning as asymptotic expansion is that for any integer N ≥ 1Script error: No such module "Check for unknown parameters". one has where the remainder is which follows easily by induction, writing and integrating by parts.
The asymptotic behavior of the remainder term, in Landau notation, is as x → ∞Script error: No such module "Check for unknown parameters".. This can be found by For large enough values of Template:Mvar, only the first few terms of this asymptotic expansion are needed to obtain a good approximation of erfc xScript error: No such module "Check for unknown parameters". (while for not too large values of Template:Mvar, the above Taylor expansion at 0 provides a very fast convergence).
Continued fraction expansion
A continued fraction expansion of the complementary error function was found by Laplace:[10][11]
Factorial series
The inverse factorial series: converges for Re(z2) > 0Script error: No such module "Check for unknown parameters".. Here znScript error: No such module "Check for unknown parameters". denotes the rising factorial, and s(n,k)Script error: No such module "Check for unknown parameters". denotes a signed Stirling number of the first kind.[12][13] The Taylor series can be written in terms of the double factorial:
Bounds and numerical approximations
Approximation with elementary functions
Abramowitz and Stegun give several approximations of varying accuracy (equations 7.1.25–28). This allows one to choose the fastest approximation suitable for a given application. In order of increasing accuracy, they are: (maximum error: Script error: No such module "val".) Template:Pb where a1 = 0.278393Script error: No such module "Check for unknown parameters"., a2 = 0.230389Script error: No such module "Check for unknown parameters"., a3 = 0.000972Script error: No such module "Check for unknown parameters"., a4 = 0.078108Script error: No such module "Check for unknown parameters".
(maximum error: Script error: No such module "val".) Template:Pb where p = 0.47047Script error: No such module "Check for unknown parameters"., a1 = 0.3480242Script error: No such module "Check for unknown parameters"., a2 = −0.0958798Script error: No such module "Check for unknown parameters"., a3 = 0.7478556Script error: No such module "Check for unknown parameters".
(maximum error: Script error: No such module "val".) Template:Pb where a1 = 0.0705230784Script error: No such module "Check for unknown parameters"., a2 = 0.0422820123Script error: No such module "Check for unknown parameters"., a3 = 0.0092705272Script error: No such module "Check for unknown parameters"., a4 = 0.0001520143Script error: No such module "Check for unknown parameters"., a5 = 0.0002765672Script error: No such module "Check for unknown parameters"., a6 = 0.0000430638Script error: No such module "Check for unknown parameters".
(maximum error: Script error: No such module "val".) Template:Pb where p = 0.3275911Script error: No such module "Check for unknown parameters"., a1 = 0.254829592Script error: No such module "Check for unknown parameters"., a2 = −0.284496736Script error: No such module "Check for unknown parameters"., a3 = 1.421413741Script error: No such module "Check for unknown parameters"., a4 = −1.453152027Script error: No such module "Check for unknown parameters"., a5 = 1.061405429Script error: No such module "Check for unknown parameters". Template:Pb
One can improve the accuracy of the A&S approximation by extending it with three extra parameters, where p1 = 0.406742016006509, p2 = 0.0072279182302319, a1 = 0.316879890481381, a2 = -0.138329314150635, a3 = 1.08680830347054, a4 = -1.11694155120396, a5 = 1.20644903073232, a6 = -0.393127715207728, a7 = 0.0382613542530727. The maximum error of this approximation is about Script error: No such module "val".. The parameters are obtained by fitting the extended approximation to the accurate values of the error function using the following Python code.
Python code to fit extended A&S approximation
|
|---|
import numpy as np
from math import erf, exp, sqrt
from scipy.optimize import least_squares
#
# Extended A&S approximation:
# erf(x) ≈ 1 − t * exp(−x^2) * (a1 + a2*t + a3*t^2 + ... + a7*t^6)
# where now
# t = 1 / (1 + p1*x + p2*x^2)
# We fit parameters p1, p2, a1..a7 over x in [0, 10].
#
def approx_erf(params, x):
p1 = params[0]
p2 = params[1]
a = params[2:]
t = 1.0 / (1.0 + p1 * x + p2 * x * x)
poly = np.zeros_like(x)
tt = np.ones_like(x) # t^0
# polynomial: a1*t^0 + a2*t^1 + ... + a7*t^6
for ak in a:
poly += ak * tt
tt *= t
return 1.0 - t * np.exp(-x * x) * poly
def residuals(params, xs, ys):
return approx_erf(params, xs) - ys
#
# Prepare data for fitting
#
N = 300
xmin = 0
xmax = 10
xs = np.linspace(xmin, xmax, N)
ys = np.array([erf(x) for x in xs], dtype=float)
#
# Initial guess for parameters
# Start from original A&S values and extend them conservatively
#
p1_0 = 0.3275911 # original A&S p
p2_0 = 0.0 # new denominator parameter
# original A&S 5 coefficients, add two => 7 in total
a0 = [
0.254829592,
-0.284496736,
1.421413741,
-1.453152027,
1.061405429,
0.0, # new term
0.0, # another new term
]
params0 = np.array([p1_0, p2_0] + a0, dtype=float)
#
# Fit using nonlinear least squares (Levenberg–Marquardt)
#
result = least_squares(
residuals, params0, args=(xs, ys), xtol=1e-14, ftol=1e-14, gtol=1e-14, max_nfev=5000
)
params = result.x
p1_fit = params[0]
p2_fit = params[1]
a_fit = params[2:]
#
# Print fitted parameters
#
print("\nFitted parameters:")
print(f"p1 = {p1_fit:.15g},")
print(f"p2 = {p2_fit:.15g},")
for i, ai in enumerate(a_fit, 1):
print(f"a{i} = {ai:.15g},")
#
# Evaluate approximation error
#
approx_vals = approx_erf(params, xs)
abs_err = np.abs(approx_vals - ys)
print(f"\nMaximum absolute error on [{xmin},{xmax}]:", np.max(abs_err))
print("RMS error:", np.sqrt(np.mean(abs_err**2)))
print("Done.")
|
All of these approximations are valid for x ≥ 0Script error: No such module "Check for unknown parameters".. To use these approximations for negative Template:Mvar, use the fact that erf(x)Script error: No such module "Check for unknown parameters". is an odd function, so erf(x) = −erf(−x)Script error: No such module "Check for unknown parameters"..
Exponential bounds and a pure exponential approximation for the complementary error function are given by[14]
The above have been generalized to sums of Template:Mvar exponentials[15] with increasing accuracy in terms of Template:Mvar so that erfc(x)Script error: No such module "Check for unknown parameters". can be accurately approximated or bounded by 2Q̃(
- REDIRECT Template:Radic
Template:Rcat shellx)Script error: No such module "Check for unknown parameters"., where In particular, there is a systematic methodology to solve the numerical coefficients {(an,bn)}Script error: No such module "Su".Script error: No such module "Check for unknown parameters". that yield a minimax approximation or bound for the closely related Q-function: Q(x) ≈ Q̃(x)Script error: No such module "Check for unknown parameters"., Q(x) ≤ Q̃(x)Script error: No such module "Check for unknown parameters"., or Q(x) ≥ Q̃(x)Script error: No such module "Check for unknown parameters". for x ≥ 0Script error: No such module "Check for unknown parameters".. The coefficients {(an,bn)}Script error: No such module "Su".Script error: No such module "Check for unknown parameters". for many variations of the exponential approximations and bounds up to N = 25Script error: No such module "Check for unknown parameters". have been released to open access as a comprehensive dataset.[16]
A tight approximation of the complementary error function for x ∈ [0,∞)Script error: No such module "Check for unknown parameters". is given by Karagiannidis & Lioumpas (2007)[17] who showed for the appropriate choice of parameters {A,B}Script error: No such module "Check for unknown parameters". that
They determined {A,B} = {1.98,1.135}Script error: No such module "Check for unknown parameters"., which gave a good approximation for all x ≥ 0Script error: No such module "Check for unknown parameters".. Alternative coefficients are also available for tailoring accuracy for a specific application or transforming the expression into a tight bound.[18]
A single-term lower bound is[19]
where the parameter Template:Mvar can be picked to minimize error on the desired interval of approximation.
Another approximation is given by Sergei Winitzki using his "global Padé approximations":[20][21]Template:Rp
where
This is designed to be very accurate in a neighborhood of 0 and a neighborhood of infinity, and the relative error is less than 0.00035 for all real Template:Mvar. Using the alternate value a ≈ 0.147Script error: No such module "Check for unknown parameters". reduces the maximum relative error to about 0.00013.[22]
Template:Pb
The extended "global Pade" approximation, provides the maximum error of about Script error: No such module "val"., as demonstrated by the following Python script.
Python script to fit extended "global Pade" approximation
|
|---|
import numpy,math
from scipy.optimize import least_squares
# approximation to erf(x)
def approx_erf(p,x):
frac=(4+p[0]*x**2+p[1]*x**4+p[2]*x**6)/(
math.pi+p[3]*x**2+p[4]*x**4+p[5]*x**6)
return numpy.sign(x)*numpy.sqrt(
1-numpy.exp(-x*x*frac))
def residuals(params, xs, ys):
return approx_erf(params, xs) - ys
# data for fitting
N = 200
xmin = 0
xmax = 9
xs = numpy.linspace(xmin, xmax, N)
ys = numpy.array([math.erf(x) for x in xs], dtype=float)
params0 = numpy.array([0.9,0.1,0.008,0.8,0.1,0.008], dtype=float)
# fitting
result = least_squares(
residuals, params0, args=(xs, ys),
xtol=1e-14, ftol=1e-14, gtol=1e-14, max_nfev=5000
)
params = result.x
# print out fitted parameters
print("\nFitted parameters:")
for i, pi in enumerate(params, 0):
print(f"p{i} = {pi:.15g},")
# evaluate approximation error
approx_vals = approx_erf(params, xs)
abs_err = numpy.abs(approx_vals - ys)
print(f"\nMaximum absolute error on [{xmin},{xmax}]:", numpy.max(abs_err))
print("RMS error:", numpy.sqrt(numpy.mean(abs_err**2)))
print("Done.")
|
The Winitzki's approximation can be inverted to obtain an approximation for the inverse error function:
An approximation with a maximal error of Script error: No such module "val". for any real argument is:[23]
with
and
An approximation of with a maximum relative error less than in absolute value is:[24]
for ,
and for
A simple approximation for real-valued arguments could be done through Hyperbolic functions:
which keeps the absolute difference .
Since the error function and the Gaussian Q-function are closely related through the identity or equivalently , bounds developed for the Q-function can be adapted to approximate the complementary error function. A pair of tight lower and upper bounds on the Gaussian Q-function for positive arguments was introduced by Abreu (2012)[25] based on a simple algebraic expression with only two exponential terms:
and
These bounds stem from a unified form where the parameters and are selected to ensure the bounding properties: for the lower bound, and , and for the upper bound, and . These expressions maintain simplicity and tightness, providing a practical trade-off between accuracy and ease of computation. They are particularly valuable in theoretical contexts, such as communication theory over fading channels, where both functions frequently appear. Additionally, the original Q-function bounds can be extended to for positive integers via the binomial theorem, suggesting potential adaptability for powers of , though this is less commonly required in error function applications.
Table of values
Script error: No such module "labelled list hatnote".
| xScript error: No such module "Check for unknown parameters". | erf(x)Script error: No such module "Check for unknown parameters". | 1 − erf(x)Script error: No such module "Check for unknown parameters". |
|---|---|---|
| 0 | Script error: No such module "val". | Script error: No such module "val". |
| 0.02 | Script error: No such module "val". | Script error: No such module "val". |
| 0.04 | Script error: No such module "val". | Script error: No such module "val". |
| 0.06 | Script error: No such module "val". | Script error: No such module "val". |
| 0.08 | Script error: No such module "val". | Script error: No such module "val". |
| 0.1 | Script error: No such module "val". | Script error: No such module "val". |
| 0.2 | Script error: No such module "val". | Script error: No such module "val". |
| 0.3 | Script error: No such module "val". | Script error: No such module "val". |
| 0.4 | Script error: No such module "val". | Script error: No such module "val". |
| 0.5 | Script error: No such module "val". | Script error: No such module "val". |
| 0.6 | Script error: No such module "val". | Script error: No such module "val". |
| 0.7 | Script error: No such module "val". | Script error: No such module "val". |
| 0.8 | Script error: No such module "val". | Script error: No such module "val". |
| 0.9 | Script error: No such module "val". | Script error: No such module "val". |
| 1 | Script error: No such module "val". | Script error: No such module "val". |
| 1.1 | Script error: No such module "val". | Script error: No such module "val". |
| 1.2 | Script error: No such module "val". | Script error: No such module "val". |
| 1.3 | Script error: No such module "val". | Script error: No such module "val". |
| 1.4 | Script error: No such module "val". | Script error: No such module "val". |
| 1.5 | Script error: No such module "val". | Script error: No such module "val". |
| 1.6 | Script error: No such module "val". | Script error: No such module "val". |
| 1.7 | Script error: No such module "val". | Script error: No such module "val". |
| 1.8 | Script error: No such module "val". | Script error: No such module "val". |
| 1.9 | Script error: No such module "val". | Script error: No such module "val". |
| 2 | Script error: No such module "val". | Script error: No such module "val". |
| 2.1 | Script error: No such module "val". | Script error: No such module "val". |
| 2.2 | Script error: No such module "val". | Script error: No such module "val". |
| 2.3 | Script error: No such module "val". | Script error: No such module "val". |
| 2.4 | Script error: No such module "val". | Script error: No such module "val". |
| 2.5 | Script error: No such module "val". | Script error: No such module "val". |
| 3 | Script error: No such module "val". | Script error: No such module "val". |
| 3.5 | Script error: No such module "val". | Script error: No such module "val". |
Related functions
Complementary error function
The complementary error function, denoted erfcScript error: No such module "Check for unknown parameters"., is defined as which also defines erfcxScript error: No such module "Check for unknown parameters"., the scaled complementary error function[26] (which can be used instead of erfcScript error: No such module "Check for unknown parameters". to avoid arithmetic underflow[26][27]). Another form of erfc xScript error: No such module "Check for unknown parameters". for x ≥ 0Script error: No such module "Check for unknown parameters". is known as Craig's formula, after its discoverer:[28] This expression is valid only for positive values of Template:Mvar, but can be used in conjunction with erfc(x) = 2 − erfc(−x)Script error: No such module "Check for unknown parameters". to obtain erfc(x)Script error: No such module "Check for unknown parameters". for negative values. This form is advantageous in that the range of integration is fixed and finite. An extension of this expression for the erfcScript error: No such module "Check for unknown parameters". of the sum of two non-negative variables is[29]
Imaginary error function
The imaginary error function, denoted erfiScript error: No such module "Check for unknown parameters"., is defined as where D(x)Script error: No such module "Check for unknown parameters". is the Dawson function (which can be used instead of erfiScript error: No such module "Check for unknown parameters". to avoid arithmetic overflow[26]).
Despite the name "imaginary error function", erfi(x)Script error: No such module "Check for unknown parameters". is real when Template:Mvar is real.
When the error function is evaluated for arbitrary complex arguments Template:Mvar, the resulting complex error function is usually discussed in scaled form as the Faddeeva function:
Cumulative distribution function
The error function is essentially identical to the standard normal cumulative distribution function, denoted ΦScript error: No such module "Check for unknown parameters"., also named norm(x)Script error: No such module "Check for unknown parameters". by some software languagesScript error: No such module "Unsubst"., as they differ only by scaling and translation. Indeed, or rearranged for erfScript error: No such module "Check for unknown parameters". and erfcScript error: No such module "Check for unknown parameters".:
Consequently, the error function is also closely related to the Q-function, which is the tail probability of the standard normal distribution. The Q-function can be expressed in terms of the error function as
The inverse of ΦScript error: No such module "Check for unknown parameters". is known as the normal quantile function, or probit function and may be expressed in terms of the inverse error function as
The standard normal cdf is used more often in probability and statistics, and the error function is used more often in other branches of mathematics.
The error function is a special case of the Mittag-Leffler function, and can also be expressed as a confluent hypergeometric function (Kummer's function):
It has a simple expression in terms of the Fresnel integral.Template:Elucidate
In terms of the regularized gamma function Template:Mvar and the incomplete gamma function, sgn(x)Script error: No such module "Check for unknown parameters". is the sign function.
Iterated integrals of the complementary error function
The iterated integrals of the complementary error function are defined by[30]
The general recurrence formula is
They have the power series from which follow the symmetry properties and
Implementations
As real function of a real argument
- In POSIX-compliant operating systems, the header
math.hshall declare and the mathematical librarylibmshall provide the functionserfanderfc(double precision) as well as their single precision and extended precision counterpartserff,erflanderfcf,erfcl.[31] - The GNU Scientific Library provides
erf,erfc,log(erf), and scaled error functions.[32]
As complex function of a complex argument
libcerf, numeric C library for complex error functions, provides the complex functionscerf,cerfc,cerfcxand the real functionserfi,erfcxwith approximately 13–14 digits precision, based on the Faddeeva function as implemented in the MIT Faddeeva Package
References
<templatestyles src="Reflist/styles.css" />
- ↑ Script error: No such module "citation/CS1".
- ↑ Script error: No such module "citation/CS1".
- ↑ Script error: No such module "Citation/CS1".
- ↑ Script error: No such module "Citation/CS1".
- ↑ Script error: No such module "Template wrapper".
- ↑ Script error: No such module "Citation/CS1".
- ↑ Script error: No such module "Template wrapper".
- ↑ Script error: No such module "citation/CS1".
- ↑ Script error: No such module "citation/CS1".
- ↑ Pierre-Simon Laplace, Traité de mécanique céleste, tome 4 (1805), livre X, page 255.
- ↑ Script error: No such module "citation/CS1".
- ↑ Script error: No such module "Citation/CS1".
- ↑ Script error: No such module "citation/CS1".
- ↑ Script error: No such module "Citation/CS1".
- ↑ Script error: No such module "Citation/CS1".
- ↑ Script error: No such module "Citation/CS1".
- ↑ Script error: No such module "Citation/CS1".
- ↑ Script error: No such module "Citation/CS1".
- ↑ Script error: No such module "Citation/CS1".
- ↑ Script error: No such module "citation/CS1".
- ↑ Script error: No such module "Citation/CS1".
- ↑ Script error: No such module "citation/CS1".
- ↑ Script error: No such module "citation/CS1".
- ↑ Script error: No such module "Citation/CS1".
- ↑ Script error: No such module "Citation/CS1".
- ↑ a b c Script error: No such module "citation/CS1".
- ↑ Script error: No such module "citation/CS1".
- ↑ John W. Craig, A new, simple and exact result for calculating the probability of error for two-dimensional signal constellations Template:Webarchive, Proceedings of the 1991 IEEE Military Communication Conference, vol. 2, pp. 571–575.
- ↑ Script error: No such module "Citation/CS1".
- ↑ Script error: No such module "citation/CS1".
- ↑ Script error: No such module "citation/CS1".
- ↑ Script error: No such module "citation/CS1".
Script error: No such module "Check for unknown parameters".
Further reading
- Script error: No such module "citation/CS1".
- Script error: No such module "citation/CS1".
- Template:Dlmf