The function arises in various physical problems, typically relating to electromagnetic responses in complicated media.
problems involving small-amplitude waves propagating through Maxwellianplasmas, and in particular appears in the plasma's permittivity from which dispersion relations are derived, hence it is sometimes referred to as the plasma dispersion function[1][2] (although this name is sometimes used instead for the rescaled function Z(z) = i√πw(z) defined by Fried and Conte, 1961[1][3]).
the infrared permittivity functions of amorphous oxides have resonances (due to phonons) that are sometimes too complicated to fit using simple harmonic oscillators. The Brendel–Bormann oscillator model uses an infinite superposition of oscillators having slightly different frequencies, with a Gaussian distribution.[4] The integrated response can be written in terms of the Faddeeva function.
the Faddeeva function is also used in the analysis of electromagnetic waves of the type used in AM radio.[citation needed] Groundwaves are vertically polarised waves propagating over a lossy ground with finite resistivity and permittivity.
the Faddeeva function also describes the changes of the neutron cross sections of materials as temperature is varied.[5]
Properties
Real and imaginary parts
The decomposition into real and imaginary parts is usually written
,
where V and L are called the real and imaginary Voigt functions, since V(x,y) is the Voigt profile (up to prefactors).
Sign inversion
For sign-inverted arguments, the following both apply:
and
where * denotes complex conjugate.
Relation to the complementary error function
The Faddeeva function evaluated on imaginary arguments equals the scaled complementary error function ():
In some applications, it is necessary to know not only the original values of the Faddeeva function, but also its derivative (e.g. in Non-linear least squares regression in spectroscopy). Its derivative is given by:[6][7]
This expression can also be broken down further in terms of changes in the real and imaginary part of the Faddeeva function and . Basically, this requires knowledge about the real and imaginary part of the product . Making use of the above definition , the derivative can therefore be split into partial derivatives with respect to and as follows:
and
and
A practical example for the use of these partial derivatives can be found here.
Integral representation
The Faddeeva function occurs as
meaning that it is a convolution of a Gaussian with a simple pole.
History
The function was tabulated by Vera Faddeeva and N. N. Terentyev in 1954.[8] It appears as nameless function w(z) in Abramowitz and Stegun (1964), formula 7.1.3. The name Faddeeva function was apparently introduced by G. P. M. Poppe and C. M. J. Wijers in 1990;[9][better source needed] previously, it was known as Kramp's function (probably after Christian Kramp).[10]
Early implementations used methods by Walter Gautschi (1969–70; ACM Algorithm 363)[11] or by J. Humlicek (1982).[12] A more efficient algorithm was proposed by Poppe and Wijers (1990; ACM Algorithm 680).[13] J.A.C. Weideman (1994) proposed a particularly short algorithm that takes no more than eight lines of MATLAB code.[14] Zaghloul and Ali pointed out deficiencies of previous algorithms and proposed a new one (2011; ACM Algorithm 916).[2] Another algorithm has been proposed by M. Abrarov and B.M. Quine (2011/2012).[15]
A free and open source C or C++ implementation derived from a combination of Algorithm 680 and Algorithm 916 (using different algorithms for different z) is also available under the MIT License,[20] and is maintained as a library package libcerf.[21]
This implementation is also available as a plug-in for Matlab,[20]GNU Octave,[20] and in Python via Scipy as scipy.special.wofz (which was originally the TOMS 680 code, but was replaced due to copyright concerns[22]).
For fast but still accurate calculation of plasma dispersion function , the J-pole Pade approximation is found to be useful,[23] i.e.,
For J=8, one can use
b1= -0.017340112270401 - 0.046306439626294i;
b2= -0.739917811220052 + 0.839518284620274i;
b3= 5.840632105105495 + 0.953602751322040i;
b4= -5.583374181615043 -11.208550459628098i;
c1= 2.237687725134293 - 1.625941024120362i;
c2= 1.465234091939142 - 1.789620299603315i;
c3= 0.839253966367922 - 1.891995211531426i;
c4= 0.273936218055381 - 1.941787037576095i;
b(5:8)=(b(1:4))*;
c(5:8)=-(c(1:4))*,
where * denotes complex conjugate. The above approximation is valid for the upper plane. For weakly close to the real axis, i.e., not far from the real axis of the lower plane, the above approximation is also valid. For accurate calculation of
, one can use
A coding of the above J-pole approach and comparison with an accurate plasma dispersion function can be found.[24] Comphensive coefficients to rapid computation of the plasma dispersion function with rational and multi-pole approximation are also available.[25]
^V. N. Faddeeva and N. N. Terent'ev: Tables of values of the function for complex argument. Gosud. Izdat. Teh.-Teor. Lit., Moscow, 1954; English transl., Pergamon Press, New York, 1961. Unverified citation, copied from Poppe and Wijers (1990).
^Earliest search result in Google Scholar as of Oct 2012.
^For instance in Al'pert, Space Science Reviews 6, 781 (1967), formula (3.13), with reference to Faddeeva and Terent'ev.
^See references 3 and 4 in Poppe and Wijers (1990).
^J. Humlicek, J. Quant. Spectrosc. Radiat. Transfer 27, 437-444 (1982).