mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-25 10:00:23 -04:00 
			
		
		
		
	
		
			
	
	
		
			160 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
		
		
			
		
	
	
			160 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
|  | [section:laguerre Laguerre (and Associated) Polynomials] | ||
|  | 
 | ||
|  | [h4 Synopsis] | ||
|  | 
 | ||
|  | `` | ||
|  | #include <boost/math/special_functions/laguerre.hpp> | ||
|  | `` | ||
|  | 
 | ||
|  |    namespace boost{ namespace math{ | ||
|  |     | ||
|  |    template <class T> | ||
|  |    ``__sf_result`` laguerre(unsigned n, T x); | ||
|  |     | ||
|  |    template <class T, class ``__Policy``> | ||
|  |    ``__sf_result`` laguerre(unsigned n, T x, const ``__Policy``&); | ||
|  |     | ||
|  |    template <class T> | ||
|  |    ``__sf_result`` laguerre(unsigned n, unsigned m, T x); | ||
|  |     | ||
|  |    template <class T, class ``__Policy``> | ||
|  |    ``__sf_result`` laguerre(unsigned n, unsigned m, T x, const ``__Policy``&); | ||
|  |     | ||
|  |    template <class T1, class T2, class T3> | ||
|  |    ``__sf_result`` laguerre_next(unsigned n, T1 x, T2 Ln, T3 Lnm1); | ||
|  |     | ||
|  |    template <class T1, class T2, class T3> | ||
|  |    ``__sf_result`` laguerre_next(unsigned n, unsigned m, T1 x, T2 Ln, T3 Lnm1); | ||
|  | 
 | ||
|  |     | ||
|  |    }} // namespaces | ||
|  |     | ||
|  | [h4 Description] | ||
|  | 
 | ||
|  | The return type of these functions is computed using the __arg_promotion_rules: | ||
|  | note than when there is a single template argument the result is the same type  | ||
|  | as that argument or `double` if the template argument is an integer type. | ||
|  | 
 | ||
|  | [optional_policy] | ||
|  | 
 | ||
|  |    template <class T> | ||
|  |    ``__sf_result`` laguerre(unsigned n, T x); | ||
|  |     | ||
|  |    template <class T, class ``__Policy``> | ||
|  |    ``__sf_result`` laguerre(unsigned n, T x, const ``__Policy``&); | ||
|  |     | ||
|  | Returns the value of the Laguerre Polynomial of order /n/ at point /x/: | ||
|  | 
 | ||
|  | [equation laguerre_0] | ||
|  | 
 | ||
|  | The following graph illustrates the behaviour of the first few  | ||
|  | Laguerre Polynomials: | ||
|  | 
 | ||
|  | [graph laguerre] | ||
|  |     | ||
|  |    template <class T> | ||
|  |    ``__sf_result`` laguerre(unsigned n, unsigned m, T x); | ||
|  |     | ||
|  |    template <class T, class ``__Policy``> | ||
|  |    ``__sf_result`` laguerre(unsigned n, unsigned m, T x, const ``__Policy``&); | ||
|  |     | ||
|  | Returns the Associated Laguerre polynomial of degree /n/  | ||
|  | and order /m/ at point /x/: | ||
|  | 
 | ||
|  | [equation laguerre_1] | ||
|  |     | ||
|  |    template <class T1, class T2, class T3> | ||
|  |    ``__sf_result`` laguerre_next(unsigned n, T1 x, T2 Ln, T3 Lnm1); | ||
|  |     | ||
|  | Implements the three term recurrence relation for the Laguerre | ||
|  | polynomials, this function can be used to create a sequence of | ||
|  | values evaluated at the same /x/, and for rising /n/. | ||
|  | 
 | ||
|  | [equation laguerre_2] | ||
|  | 
 | ||
|  | For example we could produce a vector of the first 10 polynomial | ||
|  | values using: | ||
|  | 
 | ||
|  |    double x = 0.5;  // Abscissa value | ||
|  |    vector<double> v; | ||
|  |    v.push_back(laguerre(0, x)).push_back(laguerre(1, x)); | ||
|  |    for(unsigned l = 1; l < 10; ++l) | ||
|  |       v.push_back(laguerre_next(l, x, v[l], v[l-1])); | ||
|  |        | ||
|  | Formally the arguments are: | ||
|  | 
 | ||
|  | [variablelist | ||
|  | [[n][The degree /n/ of the last polynomial calculated.]] | ||
|  | [[x][The abscissa value]] | ||
|  | [[Ln][The value of the polynomial evaluated at degree /n/.]] | ||
|  | [[Lnm1][The value of the polynomial evaluated at degree /n-1/.]] | ||
|  | ] | ||
|  |     | ||
|  |    template <class T1, class T2, class T3> | ||
|  |    ``__sf_result`` laguerre_next(unsigned n, unsigned m, T1 x, T2 Ln, T3 Lnm1); | ||
|  | 
 | ||
|  | Implements the three term recurrence relation for the Associated Laguerre | ||
|  | polynomials, this function can be used to create a sequence of | ||
|  | values evaluated at the same /x/, and for rising degree /n/. | ||
|  | 
 | ||
|  | [equation laguerre_3] | ||
|  | 
 | ||
|  | For example we could produce a vector of the first 10 polynomial | ||
|  | values using: | ||
|  | 
 | ||
|  |    double x = 0.5;  // Abscissa value | ||
|  |    int m = 10;      // order | ||
|  |    vector<double> v; | ||
|  |    v.push_back(laguerre(0, m, x)).push_back(laguerre(1, m, x)); | ||
|  |    for(unsigned l = 1; l < 10; ++l) | ||
|  |       v.push_back(laguerre_next(l, m, x, v[l], v[l-1])); | ||
|  |        | ||
|  | Formally the arguments are: | ||
|  | 
 | ||
|  | [variablelist | ||
|  | [[n][The degree of the last polynomial calculated.]] | ||
|  | [[m][The order of the Associated Polynomial.]] | ||
|  | [[x][The abscissa value.]] | ||
|  | [[Ln][The value of the polynomial evaluated at degree /n/.]] | ||
|  | [[Lnm1][The value of the polynomial evaluated at degree /n-1/.]] | ||
|  | ] | ||
|  |     | ||
|  | [h4 Accuracy] | ||
|  | 
 | ||
|  | The following table shows peak errors (in units of epsilon)  | ||
|  | for various domains of input arguments.   | ||
|  | Note that only results for the widest floating point type on the system are  | ||
|  | given as narrower types have __zero_error. | ||
|  | 
 | ||
|  | [table_laguerre_n_x_] | ||
|  | 
 | ||
|  | [table_laguerre_n_m_x_] | ||
|  | 
 | ||
|  | Note that the worst errors occur when the degree increases, values greater than | ||
|  | ~120 are very unlikely to produce sensible results, especially in the associated | ||
|  | polynomial case when the order is also large.  Further the relative errors | ||
|  | are likely to grow arbitrarily large when the function is very close to a root. | ||
|  | 
 | ||
|  | [h4 Testing] | ||
|  | 
 | ||
|  | A mixture of spot tests of values calculated using functions.wolfram.com,  | ||
|  | and randomly generated test data are | ||
|  | used: the test data was computed using | ||
|  | [@http://shoup.net/ntl/doc/RR.txt NTL::RR] at 1000-bit precision. | ||
|  | 
 | ||
|  | [h4 Implementation] | ||
|  | 
 | ||
|  | These functions are implemented using the stable three term | ||
|  | recurrence relations.  These relations guarantee low absolute error | ||
|  | but cannot guarantee low relative error near one of the roots of the | ||
|  | polynomials. | ||
|  | 
 | ||
|  | [endsect][/section:beta_function The Beta Function] | ||
|  | [/  | ||
|  |   Copyright 2006 John Maddock and Paul A. Bristow. | ||
|  |   Distributed under the Boost Software License, Version 1.0. | ||
|  |   (See accompanying file LICENSE_1_0.txt or copy at | ||
|  |   http://www.boost.org/LICENSE_1_0.txt). | ||
|  | ] | ||
|  | 
 |