3 <meta http-equiv=
"Content-Type" content=
"text/html; charset=US-ASCII">
4 <title>Elliptic Integral D - Legendre Form
</title>
5 <link rel=
"stylesheet" href=
"../../math.css" type=
"text/css">
6 <meta name=
"generator" content=
"DocBook XSL Stylesheets V1.77.1">
7 <link rel=
"home" href=
"../../index.html" title=
"Math Toolkit 2.5.1">
8 <link rel=
"up" href=
"../ellint.html" title=
"Elliptic Integrals">
9 <link rel=
"prev" href=
"ellint_3.html" title=
"Elliptic Integrals of the Third Kind - Legendre Form">
10 <link rel=
"next" href=
"jacobi_zeta.html" title=
"Jacobi Zeta Function">
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>
22 <div class=
"spirit-nav">
23 <a accesskey=
"p" href=
"ellint_3.html"><img src=
"../../../../../../doc/src/images/prev.png" alt=
"Prev"></a><a accesskey=
"u" href=
"../ellint.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=
"jacobi_zeta.html"><img src=
"../../../../../../doc/src/images/next.png" alt=
"Next"></a>
26 <div class=
"titlepage"><div><div><h3 class=
"title">
27 <a name=
"math_toolkit.ellint.ellint_d"></a><a class=
"link" href=
"ellint_d.html" title=
"Elliptic Integral D - Legendre Form">Elliptic Integral D - Legendre
29 </h3></div></div></div>
31 <a name=
"math_toolkit.ellint.ellint_d.h0"></a>
32 <span class=
"phrase"><a name=
"math_toolkit.ellint.ellint_d.synopsis"></a></span><a class=
"link" href=
"ellint_d.html#math_toolkit.ellint.ellint_d.synopsis">Synopsis
</a>
34 <pre class=
"programlisting"><span class=
"preprocessor">#include
</span> <span class=
"special"><</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">ellint_d
</span><span class=
"special">.
</span><span class=
"identifier">hpp
</span><span class=
"special">></span>
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>
38 <span class=
"keyword">template
</span> <span class=
"special"><</span><span class=
"keyword">class
</span> <span class=
"identifier">T1
</span><span class=
"special">,
</span> <span class=
"keyword">class
</span> <span class=
"identifier">T2
</span><span class=
"special">></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">ellint_d
</span><span class=
"special">(
</span><span class=
"identifier">T1
</span> <span class=
"identifier">k
</span><span class=
"special">,
</span> <span class=
"identifier">T2
</span> <span class=
"identifier">phi
</span><span class=
"special">);
</span>
41 <span class=
"keyword">template
</span> <span class=
"special"><</span><span class=
"keyword">class
</span> <span class=
"identifier">T1
</span><span class=
"special">,
</span> <span class=
"keyword">class
</span> <span class=
"identifier">T2
</span><span class=
"special">,
</span> <span class=
"keyword">class
</span> <a class=
"link" href=
"../../policy.html" title=
"Chapter 15. Policies: Controlling Precision, Error Handling etc">Policy
</a><span class=
"special">></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">ellint_d
</span><span class=
"special">(
</span><span class=
"identifier">T1
</span> <span class=
"identifier">k
</span><span class=
"special">,
</span> <span class=
"identifier">T2
</span> <span class=
"identifier">phi
</span><span class=
"special">,
</span> <span class=
"keyword">const
</span> <a class=
"link" href=
"../../policy.html" title=
"Chapter 15. Policies: Controlling Precision, Error Handling etc">Policy
</a><span class=
"special">&);
</span>
44 <span class=
"keyword">template
</span> <span class=
"special"><</span><span class=
"keyword">class
</span> <span class=
"identifier">T1
</span><span class=
"special">></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">ellint_d
</span><span class=
"special">(
</span><span class=
"identifier">T1
</span> <span class=
"identifier">k
</span><span class=
"special">);
</span>
47 <span class=
"keyword">template
</span> <span class=
"special"><</span><span class=
"keyword">class
</span> <span class=
"identifier">T1
</span><span class=
"special">,
</span> <span class=
"keyword">class
</span> <a class=
"link" href=
"../../policy.html" title=
"Chapter 15. Policies: Controlling Precision, Error Handling etc">Policy
</a><span class=
"special">></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">ellint_d
</span><span class=
"special">(
</span><span class=
"identifier">T1
</span> <span class=
"identifier">k
</span><span class=
"special">,
</span> <span class=
"keyword">const
</span> <a class=
"link" href=
"../../policy.html" title=
"Chapter 15. Policies: Controlling Precision, Error Handling etc">Policy
</a><span class=
"special">&);
</span>
50 <span class=
"special">}}
</span> <span class=
"comment">// namespaces
</span>
53 <a name=
"math_toolkit.ellint.ellint_d.h1"></a>
54 <span class=
"phrase"><a name=
"math_toolkit.ellint.ellint_d.description"></a></span><a class=
"link" href=
"ellint_d.html#math_toolkit.ellint.ellint_d.description">Description
</a>
57 These two functions evaluate the incomplete elliptic integral
<span class=
"emphasis"><em>D(
φ,
58 k)
</em></span> and its complete counterpart
<span class=
"emphasis"><em>D(k) = D(
π/
2, k)
</em></span>.
61 The return type of these functions is computed using the __arg_pomotion_rules
62 when the arguments are of different types: when they are the same type then
63 the result is the same type as the arguments.
65 <pre class=
"programlisting"><span class=
"keyword">template
</span> <span class=
"special"><</span><span class=
"keyword">class
</span> <span class=
"identifier">T1
</span><span class=
"special">,
</span> <span class=
"keyword">class
</span> <span class=
"identifier">T2
</span><span class=
"special">></span>
66 <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">ellint_d
</span><span class=
"special">(
</span><span class=
"identifier">T1
</span> <span class=
"identifier">k
</span><span class=
"special">,
</span> <span class=
"identifier">T2
</span> <span class=
"identifier">phi
</span><span class=
"special">);
</span>
68 <span class=
"keyword">template
</span> <span class=
"special"><</span><span class=
"keyword">class
</span> <span class=
"identifier">T1
</span><span class=
"special">,
</span> <span class=
"keyword">class
</span> <span class=
"identifier">T2
</span><span class=
"special">,
</span> <span class=
"keyword">class
</span> <a class=
"link" href=
"../../policy.html" title=
"Chapter 15. Policies: Controlling Precision, Error Handling etc">Policy
</a><span class=
"special">></span>
69 <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">ellint_3
</span><span class=
"special">(
</span><span class=
"identifier">T1
</span> <span class=
"identifier">k
</span><span class=
"special">,
</span> <span class=
"identifier">T2
</span> <span class=
"identifier">phi
</span><span class=
"special">,
</span> <span class=
"keyword">const
</span> <a class=
"link" href=
"../../policy.html" title=
"Chapter 15. Policies: Controlling Precision, Error Handling etc">Policy
</a><span class=
"special">&);
</span>
72 Returns the incomplete elliptic integral:
75 <span class=
"inlinemediaobject"><img src=
"../../../equations/ellint_d.svg"></span>
78 Requires
<span class=
"emphasis"><em>-
1 <= k
<=
1</em></span>, otherwise returns the result
79 of
<a class=
"link" href=
"../error_handling.html#math_toolkit.error_handling.domain_error">domain_error
</a>
80 (outside this range the result would be complex).
83 The final
<a class=
"link" href=
"../../policy.html" title=
"Chapter 15. Policies: Controlling Precision, Error Handling etc">Policy
</a> argument is optional and can
84 be used to control the behaviour of the function: how it handles errors,
85 what level of precision to use etc. Refer to the
<a class=
"link" href=
"../../policy.html" title=
"Chapter 15. Policies: Controlling Precision, Error Handling etc">policy
86 documentation for more details
</a>.
88 <pre class=
"programlisting"><span class=
"keyword">template
</span> <span class=
"special"><</span><span class=
"keyword">class
</span> <span class=
"identifier">T1
</span><span class=
"special">></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">ellint_d
</span><span class=
"special">(
</span><span class=
"identifier">T1
</span> <span class=
"identifier">k
</span><span class=
"special">);
</span>
91 <span class=
"keyword">template
</span> <span class=
"special"><</span><span class=
"keyword">class
</span> <span class=
"identifier">T1
</span><span class=
"special">,
</span> <span class=
"keyword">class
</span> <a class=
"link" href=
"../../policy.html" title=
"Chapter 15. Policies: Controlling Precision, Error Handling etc">Policy
</a><span class=
"special">></span>
92 <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">ellint_d
</span><span class=
"special">(
</span><span class=
"identifier">T1
</span> <span class=
"identifier">k
</span><span class=
"special">,
</span> <span class=
"keyword">const
</span> <a class=
"link" href=
"../../policy.html" title=
"Chapter 15. Policies: Controlling Precision, Error Handling etc">Policy
</a><span class=
"special">&);
</span>
95 Returns the complete elliptic integral
<span class=
"emphasis"><em>D(k) = D(
π/
2, k)
</em></span>
98 Requires
<span class=
"emphasis"><em>-
1 <= k
<=
1</em></span> otherwise returns the result
99 of
<a class=
"link" href=
"../error_handling.html#math_toolkit.error_handling.domain_error">domain_error
</a>
100 (outside this range the result would be complex).
103 The final
<a class=
"link" href=
"../../policy.html" title=
"Chapter 15. Policies: Controlling Precision, Error Handling etc">Policy
</a> argument is optional and can
104 be used to control the behaviour of the function: how it handles errors,
105 what level of precision to use etc. Refer to the
<a class=
"link" href=
"../../policy.html" title=
"Chapter 15. Policies: Controlling Precision, Error Handling etc">policy
106 documentation for more details
</a>.
109 <a name=
"math_toolkit.ellint.ellint_d.h2"></a>
110 <span class=
"phrase"><a name=
"math_toolkit.ellint.ellint_d.accuracy"></a></span><a class=
"link" href=
"ellint_d.html#math_toolkit.ellint.ellint_d.accuracy">Accuracy
</a>
113 These functions are trivially computed in terms of other elliptic integrals
114 and generally have very low error rates (a few epsilon) unless parameter
116 is very large, in which case the usual trigonometric function argument-reduction
120 <a name=
"math_toolkit.ellint.ellint_d.table_ellint_d_complete_"></a><p class=
"title"><b>Table
 6.66.
 Error rates for ellint_d (complete)
</b></p>
121 <div class=
"table-contents"><table class=
"table" summary=
"Error rates for ellint_d (complete)">
134 Microsoft Visual C++ version
12.0<br> Win32
<br> double
139 GNU C++ version
5.1.0<br> linux
<br> double
144 GNU C++ version
5.1.0<br> linux
<br> long double
149 Sun compiler version
0x5130<br> Sun Solaris
<br> long double
157 Elliptic Integral E: Mathworld Data
162 <span class=
"blue">Max =
0.637ε (Mean =
0.368ε)
</span>
167 <span class=
"blue">Max =
0.637ε (Mean =
0.368ε)
</span>
172 <span class=
"blue">Max =
1.27ε (Mean =
0.735ε)
</span>
177 <span class=
"blue">Max =
1.27ε (Mean =
0.735ε)
</span>
184 Elliptic Integral D: Random Data
189 <span class=
"blue">Max =
1.27ε (Mean =
0.355ε)
</span>
194 <span class=
"blue">Max =
0ε (Mean =
0ε)
</span>
199 <span class=
"blue">Max =
1.27ε (Mean =
0.334ε)
</span>
204 <span class=
"blue">Max =
1.27ε (Mean =
0.334ε)
</span>
211 <br class=
"table-break"><div class=
"table">
212 <a name=
"math_toolkit.ellint.ellint_d.table_ellint_d"></a><p class=
"title"><b>Table
 6.67.
 Error rates for ellint_d
</b></p>
213 <div class=
"table-contents"><table class=
"table" summary=
"Error rates for ellint_d">
226 Microsoft Visual C++ version
12.0<br> Win32
<br> double
231 GNU C++ version
5.1.0<br> linux
<br> double
236 GNU C++ version
5.1.0<br> linux
<br> long double
241 Sun compiler version
0x5130<br> Sun Solaris
<br> long double
249 Elliptic Integral E: Mathworld Data
254 <span class=
"blue">Max =
0.862ε (Mean =
0.457ε)
</span>
259 <span class=
"blue">Max =
0ε (Mean =
0ε)
</span><br> <br> (
<span class=
"emphasis"><em>GSL
260 1.16:
</em></span> Max =
0.862ε (Mean =
0.568ε))
265 <span class=
"blue">Max =
1.3ε (Mean =
0.813ε)
</span>
270 <span class=
"blue">Max =
1.3ε (Mean =
0.813ε)
</span>
277 Elliptic Integral D: Random Data
282 <span class=
"blue">Max =
2.87ε (Mean =
0.805ε)
</span>
287 <span class=
"blue">Max =
0ε (Mean =
0ε)
</span><br> <br> (
<span class=
"emphasis"><em>GSL
288 1.16:
</em></span> Max =
3.01ε (Mean =
0.928ε))
293 <span class=
"blue">Max =
2.51ε (Mean =
0.883ε)
</span>
298 <span class=
"blue">Max =
2.51ε (Mean =
0.883ε)
</span>
305 <br class=
"table-break"><h5>
306 <a name=
"math_toolkit.ellint.ellint_d.h3"></a>
307 <span class=
"phrase"><a name=
"math_toolkit.ellint.ellint_d.testing"></a></span><a class=
"link" href=
"ellint_d.html#math_toolkit.ellint.ellint_d.testing">Testing
</a>
310 The tests use a mixture of spot test values calculated using values calculated
311 at wolframalpha.com, and random test data generated using MPFR at
1000-bit
312 precision and a deliberately naive implementation in terms of the Legendre
316 <a name=
"math_toolkit.ellint.ellint_d.h4"></a>
317 <span class=
"phrase"><a name=
"math_toolkit.ellint.ellint_d.implementation"></a></span><a class=
"link" href=
"ellint_d.html#math_toolkit.ellint.ellint_d.implementation">Implementation
</a>
320 The implementation for D(
φ, k) first performs argument reduction using the
324 <span class=
"emphasis"><em>D(-
φ, k) = -D(
φ, k)
</em></span>
330 <span class=
"emphasis"><em>D(n
π+
φ, k) =
2nD(k) + D(
φ, k)
</em></span>
333 to move
φ   to the range [
0,
π/
2].
336 The functions are then implemented in terms of Carlson's integral R
<sub>D
</sub>
341 <span class=
"inlinemediaobject"><img src=
"../../../equations/ellint_d.svg"></span>
344 <table xmlns:
rev=
"http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width=
"100%"><tr>
345 <td align=
"left"></td>
346 <td align=
"right"><div class=
"copyright-footer">Copyright
© 2006-
2010,
2012-
2014 Nikhar Agrawal,
347 Anton Bikineev, Paul A. Bristow, Marco Guazzone, Christopher Kormanyos, Hubert
348 Holin, Bruno Lalande, John Maddock, Jeremy Murphy, Johan R
åde, Gautam Sewani,
349 Benjamin Sobotta, Thijs van den Berg, Daryle Walker and Xiaogang Zhang
<p>
350 Distributed under the Boost Software License, Version
1.0. (See accompanying
351 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>)
356 <div class=
"spirit-nav">
357 <a accesskey=
"p" href=
"ellint_3.html"><img src=
"../../../../../../doc/src/images/prev.png" alt=
"Prev"></a><a accesskey=
"u" href=
"../ellint.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=
"jacobi_zeta.html"><img src=
"../../../../../../doc/src/images/next.png" alt=
"Next"></a>