• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1<html>
2<head>
3<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
4<title>Error Function erf and complement erfc</title>
5<link rel="stylesheet" href="../../math.css" type="text/css">
6<meta name="generator" content="DocBook XSL Stylesheets V1.79.1">
7<link rel="home" href="../../index.html" title="Math Toolkit 2.12.0">
8<link rel="up" href="../sf_erf.html" title="Error Functions">
9<link rel="prev" href="../sf_erf.html" title="Error Functions">
10<link rel="next" href="error_inv.html" title="Error Function Inverses">
11</head>
12<body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF">
13<table cellpadding="2" width="100%"><tr>
14<td valign="top"><img alt="Boost C++ Libraries" width="277" height="86" src="../../../../../../boost.png"></td>
15<td align="center"><a href="../../../../../../index.html">Home</a></td>
16<td align="center"><a href="../../../../../../libs/libraries.htm">Libraries</a></td>
17<td align="center"><a href="http://www.boost.org/users/people.html">People</a></td>
18<td align="center"><a href="http://www.boost.org/users/faq.html">FAQ</a></td>
19<td align="center"><a href="../../../../../../more/index.htm">More</a></td>
20</tr></table>
21<hr>
22<div class="spirit-nav">
23<a accesskey="p" href="../sf_erf.html"><img src="../../../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../sf_erf.html"><img src="../../../../../../doc/src/images/up.png" alt="Up"></a><a accesskey="h" href="../../index.html"><img src="../../../../../../doc/src/images/home.png" alt="Home"></a><a accesskey="n" href="error_inv.html"><img src="../../../../../../doc/src/images/next.png" alt="Next"></a>
24</div>
25<div class="section">
26<div class="titlepage"><div><div><h3 class="title">
27<a name="math_toolkit.sf_erf.error_function"></a><a class="link" href="error_function.html" title="Error Function erf and complement erfc">Error Function erf
28      and complement erfc</a>
29</h3></div></div></div>
30<h5>
31<a name="math_toolkit.sf_erf.error_function.h0"></a>
32        <span class="phrase"><a name="math_toolkit.sf_erf.error_function.synopsis"></a></span><a class="link" href="error_function.html#math_toolkit.sf_erf.error_function.synopsis">Synopsis</a>
33      </h5>
34<pre class="programlisting"><span class="preprocessor">#include</span> <span class="special">&lt;</span><span class="identifier">boost</span><span class="special">/</span><span class="identifier">math</span><span class="special">/</span><span class="identifier">special_functions</span><span class="special">/</span><span class="identifier">erf</span><span class="special">.</span><span class="identifier">hpp</span><span class="special">&gt;</span>
35</pre>
36<pre class="programlisting"><span class="keyword">namespace</span> <span class="identifier">boost</span><span class="special">{</span> <span class="keyword">namespace</span> <span class="identifier">math</span><span class="special">{</span>
37
38<span class="keyword">template</span> <span class="special">&lt;</span><span class="keyword">class</span> <span class="identifier">T</span><span class="special">&gt;</span>
39<a class="link" href="../result_type.html" title="Calculation of the Type of the Result"><span class="emphasis"><em>calculated-result-type</em></span></a> <span class="identifier">erf</span><span class="special">(</span><span class="identifier">T</span> <span class="identifier">z</span><span class="special">);</span>
40
41<span class="keyword">template</span> <span class="special">&lt;</span><span class="keyword">class</span> <span class="identifier">T</span><span class="special">,</span> <span class="keyword">class</span> <a class="link" href="../../policy.html" title="Chapter 21. Policies: Controlling Precision, Error Handling etc">Policy</a><span class="special">&gt;</span>
42<a class="link" href="../result_type.html" title="Calculation of the Type of the Result"><span class="emphasis"><em>calculated-result-type</em></span></a> <span class="identifier">erf</span><span class="special">(</span><span class="identifier">T</span> <span class="identifier">z</span><span class="special">,</span> <span class="keyword">const</span> <a class="link" href="../../policy.html" title="Chapter 21. Policies: Controlling Precision, Error Handling etc">Policy</a><span class="special">&amp;);</span>
43
44<span class="keyword">template</span> <span class="special">&lt;</span><span class="keyword">class</span> <span class="identifier">T</span><span class="special">&gt;</span>
45<a class="link" href="../result_type.html" title="Calculation of the Type of the Result"><span class="emphasis"><em>calculated-result-type</em></span></a> <span class="identifier">erfc</span><span class="special">(</span><span class="identifier">T</span> <span class="identifier">z</span><span class="special">);</span>
46
47<span class="keyword">template</span> <span class="special">&lt;</span><span class="keyword">class</span> <span class="identifier">T</span><span class="special">,</span> <span class="keyword">class</span> <a class="link" href="../../policy.html" title="Chapter 21. Policies: Controlling Precision, Error Handling etc">Policy</a><span class="special">&gt;</span>
48<a class="link" href="../result_type.html" title="Calculation of the Type of the Result"><span class="emphasis"><em>calculated-result-type</em></span></a> <span class="identifier">erfc</span><span class="special">(</span><span class="identifier">T</span> <span class="identifier">z</span><span class="special">,</span> <span class="keyword">const</span> <a class="link" href="../../policy.html" title="Chapter 21. Policies: Controlling Precision, Error Handling etc">Policy</a><span class="special">&amp;);</span>
49
50<span class="special">}}</span> <span class="comment">// namespaces</span>
51</pre>
52<p>
53        The return type of these functions is computed using the <a class="link" href="../result_type.html" title="Calculation of the Type of the Result"><span class="emphasis"><em>result
54        type calculation rules</em></span></a>: the return type is <code class="computeroutput"><span class="keyword">double</span></code> if T is an integer type, and T otherwise.
55      </p>
56<p>
57        The final <a class="link" href="../../policy.html" title="Chapter 21. Policies: Controlling Precision, Error Handling etc">Policy</a> argument is optional and can
58        be used to control the behaviour of the function: how it handles errors,
59        what level of precision to use etc. Refer to the <a class="link" href="../../policy.html" title="Chapter 21. Policies: Controlling Precision, Error Handling etc">policy
60        documentation for more details</a>.
61      </p>
62<h5>
63<a name="math_toolkit.sf_erf.error_function.h1"></a>
64        <span class="phrase"><a name="math_toolkit.sf_erf.error_function.description"></a></span><a class="link" href="error_function.html#math_toolkit.sf_erf.error_function.description">Description</a>
65      </h5>
66<pre class="programlisting"><span class="keyword">template</span> <span class="special">&lt;</span><span class="keyword">class</span> <span class="identifier">T</span><span class="special">&gt;</span>
67<a class="link" href="../result_type.html" title="Calculation of the Type of the Result"><span class="emphasis"><em>calculated-result-type</em></span></a> <span class="identifier">erf</span><span class="special">(</span><span class="identifier">T</span> <span class="identifier">z</span><span class="special">);</span>
68
69<span class="keyword">template</span> <span class="special">&lt;</span><span class="keyword">class</span> <span class="identifier">T</span><span class="special">,</span> <span class="keyword">class</span> <a class="link" href="../../policy.html" title="Chapter 21. Policies: Controlling Precision, Error Handling etc">Policy</a><span class="special">&gt;</span>
70<a class="link" href="../result_type.html" title="Calculation of the Type of the Result"><span class="emphasis"><em>calculated-result-type</em></span></a> <span class="identifier">erf</span><span class="special">(</span><span class="identifier">T</span> <span class="identifier">z</span><span class="special">,</span> <span class="keyword">const</span> <a class="link" href="../../policy.html" title="Chapter 21. Policies: Controlling Precision, Error Handling etc">Policy</a><span class="special">&amp;);</span>
71</pre>
72<p>
73        Returns the <a href="http://en.wikipedia.org/wiki/Error_function" target="_top">error
74        function</a> <a href="http://functions.wolfram.com/GammaBetaErf/Erf/" target="_top">erf</a>
75        of z:
76      </p>
77<div class="blockquote"><blockquote class="blockquote"><p>
78          <span class="inlinemediaobject"><img src="../../../equations/erf1.svg"></span>
79
80        </p></blockquote></div>
81<div class="blockquote"><blockquote class="blockquote"><p>
82          <span class="inlinemediaobject"><img src="../../../graphs/erf.svg" align="middle"></span>
83
84        </p></blockquote></div>
85<pre class="programlisting"><span class="keyword">template</span> <span class="special">&lt;</span><span class="keyword">class</span> <span class="identifier">T</span><span class="special">&gt;</span>
86<a class="link" href="../result_type.html" title="Calculation of the Type of the Result"><span class="emphasis"><em>calculated-result-type</em></span></a> <span class="identifier">erfc</span><span class="special">(</span><span class="identifier">T</span> <span class="identifier">z</span><span class="special">);</span>
87
88<span class="keyword">template</span> <span class="special">&lt;</span><span class="keyword">class</span> <span class="identifier">T</span><span class="special">,</span> <span class="keyword">class</span> <a class="link" href="../../policy.html" title="Chapter 21. Policies: Controlling Precision, Error Handling etc">Policy</a><span class="special">&gt;</span>
89<a class="link" href="../result_type.html" title="Calculation of the Type of the Result"><span class="emphasis"><em>calculated-result-type</em></span></a> <span class="identifier">erfc</span><span class="special">(</span><span class="identifier">T</span> <span class="identifier">z</span><span class="special">,</span> <span class="keyword">const</span> <a class="link" href="../../policy.html" title="Chapter 21. Policies: Controlling Precision, Error Handling etc">Policy</a><span class="special">&amp;);</span>
90</pre>
91<p>
92        Returns the complement of the <a href="http://functions.wolfram.com/GammaBetaErf/Erfc/" target="_top">error
93        function</a> of z:
94      </p>
95<div class="blockquote"><blockquote class="blockquote"><p>
96          <span class="inlinemediaobject"><img src="../../../equations/erf2.svg"></span>
97
98        </p></blockquote></div>
99<div class="blockquote"><blockquote class="blockquote"><p>
100          <span class="inlinemediaobject"><img src="../../../graphs/erfc.svg" align="middle"></span>
101
102        </p></blockquote></div>
103<h5>
104<a name="math_toolkit.sf_erf.error_function.h2"></a>
105        <span class="phrase"><a name="math_toolkit.sf_erf.error_function.accuracy"></a></span><a class="link" href="error_function.html#math_toolkit.sf_erf.error_function.accuracy">Accuracy</a>
106      </h5>
107<p>
108        The following table shows the peak errors (in units of epsilon) found on
109        various platforms with various floating-point types, along with comparisons
110        to the <a href="http://www.gnu.org/software/gsl/" target="_top">GSL-1.9</a>, <a href="http://www.gnu.org/software/libc/" target="_top">GNU C Lib</a>, <a href="http://docs.hp.com/en/B9106-90010/index.html" target="_top">HP-UX
111        C Library</a> and <a href="http://www.netlib.org/cephes/" target="_top">Cephes</a>
112        libraries. Unless otherwise specified any floating-point type that is narrower
113        than the one shown will have <a class="link" href="../relative_error.html#math_toolkit.relative_error.zero_error">effectively
114        zero error</a>.
115      </p>
116<div class="table">
117<a name="math_toolkit.sf_erf.error_function.table_erf"></a><p class="title"><b>Table 8.28. Error rates for erf</b></p>
118<div class="table-contents"><table class="table" summary="Error rates for erf">
119<colgroup>
120<col>
121<col>
122<col>
123<col>
124<col>
125</colgroup>
126<thead><tr>
127<th>
128              </th>
129<th>
130                <p>
131                  GNU C++ version 7.1.0<br> linux<br> long double
132                </p>
133              </th>
134<th>
135                <p>
136                  GNU C++ version 7.1.0<br> linux<br> double
137                </p>
138              </th>
139<th>
140                <p>
141                  Sun compiler version 0x5150<br> Sun Solaris<br> long double
142                </p>
143              </th>
144<th>
145                <p>
146                  Microsoft Visual C++ version 14.1<br> Win32<br> double
147                </p>
148              </th>
149</tr></thead>
150<tbody>
151<tr>
152<td>
153                <p>
154                  Erf Function: Small Values
155                </p>
156              </td>
157<td>
158                <p>
159                  <span class="blue">Max = 0.925ε (Mean = 0.193ε)</span><br> <br>
160                  (<span class="emphasis"><em>&lt;cmath&gt;:</em></span> Max = 0.944ε (Mean = 0.191ε))<br>
161                  (<span class="emphasis"><em>&lt;math.h&gt;:</em></span> Max = 0.944ε (Mean = 0.191ε))
162                </p>
163              </td>
164<td>
165                <p>
166                  <span class="blue">Max = 0.841ε (Mean = 0.0687ε)</span><br>
167                  <br> (<span class="emphasis"><em>GSL 2.1:</em></span> Max = 2.06ε (Mean = 0.319ε))
168                </p>
169              </td>
170<td>
171                <p>
172                  <span class="blue">Max = 0.925ε (Mean = 0.193ε)</span><br> <br>
173                  (<span class="emphasis"><em>&lt;math.h&gt;:</em></span> Max = 0.944ε (Mean = 0.194ε))
174                </p>
175              </td>
176<td>
177                <p>
178                  <span class="blue">Max = 0.996ε (Mean = 0.182ε)</span><br> <br>
179                  (<span class="emphasis"><em>&lt;math.h&gt;:</em></span> Max = 1.57ε (Mean = 0.317ε))
180                </p>
181              </td>
182</tr>
183<tr>
184<td>
185                <p>
186                  Erf Function: Medium Values
187                </p>
188              </td>
189<td>
190                <p>
191                  <span class="blue">Max = 1.5ε (Mean = 0.193ε)</span><br> <br>
192                  (<span class="emphasis"><em>&lt;cmath&gt;:</em></span> Max = 0.921ε (Mean = 0.0723ε))<br>
193                  (<span class="emphasis"><em>&lt;math.h&gt;:</em></span> Max = 0.921ε (Mean = 0.0723ε))
194                </p>
195              </td>
196<td>
197                <p>
198                  <span class="blue">Max = 1ε (Mean = 0.119ε)</span><br> <br>
199                  (<span class="emphasis"><em>GSL 2.1:</em></span> Max = 2.31ε (Mean = 0.368ε))
200                </p>
201              </td>
202<td>
203                <p>
204                  <span class="blue">Max = 1.5ε (Mean = 0.197ε)</span><br> <br>
205                  (<span class="emphasis"><em>&lt;math.h&gt;:</em></span> Max = 0.921ε (Mean = 0.071ε))
206                </p>
207              </td>
208<td>
209                <p>
210                  <span class="blue">Max = 1ε (Mean = 0.171ε)</span><br> <br>
211                  (<span class="emphasis"><em>&lt;math.h&gt;:</em></span> Max = 1.19ε (Mean = 0.244ε))
212                </p>
213              </td>
214</tr>
215<tr>
216<td>
217                <p>
218                  Erf Function: Large Values
219                </p>
220              </td>
221<td>
222                <p>
223                  <span class="blue">Max = 0ε (Mean = 0ε)</span><br> <br> (<span class="emphasis"><em>&lt;cmath&gt;:</em></span>
224                  Max = 0ε (Mean = 0ε))<br> (<span class="emphasis"><em>&lt;math.h&gt;:</em></span>
225                  Max = 0ε (Mean = 0ε))
226                </p>
227              </td>
228<td>
229                <p>
230                  <span class="blue">Max = 0ε (Mean = 0ε)</span><br> <br> (<span class="emphasis"><em>GSL
231                  2.1:</em></span> Max = 0ε (Mean = 0ε))
232                </p>
233              </td>
234<td>
235                <p>
236                  <span class="blue">Max = 0ε (Mean = 0ε)</span><br> <br> (<span class="emphasis"><em>&lt;math.h&gt;:</em></span>
237                  Max = 0ε (Mean = 0ε))
238                </p>
239              </td>
240<td>
241                <p>
242                  <span class="blue">Max = 0ε (Mean = 0ε)</span><br> <br> (<span class="emphasis"><em>&lt;math.h&gt;:</em></span>
243                  Max = 0ε (Mean = 0ε))
244                </p>
245              </td>
246</tr>
247</tbody>
248</table></div>
249</div>
250<br class="table-break"><div class="table">
251<a name="math_toolkit.sf_erf.error_function.table_erfc"></a><p class="title"><b>Table 8.29. Error rates for erfc</b></p>
252<div class="table-contents"><table class="table" summary="Error rates for erfc">
253<colgroup>
254<col>
255<col>
256<col>
257<col>
258<col>
259</colgroup>
260<thead><tr>
261<th>
262              </th>
263<th>
264                <p>
265                  GNU C++ version 7.1.0<br> linux<br> long double
266                </p>
267              </th>
268<th>
269                <p>
270                  GNU C++ version 7.1.0<br> linux<br> double
271                </p>
272              </th>
273<th>
274                <p>
275                  Sun compiler version 0x5150<br> Sun Solaris<br> long double
276                </p>
277              </th>
278<th>
279                <p>
280                  Microsoft Visual C++ version 14.1<br> Win32<br> double
281                </p>
282              </th>
283</tr></thead>
284<tbody>
285<tr>
286<td>
287                <p>
288                  Erf Function: Small Values
289                </p>
290              </td>
291<td>
292                <p>
293                  <span class="blue">Max = 0ε (Mean = 0ε)</span><br> <br> (<span class="emphasis"><em>&lt;cmath&gt;:</em></span>
294                  Max = 0ε (Mean = 0ε))<br> (<span class="emphasis"><em>&lt;math.h&gt;:</em></span>
295                  Max = 0ε (Mean = 0ε))
296                </p>
297              </td>
298<td>
299                <p>
300                  <span class="blue">Max = 0.658ε (Mean = 0.0537ε)</span><br>
301                  <br> (<span class="emphasis"><em>GSL 2.1:</em></span> Max = 1.01ε (Mean = 0.485ε))
302                </p>
303              </td>
304<td>
305                <p>
306                  <span class="blue">Max = 0ε (Mean = 0ε)</span><br> <br> (<span class="emphasis"><em>&lt;math.h&gt;:</em></span>
307                  Max = 0ε (Mean = 0ε))
308                </p>
309              </td>
310<td>
311                <p>
312                  <span class="blue">Max = 0ε (Mean = 0ε)</span><br> <br> (<span class="emphasis"><em>&lt;math.h&gt;:</em></span>
313                  Max = 0ε (Mean = 0ε))
314                </p>
315              </td>
316</tr>
317<tr>
318<td>
319                <p>
320                  Erf Function: Medium Values
321                </p>
322              </td>
323<td>
324                <p>
325                  <span class="blue">Max = 1.76ε (Mean = 0.365ε)</span><br> <br>
326                  (<span class="emphasis"><em>&lt;cmath&gt;:</em></span> Max = 1.35ε (Mean = 0.307ε))<br>
327                  (<span class="emphasis"><em>&lt;math.h&gt;:</em></span> Max = 1.35ε (Mean = 0.307ε))
328                </p>
329              </td>
330<td>
331                <p>
332                  <span class="blue">Max = 0.983ε (Mean = 0.213ε)</span><br> <br>
333                  (<span class="emphasis"><em>GSL 2.1:</em></span> Max = 2.64ε (Mean = 0.662ε))
334                </p>
335              </td>
336<td>
337                <p>
338                  <span class="blue">Max = 1.76ε (Mean = 0.38ε)</span><br> <br>
339                  (<span class="emphasis"><em>&lt;math.h&gt;:</em></span> Max = 2.81ε (Mean = 0.739ε))
340                </p>
341              </td>
342<td>
343                <p>
344                  <span class="blue">Max = 1.65ε (Mean = 0.373ε)</span><br> <br>
345                  (<span class="emphasis"><em>&lt;math.h&gt;:</em></span> Max = 2.36ε (Mean = 0.539ε))
346                </p>
347              </td>
348</tr>
349<tr>
350<td>
351                <p>
352                  Erf Function: Large Values
353                </p>
354              </td>
355<td>
356                <p>
357                  <span class="blue">Max = 1.57ε (Mean = 0.542ε)</span><br> <br>
358                  (<span class="emphasis"><em>&lt;cmath&gt;:</em></span> Max = 1.26ε (Mean = 0.441ε))<br>
359                  (<span class="emphasis"><em>&lt;math.h&gt;:</em></span> Max = 1.26ε (Mean = 0.441ε))
360                </p>
361              </td>
362<td>
363                <p>
364                  <span class="blue">Max = 0.868ε (Mean = 0.147ε)</span><br> <br>
365                  (<span class="emphasis"><em>GSL 2.1:</em></span> Max = 3.9ε (Mean = 0.472ε))
366                </p>
367              </td>
368<td>
369                <p>
370                  <span class="blue">Max = 1.57ε (Mean = 0.564ε)</span><br> <br>
371                  (<span class="emphasis"><em>&lt;math.h&gt;:</em></span> Max = 4.91ε (Mean = 1.54ε))
372                </p>
373              </td>
374<td>
375                <p>
376                  <span class="blue">Max = 1.14ε (Mean = 0.248ε)</span><br> <br>
377                  (<span class="emphasis"><em>&lt;math.h&gt;:</em></span> Max = 1.84ε (Mean = 0.331ε))
378                </p>
379              </td>
380</tr>
381</tbody>
382</table></div>
383</div>
384<br class="table-break"><p>
385        The following error plot are based on an exhaustive search of the functions
386        domain, MSVC-15.5 at <code class="computeroutput"><span class="keyword">double</span></code>
387        precision, and GCC-7.1/Ubuntu for <code class="computeroutput"><span class="keyword">long</span>
388        <span class="keyword">double</span></code> and <code class="computeroutput"><span class="identifier">__float128</span></code>.
389      </p>
390<div class="blockquote"><blockquote class="blockquote"><p>
391          <span class="inlinemediaobject"><img src="../../../graphs/erf__double.svg" align="middle"></span>
392
393        </p></blockquote></div>
394<div class="blockquote"><blockquote class="blockquote"><p>
395          <span class="inlinemediaobject"><img src="../../../graphs/erf__80_bit_long_double.svg" align="middle"></span>
396
397        </p></blockquote></div>
398<div class="blockquote"><blockquote class="blockquote"><p>
399          <span class="inlinemediaobject"><img src="../../../graphs/erf____float128.svg" align="middle"></span>
400
401        </p></blockquote></div>
402<h5>
403<a name="math_toolkit.sf_erf.error_function.h3"></a>
404        <span class="phrase"><a name="math_toolkit.sf_erf.error_function.testing"></a></span><a class="link" href="error_function.html#math_toolkit.sf_erf.error_function.testing">Testing</a>
405      </h5>
406<p>
407        The tests for these functions come in two parts: basic sanity checks use
408        spot values calculated using <a href="http://functions.wolfram.com/webMathematica/FunctionEvaluation.jsp?name=Erf" target="_top">Mathworld's
409        online evaluator</a>, while accuracy checks use high-precision test values
410        calculated at 1000-bit precision with <a href="http://shoup.net/ntl/doc/RR.txt" target="_top">NTL::RR</a>
411        and this implementation. Note that the generic and type-specific versions
412        of these functions use differing implementations internally, so this gives
413        us reasonably independent test data. Using our test data to test other "known
414        good" implementations also provides an additional sanity check.
415      </p>
416<h5>
417<a name="math_toolkit.sf_erf.error_function.h4"></a>
418        <span class="phrase"><a name="math_toolkit.sf_erf.error_function.implementation"></a></span><a class="link" href="error_function.html#math_toolkit.sf_erf.error_function.implementation">Implementation</a>
419      </h5>
420<p>
421        All versions of these functions first use the usual reflection formulas to
422        make their arguments positive:
423      </p>
424<div class="blockquote"><blockquote class="blockquote"><p>
425          <span class="serif_italic"><span class="emphasis"><em>erf(-z) = 1 - erf(z);</em></span>
426          </span>
427        </p></blockquote></div>
428<div class="blockquote"><blockquote class="blockquote"><p>
429          <span class="serif_italic"><span class="emphasis"><em>erfc(-z) = 2 - erfc(z);</em></span>
430          // preferred when -z &lt; -0.5</span>
431        </p></blockquote></div>
432<div class="blockquote"><blockquote class="blockquote"><p>
433          <span class="serif_italic"><span class="emphasis"><em>erfc(-z) = 1 + erf(z);</em></span>
434          // preferred when -0.5 &lt;= -z &lt; 0</span>
435        </p></blockquote></div>
436<p>
437        The generic versions of these functions are implemented in terms of the incomplete
438        gamma function.
439      </p>
440<p>
441        When the significand (mantissa) size is recognised (currently for 53, 64
442        and 113-bit reals, plus single-precision 24-bit handled via promotion to
443        double) then a series of rational approximations <a class="link" href="../sf_implementation.html#math_toolkit.sf_implementation.rational_approximations_used">devised
444        by JM</a> are used.
445      </p>
446<p>
447        For <code class="computeroutput"><span class="identifier">z</span> <span class="special">&lt;=</span>
448        <span class="number">0.5</span></code> then a rational approximation to
449        erf is used, based on the observation that erf is an odd function and therefore
450        erf is calculated using:
451      </p>
452<div class="blockquote"><blockquote class="blockquote"><p>
453          <span class="serif_italic"><span class="emphasis"><em>erf(z) = z * (C + R(z*z));</em></span></span>
454        </p></blockquote></div>
455<p>
456        where the rational approximation <span class="emphasis"><em>R(z*z)</em></span> is optimised
457        for absolute error: as long as its absolute error is small enough compared
458        to the constant C, then any round-off error incurred during the computation
459        of R(z*z) will effectively disappear from the result. As a result the error
460        for erf and erfc in this region is very low: the last bit is incorrect in
461        only a very small number of cases.
462      </p>
463<p>
464        For <code class="computeroutput"><span class="identifier">z</span> <span class="special">&gt;</span>
465        <span class="number">0.5</span></code> we observe that over a small interval
466        [<span class="emphasis"><em>a, b)</em></span> then:
467      </p>
468<div class="blockquote"><blockquote class="blockquote"><p>
469          <span class="serif_italic"><span class="emphasis"><em>erfc(z) * exp(z*z) * z ~ c</em></span></span>
470        </p></blockquote></div>
471<p>
472        for some constant c.
473      </p>
474<p>
475        Therefore for <code class="computeroutput"><span class="identifier">z</span> <span class="special">&gt;</span>
476        <span class="number">0.5</span></code> we calculate <code class="computeroutput"><span class="identifier">erfc</span></code>
477        using:
478      </p>
479<div class="blockquote"><blockquote class="blockquote"><p>
480          <span class="serif_italic"><span class="emphasis"><em>erfc(z) = exp(-z*z) * (C + R(z -
481          B)) / z;</em></span></span>
482        </p></blockquote></div>
483<p>
484        Again R(z - B) is optimised for absolute error, and the constant <code class="computeroutput"><span class="identifier">C</span></code> is the average of <code class="computeroutput"><span class="identifier">erfc</span><span class="special">(</span><span class="identifier">z</span><span class="special">)</span>
485        <span class="special">*</span> <span class="identifier">exp</span><span class="special">(</span><span class="identifier">z</span><span class="special">*</span><span class="identifier">z</span><span class="special">)</span> <span class="special">*</span>
486        <span class="identifier">z</span></code> taken at the endpoints of the
487        range. Once again, as long as the absolute error in R(z - B) is small compared
488        to <code class="computeroutput"><span class="identifier">c</span></code> then <code class="computeroutput"><span class="identifier">c</span>
489        <span class="special">+</span> <span class="identifier">R</span><span class="special">(</span><span class="identifier">z</span> <span class="special">-</span>
490        <span class="identifier">B</span><span class="special">)</span></code>
491        will be correctly rounded, and the error in the result will depend only on
492        the accuracy of the exp function. In practice, in all but a very small number
493        of cases, the error is confined to the last bit of the result. The constant
494        <code class="computeroutput"><span class="identifier">B</span></code> is chosen so that the left
495        hand end of the range of the rational approximation is 0.
496      </p>
497<p>
498        For large <code class="computeroutput"><span class="identifier">z</span></code> over a range
499        [a, +∞] the above approximation is modified to:
500      </p>
501<div class="blockquote"><blockquote class="blockquote"><p>
502          <span class="serif_italic"><span class="emphasis"><em>erfc(z) = exp(-z*z) * (C + R(1 /
503          z)) / z;</em></span></span>
504        </p></blockquote></div>
505</div>
506<table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr>
507<td align="left"></td>
508<td align="right"><div class="copyright-footer">Copyright © 2006-2019 Nikhar
509      Agrawal, Anton Bikineev, Paul A. Bristow, Marco Guazzone, Christopher Kormanyos,
510      Hubert Holin, Bruno Lalande, John Maddock, Jeremy Murphy, Matthew Pulver, Johan
511      Råde, Gautam Sewani, Benjamin Sobotta, Nicholas Thompson, Thijs van den Berg,
512      Daryle Walker and Xiaogang Zhang<p>
513        Distributed under the Boost Software License, Version 1.0. (See accompanying
514        file LICENSE_1_0.txt or copy at <a href="http://www.boost.org/LICENSE_1_0.txt" target="_top">http://www.boost.org/LICENSE_1_0.txt</a>)
515      </p>
516</div></td>
517</tr></table>
518<hr>
519<div class="spirit-nav">
520<a accesskey="p" href="../sf_erf.html"><img src="../../../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../sf_erf.html"><img src="../../../../../../doc/src/images/up.png" alt="Up"></a><a accesskey="h" href="../../index.html"><img src="../../../../../../doc/src/images/home.png" alt="Home"></a><a accesskey="n" href="error_inv.html"><img src="../../../../../../doc/src/images/next.png" alt="Next"></a>
521</div>
522</body>
523</html>
524