Error function

From Wikipedia, the free encyclopedia
Jump to navigation Jump to search

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 erf: defined as:[1] erf(z)=2π0zet2dt. Template:Infobox mathematical function

The integral here is a complex contour integral which is path-independent because exp(t2) 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 2π. 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 12, 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 erfc: is defined as

erfc(z)=1erf(z),

and the imaginary error function erfi: is defined as

erfi(z)=ierf(iz),

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 f(x)=(cπ)1/2ecx2 (the normal distribution), Glaisher calculates the probability of an error lying between Template:Mvar and Template:Mvar as (cπ)12pqecx2dx=12(erf(qc)erf(pc)).

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: Pr[XL]=12+12erf(Lμ2σ)Aexp(B(Lμσ)2)

where Template:Mvar and Template:Mvar are certain numeric constants. If Template:Mvar is sufficiently far from the mean, specifically μLσ

  1. REDIRECT Template:Radic

Template:Rcat shellScript error: No such module "Check for unknown parameters"., then:

Pr[XL]Aexp(Bln(k))=AkB

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 Pr[LaXLb]=LaLb12πσexp((xμ)22σ2)dx=12(erf(Lbμ2σ)erf(Laμ2σ)).

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 et2Script 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: erf(z)=erf(z) where z denotes the complex conjugate of z.

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 ±iScript 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 ez2Script 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: erf(z)=2πn=0(1)nz2n+1n!(2n+1)=2π(zz33+z510z742+z9216) 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:

erf(z)=2zπ1F1(1/2;3/2;z2).

For iterative calculation of the above series, the following alternative formulation may be useful: erf(z)=2πn=0(zk=1n(2k1)z2k(2k+1))=2πn=0z2n+1k=1nz2k 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: erfi(z)=2πn=0z2n+1n!(2n+1)=2π(z+z33+z510+z742+z9216+) which holds for every complex number Template:Mvar.

Derivative and integral

The derivative of the error function follows immediately from its definition: ddzerf(z)=2πez2. From this, the derivative of the imaginary error function is also immediate: ddzerfi(z)=2πez2.Higher order derivatives are given by erf(k)(z)=2(1)k1πHk1(z)ez2=2πdk1dzk1(ez2),k=1,2, where Template:Mvar are the physicists' Hermite polynomials.[5]

An antiderivative of the error function, obtainable by integration by parts, is erf(z)dz=zerf(z)+ez2π+C. An antiderivative of the imaginary error function, also obtainable by integration by parts, is erfi(z)dz=zerfi(z)ez2π+C.

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] erf(x)=2πsgn(x)1ex2(1112(1ex2)7480(1ex2)25896(1ex2)3787276480(1ex2)4)=2πsgn(x)1ex2(π2+k=1ckekx2). 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: erf(x)2πsgn(x)1ex2(π2+31200ex23418000e2x2).

Inverse functions

File:Mplwp erf inv.svg
Inverse error function

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 erf(erf1(x))=x.

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] erf1(z)=k=0ck2k+1(π2z)2k+1, where c0 = 1Script error: No such module "Check for unknown parameters". and ck=m=0k1cmck1m(m+1)(2m+1)={1,1,76,12790,43692520,3480716200,}.

So we have the series expansion (common factors have been canceled from numerators and denominators): erf1(z)=π2(z+π12z3+7π2480z5+127π340320z7+4369π45806080z9+34807π5182476800z11+). (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 erfc1(1z)=erf1(z). 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: erfi1(z)=k=0(1)kck2k+1(π2z)2k+1, 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 erfc(x)=ex2xπ(1+n=1(1)n135(2n1)(2x2)n)=ex2xπn=0(1)n(2n1)!!(2x2)n, 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 erfc(x)=ex2xπn=0N1(1)n(2n1)!!(2x2)n+RN(x) where the remainder is RN(x):=(1)N(2N1)!!π2N1xt2Net2dt, which follows easily by induction, writing et2=12tddtet2 and integrating by parts.

The asymptotic behavior of the remainder term, in Landau notation, is RN(x)=O(x(1+2N)ex2) as x → ∞Script error: No such module "Check for unknown parameters".. This can be found by RN(x)xt2Net2dt=ex20(t+x)2Net22txdtex20x2Ne2txdtx(1+2N)ex2. 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] erfc(z)=zπez21z2+a11+a2z2+a31+,am=m2.

Factorial series

The inverse factorial series: erfc(z)=ez2πzn=0(1)nQn(z2+1)n¯=ez2πz[1121(z2+1)+141(z2+1)(z2+2)] converges for Re(z2) > 0Script error: No such module "Check for unknown parameters".. Here Qn=def1Γ(12)0τ(τ1)(τn+1)τ12eτdτ=k=0n(12)k¯s(n,k), 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: erf(z)=2πn=0(2)n(2n1)!!(2n+1)!z2n+1

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: erf(x)11(1+a1x+a2x2+a3x3+a4x4)4,x0 (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".

erf(x)1(a1t+a2t2+a3t3)ex2,t=11+px,x0 (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".

erf(x)11(1+a1x+a2x2++a6x6)16,x0 (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".

erf(x)1(a1t+a2t2++a5t5)ex2,t=11+px (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, erf(x)1(a1t+a2t2++a5t5+a6t6+a7t7)ex2,t=11+p1x+p2x2 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] erfc(x)12e2x2+12ex2ex2,x>0erfc(x)16ex2+12e43x2,x>0.


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 2(

  1. REDIRECT Template:Radic

Template:Rcat shellx)Script error: No such module "Check for unknown parameters"., where Q~(x)=n=1Nanebnx2. 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) ≈ (x)Script error: No such module "Check for unknown parameters"., Q(x) ≤ (x)Script error: No such module "Check for unknown parameters"., or Q(x) ≥ (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 erfc(x)(1eAx)ex2Bπx. 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] erfc(x)2eπβ1βeβx2,x0,β>1, 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 erf(x)sgnx1exp(x24π+ax21+ax2) where a=8(π3)3π(4π)0.140012. 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, erf(x)sgnx1exp(x24+0.880877880079853x2+0.144026670907584x4+0.0077581300270021x6π+0.786235558186528x2+0.128368576906837x4+0.00773380006014367x6), 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: erf1(x)sgnx(2πa+ln(1x2)2)2ln(1x2)a(2πa+ln(1x2)2).


An approximation with a maximal error of Script error: No such module "val". for any real argument is:[23] erf(x)={1τx0τ1x<0 with τ=texp(x21.26551223+1.00002368t+0.37409196t2+0.09678418t30.18628806t4+0.27886807t51.13520398t6+1.48851587t70.82215223t8+0.17087277t9) and t=11+12|x|.


An approximation of erfc with a maximum relative error less than 253 (1.1×1016) in absolute value is:[24] for x0, erfc(x)=(0.56418958354775629x+2.06955023132914151)(x2+2.71078540045147805x+5.80755613130301624x2+3.47954057099518960x+12.06166887286239555)(x2+3.47469513777439592x+12.07402036406381411x2+3.72068443960225092x+8.44319781003968454)(x2+4.00561509202259545x+9.30596659485887898x2+3.90225704029924078x+6.36161630953880464)(x2+5.16722705817812584x+9.12661617673673262x2+4.03296893109262491x+5.13578530585681539)(x2+5.95908795446633271x+9.19435612886969243x2+4.11240942957450885x+4.48640329523408675)ex2 and for x<0 erfc(x)=2erfc(x)


A simple approximation for real-valued arguments could be done through Hyperbolic functions: erf(x)z(x)=tanh(2π(x+11123x3)) which keeps the absolute difference |erf(x)z(x)|<0.000358,x.


Since the error function and the Gaussian Q-function are closely related through the identity erfc(x)=2Q(2x) or equivalently Q(x)=12erfc(x2), 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 x[0,) was introduced by Abreu (2012)[25] based on a simple algebraic expression with only two exponential terms: Q(x)112ex2+12π(x+1)ex2/2,x0, and Q(x)150ex2+12(x+1)ex2/2,x0.

These bounds stem from a unified form QB(x;a,b)=exp(x2)a+exp(x2/2)b(x+1), where the parameters a and b are selected to ensure the bounding properties: for the lower bound, aL=12 and bL=2π, and for the upper bound, aU=50 and bU=2. 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 Qn(x) for positive integers n via the binomial theorem, suggesting potential adaptability for powers of erfc(x), 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

File:Plot of the error function Erf(z) in the complex plane from -2-2i to 2+2i with colors created with Mathematica 13.1 function ComplexPlot3D.svg
Plot of the error function erf(z) in the complex plane from −2 − 2i to 2 + 2i

The complementary error function, denoted erfcScript error: No such module "Check for unknown parameters"., is defined as erfc(x)=1erf(x)=2πxet2dt=ex2erfcx(x), 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] erfc(xx0)=2π0π2exp(x2sin2θ)dθ. 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] erfc(x+yx,y0)=2π0π2exp(x2sin2θy2cos2θ)dθ.

Imaginary error function

File:Plot of the imaginary error function Erfi(z) in the complex plane from -2-2i to 2+2i with colors created with Mathematica 13.1 function ComplexPlot3D.svg
Plot of the imaginary error function erfi(z) in the complex plane from −2 − 2i to 2 + 2i

The imaginary error function, denoted erfiScript error: No such module "Check for unknown parameters"., is defined as erfi(x)=ierf(ix)=2π0xet2dt=2πex2D(x), 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: w(z)=ez2erfc(iz)=erfcx(iz).

Cumulative distribution function

File:Normal cumulative distribution function complex plot in Mathematica 13.1 with ComplexPlot3D.svg
The normal cumulative distribution function plotted in the complex plane

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, Φ(x)=12πxet22dt=12(1+erf(x2))=12erfc(x2) or rearranged for erfScript error: No such module "Check for unknown parameters". and erfcScript error: No such module "Check for unknown parameters".: erf(x)=2Φ(x2)1erfc(x)=2Φ(x2)=2(1Φ(x2)).

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 Q(x)=1212erf(x2)=12erfc(x2).

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 probit(p)=Φ1(p)=2erf1(2p1)=2erfc1(2p).

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): erf(x)=2xπM(12,32,x2).

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, erf(x)=sgn(x)P(12,x2)=sgn(x)πγ(12,x2).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] inerfc(z)=zin1erfc(ζ)dζi0erfc(z)=erfc(z)i1erfc(z)=ierfc(z)=1πez2zerfc(z)i2erfc(z)=14(erfc(z)2zierfc(z))

The general recurrence formula is 2ninerfc(z)=in2erfc(z)2zin1erfc(z)

They have the power series inerfc(z)=j=0(z)j2njj!Γ(1+nj2), from which follow the symmetry properties i2merfc(z)=i2merfc(z)+q=0mz2q22(mq)1(2q)!(mq)! and i2m+1erfc(z)=i2m+1erfc(z)+q=0mz2q+122(mq)1(2q+1)!(mq)!.

Implementations

As real function of a real argument

As complex function of a complex argument

  • libcerf, numeric C library for complex error functions, provides the complex functions cerf, cerfc, cerfcx and the real functions erfi, erfcx with approximately 13–14 digits precision, based on the Faddeeva function as implemented in the MIT Faddeeva Package

References

<templatestyles src="Reflist/styles.css" />

  1. Script error: No such module "citation/CS1".
  2. Script error: No such module "citation/CS1".
  3. Script error: No such module "Citation/CS1".
  4. Script error: No such module "Citation/CS1".
  5. Script error: No such module "Template wrapper".
  6. Script error: No such module "Citation/CS1".
  7. Script error: No such module "Template wrapper".
  8. Script error: No such module "citation/CS1".
  9. Script error: No such module "citation/CS1".
  10. Pierre-Simon Laplace, Traité de mécanique céleste, tome 4 (1805), livre X, page 255.
  11. Script error: No such module "citation/CS1".
  12. Script error: No such module "Citation/CS1".
  13. Script error: No such module "citation/CS1".
  14. Script error: No such module "Citation/CS1".
  15. Script error: No such module "Citation/CS1".
  16. Script error: No such module "Citation/CS1".
  17. Script error: No such module "Citation/CS1".
  18. Script error: No such module "Citation/CS1".
  19. Script error: No such module "Citation/CS1".
  20. Script error: No such module "citation/CS1".
  21. Script error: No such module "Citation/CS1".
  22. Script error: No such module "citation/CS1".
  23. Script error: No such module "citation/CS1".
  24. Script error: No such module "Citation/CS1".
  25. Script error: No such module "Citation/CS1".
  26. a b c Script error: No such module "citation/CS1".
  27. Script error: No such module "citation/CS1".
  28. 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.
  29. Script error: No such module "Citation/CS1".
  30. Script error: No such module "citation/CS1".
  31. Script error: No such module "citation/CS1".
  32. 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

External links

Template:Nonelementary Integral Template:Authority control