summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorbkoz <bkoz@138bc75d-0d04-0410-961f-82ee72b054a4>2007-03-16 10:35:16 +0000
committerbkoz <bkoz@138bc75d-0d04-0410-961f-82ee72b054a4>2007-03-16 10:35:16 +0000
commitb34f60accb416680ed11789c89296e3c68ed68f1 (patch)
treedecac71c7af454edb119868a1763aff3b7c70e56
parent15ec875c733b473953eae3637f13665dffb0589b (diff)
downloadgcc-b34f60accb416680ed11789c89296e3c68ed68f1.tar.gz
2007-03-16 Benjamin Kosnik <bkoz@redhat.com>
* testsuite/lib/dg-options.exp (dg-require-c-std): New. * testsuite/lib/libstdc++.exp (check_v3_target_c_std): New. Check to see if _GLIBCXX_USE_C99_MATH is active. * testsuite/tr1/5_numerical_facilities/special_functions/ 08_cyl_bessel_i/check_nan.cc: Use dg-require-c-std. * testsuite/tr1/5_numerical_facilities/special_functions/ 17_hyperg/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 13_ellint_2/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 20_riemann_zeta/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 01_assoc_laguerre/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 02_assoc_legendre/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 22_sph_legendre/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 10_cyl_bessel_k/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 09_cyl_bessel_j/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 21_sph_bessel/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 07_conf_hyperg/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 16_hermite/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 12_ellint_1/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 05_comp_ellint_2/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 18_laguerre/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 14_ellint_3/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 04_comp_ellint_1/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 06_comp_ellint_3/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 19_legendre/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 03_beta/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 11_cyl_neumann/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 15_expint/check_nan.cc: Same. * testsuite/tr1/5_numerical_facilities/special_functions/ 23_sph_neumann/check_nan.cc: Same. * include/tr1/poly_laguerre.tcc (__poly_laguerre): Don't check if unsigned int can be a NaN. 2007-03-16 Edward M. Smith-Rowland <3dw4rd@verizon.net> * docs/html/ext/tr1.html : Marked tr1 math special functions done. * docs/html/faq/index.html : Ditto. * include/Makefile.in : Added new special function header files. * include/Makefile.am : Ditto. * include/tr1/common.h : Added type promotion routines for three and four args. * include/tr1/special_function_util.h: New. * include/tr1/bessel_function.tcc: New. * include/tr1/beta_function.tcc: New. * include/tr1/ell_integral.tcc: New. * include/tr1/exp_integral.tcc: New. * include/tr1/gamma.tcc: New. * include/tr1/hypergeometric.tcc: New. * include/tr1/legendre_function.tcc: New. * include/tr1/modified_bessel_func.tcc: New. * include/tr1/poly_hermite.tcc: New. * include/tr1/poly_laguerre.tcc: New. * include/tr1/riemann_zeta.tcc: New. * include/tr1/cmath : Included tr1 math special functions. * include/tr1/math.h : Ditto. * testsuite/tr1/5_numerical_facilities/special_functions/ testcase.h: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 01_assoc_laguerre/compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 01_assoc_laguerre/check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 01_assoc_laguerre/check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 01_assoc_laguerre/compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 02_assoc_legendre/compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 02_assoc_legendre/check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 02_assoc_legendre/check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 02_assoc_legendre/compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/03_beta/ compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/03_beta/ check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/03_beta/ check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/03_beta/ compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 04_comp_ellint_1/compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 04_comp_ellint_1/check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 04_comp_ellint_1/check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 04_comp_ellint_1/compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 05_comp_ellint_2/compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 05_comp_ellint_2/check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 05_comp_ellint_2/check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 05_comp_ellint_2/compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 06_comp_ellint_3/compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 06_comp_ellint_3/check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 06_comp_ellint_3/check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 06_comp_ellint_3/compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 07_conf_hyperg/compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 07_conf_hyperg/check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 07_conf_hyperg/check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 07_conf_hyperg/compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 08_cyl_bessel_i/compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 08_cyl_bessel_i/check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 08_cyl_bessel_i/check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 08_cyl_bessel_i/compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 09_cyl_bessel_j/compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 09_cyl_bessel_j/check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 09_cyl_bessel_j/check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 09_cyl_bessel_j/compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 10_cyl_bessel_k/compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 10_cyl_bessel_k/check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 10_cyl_bessel_k/check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 10_cyl_bessel_k/compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 11_cyl_neumann/compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 11_cyl_neumann/check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 11_cyl_neumann/check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 11_cyl_neumann/compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/ compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/ check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/ check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/ compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/ compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/ check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/ check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/ compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/ compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/ check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/ check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/ compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/15_expint/ check_value_neg.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/15_expint/ compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/15_expint/ check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/15_expint/ compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/15_expint/ check_value_pos.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/ compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/ check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/ compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/ compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/ check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/ check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/ compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/ compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/ check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/ check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/ compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/ compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/ check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/ check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/ compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 20_riemann_zeta/check_value_neg.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 20_riemann_zeta/compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 20_riemann_zeta/check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 20_riemann_zeta/compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 20_riemann_zeta/check_value_pos.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 21_sph_bessel/compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 21_sph_bessel/check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 21_sph_bessel/check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 21_sph_bessel/compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 22_sph_legendre/compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 22_sph_legendre/check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 22_sph_legendre/check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 22_sph_legendre/compile_2.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 23_sph_neumann/compile.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 23_sph_neumann/check_nan.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 23_sph_neumann/check_value.cc: New. * testsuite/tr1/5_numerical_facilities/special_functions/ 23_sph_neumann/ compile_2.cc: New. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@122986 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--libstdc++-v3/ChangeLog276
-rw-r--r--libstdc++-v3/docs/html/ext/tr1.html52
-rw-r--r--libstdc++-v3/docs/html/faq/index.html2
-rw-r--r--libstdc++-v3/include/Makefile.am12
-rw-r--r--libstdc++-v3/include/Makefile.in12
-rw-r--r--libstdc++-v3/include/tr1/bessel_function.tcc641
-rw-r--r--libstdc++-v3/include/tr1/beta_function.tcc211
-rw-r--r--libstdc++-v3/include/tr1/cmath469
-rw-r--r--libstdc++-v3/include/tr1/common.h13
-rw-r--r--libstdc++-v3/include/tr1/ell_integral.tcc762
-rw-r--r--libstdc++-v3/include/tr1/exp_integral.tcc538
-rw-r--r--libstdc++-v3/include/tr1/gamma.tcc486
-rw-r--r--libstdc++-v3/include/tr1/hypergeometric.tcc788
-rw-r--r--libstdc++-v3/include/tr1/legendre_function.tcc318
-rw-r--r--libstdc++-v3/include/tr1/math.h92
-rw-r--r--libstdc++-v3/include/tr1/modified_bessel_func.tcc450
-rw-r--r--libstdc++-v3/include/tr1/poly_hermite.tcc138
-rw-r--r--libstdc++-v3/include/tr1/poly_laguerre.tcc342
-rw-r--r--libstdc++-v3/include/tr1/riemann_zeta.tcc449
-rw-r--r--libstdc++-v3/include/tr1/special_function_util.h155
-rw-r--r--libstdc++-v3/testsuite/lib/dg-options.exp25
-rw-r--r--libstdc++-v3/testsuite/lib/libstdc++.exp61
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/01_assoc_laguerre/check_nan.cc57
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/01_assoc_laguerre/check_value.cc3566
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/01_assoc_laguerre/compile.cc44
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/01_assoc_laguerre/compile_2.cc44
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/02_assoc_legendre/check_nan.cc59
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/02_assoc_legendre/check_value.cc2746
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/02_assoc_legendre/compile.cc44
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/02_assoc_legendre/compile_2.cc44
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/03_beta/check_nan.cc87
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/03_beta/check_value.cc466
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/03_beta/compile.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/03_beta/compile_2.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/04_comp_ellint_1/check_nan.cc57
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/04_comp_ellint_1/check_value.cc97
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/04_comp_ellint_1/compile.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/04_comp_ellint_1/compile_2.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/05_comp_ellint_2/check_nan.cc57
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/05_comp_ellint_2/check_value.cc97
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/05_comp_ellint_2/compile.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/05_comp_ellint_2/compile_2.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/06_comp_ellint_3/check_nan.cc87
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/06_comp_ellint_3/check_value.cc844
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/06_comp_ellint_3/compile.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/06_comp_ellint_3/compile_2.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/07_conf_hyperg/check_nan.cc126
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/07_conf_hyperg/check_value.cc5294
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/07_conf_hyperg/compile.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/07_conf_hyperg/compile_2.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/08_cyl_bessel_i/check_nan.cc87
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/08_cyl_bessel_i/check_value.cc629
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/08_cyl_bessel_i/compile.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/08_cyl_bessel_i/compile_2.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/09_cyl_bessel_j/check_nan.cc87
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/09_cyl_bessel_j/check_value.cc629
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/09_cyl_bessel_j/compile.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/09_cyl_bessel_j/compile_2.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/10_cyl_bessel_k/check_nan.cc87
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/10_cyl_bessel_k/check_value.cc618
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/10_cyl_bessel_k/compile.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/10_cyl_bessel_k/compile_2.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/11_cyl_neumann/check_nan.cc87
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/11_cyl_neumann/check_value.cc618
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/11_cyl_neumann/compile.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/11_cyl_neumann/compile_2.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/check_nan.cc87
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/check_value.cc844
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/compile.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/compile_2.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/check_nan.cc87
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/check_value.cc844
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/compile.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/compile_2.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/check_nan.cc126
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/check_value.cc10116
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/compile.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/compile_2.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/check_nan.cc57
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/check_value_neg.cc128
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/check_value_pos.cc128
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/compile.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/compile_2.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/check_nan.cc59
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/compile.cc44
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/compile_2.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/check_nan.cc173
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/check_value.cc17196
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/compile.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/compile_2.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/check_nan.cc59
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/check_value.cc470
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/compile.cc44
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/compile_2.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/check_nan.cc59
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/check_value.cc470
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/compile.cc44
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/compile_2.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/check_nan.cc57
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/check_value_neg.cc133
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/check_value_pos.cc223
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/compile.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/compile_2.cc42
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/21_sph_bessel/check_nan.cc58
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/21_sph_bessel/check_value.cc470
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/21_sph_bessel/compile.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/21_sph_bessel/compile_2.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/22_sph_legendre/check_nan.cc58
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/22_sph_legendre/check_value.cc2746
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/22_sph_legendre/compile.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/22_sph_legendre/compile_2.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/23_sph_neumann/check_nan.cc58
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/23_sph_neumann/check_value.cc462
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/23_sph_neumann/compile.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/23_sph_neumann/compile_2.cc43
-rw-r--r--libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/testcase.h259
116 files changed, 60128 insertions, 39 deletions
diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog
index e042e395628..22107cd83dc 100644
--- a/libstdc++-v3/ChangeLog
+++ b/libstdc++-v3/ChangeLog
@@ -1,3 +1,270 @@
+2007-03-16 Benjamin Kosnik <bkoz@redhat.com>
+
+ * testsuite/lib/dg-options.exp (dg-require-c-std): New.
+ * testsuite/lib/libstdc++.exp (check_v3_target_c_std): New. Check to
+ see if _GLIBCXX_USE_C99_MATH is active.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 08_cyl_bessel_i/check_nan.cc: Use dg-require-c-std.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 17_hyperg/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 13_ellint_2/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 20_riemann_zeta/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 01_assoc_laguerre/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 02_assoc_legendre/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 22_sph_legendre/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 10_cyl_bessel_k/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 09_cyl_bessel_j/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 21_sph_bessel/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 07_conf_hyperg/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 16_hermite/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 12_ellint_1/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 05_comp_ellint_2/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 18_laguerre/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 14_ellint_3/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 04_comp_ellint_1/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 06_comp_ellint_3/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 19_legendre/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 03_beta/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 11_cyl_neumann/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 15_expint/check_nan.cc: Same.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 23_sph_neumann/check_nan.cc: Same.
+
+ * include/tr1/poly_laguerre.tcc (__poly_laguerre): Don't check if
+ unsigned int can be a NaN.
+
+2007-03-16 Edward M. Smith-Rowland <3dw4rd@verizon.net>
+
+ * docs/html/ext/tr1.html : Marked tr1 math special functions done.
+ * docs/html/faq/index.html : Ditto.
+ * include/Makefile.in : Added new special function header files.
+ * include/Makefile.am : Ditto.
+ * include/tr1/common.h : Added type promotion routines for three
+ and four args.
+
+ * include/tr1/special_function_util.h: New.
+ * include/tr1/bessel_function.tcc: New.
+ * include/tr1/beta_function.tcc: New.
+ * include/tr1/ell_integral.tcc: New.
+ * include/tr1/exp_integral.tcc: New.
+ * include/tr1/gamma.tcc: New.
+ * include/tr1/hypergeometric.tcc: New.
+ * include/tr1/legendre_function.tcc: New.
+ * include/tr1/modified_bessel_func.tcc: New.
+ * include/tr1/poly_hermite.tcc: New.
+ * include/tr1/poly_laguerre.tcc: New.
+ * include/tr1/riemann_zeta.tcc: New.
+ * include/tr1/cmath : Included tr1 math special functions.
+ * include/tr1/math.h : Ditto.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ testcase.h: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 01_assoc_laguerre/compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 01_assoc_laguerre/check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 01_assoc_laguerre/check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 01_assoc_laguerre/compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 02_assoc_legendre/compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 02_assoc_legendre/check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 02_assoc_legendre/check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 02_assoc_legendre/compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/03_beta/
+ compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/03_beta/
+ check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/03_beta/
+ check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/03_beta/
+ compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 04_comp_ellint_1/compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 04_comp_ellint_1/check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 04_comp_ellint_1/check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 04_comp_ellint_1/compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 05_comp_ellint_2/compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 05_comp_ellint_2/check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 05_comp_ellint_2/check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 05_comp_ellint_2/compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 06_comp_ellint_3/compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 06_comp_ellint_3/check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 06_comp_ellint_3/check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 06_comp_ellint_3/compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 07_conf_hyperg/compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 07_conf_hyperg/check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 07_conf_hyperg/check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 07_conf_hyperg/compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 08_cyl_bessel_i/compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 08_cyl_bessel_i/check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 08_cyl_bessel_i/check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 08_cyl_bessel_i/compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 09_cyl_bessel_j/compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 09_cyl_bessel_j/check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 09_cyl_bessel_j/check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 09_cyl_bessel_j/compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 10_cyl_bessel_k/compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 10_cyl_bessel_k/check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 10_cyl_bessel_k/check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 10_cyl_bessel_k/compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 11_cyl_neumann/compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 11_cyl_neumann/check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 11_cyl_neumann/check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 11_cyl_neumann/compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/
+ compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/
+ check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/
+ check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/
+ compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/
+ compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/
+ check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/
+ check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/
+ compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/
+ compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/
+ check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/
+ check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/
+ compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/15_expint/
+ check_value_neg.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/15_expint/
+ compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/15_expint/
+ check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/15_expint/
+ compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/15_expint/
+ check_value_pos.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/
+ compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/
+ check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/
+ compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/
+ compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/
+ check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/
+ check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/
+ compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/
+ compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/
+ check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/
+ check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/
+ compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/
+ compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/
+ check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/
+ check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/
+ compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 20_riemann_zeta/check_value_neg.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 20_riemann_zeta/compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 20_riemann_zeta/check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 20_riemann_zeta/compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 20_riemann_zeta/check_value_pos.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 21_sph_bessel/compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 21_sph_bessel/check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 21_sph_bessel/check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 21_sph_bessel/compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 22_sph_legendre/compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 22_sph_legendre/check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 22_sph_legendre/check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 22_sph_legendre/compile_2.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 23_sph_neumann/compile.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 23_sph_neumann/check_nan.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 23_sph_neumann/check_value.cc: New.
+ * testsuite/tr1/5_numerical_facilities/special_functions/
+ 23_sph_neumann/ compile_2.cc: New.
+
2007-03-15 Hans-Peter Nilsson <hp@axis.com>
* testsuite/lib/libstdc++.exp (v3-build_support) <ar>: If it
@@ -145,9 +412,12 @@
* testsuite/27_io/basic_filebuf/sputn/char/9339.cc: Use it.
* testsuite/27_io/basic_filebuf/pbackfail/char/9761.cc: Use it.
* testsuite/27_io/basic_filebuf/sync/char/9182-1.cc: Use it.
- * testsuite/21_strings/basic_string/inserters_extractors/char/10.cc: Use it.
- * testsuite/21_strings/basic_string/inserters_extractors/char/11.cc: Use it.
- * testsuite/21_strings/basic_string/inserters_extractors/char/5.cc: Use it.
+ * testsuite/21_strings/basic_string/inserters_extractors/
+ char/10.cc: Use it.
+ * testsuite/21_strings/basic_string/inserters_extractors/
+ char/11.cc: Use it.
+ * testsuite/21_strings/basic_string/inserters_extractors/
+ char/5.cc: Use it.
2007-03-13 Paolo Carlini <pcarlini@suse.de>
diff --git a/libstdc++-v3/docs/html/ext/tr1.html b/libstdc++-v3/docs/html/ext/tr1.html
index d8ae3971540..4a021df09a6 100644
--- a/libstdc++-v3/docs/html/ext/tr1.html
+++ b/libstdc++-v3/docs/html/ext/tr1.html
@@ -807,209 +807,209 @@ release.
<tr>
<td>5.2</td>
<td>Mathematical special functions</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1</td>
<td>Additions to header <code>&lt;cmath&gt;</code> synopsis</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.1</td>
<td>associated Laguerre polynomials</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.2</td>
<td>associated Legendre functions</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.3</td>
<td>beta function</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.4</td>
<td>(complete) elliptic integral of the first kind</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.5</td>
<td>(complete) elliptic integral of the second kind</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.6</td>
<td>(complete) elliptic integral of the third kind</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.7</td>
<td>confluent hypergeometric functions</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.8</td>
<td>regular modified cylindrical Bessel functions</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.9</td>
<td>cylindrical Bessel functions (of the first kind)</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.10</td>
<td>irregular modified cylindrical Bessel functions</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.11</td>
<td>cylindrical Neumann functions</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.12</td>
<td>(incomplete) elliptic integral of the first kind</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.13</td>
<td>(incomplete) elliptic integral of the second kind</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.14</td>
<td>(incomplete) elliptic integral of the third kind</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.15</td>
<td>exponential integral</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.16</td>
<td>Hermite polynomials</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.17</td>
<td>hypergeometric functions</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.18</td>
<td>Laguerre polynomials</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.19</td>
<td>Legendre polynomials</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.20</td>
<td>Riemann zeta function</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.21</td>
<td>spherical Bessel functions (of the first kind)</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.22</td>
<td>spherical associated Legendre functions</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.1.23</td>
<td>spherical Neumann functions</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
<td>5.2.2</td>
<td>Additions to header <code>&lt;math.h&gt;</code> synopsis</td>
+ <td>done</td>
<td></td>
<td></td>
- <td>missing</td>
<td></td>
</tr>
<tr>
diff --git a/libstdc++-v3/docs/html/faq/index.html b/libstdc++-v3/docs/html/faq/index.html
index 3c907beff9c..298ae37cdb6 100644
--- a/libstdc++-v3/docs/html/faq/index.html
+++ b/libstdc++-v3/docs/html/faq/index.html
@@ -1047,7 +1047,7 @@ http://clisp.cons.org/~haible/gccinclude-glibc-2.2-compat.diff
and the C++ languages.
</p>
- <p><strong>Special functions - Under construction - </strong>
+ <p><strong>Special functions - Complete - </strong>
Twenty-three mathematical functions familiar to physicists and
engineers are included: cylindrical and spherical Bessel and Neumann
functions, hypergeometric functions, Laguerre polynomials, Legendre
diff --git a/libstdc++-v3/include/Makefile.am b/libstdc++-v3/include/Makefile.am
index 9cc39c16eba..e3ca800a27e 100644
--- a/libstdc++-v3/include/Makefile.am
+++ b/libstdc++-v3/include/Makefile.am
@@ -533,6 +533,8 @@ tr1_srcdir = ${glibcxx_srcdir}/include/tr1
tr1_builddir = ./tr1
tr1_headers = \
${tr1_srcdir}/array \
+ ${tr1_srcdir}/bessel_function.tcc \
+ ${tr1_srcdir}/beta_function.tcc \
${tr1_srcdir}/boost_shared_ptr.h \
${tr1_srcdir}/ccomplex \
${tr1_srcdir}/cctype \
@@ -554,19 +556,29 @@ tr1_headers = \
${tr1_srcdir}/ctype.h \
${tr1_srcdir}/cwchar \
${tr1_srcdir}/cwctype \
+ ${tr1_srcdir}/ell_integral.tcc \
+ ${tr1_srcdir}/exp_integral.tcc \
${tr1_srcdir}/fenv.h \
${tr1_srcdir}/float.h \
${tr1_srcdir}/functional \
${tr1_srcdir}/functional_hash.h \
+ ${tr1_srcdir}/gamma.tcc \
${tr1_srcdir}/hashtable \
+ ${tr1_srcdir}/hypergeometric.tcc \
${tr1_srcdir}/hashtable_policy.h \
${tr1_srcdir}/inttypes.h \
${tr1_srcdir}/limits.h \
${tr1_srcdir}/math.h \
${tr1_srcdir}/memory \
+ ${tr1_srcdir}/modified_bessel_func.tcc \
+ ${tr1_srcdir}/poly_hermite.tcc \
+ ${tr1_srcdir}/poly_laguerre.tcc \
+ ${tr1_srcdir}/legendre_function.tcc \
${tr1_srcdir}/random \
${tr1_srcdir}/random.tcc \
${tr1_srcdir}/regex \
+ ${tr1_srcdir}/riemann_zeta.tcc \
+ ${tr1_srcdir}/special_function_util.h \
${tr1_srcdir}/stdarg.h \
${tr1_srcdir}/stdbool.h \
${tr1_srcdir}/stdint.h \
diff --git a/libstdc++-v3/include/Makefile.in b/libstdc++-v3/include/Makefile.in
index 2f8417a0362..02de25c272f 100644
--- a/libstdc++-v3/include/Makefile.in
+++ b/libstdc++-v3/include/Makefile.in
@@ -763,6 +763,8 @@ tr1_srcdir = ${glibcxx_srcdir}/include/tr1
tr1_builddir = ./tr1
tr1_headers = \
${tr1_srcdir}/array \
+ ${tr1_srcdir}/bessel_function.tcc \
+ ${tr1_srcdir}/beta_function.tcc \
${tr1_srcdir}/boost_shared_ptr.h \
${tr1_srcdir}/ccomplex \
${tr1_srcdir}/cctype \
@@ -784,19 +786,29 @@ tr1_headers = \
${tr1_srcdir}/ctype.h \
${tr1_srcdir}/cwchar \
${tr1_srcdir}/cwctype \
+ ${tr1_srcdir}/ell_integral.tcc \
+ ${tr1_srcdir}/exp_integral.tcc \
${tr1_srcdir}/fenv.h \
${tr1_srcdir}/float.h \
${tr1_srcdir}/functional \
${tr1_srcdir}/functional_hash.h \
+ ${tr1_srcdir}/gamma.tcc \
${tr1_srcdir}/hashtable \
+ ${tr1_srcdir}/hypergeometric.tcc \
${tr1_srcdir}/hashtable_policy.h \
${tr1_srcdir}/inttypes.h \
${tr1_srcdir}/limits.h \
${tr1_srcdir}/math.h \
${tr1_srcdir}/memory \
+ ${tr1_srcdir}/modified_bessel_func.tcc \
+ ${tr1_srcdir}/poly_hermite.tcc \
+ ${tr1_srcdir}/poly_laguerre.tcc \
+ ${tr1_srcdir}/legendre_function.tcc \
${tr1_srcdir}/random \
${tr1_srcdir}/random.tcc \
${tr1_srcdir}/regex \
+ ${tr1_srcdir}/riemann_zeta.tcc \
+ ${tr1_srcdir}/special_function_util.h \
${tr1_srcdir}/stdarg.h \
${tr1_srcdir}/stdbool.h \
${tr1_srcdir}/stdint.h \
diff --git a/libstdc++-v3/include/tr1/bessel_function.tcc b/libstdc++-v3/include/tr1/bessel_function.tcc
new file mode 100644
index 00000000000..68ca9a31703
--- /dev/null
+++ b/libstdc++-v3/include/tr1/bessel_function.tcc
@@ -0,0 +1,641 @@
+// Special functions -*- C++ -*-
+
+// Copyright (C) 2006-2007
+// Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+// USA.
+//
+// As a special exception, you may use this file as part of a free software
+// library without restriction. Specifically, if other files instantiate
+// templates or use macros or inline functions from this file, or you compile
+// this file and link it with other files to produce an executable, this
+// file does not by itself cause the resulting executable to be covered by
+// the GNU General Public License. This exception does not however
+// invalidate any other reasons why the executable file might be covered by
+// the GNU General Public License.
+
+/** @file tr1/bessel_function.tcc
+ * This is an internal header file, included by other library headers.
+ * You should not attempt to use it directly.
+ */
+
+//
+// ISO C++ 14882 TR1: 5.2 Special functions
+//
+
+// Written by Edward Smith-Rowland.
+//
+// References:
+// (1) Handbook of Mathematical Functions,
+// ed. Milton Abramowitz and Irene A. Stegun,
+// Dover Publications,
+// Section 9, pp. 355-434, Section 10 pp. 435-478
+// (2) The Gnu Scientific Library, http://www.gnu.org/software/gsl
+// (3) Numerical Recipes in C, by W. H. Press, S. A. Teukolsky,
+// W. T. Vetterling, B. P. Flannery, Cambridge University Press (1992),
+// 2nd ed, pp. 240-245
+
+#ifndef _TR1_BESSEL_FUNCTION_TCC
+#define _TR1_BESSEL_FUNCTION_TCC 1
+
+#include "special_function_util.h"
+
+namespace std
+{
+_GLIBCXX_BEGIN_NAMESPACE(_GLIBCXX_TR1)
+
+ // [5.2] Special functions
+
+ /**
+ * @ingroup tr1_math_spec_func
+ * @{
+ */
+
+ //
+ // Implementation-space details.
+ //
+ namespace __detail
+ {
+
+ /**
+ * @brief Compute the gamma functions required by the Temme series
+ * expansions of @f$ N_\nu(x) @f$ and @f$ K_\nu(x) @f$.
+ * @f[
+ * \Gamma_1 = \frac{1}{2\mu}
+ * [\frac{1}{\Gamma(1 - \mu)} - \frac{1}{\Gamma(1 + \mu)}]
+ * @f]
+ * and
+ * @f[
+ * \Gamma_2 = \frac{1}{2}
+ * [\frac{1}{\Gamma(1 - \mu)} + \frac{1}{\Gamma(1 + \mu)}]
+ * @f]
+ * where @f$ -1/2 <= \mu <= 1/2 @f$ is @f$ \mu = \nu - N @f$ and @f$ N @f$.
+ * is the nearest integer to @f$ \nu @f$.
+ * The values of \f$ \Gamma(1 + \mu) \f$ and \f$ \Gamma(1 - \mu) \f$
+ * are returned as well.
+ *
+ * The accuracy requirements on this are exquisite.
+ *
+ * @param __mu The input parameter of the gamma functions.
+ * @param __gam1 The output function \f$ \Gamma_1(\mu) \f$
+ * @param __gam2 The output function \f$ \Gamma_2(\mu) \f$
+ * @param __gampl The output function \f$ \Gamma(1 + \mu) \f$
+ * @param __gammi The output function \f$ \Gamma(1 - \mu) \f$
+ */
+ template <typename _Tp>
+ void
+ __gamma_temme(const _Tp __mu,
+ _Tp & __gam1, _Tp & __gam2, _Tp & __gampl, _Tp & __gammi)
+ {
+#if _GLIBCXX_USE_C99_MATH_TR1
+ __gampl = _Tp(1) / std::_GLIBCXX_TR1::tgamma(_Tp(1) + __mu);
+ __gammi = _Tp(1) / std::_GLIBCXX_TR1::tgamma(_Tp(1) - __mu);
+#else
+ __gampl = _Tp(1) / __gamma(_Tp(1) + __mu);
+ __gammi = _Tp(1) / __gamma(_Tp(1) - __mu);
+#endif
+
+ if (std::abs(__mu) < std::numeric_limits<_Tp>::epsilon())
+ __gam1 = -_Tp(__numeric_constants<_Tp>::__gamma_e());
+ else
+ __gam1 = (__gammi - __gampl) / (_Tp(2) * __mu);
+
+ __gam2 = (__gammi + __gampl) / (_Tp(2));
+
+ return;
+ }
+
+
+ /**
+ * @brief Compute the Bessel @f$ J_\nu(x) @f$ and Neumann
+ * @f$ N_\nu(x) @f$ functions and their first derivatives
+ * @f$ J'_\nu(x) @f$ and @f$ N'_\nu(x) @f$ respectively.
+ * These four functions are computed together for numerical
+ * stability.
+ *
+ * @param __nu The order of the Bessel functions.
+ * @param __x The argument of the Bessel functions.
+ * @param __Jnu The output Bessel function of the first kind.
+ * @param __Nnu The output Neumann function (Bessel fuction of the second kind).
+ * @param __Jpnu The output derivative of the Bessel function of the first kind.
+ * @param __Npnu The output derivative of the Neumann function.
+ */
+ template <typename _Tp>
+ void
+ __bessel_jn(const _Tp __nu, const _Tp __x,
+ _Tp & __Jnu, _Tp & __Nnu, _Tp & __Jpnu, _Tp & __Npnu)
+ {
+ if (__x == _Tp(0))
+ {
+ if (__nu == _Tp(0))
+ {
+ __Jnu = _Tp(1);
+ __Jpnu = _Tp(0);
+ }
+ else if (__nu == _Tp(1))
+ {
+ __Jnu = _Tp(0);
+ __Jpnu = _Tp(0.5L);
+ }
+ else
+ {
+ __Jnu = _Tp(0);
+ __Jpnu = _Tp(0);
+ }
+ __Nnu = -std::numeric_limits<_Tp>::infinity();
+ __Npnu = std::numeric_limits<_Tp>::infinity();
+ return;
+ }
+
+ const _Tp __eps = std::numeric_limits<_Tp>::epsilon();
+ // When the multiplier is N i.e.
+ // fp_min = N * min()
+ // Then J_0 and N_0 tank at x = 8 * N (J_0 = 0 and N_0 = nan)!
+ //const _Tp __fp_min = _Tp(20) * std::numeric_limits<_Tp>::min();
+ const _Tp __fp_min = std::sqrt(std::numeric_limits<_Tp>::min());
+ const int __max_iter = 15000;
+ const _Tp __x_min = _Tp(2);
+
+ const int __nl = (__x < __x_min
+ ? static_cast<int>(__nu + _Tp(0.5L))
+ : std::max(0, static_cast<int>(__nu - __x + _Tp(1.5L))));
+
+ const _Tp __mu = __nu - __nl;
+ const _Tp __mu2 = __mu * __mu;
+ const _Tp __xi = _Tp(1) / __x;
+ const _Tp __xi2 = _Tp(2) * __xi;
+ _Tp __w = __xi2 / __numeric_constants<_Tp>::__pi();
+ int __isign = 1;
+ _Tp __h = __nu * __xi;
+ if (__h < __fp_min)
+ __h = __fp_min;
+ _Tp __b = __xi2 * __nu;
+ _Tp __d = _Tp(0);
+ _Tp __c = __h;
+ int __i;
+ for (__i = 1; __i <= __max_iter; ++__i)
+ {
+ __b += __xi2;
+ __d = __b - __d;
+ if (std::abs(__d) < __fp_min)
+ __d = __fp_min;
+ __c = __b - _Tp(1) / __c;
+ if (std::abs(__c) < __fp_min)
+ __c = __fp_min;
+ __d = _Tp(1) / __d;
+ const _Tp __del = __c * __d;
+ __h *= __del;
+ if (__d < _Tp(0))
+ __isign = -__isign;
+ if (std::abs(__del - _Tp(1)) < __eps)
+ break;
+ }
+ if (__i > __max_iter)
+ std::__throw_runtime_error(__N("Argument x too large in __bessel_jn; "
+ "try asymptotic expansion."));
+ _Tp __Jnul = __isign * __fp_min;
+ _Tp __Jpnul = __h * __Jnul;
+ _Tp __Jnul1 = __Jnul;
+ _Tp __Jpnu1 = __Jpnul;
+ _Tp __fact = __nu * __xi;
+ for ( int __l = __nl; __l >= 1; --__l )
+ {
+ const _Tp __Jnutemp = __fact * __Jnul + __Jpnul;
+ __fact -= __xi;
+ __Jpnul = __fact * __Jnutemp - __Jnul;
+ __Jnul = __Jnutemp;
+ }
+ if (__Jnul == _Tp(0))
+ __Jnul = __eps;
+ _Tp __f= __Jpnul / __Jnul;
+ _Tp __Nmu, __Nnu1, __Npmu, __Jmu;
+ if (__x < __x_min)
+ {
+ const _Tp __x2 = __x / _Tp(2);
+ const _Tp __pimu = __numeric_constants<_Tp>::__pi() * __mu;
+ _Tp __fact = (std::abs(__pimu) < __eps
+ ? _Tp(1) : __pimu / std::sin(__pimu));
+ _Tp __d = -std::log(__x2);
+ _Tp __e = __mu * __d;
+ _Tp __fact2 = (std::abs(__e) < __eps
+ ? _Tp(1) : std::sinh(__e) / __e);
+ _Tp __gam1, __gam2, __gampl, __gammi;
+ __gamma_temme(__mu, __gam1, __gam2, __gampl, __gammi);
+ _Tp __ff = (_Tp(2) / __numeric_constants<_Tp>::__pi())
+ * __fact * (__gam1 * std::cosh(__e) + __gam2 * __fact2 * __d);
+ __e = std::exp(__e);
+ _Tp __p = __e / (__numeric_constants<_Tp>::__pi() * __gampl);
+ _Tp __q = _Tp(1) / (__e * __numeric_constants<_Tp>::__pi() * __gammi);
+ const _Tp __pimu2 = __pimu / _Tp(2);
+ _Tp __fact3 = (std::abs(__pimu2) < __eps
+ ? _Tp(1) : std::sin(__pimu2) / __pimu2 );
+ _Tp __r = __numeric_constants<_Tp>::__pi() * __pimu2 * __fact3 * __fact3;
+ _Tp __c = _Tp(1);
+ __d = -__x2 * __x2;
+ _Tp __sum = __ff + __r * __q;
+ _Tp __sum1 = __p;
+ for (__i = 1; __i <= __max_iter; ++__i)
+ {
+ __ff = (__i * __ff + __p + __q) / (__i * __i - __mu2);
+ __c *= __d / _Tp(__i);
+ __p /= _Tp(__i) - __mu;
+ __q /= _Tp(__i) + __mu;
+ const _Tp __del = __c * (__ff + __r * __q);
+ __sum += __del;
+ const _Tp __del1 = __c * __p - __i * __del;
+ __sum1 += __del1;
+ if ( std::abs(__del) < __eps * (_Tp(1) + std::abs(__sum)) )
+ break;
+ }
+ if ( __i > __max_iter )
+ std::__throw_runtime_error(__N("Bessel y series failed to converge "
+ "in __bessel_jn."));
+ __Nmu = -__sum;
+ __Nnu1 = -__sum1 * __xi2;
+ __Npmu = __mu * __xi * __Nmu - __Nnu1;
+ __Jmu = __w / (__Npmu - __f * __Nmu);
+ }
+ else
+ {
+ _Tp __a = _Tp(0.25L) - __mu2;
+ _Tp __q = _Tp(1);
+ _Tp __p = -__xi / _Tp(2);
+ _Tp __br = _Tp(2) * __x;
+ _Tp __bi = _Tp(2);
+ _Tp __fact = __a * __xi / (__p * __p + __q * __q);
+ _Tp __cr = __br + __q * __fact;
+ _Tp __ci = __bi + __p * __fact;
+ _Tp __den = __br * __br + __bi * __bi;
+ _Tp __dr = __br / __den;
+ _Tp __di = -__bi / __den;
+ _Tp __dlr = __cr * __dr - __ci * __di;
+ _Tp __dli = __cr * __di + __ci * __dr;
+ _Tp __temp = __p * __dlr - __q * __dli;
+ __q = __p * __dli + __q * __dlr;
+ __p = __temp;
+ int __i;
+ for (__i = 2; __i <= __max_iter; ++__i)
+ {
+ __a += _Tp(2 * (__i - 1));
+ __bi += _Tp(2);
+ __dr = __a * __dr + __br;
+ __di = __a * __di + __bi;
+ if (std::abs(__dr) + std::abs(__di) < __fp_min)
+ __dr = __fp_min;
+ __fact = __a / (__cr * __cr + __ci * __ci);
+ __cr = __br + __cr * __fact;
+ __ci = __bi - __ci * __fact;
+ if (std::abs(__cr) + std::abs(__ci) < __fp_min)
+ __cr = __fp_min;
+ __den = __dr * __dr + __di * __di;
+ __dr /= __den;
+ __di /= -__den;
+ __dlr = __cr * __dr - __ci * __di;
+ __dli = __cr * __di + __ci * __dr;
+ __temp = __p * __dlr - __q * __dli;
+ __q = __p * __dli + __q * __dlr;
+ __p = __temp;
+ if (std::abs(__dlr - _Tp(1)) + std::abs(__dli) < __eps)
+ break;
+ }
+ if (__i > __max_iter)
+ std::__throw_runtime_error(__N("Lentz's method failed "
+ "in __bessel_jn."));
+ const _Tp __gam = (__p - __f) / __q;
+ __Jmu = std::sqrt(__w / ((__p - __f) * __gam + __q));
+#if _GLIBCXX_USE_C99_MATH_TR1
+ __Jmu = std::_GLIBCXX_TR1::copysign(__Jmu, __Jnul);
+#else
+ if (__Jmu * __Jnul < _Tp(0))
+ __Jmu = -__Jmu;
+#endif
+ __Nmu = __gam * __Jmu;
+ __Npmu = (__p + __q / __gam) * __Nmu;
+ __Nnu1 = __mu * __xi * __Nmu - __Npmu;
+ }
+ __fact = __Jmu / __Jnul;
+ __Jnu = __fact * __Jnul1;
+ __Jpnu = __fact * __Jpnu1;
+ for (__i = 1; __i <= __nl; ++__i)
+ {
+ const _Tp __Nnutemp = (__mu + __i) * __xi2 * __Nnu1 - __Nmu;
+ __Nmu = __Nnu1;
+ __Nnu1 = __Nnutemp;
+ }
+ __Nnu = __Nmu;
+ __Npnu = __nu * __xi * __Nmu - __Nnu1;
+
+ return;
+ }
+
+
+ /**
+ * @brief This routine computes the asyptotic cylindrical Bessel
+ * and Neumann functions of order nu: \f$ J_{\nu} \f$,
+ * \f$ N_{\nu} \f$.
+ *
+ * References:
+ * (1) Handbook of Mathematical Functions,
+ * ed. Milton Abramowitz and Irene A. Stegun,
+ * Dover Publications,
+ * Section 9 p. 364, Equations 9.2.5-9.2.10
+ *
+ * @param __nu The order of the Bessel functions.
+ * @param __x The argument of the Bessel functions.
+ * @param __Jnu The output Bessel function of the first kind.
+ * @param __Nnu The output Neumann function (Bessel fuction of the second kind).
+ */
+ template <typename _Tp>
+ void
+ __cyl_bessel_jn_asymp(const _Tp __nu, const _Tp __x,
+ _Tp & __Jnu, _Tp & __Nnu)
+ {
+ const _Tp __coef = std::sqrt(_Tp(2)
+ / (__numeric_constants<_Tp>::__pi() * __x));
+ const _Tp __mu = _Tp(4) * __nu * __nu;
+ const _Tp __mum1 = __mu - _Tp(1);
+ const _Tp __mum9 = __mu - _Tp(9);
+ const _Tp __mum25 = __mu - _Tp(25);
+ const _Tp __mum49 = __mu - _Tp(49);
+ const _Tp __xx = _Tp(64) * __x * __x;
+ const _Tp __P = _Tp(1) - __mum1 * __mum9 / (_Tp(2) * __xx)
+ * (_Tp(1) - __mum25 * __mum49 / (_Tp(12) * __xx));
+ const _Tp __Q = __mum1 / (_Tp(8) * __x)
+ * (_Tp(1) - __mum9 * __mum25 / (_Tp(6) * __xx));
+
+ const _Tp __chi = __x - (__nu + _Tp(0.5L))
+ * __numeric_constants<_Tp>::__pi_2();
+ const _Tp __c = std::cos(__chi);
+ const _Tp __s = std::sin(__chi);
+
+ __Jnu = __coef * (__c * __P - __s * __Q);
+ __Nnu = __coef * (__s * __P + __c * __Q);
+
+ return;
+ }
+
+
+ /**
+ * @brief This routine returns the cylindrical Bessel functions
+ * of order \f$ \nu \f$: \f$ J_{\nu} \f$ or \f$ I_{\nu} \f$
+ * by series expansion.
+ *
+ * The modified cylindrical Bessel function is:
+ * @f[
+ * Z_{\nu}(x) = \sum_{k=0}^{\infty}
+ * \frac{\sigma^k (x/2)^{\nu + 2k}}{k!\Gamma(\nu+k+1)}
+ * @f]
+ * where \f$ \sigma = +1 \f$ or\f$ -1 \f$ for
+ * \f$ Z = I \f$ or \f$ J \f$ respecively.
+ *
+ * See Abramowitz & Stegun, 9.1.10
+ * Abramowitz & Stegun, 9.6.7
+ * (1) Handbook of Mathematical Functions,
+ * ed. Milton Abramowitz and Irene A. Stegun,
+ * Dover Publications,
+ * Equation 9.1.10 p. 360 and Equation 9.6.10 p. 375
+ *
+ * @param __nu The order of the Bessel function.
+ * @param __x The argument of the Bessel function.
+ * @param __sgn The sign of the alternate terms
+ * -1 for the Bessel function of the first kind.
+ * +1 for the modified Bessel function of the first kind.
+ * @return The output Bessel function.
+ */
+ template <typename _Tp>
+ _Tp
+ __cyl_bessel_ij_series(const _Tp __nu, const _Tp __x, const _Tp __sgn,
+ const unsigned int __max_iter)
+ {
+
+ const _Tp __x2 = __x / _Tp(2);
+ _Tp __fact = __nu * std::log(__x2);
+#if _GLIBCXX_USE_C99_MATH_TR1
+ __fact -= std::_GLIBCXX_TR1::lgamma(__nu + _Tp(1));
+#else
+ __fact -= __log_gamma(__nu + _Tp(1));
+#endif
+ __fact = std::exp(__fact);
+ const _Tp __xx4 = __sgn * __x2 * __x2;
+ _Tp __Jn = _Tp(1);
+ _Tp __term = _Tp(1);
+
+ for (unsigned int __i = 1; __i < __max_iter; ++__i)
+ {
+ __term *= __xx4 / (_Tp(__i) * (__nu + _Tp(__i)));
+ __Jn += __term;
+ if (std::abs(__term / __Jn) < std::numeric_limits<_Tp>::epsilon())
+ break;
+ }
+
+ return __fact * __Jn;
+ }
+
+
+ /**
+ * @brief Return the Bessel function of order \f$ \nu \f$:
+ * \f$ J_{\nu}(x) \f$.
+ *
+ * The cylindrical Bessel function is:
+ * @f[
+ * J_{\nu}(x) = \sum_{k=0}^{\infty}
+ * \frac{(-1)^k (x/2)^{\nu + 2k}}{k!\Gamma(\nu+k+1)}
+ * @f]
+ *
+ * @param __nu The order of the Bessel function.
+ * @param __x The argument of the Bessel function.
+ * @return The output Bessel function.
+ */
+ template<typename _Tp>
+ _Tp
+ __cyl_bessel_j(const _Tp __nu, const _Tp __x)
+ {
+ if (__nu < _Tp(0) || __x < _Tp(0))
+ std::__throw_domain_error(__N("Bad argument "
+ "in __cyl_bessel_j."));
+ else if (__isnan(__nu) || __isnan(__x))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (__x * __x < _Tp(10) * (__nu + _Tp(1)))
+ return __cyl_bessel_ij_series(__nu, __x, -_Tp(1), 200);
+ else if (__x > _Tp(1000))
+ {
+ _Tp __J_nu, __N_nu;
+ __cyl_bessel_jn_asymp(__nu, __x, __J_nu, __N_nu);
+ return __J_nu;
+ }
+ else
+ {
+ _Tp __J_nu, __N_nu, __Jp_nu, __Np_nu;
+ __bessel_jn(__nu, __x, __J_nu, __N_nu, __Jp_nu, __Np_nu);
+ return __J_nu;
+ }
+ }
+
+
+ /**
+ * @brief Return the Neunamm function of order \f$ \nu \f$:
+ * \f$ N_{\nu}(x) \f$.
+ *
+ * The Neumann function is defined by:
+ * @f[
+ * N_{\nu}(x) = \frac{J_{\nu}(x) \cos \nu\pi - J_{-\nu}(x)}
+ * {\sin \nu\pi}
+ * @f]
+ * where for integral \f$ \nu = n \f$ a limit is taken:
+ * \f$ lim_{\nu \to n} \f$.
+ *
+ * @param __nu The order of the Neumann function.
+ * @param __x The argument of the Neumann function.
+ * @return The output Neumann function.
+ */
+ template<typename _Tp>
+ _Tp
+ __cyl_neumann_n(const _Tp __nu, const _Tp __x)
+ {
+ if (__nu < _Tp(0) || __x < _Tp(0))
+ std::__throw_domain_error(__N("Bad argument "
+ "in __cyl_neumann_n."));
+ else if (__isnan(__nu) || __isnan(__x))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (__x > _Tp(1000))
+ {
+ _Tp __J_nu, __N_nu;
+ __cyl_bessel_jn_asymp(__nu, __x, __J_nu, __N_nu);
+ return __N_nu;
+ }
+ else
+ {
+ _Tp __J_nu, __N_nu, __Jp_nu, __Np_nu;
+ __bessel_jn(__nu, __x, __J_nu, __N_nu, __Jp_nu, __Np_nu);
+ return __N_nu;
+ }
+ }
+
+
+ /**
+ * @brief Compute the spherical Bessel @f$ j_n(x) @f$
+ * and Neumann @f$ n_n(x) @f$ functions and their first
+ * derivatives @f$ j'_n(x) @f$ and @f$ n'_n(x) @f$
+ * respectively.
+ *
+ * @param __n The order of the spherical Bessel function.
+ * @param __x The argument of the spherical Bessel function.
+ * @param __j_n The output spherical Bessel function.
+ * @param __n_n The output spherical Neumann function.
+ * @param __jp_n The output derivative of the spherical Bessel function.
+ * @param __np_n The output derivative of the spherical Neumann function.
+ */
+ template <typename _Tp>
+ void
+ __sph_bessel_jn(const unsigned int __n, const _Tp __x,
+ _Tp & __j_n, _Tp & __n_n, _Tp & __jp_n, _Tp & __np_n)
+ {
+ const _Tp __nu = _Tp(__n) + _Tp(0.5L);
+
+ _Tp __J_nu, __N_nu, __Jp_nu, __Np_nu;
+ __bessel_jn(__nu, __x, __J_nu, __N_nu, __Jp_nu, __Np_nu);
+
+ const _Tp __factor = __numeric_constants<_Tp>::__sqrtpio2()
+ / std::sqrt(__x);
+
+ __j_n = __factor * __J_nu;
+ __n_n = __factor * __N_nu;
+ __jp_n = __factor * __Jp_nu - __j_n / (_Tp(2) * __x);
+ __np_n = __factor * __Np_nu - __n_n / (_Tp(2) * __x);
+
+ return;
+ }
+
+
+ /**
+ * @brief Return the spherical Bessel function
+ * @f$ j_n(x) @f$ of order n.
+ *
+ * The spherical Bessel function is defined by:
+ * @f[
+ * j_n(x) = \left( \frac{\pi}{2x} \right) ^{1/2} J_{n+1/2}(x)
+ * @f]
+ *
+ * @param __n The order of the spherical Bessel function.
+ * @param __x The argument of the spherical Bessel function.
+ * @return The output spherical Bessel function.
+ */
+ template <typename _Tp>
+ _Tp
+ __sph_bessel(const unsigned int __n, const _Tp __x)
+ {
+ if (__x < _Tp(0))
+ std::__throw_domain_error(__N("Bad argument "
+ "in __sph_bessel."));
+ else if (__isnan(__x))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (__x == _Tp(0))
+ {
+ if (__n == 0)
+ return _Tp(1);
+ else
+ return _Tp(0);
+ }
+ else
+ {
+ _Tp __j_n, __n_n, __jp_n, __np_n;
+ __sph_bessel_jn(__n, __x, __j_n, __n_n, __jp_n, __np_n);
+ return __j_n;
+ }
+ }
+
+
+ /**
+ * @brief Return the spherical Neumann function
+ * @f$ n_n(x) @f$.
+ *
+ * The spherical Neumann function is defined by:
+ * @f[
+ * n_n(x) = \left( \frac{\pi}{2x} \right) ^{1/2} N_{n+1/2}(x)
+ * @f]
+ *
+ * @param __n The order of the spherical Neumann function.
+ * @param __x The argument of the spherical Neumann function.
+ * @return The output spherical Neumann function.
+ */
+ template <typename _Tp>
+ _Tp
+ __sph_neumann(const unsigned int __n, const _Tp __x)
+ {
+ if (__x < _Tp(0))
+ std::__throw_domain_error(__N("Bad argument "
+ "in __sph_neumann."));
+ else if (__isnan(__x))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (__x == _Tp(0))
+ return -std::numeric_limits<_Tp>::infinity();
+ else
+ {
+ _Tp __j_n, __n_n, __jp_n, __np_n;
+ __sph_bessel_jn(__n, __x, __j_n, __n_n, __jp_n, __np_n);
+ return __n_n;
+ }
+ }
+
+ } // namespace std::tr1::__detail
+
+ /* @} */ // group tr1_math_spec_func
+
+_GLIBCXX_END_NAMESPACE
+}
+
+#endif // _TR1_BESSEL_FUNCTION_TCC
diff --git a/libstdc++-v3/include/tr1/beta_function.tcc b/libstdc++-v3/include/tr1/beta_function.tcc
new file mode 100644
index 00000000000..a46011708f1
--- /dev/null
+++ b/libstdc++-v3/include/tr1/beta_function.tcc
@@ -0,0 +1,211 @@
+// Special functions -*- C++ -*-
+
+// Copyright (C) 2006-2007
+// Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+// USA.
+//
+// As a special exception, you may use this file as part of a free software
+// library without restriction. Specifically, if other files instantiate
+// templates or use macros or inline functions from this file, or you compile
+// this file and link it with other files to produce an executable, this
+// file does not by itself cause the resulting executable to be covered by
+// the GNU General Public License. This exception does not however
+// invalidate any other reasons why the executable file might be covered by
+// the GNU General Public License.
+
+/** @file tr1/beta_function.tcc
+ * This is an internal header file, included by other library headers.
+ * You should not attempt to use it directly.
+ */
+
+//
+// ISO C++ 14882 TR1: 5.2 Special functions
+//
+
+// Written by Edward Smith-Rowland based on:
+// (1) Handbook of Mathematical Functions,
+// ed. Milton Abramowitz and Irene A. Stegun,
+// Dover Publications,
+// Section 6, pp. 253-266
+// (2) The Gnu Scientific Library, http://www.gnu.org/software/gsl
+// (3) Numerical Recipes in C, by W. H. Press, S. A. Teukolsky,
+// W. T. Vetterling, B. P. Flannery, Cambridge University Press (1992),
+// 2nd ed, pp. 213-216
+// (4) Gamma, Exploring Euler's Constant, Julian Havil,
+// Princeton, 2003.
+
+#ifndef _TR1_BETA_FUNCTION_TCC
+#define _TR1_BETA_FUNCTION_TCC 1
+
+namespace std
+{
+_GLIBCXX_BEGIN_NAMESPACE(_GLIBCXX_TR1)
+
+ // [5.2] Special functions
+
+ /**
+ * @ingroup tr1_math_spec_func
+ * @{
+ */
+
+ //
+ // Implementation-space details.
+ //
+ namespace __detail
+ {
+
+ /**
+ * @brief Return the beta function: \f$B(x,y)\f$.
+ *
+ * The beta function is defined by
+ * @f[
+ * B(x,y) = \frac{\Gamma(x)\Gamma(y)}{\Gamma(x+y)}
+ * @f]
+ *
+ * @param __x The first argument of the beta function.
+ * @param __y The second argument of the beta function.
+ * @return The beta function.
+ */
+ template<typename _Tp>
+ _Tp
+ __beta_gamma(_Tp __x, _Tp __y)
+ {
+
+ _Tp __bet;
+#if _GLIBCXX_USE_C99_MATH_TR1
+ if (__x > __y)
+ {
+ __bet = std::_GLIBCXX_TR1::tgamma(__x)
+ / std::_GLIBCXX_TR1::tgamma(__x + __y);
+ __bet *= std::_GLIBCXX_TR1::tgamma(__y);
+ }
+ else
+ {
+ __bet = std::_GLIBCXX_TR1::tgamma(__y)
+ / std::_GLIBCXX_TR1::tgamma(__x + __y);
+ __bet *= std::_GLIBCXX_TR1::tgamma(__x);
+ }
+#else
+ if (__x > __y)
+ {
+ __bet = __gamma(__x) / __gamma(__x + __y);
+ __bet *= __gamma(__y);
+ }
+ else
+ {
+ __bet = __gamma(__y) / __gamma(__x + __y);
+ __bet *= __gamma(__x);
+ }
+#endif
+
+ return __bet;
+ }
+
+ /**
+ * @brief Return the beta function \f$B(x,y)\f$ using
+ * the log gamma functions.
+ *
+ * The beta function is defined by
+ * @f[
+ * B(x,y) = \frac{\Gamma(x)\Gamma(y)}{\Gamma(x+y)}
+ * @f]
+ *
+ * @param __x The first argument of the beta function.
+ * @param __y The second argument of the beta function.
+ * @return The beta function.
+ */
+ template<typename _Tp>
+ _Tp
+ __beta_lgamma(_Tp __x, _Tp __y)
+ {
+#if _GLIBCXX_USE_C99_MATH_TR1
+ _Tp __bet = std::_GLIBCXX_TR1::lgamma(__x)
+ + std::_GLIBCXX_TR1::lgamma(__y)
+ - std::_GLIBCXX_TR1::lgamma(__x + __y);
+#else
+ _Tp __bet = __log_gamma(__x)
+ + __log_gamma(__y)
+ - __log_gamma(__x + __y);
+#endif
+ __bet = std::exp(__bet);
+ return __bet;
+ }
+
+
+ /**
+ * @brief Return the beta function \f$B(x,y)\f$ using
+ * the product form.
+ *
+ * The beta function is defined by
+ * @f[
+ * B(x,y) = \frac{\Gamma(x)\Gamma(y)}{\Gamma(x+y)}
+ * @f]
+ *
+ * @param __x The first argument of the beta function.
+ * @param __y The second argument of the beta function.
+ * @return The beta function.
+ */
+ template<typename _Tp>
+ _Tp
+ __beta_product(_Tp __x, _Tp __y)
+ {
+
+ _Tp __bet = (__x + __y) / (__x * __y);
+
+ unsigned int __max_iter = 1000000;
+ for (unsigned int __k = 1; __k < __max_iter; ++__k)
+ {
+ _Tp __term = (_Tp(1) + (__x + __y) / __k)
+ / ((_Tp(1) + __x / __k) * (_Tp(1) + __y / __k));
+ __bet *= __term;
+ }
+
+ return __bet;
+ }
+
+
+ /**
+ * @brief Return the beta function \f$ B(x,y) \f$.
+ *
+ * The beta function is defined by
+ * @f[
+ * B(x,y) = \frac{\Gamma(x)\Gamma(y)}{\Gamma(x+y)}
+ * @f]
+ *
+ * @param __x The first argument of the beta function.
+ * @param __y The second argument of the beta function.
+ * @return The beta function.
+ */
+ template<typename _Tp>
+ inline _Tp
+ __beta(_Tp __x, _Tp __y)
+ {
+ if (__isnan(__x) || __isnan(__y))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else
+ return __beta_lgamma(__x, __y);
+ }
+
+ } // namespace std::tr1::__detail
+
+ /* @} */ // group tr1_math_spec_func
+
+_GLIBCXX_END_NAMESPACE
+}
+
+#endif // _TR1_BETA_FUNCTION_TCC
diff --git a/libstdc++-v3/include/tr1/cmath b/libstdc++-v3/include/tr1/cmath
index 65115e67350..b07add26156 100644
--- a/libstdc++-v3/include/tr1/cmath
+++ b/libstdc++-v3/include/tr1/cmath
@@ -1,6 +1,6 @@
// TR1 cmath -*- C++ -*-
-// Copyright (C) 2006 Free Software Foundation, Inc.
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
//
// This file is part of the GNU ISO C++ Library. This library is free
// software; you can redistribute it and/or modify it under the
@@ -35,6 +35,7 @@
#define _TR1_CMATH 1
#include <bits/c++config.h>
+#include <algorithm>
#include <cmath>
#include <tr1/common.h>
@@ -940,4 +941,470 @@ _GLIBCXX_BEGIN_NAMESPACE(_GLIBCXX_TR1)
_GLIBCXX_END_NAMESPACE
}
+ /**
+ * @defgroup tr1_math_spec_func Mathematical Special Functions
+ * A collection of advanced mathematical special functions.
+ * @{
+ */
+
+#include <tr1/gamma.tcc>
+#include <tr1/bessel_function.tcc>
+#include <tr1/beta_function.tcc>
+#include <tr1/ell_integral.tcc>
+#include <tr1/exp_integral.tcc>
+#include <tr1/hypergeometric.tcc>
+#include <tr1/legendre_function.tcc>
+#include <tr1/modified_bessel_func.tcc>
+#include <tr1/poly_hermite.tcc>
+#include <tr1/poly_laguerre.tcc>
+#include <tr1/riemann_zeta.tcc>
+
+// namespace std::tr1
+namespace std
+{
+_GLIBCXX_BEGIN_NAMESPACE(_GLIBCXX_TR1)
+
+ // 5.2.1.1 Associated Laguerre polynomials.
+
+ inline float
+ assoc_laguerref(unsigned int __n, unsigned int __m, float __x)
+ { return __detail::__assoc_laguerre<float>(__n, __m, __x); }
+
+ inline long double
+ assoc_laguerrel(unsigned int __n, unsigned int __m, long double __x)
+ {
+ return __detail::__assoc_laguerre<long double>(__n, __m, __x);
+ }
+
+ template<typename _Tp>
+ inline typename __promote<_Tp>::__type
+ assoc_laguerre(unsigned int __n, unsigned int __m, _Tp __x)
+ {
+ typedef typename __promote<_Tp>::__type __type;
+ return __detail::__assoc_laguerre<__type>(__n, __m, __x);
+ }
+
+
+ // 5.2.1.2 Associated Legendre functions.
+
+ inline float
+ assoc_legendref(unsigned int __l, unsigned int __m, float __x)
+ { return __detail::__assoc_legendre_p<float>(__l, __m, __x); }
+
+ inline long double
+ assoc_legendrel(unsigned int __l, unsigned int __m, long double __x)
+ { return __detail::__assoc_legendre_p<long double>(__l, __m, __x); }
+
+ template<typename _Tp>
+ inline typename __promote<_Tp>::__type
+ assoc_legendre(unsigned int __l, unsigned int __m, _Tp __x)
+ {
+ typedef typename __promote<_Tp>::__type __type;
+ return __detail::__assoc_legendre_p<__type>(__l, __m, __x);
+ }
+
+
+ // 5.2.1.3 Beta functions.
+
+ inline float
+ betaf(float __x, float __y)
+ { return __detail::__beta<float>(__x, __y); }
+
+ inline long double
+ betal(long double __x, long double __y)
+ { return __detail::__beta<long double>(__x, __y); }
+
+ template<typename _Tpx, typename _Tpy>
+ inline typename __promote_2<_Tpx, _Tpy>::__type
+ beta(_Tpx __x, _Tpy __y)
+ {
+ typedef typename __promote_2<_Tpx, _Tpy>::__type __type;
+ return __detail::__beta<__type>(__x, __y);
+ }
+
+
+ // 5.2.1.4 Complete elliptic interals of the first kind.
+
+ inline float
+ comp_ellint_1f(float __k)
+ { return __detail::__comp_ellint_1<float>(__k); }
+
+ inline long double
+ comp_ellint_1l(long double __k)
+ { return __detail::__comp_ellint_1<long double>(__k); }
+
+ template<typename _Tp>
+ inline typename __promote<_Tp>::__type
+ comp_ellint_1(_Tp __k)
+ {
+ typedef typename __promote<_Tp>::__type __type;
+ return __detail::__comp_ellint_1<__type>(__k);
+ }
+
+
+ // 5.2.1.5 Complete elliptic interals of the second kind.
+
+ inline float
+ comp_ellint_2f(float __k)
+ { return __detail::__comp_ellint_2<float>(__k); }
+
+ inline long double
+ comp_ellint_2l(long double __k)
+ { return __detail::__comp_ellint_2<long double>(__k); }
+
+ template<typename _Tp>
+ inline typename __promote<_Tp>::__type
+ comp_ellint_2(_Tp __k)
+ {
+ typedef typename __promote<_Tp>::__type __type;
+ return __detail::__comp_ellint_2<__type>(__k);
+ }
+
+
+ // 5.2.1.6 Complete elliptic interals of the third kind.
+
+ inline float
+ comp_ellint_3f(float __k, float __nu)
+ { return __detail::__comp_ellint_3<float>(__k, __nu); }
+
+ inline long double
+ comp_ellint_3l(long double __k, long double __nu)
+ { return __detail::__comp_ellint_3<long double>(__k, __nu); }
+
+ template<typename _Tp, typename _Tpn>
+ inline typename __promote_2<_Tp, _Tpn>::__type
+ comp_ellint_3(_Tp __k, _Tpn __nu)
+ {
+ typedef typename __promote_2<_Tp, _Tpn>::__type __type;
+ return __detail::__comp_ellint_3<__type>(__k, __nu);
+ }
+
+
+ // 5.2.1.7 Confluent hypergeometric functions.
+
+ inline float
+ conf_hypergf(float __a, float __c, float __x)
+ { return __detail::__conf_hyperg<float>(__a, __c, __x); }
+
+ inline long double
+ conf_hypergl(long double __a, long double __c, long double __x)
+ { return __detail::__conf_hyperg<long double>(__a, __c, __x); }
+
+ template<typename _Tpa, typename _Tpc, typename _Tp>
+ inline typename __promote_3<_Tpa, _Tpc, _Tp>::__type
+ conf_hyperg(_Tpa __a, _Tpc __c, _Tp __x)
+ {
+ typedef typename __promote_3<_Tpa, _Tpc, _Tp>::__type __type;
+ return __detail::__conf_hyperg<__type>(__a, __c, __x);
+ }
+
+
+ // 5.2.1.8 Regular modified cylindrical Bessel functions.
+
+ inline float
+ cyl_bessel_if(float __nu, float __x)
+ { return __detail::__cyl_bessel_i<float>(__nu, __x); }
+
+ inline long double
+ cyl_bessel_il(long double __nu, long double __x)
+ { return __detail::__cyl_bessel_i<long double>(__nu, __x); }
+
+ template<typename _Tpnu, typename _Tp>
+ inline typename __promote_2<_Tpnu, _Tp>::__type
+ cyl_bessel_i(_Tpnu __nu, _Tp __x)
+ {
+ typedef typename __promote_2<_Tpnu, _Tp>::__type __type;
+ return __detail::__cyl_bessel_i<__type>(__nu, __x);
+ }
+
+
+ // 5.2.1.9 Cylindrical Bessel functions (of the first kind).
+
+ inline float
+ cyl_bessel_jf(float __nu, float __x)
+ { return __detail::__cyl_bessel_j<float>(__nu, __x); }
+
+ inline long double
+ cyl_bessel_jl(long double __nu, long double __x)
+ { return __detail::__cyl_bessel_j<long double>(__nu, __x); }
+
+ template<typename _Tpnu, typename _Tp>
+ inline typename __promote_2<_Tpnu, _Tp>::__type
+ cyl_bessel_j(_Tpnu __nu, _Tp __x)
+ {
+ typedef typename __promote_2<_Tpnu, _Tp>::__type __type;
+ return __detail::__cyl_bessel_j<__type>(__nu, __x);
+ }
+
+
+ // 5.2.1.10 Irregular modified cylindrical Bessel functions.
+
+ inline float
+ cyl_bessel_kf(float __nu, float __x)
+ { return __detail::__cyl_bessel_k<float>(__nu, __x); }
+
+ inline long double
+ cyl_bessel_kl(long double __nu, long double __x)
+ { return __detail::__cyl_bessel_k<long double>(__nu, __x); }
+
+ template<typename _Tpnu, typename _Tp>
+ inline typename __promote_2<_Tpnu, _Tp>::__type
+ cyl_bessel_k(_Tpnu __nu, _Tp __x)
+ {
+ typedef typename __promote_2<_Tpnu, _Tp>::__type __type;
+ return __detail::__cyl_bessel_k<__type>(__nu, __x);
+ }
+
+
+ // 5.2.1.11 Cylindrical Neumann functions.
+
+ inline float
+ cyl_neumannf(float __nu, float __x)
+ { return __detail::__cyl_neumann_n<float>(__nu, __x); }
+
+ inline long double
+ cyl_neumannl(long double __nu, long double __x)
+ { return __detail::__cyl_neumann_n<long double>(__nu, __x); }
+
+ template<typename _Tpnu, typename _Tp>
+ inline typename __promote_2<_Tpnu, _Tp>::__type
+ cyl_neumann(_Tpnu __nu, _Tp __x)
+ {
+ typedef typename __promote_2<_Tpnu, _Tp>::__type __type;
+ return __detail::__cyl_neumann_n<__type>(__nu, __x);
+ }
+
+
+ // 5.2.1.12 Incomplete elliptic interals of the first kind.
+
+ inline float
+ ellint_1f(float __k, float __phi)
+ { return __detail::__ellint_1<float>(__k, __phi); }
+
+ inline long double
+ ellint_1l(long double __k, long double __phi)
+ { return __detail::__ellint_1<long double>(__k, __phi); }
+
+ template<typename _Tp, typename _Tpp>
+ inline typename __promote_2<_Tp, _Tpp>::__type
+ ellint_1(_Tp __k, _Tpp __phi)
+ {
+ typedef typename __promote_2<_Tp, _Tpp>::__type __type;
+ return __detail::__ellint_1<__type>(__k, __phi);
+ }
+
+
+ // 5.2.1.13 Incomplete elliptic interals of the second kind.
+
+ inline float
+ ellint_2f(float __k, float __phi)
+ { return __detail::__ellint_2<float>(__k, __phi); }
+
+ inline long double
+ ellint_2l(long double __k, long double __phi)
+ { return __detail::__ellint_2<long double>(__k, __phi); }
+
+ template<typename _Tp, typename _Tpp>
+ inline typename __promote_2<_Tp, _Tpp>::__type
+ ellint_2(_Tp __k, _Tpp __phi)
+ {
+ typedef typename __promote_2<_Tp, _Tpp>::__type __type;
+ return __detail::__ellint_2<__type>(__k, __phi);
+ }
+
+
+ // 5.2.1.14 Incomplete elliptic interals of the third kind.
+
+ inline float
+ ellint_3f(float __k, float __nu, float __phi)
+ { return __detail::__ellint_3<float>(__k, __nu, __phi); }
+
+ inline long double
+ ellint_3l(long double __k, long double __nu, long double __phi)
+ { return __detail::__ellint_3<long double>(__k, __nu, __phi); }
+
+ template<typename _Tp, typename _Tpn, typename _Tpp>
+ inline typename __promote_3<_Tp, _Tpn, _Tpp>::__type
+ ellint_3(_Tp __k, _Tpn __nu, _Tpp __phi)
+ {
+ typedef typename __promote_3<_Tp, _Tpn, _Tpp>::__type __type;
+ return __detail::__ellint_3<__type>(__k, __nu, __phi);
+ }
+
+
+ // 5.2.1.15 Exponential integrals.
+
+ inline float
+ expintf(float __x)
+ { return __detail::__expint<float>(__x); }
+
+ inline long double
+ expintl(long double __x)
+ { return __detail::__expint<long double>(__x); }
+
+ template<typename _Tp>
+ inline typename __promote<_Tp>::__type
+ expint(_Tp __x)
+ {
+ typedef typename __promote<_Tp>::__type __type;
+ return __detail::__expint<__type>(__x);
+ }
+
+
+ // 5.2.1.16 Hermite polynomials.
+
+ inline float
+ hermitef(unsigned int __n, float __x)
+ { return __detail::__poly_hermite<float>(__n, __x); }
+
+ inline long double
+ hermitel(unsigned int __n, long double __x)
+ { return __detail::__poly_hermite<long double>(__n, __x); }
+
+ template<typename _Tp>
+ inline typename __promote<_Tp>::__type
+ hermite(unsigned int __n, _Tp __x)
+ {
+ typedef typename __promote<_Tp>::__type __type;
+ return __detail::__poly_hermite<__type>(__n, __x);
+ }
+
+
+ // 5.2.1.17 Hypergeometric functions.
+
+ inline float
+ hypergf(float __a, float __b, float __c, float __x)
+ { return __detail::__hyperg<float>(__a, __b, __c, __x); }
+
+ inline long double
+ hypergl(long double __a, long double __b, long double __c, long double __x)
+ { return __detail::__hyperg<long double>(__a, __b, __c, __x); }
+
+ template<typename _Tpa, typename _Tpb, typename _Tpc, typename _Tp>
+ inline typename __promote_4<_Tpa, _Tpb, _Tpc, _Tp>::__type
+ hyperg(_Tpa __a, _Tpb __b, _Tpc __c, _Tp __x)
+ {
+ typedef typename __promote_4<_Tpa, _Tpb, _Tpc, _Tp>::__type __type;
+ return __detail::__hyperg<__type>(__a, __b, __c, __x);
+ }
+
+
+ // 5.2.1.18 Laguerre polynomials.
+
+ inline float
+ laguerref(unsigned int __n, float __x)
+ { return __detail::__laguerre<float>(__n, __x); }
+
+ inline long double
+ laguerrel(unsigned int __n, long double __x)
+ { return __detail::__laguerre<long double>(__n, __x); }
+
+ template<typename _Tp>
+ inline typename __promote<_Tp>::__type
+ laguerre(unsigned int __n, _Tp __x)
+ {
+ typedef typename __promote<_Tp>::__type __type;
+ return __detail::__laguerre<__type>(__n, __x);
+ }
+
+
+ // 5.2.1.19 Legendre polynomials.
+
+ inline float
+ legendref(unsigned int __n, float __x)
+ { return __detail::__poly_legendre_p<float>(__n, __x); }
+
+ inline long double
+ legendrel(unsigned int __n, long double __x)
+ { return __detail::__poly_legendre_p<long double>(__n, __x); }
+
+ template<typename _Tp>
+ inline typename __promote<_Tp>::__type
+ legendre(unsigned int __n, _Tp __x)
+ {
+ typedef typename __promote<_Tp>::__type __type;
+ return __detail::__poly_legendre_p<__type>(__n, __x);
+ }
+
+
+ // 5.2.1.20 Riemann zeta function.
+
+ inline float
+ riemann_zetaf(float __x)
+ { return __detail::__riemann_zeta<float>(__x); }
+
+ inline long double
+ riemann_zetal(long double __x)
+ { return __detail::__riemann_zeta<long double>(__x); }
+
+ template<typename _Tp>
+ inline typename __promote<_Tp>::__type
+ riemann_zeta(_Tp __x)
+ {
+ typedef typename __promote<_Tp>::__type __type;
+ return __detail::__riemann_zeta<__type>(__x);
+ }
+
+
+ // 5.2.1.21 Spherical Bessel functions.
+
+ inline float
+ sph_besself(unsigned int __n, float __x)
+ { return __detail::__sph_bessel<float>(__n, __x); }
+
+ inline long double
+ sph_bessell(unsigned int __n, long double __x)
+ { return __detail::__sph_bessel<long double>(__n, __x); }
+
+ template<typename _Tp>
+ inline typename __promote<_Tp>::__type
+ sph_bessel(unsigned int __n, _Tp __x)
+ {
+ typedef typename __promote<_Tp>::__type __type;
+ return __detail::__sph_bessel<__type>(__n, __x);
+ }
+
+
+ // 5.2.1.22 Spherical associated Legendre functions.
+
+ inline float
+ sph_legendref(unsigned int __l, unsigned int __m, float __theta)
+ { return __detail::__sph_legendre<float>(__l, __m, __theta); }
+
+ inline long double
+ sph_legendrel(unsigned int __l, unsigned int __m, long double __theta)
+ { return __detail::__sph_legendre<long double>(__l, __m, __theta); }
+
+ template<typename _Tp>
+ inline typename __promote<_Tp>::__type
+ sph_legendre(unsigned int __l, unsigned int __m, _Tp __theta)
+ {
+ typedef typename __promote<_Tp>::__type __type;
+ return __detail::__sph_legendre<__type>(__l, __m, __theta);
+ }
+
+
+ // 5.2.1.23 Spherical Neumann functions.
+
+ inline float
+ sph_neumannf(unsigned int __n, float __x)
+ { return __detail::__sph_neumann<float>(__n, __x); }
+
+ inline long double
+ sph_neumannl(unsigned int __n, long double __x)
+ { return __detail::__sph_neumann<long double>(__n, __x); }
+
+ template<typename _Tp>
+ inline typename __promote<_Tp>::__type
+ sph_neumann(unsigned int __n, _Tp __x)
+ {
+ typedef typename __promote<_Tp>::__type __type;
+ return __detail::__sph_neumann<__type>(__n, __x);
+ }
+
+ /* @} */ // group tr1_math_spec_func
+
+_GLIBCXX_END_NAMESPACE
+}
+
#endif
diff --git a/libstdc++-v3/include/tr1/common.h b/libstdc++-v3/include/tr1/common.h
index fb13cdea320..d26fdd6da5c 100644
--- a/libstdc++-v3/include/tr1/common.h
+++ b/libstdc++-v3/include/tr1/common.h
@@ -72,6 +72,19 @@ _GLIBCXX_BEGIN_NAMESPACE(_GLIBCXX_TR1)
typedef __typeof__(__type1() + __type2() + __type3()) __type;
};
+ template<typename _Tp, typename _Up, typename _Vp, typename _Wp>
+ struct __promote_4
+ {
+ private:
+ typedef typename __promote<_Tp>::__type __type1;
+ typedef typename __promote<_Up>::__type __type2;
+ typedef typename __promote<_Vp>::__type __type3;
+ typedef typename __promote<_Wp>::__type __type4;
+
+ public:
+ typedef __typeof__(__type1() + __type2() + __type3() + __type4()) __type;
+ };
+
_GLIBCXX_END_NAMESPACE
} // namespace std
diff --git a/libstdc++-v3/include/tr1/ell_integral.tcc b/libstdc++-v3/include/tr1/ell_integral.tcc
new file mode 100644
index 00000000000..2f2da376bf1
--- /dev/null
+++ b/libstdc++-v3/include/tr1/ell_integral.tcc
@@ -0,0 +1,762 @@
+// Special functions -*- C++ -*-
+
+// Copyright (C) 2006-2007
+// Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+// USA.
+//
+// As a special exception, you may use this file as part of a free software
+// library without restriction. Specifically, if other files instantiate
+// templates or use macros or inline functions from this file, or you compile
+// this file and link it with other files to produce an executable, this
+// file does not by itself cause the resulting executable to be covered by
+// the GNU General Public License. This exception does not however
+// invalidate any other reasons why the executable file might be covered by
+// the GNU General Public License.
+
+/** @file tr1/ell_integral.tcc
+ * This is an internal header file, included by other library headers.
+ * You should not attempt to use it directly.
+ */
+
+//
+// ISO C++ 14882 TR1: 5.2 Special functions
+//
+
+// Written by Edward Smith-Rowland based on:
+// (1) B. C. Carlson Numer. Math. 33, 1 (1979)
+// (2) B. C. Carlson, Special Functions of Applied Mathematics (1977)
+// (3) The Gnu Scientific Library, http://www.gnu.org/software/gsl
+// (4) Numerical Recipes in C, 2nd ed, by W. H. Press, S. A. Teukolsky,
+// W. T. Vetterling, B. P. Flannery, Cambridge University Press
+// (1992), pp. 261-269
+
+#ifndef _TR1_ELL_INTEGRAL_TCC
+#define _TR1_ELL_INTEGRAL_TCC 1
+
+namespace std
+{
+_GLIBCXX_BEGIN_NAMESPACE(_GLIBCXX_TR1)
+
+ // [5.2] Special functions
+
+ /**
+ * @ingroup tr1_math_spec_func
+ * @{
+ */
+
+ //
+ // Implementation-space details.
+ //
+ namespace __detail
+ {
+
+ /**
+ * @brief Return the Carlson elliptic function @f$ R_F(x,y,z) @f$
+ * of the first kind.
+ *
+ * The Carlson elliptic function of the first kind is defined by:
+ * @f[
+ * R_F(x,y,z) = \frac{1}{2} \int_0^\infty
+ * \frac{dt}{(t + x)^{1/2}(t + y)^{1/2}(t + z)^{1/2}}
+ * @f]
+ *
+ * @param __x The first of three symmetric arguments.
+ * @param __y The second of three symmetric arguments.
+ * @param __z The third of three symmetric arguments.
+ * @return The Carlson elliptic function of the first kind.
+ */
+ template<typename _Tp>
+ _Tp
+ __ellint_rf(const _Tp __x, const _Tp __y, const _Tp __z)
+ {
+ const _Tp __min = std::numeric_limits<_Tp>::min();
+ const _Tp __max = std::numeric_limits<_Tp>::max();
+ const _Tp __lolim = _Tp(5) * __min;
+ const _Tp __uplim = __max / _Tp(5);
+
+ if (__x < _Tp(0) || __y < _Tp(0) || __z < _Tp(0))
+ std::__throw_domain_error(__N("Argument less than zero "
+ "in __ellint_rf."));
+ else if (__x + __y < __lolim || __x + __z < __lolim
+ || __y + __z < __lolim)
+ std::__throw_domain_error(__N("Argument too small in __ellint_rf"));
+ else
+ {
+ const _Tp __c0 = _Tp(1) / _Tp(4);
+ const _Tp __c1 = _Tp(1) / _Tp(24);
+ const _Tp __c2 = _Tp(1) / _Tp(10);
+ const _Tp __c3 = _Tp(3) / _Tp(44);
+ const _Tp __c4 = _Tp(1) / _Tp(14);
+
+ _Tp __xn = __x;
+ _Tp __yn = __y;
+ _Tp __zn = __z;
+
+ const _Tp __eps = std::numeric_limits<_Tp>::epsilon();
+ const _Tp __errtol = std::pow(__eps, _Tp(1) / _Tp(6));
+ _Tp __mu;
+ _Tp __xndev, __yndev, __zndev;
+
+ const unsigned int __max_iter = 100;
+ for (unsigned int __iter = 0; __iter < __max_iter; ++__iter)
+ {
+ __mu = (__xn + __yn + __zn) / _Tp(3);
+ __xndev = 2 - (__mu + __xn) / __mu;
+ __yndev = 2 - (__mu + __yn) / __mu;
+ __zndev = 2 - (__mu + __zn) / __mu;
+ _Tp __epsilon = std::max(std::abs(__xndev), std::abs(__yndev));
+ __epsilon = std::max(__epsilon, std::abs(__zndev));
+ if (__epsilon < __errtol)
+ break;
+ const _Tp __xnroot = std::sqrt(__xn);
+ const _Tp __ynroot = std::sqrt(__yn);
+ const _Tp __znroot = std::sqrt(__zn);
+ const _Tp __lambda = __xnroot * (__ynroot + __znroot)
+ + __ynroot * __znroot;
+ __xn = __c0 * (__xn + __lambda);
+ __yn = __c0 * (__yn + __lambda);
+ __zn = __c0 * (__zn + __lambda);
+ }
+
+ const _Tp __e2 = __xndev * __yndev - __zndev * __zndev;
+ const _Tp __e3 = __xndev * __yndev * __zndev;
+ const _Tp __s = _Tp(1) + (__c1 * __e2 - __c2 - __c3 * __e3) * __e2
+ + __c4 * __e3;
+
+ return __s / std::sqrt(__mu);
+ }
+ }
+
+
+ /**
+ * @brief Return the complete elliptic integral of the first kind
+ * @f$ K(k) @f$ by series expansion.
+ *
+ * The complete elliptic integral of the first kind is defined as
+ * @f[
+ * K(k) = F(k,\pi/2) = \int_0^{\pi/2}\frac{d\theta}
+ * {\sqrt{1 - k^2sin^2\theta}}
+ * @f]
+ *
+ * This routine is not bad as long as |k| is somewhat smaller than 1
+ * but is not is good as the Carlson elliptic integral formulation.
+ *
+ * @param __k The argument of the complete elliptic function.
+ * @return The complete elliptic function of the first kind.
+ */
+ template<typename _Tp>
+ _Tp
+ __comp_ellint_1_series(const _Tp __k)
+ {
+
+ const _Tp __kk = __k * __k;
+
+ _Tp __term = __kk / _Tp(4);
+ _Tp __sum = _Tp(1) + __term;
+
+ const unsigned int __max_iter = 1000;
+ for (unsigned int __i = 2; __i < __max_iter; ++__i)
+ {
+ __term *= (2 * __i - 1) * __kk / (2 * __i);
+ if (__term < std::numeric_limits<_Tp>::epsilon())
+ break;
+ __sum += __term;
+ }
+
+ return __numeric_constants<_Tp>::__pi_2() * __sum;
+ }
+
+
+ /**
+ * @brief Return the complete elliptic integral of the first kind
+ * @f$ K(k) @f$ using the Carlson formulation.
+ *
+ * The complete elliptic integral of the first kind is defined as
+ * @f[
+ * K(k) = F(k,\pi/2) = \int_0^{\pi/2}\frac{d\theta}
+ * {\sqrt{1 - k^2 sin^2\theta}}
+ * @f]
+ * where @f$ F(k,\phi) @f$ is the incomplete elliptic integral of the
+ * first kind.
+ *
+ * @param __k The argument of the complete elliptic function.
+ * @return The complete elliptic function of the first kind.
+ */
+ template<typename _Tp>
+ _Tp
+ __comp_ellint_1(const _Tp __k)
+ {
+
+ if (__isnan(__k))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (std::abs(__k) >= _Tp(1))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else
+ return __ellint_rf(_Tp(0), _Tp(1) - __k * __k, _Tp(1));
+ }
+
+
+ /**
+ * @brief Return the incomplete elliptic integral of the first kind
+ * @f$ F(k,\phi) @f$ using the Carlson formulation.
+ *
+ * The incomplete elliptic integral of the first kind is defined as
+ * @f[
+ * F(k,\phi) = \int_0^{\phi}\frac{d\theta}
+ * {\sqrt{1 - k^2 sin^2\theta}}
+ * @f]
+ *
+ * @param __k The argument of the elliptic function.
+ * @param __phi The integral limit argument of the elliptic function.
+ * @return The elliptic function of the first kind.
+ */
+ template<typename _Tp>
+ _Tp
+ __ellint_1(const _Tp __k, const _Tp __phi)
+ {
+
+ if (__isnan(__k) || __isnan(__phi))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (std::abs(__k) > _Tp(1))
+ std::__throw_domain_error(__N("Bad argument in __ellint_1."));
+ else
+ {
+ // Reduce phi to -pi/2 < phi < +pi/2.
+ const int __n = std::floor(__phi / __numeric_constants<_Tp>::__pi()
+ + _Tp(0.5L));
+ const _Tp __phi_red = __phi
+ - __n * __numeric_constants<_Tp>::__pi();
+
+ const _Tp __s = std::sin(__phi_red);
+ const _Tp __c = std::cos(__phi_red);
+
+ const _Tp __F = __s
+ * __ellint_rf(__c * __c,
+ _Tp(1) - __k * __k * __s * __s, _Tp(1));
+
+ if (__n == 0)
+ return __F;
+ else
+ return __F + _Tp(2) * __n * __comp_ellint_1(__k);
+ }
+ }
+
+
+ /**
+ * @brief Return the complete elliptic integral of the second kind
+ * @f$ E(k) @f$ by series expansion.
+ *
+ * The complete elliptic integral of the second kind is defined as
+ * @f[
+ * E(k,\pi/2) = \int_0^{\pi/2}\sqrt{1 - k^2 sin^2\theta}
+ * @f]
+ *
+ * This routine is not bad as long as |k| is somewhat smaller than 1
+ * but is not is good as the Carlson elliptic integral formulation.
+ *
+ * @param __k The argument of the complete elliptic function.
+ * @return The complete elliptic function of the second kind.
+ */
+ template<typename _Tp>
+ _Tp
+ __comp_ellint_2_series(const _Tp __k)
+ {
+
+ const _Tp __kk = __k * __k;
+
+ _Tp __term = __kk;
+ _Tp __sum = __term;
+
+ const unsigned int __max_iter = 1000;
+ for (unsigned int __i = 2; __i < __max_iter; ++__i)
+ {
+ const _Tp __i2m = 2 * __i - 1;
+ const _Tp __i2 = 2 * __i;
+ __term *= __i2m * __i2m * __kk / (__i2 * __i2);
+ if (__term < std::numeric_limits<_Tp>::epsilon())
+ break;
+ __sum += __term / __i2m;
+ }
+
+ return __numeric_constants<_Tp>::__pi_2() * (_Tp(1) - __sum);
+ }
+
+
+ /**
+ * @brief Return the Carlson elliptic function of the second kind
+ * @f$ R_D(x,y,z) = R_J(x,y,z,z) @f$ where
+ * @f$ R_J(x,y,z,p) @f$ is the Carlson elliptic function
+ * of the third kind.
+ *
+ * The Carlson elliptic function of the second kind is defined by:
+ * @f[
+ * R_D(x,y,z) = \frac{3}{2} \int_0^\infty
+ * \frac{dt}{(t + x)^{1/2}(t + y)^{1/2}(t + z)^{3/2}}
+ * @f]
+ *
+ * Based on Carlson's algorithms:
+ * - B. C. Carlson Numer. Math. 33, 1 (1979)
+ * - B. C. Carlson, Special Functions of Applied Mathematics (1977)
+ * - Nunerical Recipes in C, 2nd ed, pp. 261-269,
+ * by Press, Teukolsky, Vetterling, Flannery (1992)
+ *
+ * @param __x The first of two symmetric arguments.
+ * @param __y The second of two symmetric arguments.
+ * @param __z The third argument.
+ * @return The Carlson elliptic function of the second kind.
+ */
+ template<typename _Tp>
+ _Tp
+ __ellint_rd(const _Tp __x, const _Tp __y, const _Tp __z)
+ {
+ const _Tp __eps = std::numeric_limits<_Tp>::epsilon();
+ const _Tp __errtol = std::pow(__eps / _Tp(8), _Tp(1) / _Tp(6));
+ const _Tp __min = std::numeric_limits<_Tp>::min();
+ const _Tp __max = std::numeric_limits<_Tp>::max();
+ const _Tp __lolim = _Tp(2) / std::pow(__max, _Tp(2) / _Tp(3));
+ const _Tp __uplim = std::pow(_Tp(0.1L) * __errtol / __min, _Tp(2) / _Tp(3));
+
+ if (__x < _Tp(0) || __y < _Tp(0))
+ std::__throw_domain_error(__N("Argument less than zero "
+ "in __ellint_rd."));
+ else if (__x + __y < __lolim || __z < __lolim)
+ std::__throw_domain_error(__N("Argument too small "
+ "in __ellint_rd."));
+ else
+ {
+ const _Tp __c0 = _Tp(1) / _Tp(4);
+ const _Tp __c1 = _Tp(3) / _Tp(14);
+ const _Tp __c2 = _Tp(1) / _Tp(6);
+ const _Tp __c3 = _Tp(9) / _Tp(22);
+ const _Tp __c4 = _Tp(3) / _Tp(26);
+
+ _Tp __xn = __x;
+ _Tp __yn = __y;
+ _Tp __zn = __z;
+ _Tp __sigma = _Tp(0);
+ _Tp __power4 = _Tp(1);
+
+ _Tp __mu;
+ _Tp __xndev, __yndev, __zndev;
+
+ const unsigned int __max_iter = 100;
+ for (unsigned int __iter = 0; __iter < __max_iter; ++__iter)
+ {
+ __mu = (__xn + __yn + _Tp(3) * __zn) / _Tp(5);
+ __xndev = (__mu - __xn) / __mu;
+ __yndev = (__mu - __yn) / __mu;
+ __zndev = (__mu - __zn) / __mu;
+ _Tp __epsilon = std::max(std::abs(__xndev), std::abs(__yndev));
+ __epsilon = std::max(__epsilon, std::abs(__zndev));
+ if (__epsilon < __errtol)
+ break;
+ _Tp __xnroot = std::sqrt(__xn);
+ _Tp __ynroot = std::sqrt(__yn);
+ _Tp __znroot = std::sqrt(__zn);
+ _Tp __lambda = __xnroot * (__ynroot + __znroot)
+ + __ynroot * __znroot;
+ __sigma += __power4 / (__znroot * (__zn + __lambda));
+ __power4 *= __c0;
+ __xn = __c0 * (__xn + __lambda);
+ __yn = __c0 * (__yn + __lambda);
+ __zn = __c0 * (__zn + __lambda);
+ }
+
+ _Tp __ea = __xndev * __yndev;
+ _Tp __eb = __zndev * __zndev;
+ _Tp __ec = __ea - __eb;
+ _Tp __ed = __ea - _Tp(6) * __eb;
+ _Tp __ef = __ed + __ec + __ec;
+ _Tp __s1 = __ed * (-__c1 + __c3 * __ed
+ / _Tp(3) - _Tp(3) * __c4 * __zndev * __ef
+ / _Tp(2));
+ _Tp __s2 = __zndev
+ * (__c2 * __ef
+ + __zndev * (-__c3 * __ec - __zndev * __c4 - __ea));
+
+ return _Tp(3) * __sigma + __power4 * (_Tp(1) + __s1 + __s2)
+ / (__mu * std::sqrt(__mu));
+ }
+ }
+
+
+ /**
+ * @brief Return the complete elliptic integral of the second kind
+ * @f$ E(k) @f$ using the Carlson formulation.
+ *
+ * The complete elliptic integral of the second kind is defined as
+ * @f[
+ * E(k,\pi/2) = \int_0^{\pi/2}\sqrt{1 - k^2 sin^2\theta}
+ * @f]
+ *
+ * @param __k The argument of the complete elliptic function.
+ * @return The complete elliptic function of the second kind.
+ */
+ template<typename _Tp>
+ _Tp
+ __comp_ellint_2(const _Tp __k)
+ {
+
+ if (__isnan(__k))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (std::abs(__k) == 1)
+ return _Tp(1);
+ else if (std::abs(__k) > _Tp(1))
+ std::__throw_domain_error(__N("Bad argument in __comp_ellint_2."));
+ else
+ {
+ const _Tp __kk = __k * __k;
+
+ return __ellint_rf(_Tp(0), _Tp(1) - __kk, _Tp(1))
+ - __kk * __ellint_rd(_Tp(0), _Tp(1) - __kk, _Tp(1)) / _Tp(3);
+ }
+ }
+
+
+ /**
+ * @brief Return the incomplete elliptic integral of the second kind
+ * @f$ E(k,\phi) @f$ using the Carlson formulation.
+ *
+ * The incomplete elliptic integral of the second kind is defined as
+ * @f[
+ * E(k,\phi) = \int_0^{\phi} \sqrt{1 - k^2 sin^2\theta}
+ * @f]
+ *
+ * @param __k The argument of the elliptic function.
+ * @param __phi The integral limit argument of the elliptic function.
+ * @return The elliptic function of the second kind.
+ */
+ template<typename _Tp>
+ _Tp
+ __ellint_2(const _Tp __k, const _Tp __phi)
+ {
+
+ if (__isnan(__k) || __isnan(__phi))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (std::abs(__k) > _Tp(1))
+ std::__throw_domain_error(__N("Bad argument in __ellint_2."));
+ else
+ {
+ // Reduce phi to -pi/2 < phi < +pi/2.
+ const int __n = std::floor(__phi / __numeric_constants<_Tp>::__pi()
+ + _Tp(0.5L));
+ const _Tp __phi_red = __phi
+ - __n * __numeric_constants<_Tp>::__pi();
+
+ const _Tp __kk = __k * __k;
+ const _Tp __s = std::sin(__phi_red);
+ const _Tp __ss = __s * __s;
+ const _Tp __sss = __ss * __s;
+ const _Tp __c = std::cos(__phi_red);
+ const _Tp __cc = __c * __c;
+
+ const _Tp __E = __s
+ * __ellint_rf(__cc, _Tp(1) - __kk * __ss, _Tp(1))
+ - __kk * __sss
+ * __ellint_rd(__cc, _Tp(1) - __kk * __ss, _Tp(1))
+ / _Tp(3);
+
+ if (__n == 0)
+ return __E;
+ else
+ return __E + _Tp(2) * __n * __comp_ellint_2(__k);
+ }
+ }
+
+
+ /**
+ * @brief Return the Carlson elliptic function
+ * @f$ R_C(x,y) = R_F(x,y,y) @f$ where @f$ R_F(x,y,z) @f$
+ * is the Carlson elliptic function of the first kind.
+ *
+ * The Carlson elliptic function is defined by:
+ * @f[
+ * R_C(x,y) = \frac{1}{2} \int_0^\infty
+ * \frac{dt}{(t + x)^{1/2}(t + y)}
+ * @f]
+ *
+ * Based on Carlson's algorithms:
+ * - B. C. Carlson Numer. Math. 33, 1 (1979)
+ * - B. C. Carlson, Special Functions of Applied Mathematics (1977)
+ * - Nunerical Recipes in C, 2nd ed, pp. 261-269,
+ * by Press, Teukolsky, Vetterling, Flannery (1992)
+ *
+ * @param __x The first argument.
+ * @param __y The second argument.
+ * @return The Carlson elliptic function.
+ */
+ template<typename _Tp>
+ _Tp
+ __ellint_rc(const _Tp __x, const _Tp __y)
+ {
+ const _Tp __min = std::numeric_limits<_Tp>::min();
+ const _Tp __max = std::numeric_limits<_Tp>::max();
+ const _Tp __lolim = _Tp(5) * __min;
+ const _Tp __uplim = __max / _Tp(5);
+
+ if (__x < _Tp(0) || __y < _Tp(0) || __x + __y < __lolim)
+ std::__throw_domain_error(__N("Argument less than zero "
+ "in __ellint_rc."));
+ else
+ {
+ const _Tp __c0 = _Tp(1) / _Tp(4);
+ const _Tp __c1 = _Tp(1) / _Tp(7);
+ const _Tp __c2 = _Tp(9) / _Tp(22);
+ const _Tp __c3 = _Tp(3) / _Tp(10);
+ const _Tp __c4 = _Tp(3) / _Tp(8);
+
+ _Tp __xn = __x;
+ _Tp __yn = __y;
+
+ const _Tp __eps = std::numeric_limits<_Tp>::epsilon();
+ const _Tp __errtol = std::pow(__eps / _Tp(30), _Tp(1) / _Tp(6));
+ _Tp __mu;
+ _Tp __sn;
+
+ const unsigned int __max_iter = 100;
+ for (unsigned int __iter = 0; __iter < __max_iter; ++__iter)
+ {
+ __mu = (__xn + _Tp(2) * __yn) / _Tp(3);
+ __sn = (__yn + __mu) / __mu - _Tp(2);
+ if (std::abs(__sn) < __errtol)
+ break;
+ const _Tp __lambda = _Tp(2) * std::sqrt(__xn) * std::sqrt(__yn)
+ + __yn;
+ __xn = __c0 * (__xn + __lambda);
+ __yn = __c0 * (__yn + __lambda);
+ }
+
+ _Tp __s = __sn * __sn
+ * (__c3 + __sn*(__c1 + __sn * (__c4 + __sn * __c2)));
+
+ return (_Tp(1) + __s) / std::sqrt(__mu);
+ }
+ }
+
+
+ /**
+ * @brief Return the Carlson elliptic function @f$ R_J(x,y,z,p) @f$
+ * of the third kind.
+ *
+ * The Carlson elliptic function of the third kind is defined by:
+ * @f[
+ * R_J(x,y,z,p) = \frac{3}{2} \int_0^\infty
+ * \frac{dt}{(t + x)^{1/2}(t + y)^{1/2}(t + z)^{1/2}(t + p)}
+ * @f]
+ *
+ * Based on Carlson's algorithms:
+ * - B. C. Carlson Numer. Math. 33, 1 (1979)
+ * - B. C. Carlson, Special Functions of Applied Mathematics (1977)
+ * - Nunerical Recipes in C, 2nd ed, pp. 261-269,
+ * by Press, Teukolsky, Vetterling, Flannery (1992)
+ *
+ * @param __x The first of three symmetric arguments.
+ * @param __y The second of three symmetric arguments.
+ * @param __z The third of three symmetric arguments.
+ * @param __p The fourth argument.
+ * @return The Carlson elliptic function of the fourth kind.
+ */
+ template<typename _Tp>
+ _Tp
+ __ellint_rj(const _Tp __x, const _Tp __y, const _Tp __z, const _Tp __p)
+ {
+ const _Tp __min = std::numeric_limits<_Tp>::min();
+ const _Tp __max = std::numeric_limits<_Tp>::max();
+ const _Tp __lolim = std::pow(_Tp(5) * __min, _Tp(1)/_Tp(3));
+ const _Tp __uplim = _Tp(0.3L)
+ * std::pow(_Tp(0.2L) * __max, _Tp(1)/_Tp(3));
+
+ if (__x < _Tp(0) || __y < _Tp(0) || __z < _Tp(0))
+ std::__throw_domain_error(__N("Argument less than zero "
+ "in __ellint_rj."));
+ else if (__x + __y < __lolim || __x + __z < __lolim
+ || __y + __z < __lolim || __p < __lolim)
+ std::__throw_domain_error(__N("Argument too small "
+ "in __ellint_rj"));
+ else
+ {
+ const _Tp __c0 = _Tp(1) / _Tp(4);
+ const _Tp __c1 = _Tp(3) / _Tp(14);
+ const _Tp __c2 = _Tp(1) / _Tp(3);
+ const _Tp __c3 = _Tp(3) / _Tp(22);
+ const _Tp __c4 = _Tp(3) / _Tp(26);
+
+ _Tp __xn = __x;
+ _Tp __yn = __y;
+ _Tp __zn = __z;
+ _Tp __pn = __p;
+ _Tp __sigma = _Tp(0);
+ _Tp __power4 = _Tp(1);
+
+ const _Tp __eps = std::numeric_limits<_Tp>::epsilon();
+ const _Tp __errtol = std::pow(__eps / _Tp(8), _Tp(1) / _Tp(6));
+
+ _Tp __lambda, __mu;
+ _Tp __xndev, __yndev, __zndev, __pndev;
+
+ const unsigned int __max_iter = 100;
+ for (unsigned int __iter = 0; __iter < __max_iter; ++__iter)
+ {
+ __mu = (__xn + __yn + __zn + _Tp(2) * __pn) / _Tp(5);
+ __xndev = (__mu - __xn) / __mu;
+ __yndev = (__mu - __yn) / __mu;
+ __zndev = (__mu - __zn) / __mu;
+ __pndev = (__mu - __pn) / __mu;
+ _Tp __epsilon = std::max(std::abs(__xndev), std::abs(__yndev));
+ __epsilon = std::max(__epsilon, std::abs(__zndev));
+ __epsilon = std::max(__epsilon, std::abs(__pndev));
+ if (__epsilon < __errtol)
+ break;
+ const _Tp __xnroot = std::sqrt(__xn);
+ const _Tp __ynroot = std::sqrt(__yn);
+ const _Tp __znroot = std::sqrt(__zn);
+ const _Tp __lambda = __xnroot * (__ynroot + __znroot)
+ + __ynroot * __znroot;
+ const _Tp __alpha = __pn * (__xnroot + __ynroot + __znroot)
+ + __xnroot * __ynroot * __znroot;
+ const _Tp __alpha2 = __alpha * __alpha;
+ const _Tp __beta = __pn * (__pn + __lambda)
+ * (__pn + __lambda);
+ __sigma += __power4 * __ellint_rc(__alpha2, __beta);
+ __power4 *= __c0;
+ __xn = __c0 * (__xn + __lambda);
+ __yn = __c0 * (__yn + __lambda);
+ __zn = __c0 * (__zn + __lambda);
+ __pn = __c0 * (__pn + __lambda);
+ }
+
+ _Tp __ea = __xndev * (__yndev + __zndev) + __yndev * __zndev;
+ _Tp __eb = __xndev * __yndev * __zndev;
+ _Tp __ec = __pndev * __pndev;
+ _Tp __e2 = __ea - _Tp(3) * __ec;
+ _Tp __e3 = __eb + _Tp(2) * __pndev * (__ea - __ec);
+ _Tp __s1 = _Tp(1) + __e2 * (-__c1 + _Tp(3) * __c3 * __e2 / _Tp(4)
+ - _Tp(3) * __c4 * __e3 / _Tp(2));
+ _Tp __s2 = __eb * (__c2 / _Tp(2)
+ + __pndev * (-__c3 - __c3 + __pndev * __c4));
+ _Tp __s3 = __pndev * __ea * (__c2 - __pndev * __c3)
+ - __c2 * __pndev * __ec;
+
+ return _Tp(3) * __sigma + __power4 * (__s1 + __s2 + __s3)
+ / (__mu * std::sqrt(__mu));
+ }
+ }
+
+
+ /**
+ * @brief Return the complete elliptic integral of the third kind
+ * @f$ \Pi(k,\nu) = \Pi(k,\nu,\pi/2) @f$ using the
+ * Carlson formulation.
+ *
+ * The complete elliptic integral of the third kind is defined as
+ * @f[
+ * \Pi(k,\nu) = \int_0^{\pi/2}
+ * \frac{d\theta}
+ * {(1 - \nu \sin^2\theta)\sqrt{1 - k^2 \sin^2\theta}}
+ * @f]
+ *
+ * @param __k The argument of the elliptic function.
+ * @param __nu The second argument of the elliptic function.
+ * @return The complete elliptic function of the third kind.
+ */
+ template<typename _Tp>
+ _Tp
+ __comp_ellint_3(const _Tp __k, const _Tp __nu)
+ {
+
+ if (__isnan(__k) || __isnan(__nu))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (__nu == _Tp(1))
+ return std::numeric_limits<_Tp>::infinity();
+ else if (std::abs(__k) > _Tp(1))
+ std::__throw_domain_error(__N("Bad argument in __comp_ellint_3."));
+ else
+ {
+ const _Tp __kk = __k * __k;
+
+ return __ellint_rf(_Tp(0), _Tp(1) - __kk, _Tp(1))
+ - __nu
+ * __ellint_rj(_Tp(0), _Tp(1) - __kk, _Tp(1), _Tp(1) + __nu)
+ / _Tp(3);
+ }
+ }
+
+
+ /**
+ * @brief Return the incomplete elliptic integral of the third kind
+ * @f$ \Pi(k,\nu,\phi) @f$ using the Carlson formulation.
+ *
+ * The incomplete elliptic integral of the third kind is defined as
+ * @f[
+ * \Pi(k,\nu,\phi) = \int_0^{\phi}
+ * \frac{d\theta}
+ * {(1 - \nu \sin^2\theta)
+ * \sqrt{1 - k^2 \sin^2\theta}}
+ * @f]
+ *
+ * @param __k The argument of the elliptic function.
+ * @param __nu The second argument of the elliptic function.
+ * @param __phi The integral limit argument of the elliptic function.
+ * @return The elliptic function of the third kind.
+ */
+ template<typename _Tp>
+ _Tp
+ __ellint_3(const _Tp __k, const _Tp __nu, const _Tp __phi)
+ {
+
+ if (__isnan(__k) || __isnan(__nu) || __isnan(__phi))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (std::abs(__k) > _Tp(1))
+ std::__throw_domain_error(__N("Bad argument in __ellint_3."));
+ else
+ {
+ // Reduce phi to -pi/2 < phi < +pi/2.
+ const int __n = std::floor(__phi / __numeric_constants<_Tp>::__pi()
+ + _Tp(0.5L));
+ const _Tp __phi_red = __phi
+ - __n * __numeric_constants<_Tp>::__pi();
+
+ const _Tp __kk = __k * __k;
+ const _Tp __s = std::sin(__phi_red);
+ const _Tp __ss = __s * __s;
+ const _Tp __sss = __ss * __s;
+ const _Tp __c = std::cos(__phi_red);
+ const _Tp __cc = __c * __c;
+
+ const _Tp __Pi = __s
+ * __ellint_rf(__cc, _Tp(1) - __kk * __ss, _Tp(1))
+ - __nu * __sss
+ * __ellint_rj(__cc, _Tp(1) - __kk * __ss, _Tp(1),
+ _Tp(1) + __nu * __ss) / _Tp(3);
+
+ if (__n == 0)
+ return __Pi;
+ else
+ return __Pi + _Tp(2) * __n * __comp_ellint_3(__k, __nu);
+ }
+ }
+
+ } // namespace std::tr1::__detail
+
+ /* @} */ // group tr1_math_spec_func
+
+_GLIBCXX_END_NAMESPACE
+}
+
+#endif // _TR1_ELL_INTEGRAL_TCC
+
diff --git a/libstdc++-v3/include/tr1/exp_integral.tcc b/libstdc++-v3/include/tr1/exp_integral.tcc
new file mode 100644
index 00000000000..d6acc72dba1
--- /dev/null
+++ b/libstdc++-v3/include/tr1/exp_integral.tcc
@@ -0,0 +1,538 @@
+// Special functions -*- C++ -*-
+
+// Copyright (C) 2006-2007
+// Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+// USA.
+//
+// As a special exception, you may use this file as part of a free software
+// library without restriction. Specifically, if other files instantiate
+// templates or use macros or inline functions from this file, or you compile
+// this file and link it with other files to produce an executable, this
+// file does not by itself cause the resulting executable to be covered by
+// the GNU General Public License. This exception does not however
+// invalidate any other reasons why the executable file might be covered by
+// the GNU General Public License.
+
+/** @file tr1/exp_integral.tcc
+ * This is an internal header file, included by other library headers.
+ * You should not attempt to use it directly.
+ */
+
+//
+// ISO C++ 14882 TR1: 5.2 Special functions
+//
+
+// Written by Edward Smith-Rowland based on:
+//
+// (1) Handbook of Mathematical Functions,
+// Ed. by Milton Abramowitz and Irene A. Stegun,
+// Dover Publications, New-York, Section 5, pp. 228-251.
+// (2) The Gnu Scientific Library, http://www.gnu.org/software/gsl
+// (3) Numerical Recipes in C, by W. H. Press, S. A. Teukolsky,
+// W. T. Vetterling, B. P. Flannery, Cambridge University Press (1992),
+// 2nd ed, pp. 222-225.
+//
+
+#ifndef _TR1_EXP_INTEGRAL_TCC
+#define _TR1_EXP_INTEGRAL_TCC 1
+
+#include "special_function_util.h"
+
+namespace std
+{
+_GLIBCXX_BEGIN_NAMESPACE(_GLIBCXX_TR1)
+
+ // [5.2] Special functions
+
+ /**
+ * @ingroup tr1_math_spec_func
+ * @{
+ */
+
+ //
+ // Implementation-space details.
+ //
+ namespace __detail
+ {
+
+ /**
+ * @brief Return the exponential integral @f$ E_1(x) @f$
+ * by series summation. This should be good
+ * for @f$ x < 1 @f$.
+ *
+ * The exponential integral is given by
+ * \f[
+ * E_1(x) = \int_{1}^{\infty} \frac{e^{-xt}}{t} dt
+ * \f]
+ *
+ * @param __x The argument of the exponential integral function.
+ * @return The exponential integral.
+ */
+ template<typename _Tp>
+ _Tp
+ __expint_E1_series(const _Tp __x)
+ {
+ const _Tp __eps = std::numeric_limits<_Tp>::epsilon();
+ _Tp __term = _Tp(1);
+ _Tp __esum = _Tp(0);
+ _Tp __osum = _Tp(0);
+ const unsigned int __max_iter = 100;
+ for (unsigned int __i = 1; __i < __max_iter; ++__i)
+ {
+ __term *= - __x / __i;
+ if (std::abs(__term) < __eps)
+ break;
+ if (__term >= _Tp(0))
+ __esum += __term / __i;
+ else
+ __osum += __term / __i;
+ }
+
+ return - __esum - __osum
+ - __numeric_constants<_Tp>::__gamma_e() - std::log(__x);
+ }
+
+
+ /**
+ * @brief Return the exponential integral @f$ E_1(x) @f$
+ * by asymptotic expansion.
+ *
+ * The exponential integral is given by
+ * \f[
+ * E_1(x) = \int_{1}^\infty \frac{e^{-xt}}{t} dt
+ * \f]
+ *
+ * @param __x The argument of the exponential integral function.
+ * @return The exponential integral.
+ */
+ template<typename _Tp>
+ _Tp
+ __expint_E1_asymp(const _Tp __x)
+ {
+ _Tp __term = _Tp(1);
+ _Tp __esum = _Tp(1);
+ _Tp __osum = _Tp(0);
+ const unsigned int __max_iter = 1000;
+ for (unsigned int __i = 1; __i < __max_iter; ++__i)
+ {
+ _Tp __prev = __term;
+ __term *= - __i / __x;
+ if (std::abs(__term) > std::abs(__prev))
+ break;
+ if (__term >= _Tp(0))
+ __esum += __term;
+ else
+ __osum += __term;
+ }
+
+ return std::exp(- __x) * (__esum + __osum) / __x;
+ }
+
+
+ /**
+ * @brief Return the exponential integral @f$ E_n(x) @f$
+ * by series summation.
+ *
+ * The exponential integral is given by
+ * \f[
+ * E_n(x) = \int_{1}^\infty \frac{e^{-xt}}{t^n} dt
+ * \f]
+ *
+ * @param __n The order of the exponential integral function.
+ * @param __x The argument of the exponential integral function.
+ * @return The exponential integral.
+ */
+ template<typename _Tp>
+ _Tp
+ __expint_En_series(const unsigned int __n, const _Tp __x)
+ {
+ const unsigned int __max_iter = 100;
+ const _Tp __eps = std::numeric_limits<_Tp>::epsilon();
+ const int __nm1 = __n - 1;
+ _Tp __ans = (__nm1 != 0
+ ? _Tp(1) / __nm1 : -std::log(__x)
+ - __numeric_constants<_Tp>::__gamma_e());
+ _Tp __fact = _Tp(1);
+ for (int __i = 1; __i <= __max_iter; ++__i)
+ {
+ __fact *= -__x / _Tp(__i);
+ _Tp __del;
+ if ( __i != __nm1 )
+ __del = -__fact / _Tp(__i - __nm1);
+ else
+ {
+ _Tp __psi = -_TR1_GAMMA_TCC;
+ for (int __ii = 1; __ii <= __nm1; ++__ii)
+ __psi += _Tp(1) / _Tp(__ii);
+ __del = __fact * (__psi - std::log(__x));
+ }
+ __ans += __del;
+ if (std::abs(__del) < __eps * std::abs(__ans))
+ return __ans;
+ }
+ std::__throw_runtime_error(__N("Series summation failed "
+ "in __expint_En_series."));
+ }
+
+
+ /**
+ * @brief Return the exponential integral @f$ E_n(x) @f$
+ * by continued fractions.
+ *
+ * The exponential integral is given by
+ * \f[
+ * E_n(x) = \int_{1}^\infty \frac{e^{-xt}}{t^n} dt
+ * \f]
+ *
+ * @param __n The order of the exponential integral function.
+ * @param __x The argument of the exponential integral function.
+ * @return The exponential integral.
+ */
+ template<typename _Tp>
+ _Tp
+ __expint_En_cont_frac(const unsigned int __n, const _Tp __x)
+ {
+ const unsigned int __max_iter = 100;
+ const _Tp __eps = std::numeric_limits<_Tp>::epsilon();
+ const _Tp __fp_min = std::numeric_limits<_Tp>::min();
+ const int __nm1 = __n - 1;
+ _Tp __b = __x + _Tp(__n);
+ _Tp __c = _Tp(1) / __fp_min;
+ _Tp __d = _Tp(1) / __b;
+ _Tp __h = __d;
+ for ( unsigned int __i = 1; __i <= __max_iter; ++__i )
+ {
+ _Tp __a = -_Tp(__i * (__nm1 + __i));
+ __b += _Tp(2);
+ __d = _Tp(1) / (__a * __d + __b);
+ __c = __b + __a / __c;
+ const _Tp __del = __c * __d;
+ __h *= __del;
+ if (std::abs(__del - _Tp(1)) < __eps)
+ {
+ const _Tp __ans = __h * std::exp(-__x);
+ return __ans;
+ }
+ }
+ std::__throw_runtime_error(__N("Continued fraction failed "
+ "in __expint_En_cont_frac."));
+ }
+
+
+ /**
+ * @brief Return the exponential integral @f$ E_n(x) @f$
+ * by recursion. Use upward recursion for @f$ x < n @f$
+ * and downward recursion (Miller's algorithm) otherwise.
+ *
+ * The exponential integral is given by
+ * \f[
+ * E_n(x) = \int_{1}^\infty \frac{e^{-xt}}{t^n} dt
+ * \f]
+ *
+ * @param __n The order of the exponential integral function.
+ * @param __x The argument of the exponential integral function.
+ * @return The exponential integral.
+ */
+ template<typename _Tp>
+ _Tp
+ __expint_En_recursion(const unsigned int __n, const _Tp __x)
+ {
+ _Tp __En;
+ _Tp __E1 = __expint_E1(__x);
+ if (__x < _Tp(__n))
+ {
+ // Forward recursion is stable only for n < x.
+ __En = __E1;
+ for (unsigned int __j = 2; __j < __n; ++__j)
+ __En = (std::exp(-__x) - __x * __En) / _Tp(__j - 1);
+ }
+ else
+ {
+ // Backward recursion is stable only for n >= x.
+ __En = _Tp(1);
+ const int __N = __n + 20; // TODO: Check this starting number.
+ _Tp __save = _Tp(0);
+ for (int __j = __N; __j > 0; --__j)
+ {
+ __En = (std::exp(-__x) - __j * __En) / __x;
+ if (__j == __n)
+ __save = __En;
+ }
+ _Tp __norm = __En / __E1;
+ __En /= __norm;
+ }
+
+ return __En;
+ }
+
+ /**
+ * @brief Return the exponential integral @f$ Ei(x) @f$
+ * by series summation.
+ *
+ * The exponential integral is given by
+ * \f[
+ * Ei(x) = -\int_{-x}^\infty \frac{e^t}{t} dt
+ * \f]
+ *
+ * @param __x The argument of the exponential integral function.
+ * @return The exponential integral.
+ */
+ template<typename _Tp>
+ _Tp
+ __expint_Ei_series(const _Tp __x)
+ {
+ _Tp __term = _Tp(1);
+ _Tp __sum = _Tp(0);
+ const unsigned int __max_iter = 1000;
+ for (unsigned int __i = 1; __i < __max_iter; ++__i)
+ {
+ __term *= __x / __i;
+ __sum += __term / __i;
+ if (__term < std::numeric_limits<_Tp>::epsilon() * __sum)
+ break;
+ }
+
+ return __numeric_constants<_Tp>::__gamma_e() + __sum + std::log(__x);
+ }
+
+
+ /**
+ * @brief Return the exponential integral @f$ Ei(x) @f$
+ * by asymptotic expansion.
+ *
+ * The exponential integral is given by
+ * \f[
+ * Ei(x) = -\int_{-x}^\infty \frac{e^t}{t} dt
+ * \f]
+ *
+ * @param __x The argument of the exponential integral function.
+ * @return The exponential integral.
+ */
+ template<typename _Tp>
+ _Tp
+ __expint_Ei_asymp(const _Tp __x)
+ {
+ _Tp __term = _Tp(1);
+ _Tp __sum = _Tp(1);
+ const unsigned int __max_iter = 1000;
+ for (unsigned int __i = 1; __i < __max_iter; ++__i)
+ {
+ _Tp __prev = __term;
+ __term *= __i / __x;
+ if (__term < std::numeric_limits<_Tp>::epsilon())
+ break;
+ if (__term >= __prev)
+ break;
+ __sum += __term;
+ }
+
+ return std::exp(__x) * __sum / __x;
+ }
+
+
+ /**
+ * @brief Return the exponential integral @f$ Ei(x) @f$.
+ *
+ * The exponential integral is given by
+ * \f[
+ * Ei(x) = -\int_{-x}^\infty \frac{e^t}{t} dt
+ * \f]
+ *
+ * @param __x The argument of the exponential integral function.
+ * @return The exponential integral.
+ */
+ template<typename _Tp>
+ _Tp
+ __expint_Ei(const _Tp __x)
+ {
+ if (__x < _Tp(0))
+ return -__expint_E1(-__x);
+ else if (__x < -std::log(std::numeric_limits<_Tp>::epsilon()))
+ return __expint_Ei_series(__x);
+ else
+ return __expint_Ei_asymp(__x);
+ }
+
+
+ /**
+ * @brief Return the exponential integral @f$ E_1(x) @f$.
+ *
+ * The exponential integral is given by
+ * \f[
+ * E_1(x) = \int_{1}^\infty \frac{e^{-xt}}{t} dt
+ * \f]
+ *
+ * @param __x The argument of the exponential integral function.
+ * @return The exponential integral.
+ */
+ template<typename _Tp>
+ _Tp
+ __expint_E1(const _Tp __x)
+ {
+ if (__x < _Tp(0))
+ return -__expint_Ei(-__x);
+ else if (__x < _Tp(1))
+ return __expint_E1_series(__x);
+ else if (__x < _Tp(100)) // TODO: Find a good asymptotic switch point.
+ return __expint_En_cont_frac(1, __x);
+ else
+ return __expint_E1_asymp(__x);
+ }
+
+
+ /**
+ * @brief Return the exponential integral @f$ E_n(x) @f$
+ * for large argument.
+ *
+ * The exponential integral is given by
+ * \f[
+ * E_n(x) = \int_{1}^\infty \frac{e^{-xt}}{t^n} dt
+ * \f]
+ *
+ * This is something of an extension.
+ *
+ * @param __n The order of the exponential integral function.
+ * @param __x The argument of the exponential integral function.
+ * @return The exponential integral.
+ */
+ template<typename _Tp>
+ _Tp
+ __expint_asymp(const unsigned int __n, const _Tp __x)
+ {
+ _Tp __term = _Tp(1);
+ _Tp __sum = _Tp(1);
+ for (unsigned int __i = 1; __i <= __n; ++__i)
+ {
+ _Tp __prev = __term;
+ __term *= -(__n - __i + 1) / __x;
+ if (std::abs(__term) > std::abs(__prev))
+ break;
+ __sum += __term;
+ }
+
+ return std::exp(-__x) * __sum / __x;
+ }
+
+
+ /**
+ * @brief Return the exponential integral @f$ E_n(x) @f$
+ * for large order.
+ *
+ * The exponential integral is given by
+ * \f[
+ * E_n(x) = \int_{1}^\infty \frac{e^{-xt}}{t^n} dt
+ * \f]
+ *
+ * This is something of an extension.
+ *
+ * @param __n The order of the exponential integral function.
+ * @param __x The argument of the exponential integral function.
+ * @return The exponential integral.
+ */
+ template<typename _Tp>
+ _Tp
+ __expint_large_n(const unsigned int __n, const _Tp __x)
+ {
+ const _Tp __xpn = __x + __n;
+ const _Tp __xpn2 = __xpn * __xpn;
+ _Tp __term = _Tp(1);
+ _Tp __sum = _Tp(1);
+ for (unsigned int __i = 1; __i <= __n; ++__i)
+ {
+ _Tp __prev = __term;
+ __term *= (__n - 2 * (__i - 1) * __x) / __xpn2;
+ if (std::abs(__term) < std::numeric_limits<_Tp>::epsilon())
+ break;
+ __sum += __term;
+ }
+
+ return std::exp(-__x) * __sum / __xpn;
+ }
+
+
+ /**
+ * @brief Return the exponential integral @f$ E_n(x) @f$.
+ *
+ * The exponential integral is given by
+ * \f[
+ * E_n(x) = \int_{1}^\infty \frac{e^{-xt}}{t^n} dt
+ * \f]
+ * This is something of an extension.
+ *
+ * @param __n The order of the exponential integral function.
+ * @param __x The argument of the exponential integral function.
+ * @return The exponential integral.
+ */
+ template<typename _Tp>
+ _Tp
+ __expint(const unsigned int __n, const _Tp __x)
+ {
+ // Return NaN on NaN input.
+ if (__isnan(__x))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (__n <= 1 && __x == _Tp(0))
+ return std::numeric_limits<_Tp>::infinity();
+ else
+ {
+ _Tp __E0 = std::exp(__x) / __x;
+ if (__n == 0)
+ return __E0;
+
+ _Tp __E1 = __expint_E1(__x);
+ if (__n == 1)
+ return __E1;
+
+ if (__x == _Tp(0))
+ return _Tp(1) / static_cast<_Tp>(__n - 1);
+
+ _Tp __En = __expint_En_recursion(__n, __x);
+
+ return __En;
+ }
+ }
+
+
+ /**
+ * The exponential integral @f$ Ei(x) @f$.
+ *
+ * The exponential integral is given by
+ * \f[
+ * Ei(x) = -\int_{-x}^\infty \frac{e^t}{t} dt
+ * \f]
+ *
+ * @param __x The argument of the exponential integral function.
+ * @return The exponential integral.
+ */
+ template<typename _Tp>
+ inline _Tp
+ __expint(const _Tp __x)
+ {
+ if (__isnan(__x))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else
+ return __expint_Ei(__x);
+ }
+
+ } // namespace std::tr1::__detail
+
+ /* @} */ // group tr1_math_spec_func
+
+_GLIBCXX_END_NAMESPACE
+}
+
+#endif // _TR1_EXP_INTEGRAL_TCC
diff --git a/libstdc++-v3/include/tr1/gamma.tcc b/libstdc++-v3/include/tr1/gamma.tcc
new file mode 100644
index 00000000000..407bafcaf9c
--- /dev/null
+++ b/libstdc++-v3/include/tr1/gamma.tcc
@@ -0,0 +1,486 @@
+// Special functions -*- C++ -*-
+
+// Copyright (C) 2006-2007
+// Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+// USA.
+//
+// As a special exception, you may use this file as part of a free software
+// library without restriction. Specifically, if other files instantiate
+// templates or use macros or inline functions from this file, or you compile
+// this file and link it with other files to produce an executable, this
+// file does not by itself cause the resulting executable to be covered by
+// the GNU General Public License. This exception does not however
+// invalidate any other reasons why the executable file might be covered by
+// the GNU General Public License.
+
+/** @file tr1/gamma.tcc
+ * This is an internal header file, included by other library headers.
+ * You should not attempt to use it directly.
+ */
+
+//
+// ISO C++ 14882 TR1: 5.2 Special functions
+//
+
+// Written by Edward Smith-Rowland based on:
+// (1) Handbook of Mathematical Functions,
+// ed. Milton Abramowitz and Irene A. Stegun,
+// Dover Publications,
+// Section 6, pp. 253-266
+// (2) The Gnu Scientific Library, http://www.gnu.org/software/gsl
+// (3) Numerical Recipes in C, by W. H. Press, S. A. Teukolsky,
+// W. T. Vetterling, B. P. Flannery, Cambridge University Press (1992),
+// 2nd ed, pp. 213-216
+// (4) Gamma, Exploring Euler's Constant, Julian Havil,
+// Princeton, 2003.
+
+#ifndef _TR1_GAMMA_TCC
+#define _TR1_GAMMA_TCC 1
+
+#include "special_function_util.h"
+
+namespace std
+{
+_GLIBCXX_BEGIN_NAMESPACE(_GLIBCXX_TR1)
+
+ /**
+ * @ingroup tr1_math_spec_func
+ * @{
+ */
+
+ //
+ // Implementation-space details.
+ //
+ namespace __detail
+ {
+
+ /**
+ * @brief This returns Bernoulli numbers from a table or by summation
+ * for larger values.
+ *
+ * Recursion is unstable.
+ *
+ * @param __n the order n of the Bernoulli number.
+ * @return The Bernoulli number of order n.
+ */
+ template <typename _Tp>
+ _Tp __bernoulli_series(unsigned int __n)
+ {
+
+ static const _Tp __num[28] = {
+ _Tp(1UL), -_Tp(1UL) / _Tp(2UL),
+ _Tp(1UL) / _Tp(6UL), _Tp(0UL),
+ -_Tp(1UL) / _Tp(30UL), _Tp(0UL),
+ _Tp(1UL) / _Tp(42UL), _Tp(0UL),
+ -_Tp(1UL) / _Tp(30UL), _Tp(0UL),
+ _Tp(5UL) / _Tp(66UL), _Tp(0UL),
+ -_Tp(691UL) / _Tp(2730UL), _Tp(0UL),
+ _Tp(7UL) / _Tp(6UL), _Tp(0UL),
+ -_Tp(3617UL) / _Tp(510UL), _Tp(0UL),
+ _Tp(43867UL) / _Tp(798UL), _Tp(0UL),
+ -_Tp(174611) / _Tp(330UL), _Tp(0UL),
+ _Tp(854513UL) / _Tp(138UL), _Tp(0UL),
+ -_Tp(236364091UL) / _Tp(2730UL), _Tp(0UL),
+ _Tp(8553103UL) / _Tp(6UL), _Tp(0UL)
+ };
+
+ if (__n == 0)
+ return _Tp(1);
+
+ if (__n == 1)
+ return -_Tp(1) / _Tp(2);
+
+ // Take care of the rest of the odd ones.
+ if (__n % 2 == 1)
+ return _Tp(0);
+
+ // Take care of some small evens that are painful for the series.
+ if (__n < 28)
+ return __num[__n];
+
+
+ _Tp __fact = _Tp(1);
+ if ((__n / 2) % 2 == 0)
+ __fact *= _Tp(-1);
+ for (unsigned int __k = 1; __k <= __n; ++__k)
+ __fact *= __k / (_Tp(2) * __numeric_constants<_Tp>::__pi());
+ __fact *= _Tp(2);
+
+ _Tp __sum = _Tp(0);
+ for (unsigned int __i = 1; __i < 1000; ++__i)
+ {
+ _Tp __term = std::pow(_Tp(__i), -_Tp(__n));
+ if (__term < std::numeric_limits<_Tp>::epsilon())
+ break;
+ __sum += __term;
+ }
+
+ return __fact * __sum;
+ }
+
+
+ /**
+ * @brief This returns Bernoulli number \f$B_n\f$.
+ *
+ * @param __n the order n of the Bernoulli number.
+ * @return The Bernoulli number of order n.
+ */
+ template<typename _Tp>
+ inline _Tp
+ __bernoulli(const int __n)
+ {
+ return __bernoulli_series<_Tp>(__n);
+ }
+
+
+ /**
+ * @brief Return \f$log(\Gamma(x))\f$ by asymptotic expansion
+ * with Bernoulli number coefficients. This is like
+ * Sterling's approximation.
+ *
+ * @param __x The argument of the log of the gamma function.
+ * @return The logarithm of the gamma function.
+ */
+ template<typename _Tp>
+ _Tp
+ __log_gamma_bernoulli(const _Tp __x)
+ {
+ _Tp __lg = (__x - _Tp(0.5L)) * std::log(__x) - __x
+ + _Tp(0.5L) * std::log(_Tp(2)
+ * __numeric_constants<_Tp>::__pi());
+
+ const _Tp __xx = __x * __x;
+ _Tp __help = _Tp(1) / __x;
+ for ( unsigned int __i = 1; __i < 20; ++__i )
+ {
+ const _Tp __2i = _Tp(2 * __i);
+ __help /= __2i * (__2i - _Tp(1)) * __xx;
+ __lg += __bernoulli<_Tp>(2 * __i) * __help;
+ }
+
+ return __lg;
+ }
+
+
+ /**
+ * @brief Return \f$log(\Gamma(x))\f$ by the Lanczos method.
+ * This method dominates all others on the positive axis I think.
+ *
+ * @param __x The argument of the log of the gamma function.
+ * @return The logarithm of the gamma function.
+ */
+ template<typename _Tp>
+ _Tp
+ __log_gamma_lanczos(const _Tp __x)
+ {
+ const _Tp __xm1 = __x - _Tp(1);
+
+ static const _Tp __lanczos_cheb_7[9] = {
+ _Tp( 0.99999999999980993227684700473478L),
+ _Tp( 676.520368121885098567009190444019L),
+ _Tp(-1259.13921672240287047156078755283L),
+ _Tp( 771.3234287776530788486528258894L),
+ _Tp(-176.61502916214059906584551354L),
+ _Tp( 12.507343278686904814458936853L),
+ _Tp(-0.13857109526572011689554707L),
+ _Tp( 9.984369578019570859563e-6L),
+ _Tp( 1.50563273514931155834e-7L)
+ };
+
+ static const _Tp __LOGROOT2PI
+ = _Tp(0.9189385332046727417803297364056176L);
+
+ _Tp __sum = __lanczos_cheb_7[0];
+ for(unsigned int __k = 1; __k < 9; ++__k)
+ __sum += __lanczos_cheb_7[__k] / (__xm1 + __k);
+
+ const _Tp __term1 = (__xm1 + _Tp(0.5L))
+ * std::log((__xm1 + _Tp(7.5L))
+ / __numeric_constants<_Tp>::__euler());
+ const _Tp __term2 = __LOGROOT2PI + std::log(__sum);
+ const _Tp __result = __term1 + (__term2 - _Tp(7));
+
+ return __result;
+ }
+
+
+ /**
+ * @brief Return \f$ log(|\Gamma(x)|) \f$.
+ * This will return values even for \f$ x < 0 \f$.
+ * To recover the sign of \f$ \Gamma(x) \f$ for
+ * any argument use @a __log_gamma_sign.
+ *
+ * @param __x The argument of the log of the gamma function.
+ * @return The logarithm of the gamma function.
+ */
+ template<typename _Tp>
+ _Tp
+ __log_gamma(const _Tp __x)
+ {
+ if (__x > _Tp(0.5L))
+ return __log_gamma_lanczos(__x);
+ else
+ {
+ const _Tp __sin_fact
+ = std::abs(std::sin(__numeric_constants<_Tp>::__pi() * __x));
+ if (__sin_fact == _Tp(0))
+ std::__throw_domain_error(__N("Argument is nonpositive integer "
+ "in __log_gamma"));
+ return __numeric_constants<_Tp>::__lnpi()
+ - std::log(__sin_fact)
+ - __log_gamma_lanczos(_Tp(1) - __x);
+ }
+ }
+
+
+ /**
+ * @brief Return the sign of \f$ \Gamma(x) \f$.
+ * At nonpositive integers zero is returned.
+ *
+ * @param __x The argument of the gamma function.
+ * @return The sign of the gamma function.
+ */
+ template<typename _Tp>
+ _Tp
+ __log_gamma_sign(const _Tp __x)
+ {
+ if (__x > _Tp(0))
+ return _Tp(1);
+ else
+ {
+ const _Tp __sin_fact
+ = std::sin(__numeric_constants<_Tp>::__pi() * __x);
+ if (__sin_fact > _Tp(0))
+ return (1);
+ else if (__sin_fact < _Tp(0))
+ return -_Tp(1);
+ else
+ return _Tp(0);
+ }
+ }
+
+
+ /**
+ * @brief Return the logarithm of the binomial coefficient.
+ * The binomial coefficient is given by:
+ * @f[
+ * \left( \right) = \frac{n!}{(n-k)! k!}
+ * @f]
+ *
+ * @param __n The first argument of the binomial coefficient.
+ * @param __k The second argument of the binomial coefficient.
+ * @return The binomial coefficient.
+ */
+ template<typename _Tp>
+ _Tp
+ __log_bincoef(const unsigned int __n, const unsigned int __k)
+ {
+ // Max e exponent before overflow.
+ static const _Tp __max_bincoeff
+ = std::numeric_limits<_Tp>::max_exponent10
+ * std::log(_Tp(10)) - _Tp(1);
+#if _GLIBCXX_USE_C99_MATH_TR1
+ _Tp __coeff = std::_GLIBCXX_TR1::lgamma(_Tp(1 + __n))
+ - std::_GLIBCXX_TR1::lgamma(_Tp(1 + __k))
+ - std::_GLIBCXX_TR1::lgamma(_Tp(1 + __n - __k));
+#else
+ _Tp __coeff = __log_gamma(_Tp(1 + __n))
+ - __log_gamma(_Tp(1 + __k))
+ - __log_gamma(_Tp(1 + __n - __k));
+#endif
+ }
+
+
+ /**
+ * @brief Return the binomial coefficient.
+ * The binomial coefficient is given by:
+ * @f[
+ * \left( \right) = \frac{n!}{(n-k)! k!}
+ * @f]
+ *
+ * @param __n The first argument of the binomial coefficient.
+ * @param __k The second argument of the binomial coefficient.
+ * @return The binomial coefficient.
+ */
+ template<typename _Tp>
+ _Tp
+ __bincoef(const unsigned int __n, const unsigned int __k)
+ {
+ // Max e exponent before overflow.
+ static const _Tp __max_bincoeff
+ = std::numeric_limits<_Tp>::max_exponent10
+ * std::log(_Tp(10)) - _Tp(1);
+
+ const _Tp __log_coeff = __log_bincoef<_Tp>(__n, __k);
+ if (__log_coeff > __max_bincoeff)
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else
+ return std::exp(__log_coeff);
+ }
+
+
+ /**
+ * @brief Return \f$ \Gamma(x) \f$.
+ *
+ * @param __x The argument of the gamma function.
+ * @return The gamma function.
+ */
+ template<typename _Tp>
+ inline _Tp
+ __gamma(const _Tp __x)
+ {
+ return std::exp(__log_gamma(__x));
+ }
+
+
+ /**
+ * @brief Return the digamma function by series expansion.
+ * The digamma or @f$ \psi(x) @f$ function is defined by
+ * @f[
+ * \psi(x) = \frac{\Gamma'(x)}{\Gamma(x)}
+ * @f]
+ *
+ * The series is given by:
+ * @f[
+ * \psi(x) = -\gamma_E - \frac{1}{x}
+ * \sum_{k=1}^{\infty} \frac{x}{k(x + k)}
+ * @f]
+ */
+ template<typename _Tp>
+ _Tp
+ __psi_series(const _Tp __x)
+ {
+ _Tp __sum = -__numeric_constants<_Tp>::__gamma_e() - _Tp(1) / __x;
+ const unsigned int __max_iter = 100000;
+ for (unsigned int __k = 1; __k < __max_iter; ++__k)
+ {
+ const _Tp __term = __x / (__k * (__k + __x));
+ __sum += __term;
+ if (std::abs(__term / __sum) < std::numeric_limits<_Tp>::epsilon())
+ break;
+ }
+ return __sum;
+ }
+
+
+ /**
+ * @brief Return the digamma function for large argument.
+ * The digamma or @f$ \psi(x) @f$ function is defined by
+ * @f[
+ * \psi(x) = \frac{Gamma'(x)}{\Gamma(x)}
+ * @f]
+ *
+ * The asymptotic series is given by:
+ * @f[
+ * \psi(x) = \ln(x) - \frac{1}{2x}
+ * - \sum_{n=1}^{\infty} \frac{B_{2n}}{2 n x^{2n}}
+ * @f]
+ */
+ template<typename _Tp>
+ _Tp
+ __psi_asymp(const _Tp __x)
+ {
+ _Tp __sum = std::log(__x) - _Tp(0.5L) / __x;
+ const _Tp __xx = __x * __x;
+ _Tp __xp = __xx;
+ const unsigned int __max_iter = 100;
+ for (unsigned int __k = 1; __k < __max_iter; ++__k)
+ {
+ const _Tp __term = __bernoulli<_Tp>(2 * __k) / (2 * __k * __xp);
+ __sum -= __term;
+ if (std::abs(__term / __sum) < std::numeric_limits<_Tp>::epsilon())
+ break;
+ __xp *= __xx;
+ }
+ return __sum;
+ }
+
+
+ /**
+ * @brief Return the digamma function.
+ * The digamma or @f$ \psi(x) @f$ function is defined by
+ * @f[
+ * \psi(x) = \frac{Gamma'(x)}{\Gamma(x)}
+ * @f]
+ * For negative argument the reflection formula is used:
+ * @f[
+ * \psi(x) = \psi(1-x) - \pi \cot(\pi x)
+ * @f]
+ */
+ template<typename _Tp>
+ _Tp
+ __psi(const _Tp __x)
+ {
+ const int __n = static_cast<int>(__x + 0.5L);
+ const _Tp __eps = _Tp(4) * std::numeric_limits<_Tp>::epsilon();
+ if (__n <= 0 && std::abs(__x - _Tp(__n)) < __eps)
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (__x < _Tp(0))
+ {
+ const _Tp __pi = __numeric_constants<_Tp>::__pi();
+ return __psi(_Tp(1) - __x)
+ - __pi * std::cos(__pi * __x) / std::sin(__pi * __x);
+ }
+ else if (__x > _Tp(100))
+ return __psi_asymp(__x);
+ else
+ return __psi_series(__x);
+ }
+
+
+ /**
+ * @brief Return the polygamma function @f$ \psi^{(n)}(x) @f$.
+ *
+ * The polygamma function is related to the Hurwitz zeta function:
+ * @f[
+ * \psi^{(n)}(x) = (-1)^{n+1} m! \zeta(m+1,x)
+ * @f]
+ */
+ template<typename _Tp>
+ _Tp
+ __psi(const unsigned int __n, const _Tp __x)
+ {
+ if (__x <= _Tp(0))
+ std::__throw_domain_error(__N("Argument out of range "
+ "in __psi"));
+ else if (__n == 0)
+ return __psi(__x);
+ else
+ {
+ const _Tp __hzeta = __hurwitz_zeta(_Tp(__n + 1), __x);
+#if _GLIBCXX_USE_C99_MATH_TR1
+ const _Tp __ln_nfact = std::_GLIBCXX_TR1::lgamma(_Tp(__n + 1));
+#else
+ const _Tp __ln_nfact = __log_gamma(_Tp(__n + 1));
+#endif
+ _Tp __result = std::exp(__ln_nfact) * __hzeta;
+ if (__n % 2 == 1)
+ __result = -__result;
+ return __result;
+ }
+ }
+
+ } // namespace std::tr1::__detail
+
+ /* @} */ // group tr1_math_spec_func
+
+_GLIBCXX_END_NAMESPACE
+}
+
+#endif // _TR1_GAMMA_TCC
+
diff --git a/libstdc++-v3/include/tr1/hypergeometric.tcc b/libstdc++-v3/include/tr1/hypergeometric.tcc
new file mode 100644
index 00000000000..d54e6fecde3
--- /dev/null
+++ b/libstdc++-v3/include/tr1/hypergeometric.tcc
@@ -0,0 +1,788 @@
+// Special functions -*- C++ -*-
+
+// Copyright (C) 2006-2007
+// Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+// USA.
+//
+// As a special exception, you may use this file as part of a free software
+// library without restriction. Specifically, if other files instantiate
+// templates or use macros or inline functions from this file, or you compile
+// this file and link it with other files to produce an executable, this
+// file does not by itself cause the resulting executable to be covered by
+// the GNU General Public License. This exception does not however
+// invalidate any other reasons why the executable file might be covered by
+// the GNU General Public License.
+
+/** @file tr1/hypergeometric.tcc
+ * This is an internal header file, included by other library headers.
+ * You should not attempt to use it directly.
+ */
+
+//
+// ISO C++ 14882 TR1: 5.2 Special functions
+//
+
+// Written by Edward Smith-Rowland based:
+// (1) Handbook of Mathematical Functions,
+// ed. Milton Abramowitz and Irene A. Stegun,
+// Dover Publications,
+// Section 6, pp. 555-566
+// (2) The Gnu Scientific Library, http://www.gnu.org/software/gsl
+
+#ifndef _TR1_HYPERGEOMETRIC_TCC
+#define _TR1_HYPERGEOMETRIC_TCC 1
+
+namespace std
+{
+_GLIBCXX_BEGIN_NAMESPACE(_GLIBCXX_TR1)
+
+ // [5.2] Special functions
+
+ /**
+ * @ingroup tr1_math_spec_func
+ * @{
+ */
+
+ //
+ // Implementation-space details.
+ //
+ namespace __detail
+ {
+
+ /**
+ * @brief This routine returns the confluent hypereometric function
+ * by series expansion.
+ *
+ * @f[
+ * _1F_1(a;c;x) = \frac{\Gamma(c)}{\Gamma(a)}
+ * \sum_{n=0}^{\infty}
+ * \frac{\Gamma(a+n)}{\Gamma(c+n)}
+ * \frac{x^n}{n!}
+ * @f]
+ *
+ * If a and b are integers and a < 0 and either b > 0 or b < a then the
+ * series is a polynomial with a finite number of terms. If b is an integer
+ * and b <= 0 the the confluent hypergeometric function is undefined.
+ *
+ * @param __a The "numerator" parameter.
+ * @param __c The "denominator" parameter.
+ * @param __x The argument of the confluent hypergeometric function.
+ * @return The confluent hypergeometric function.
+ */
+ template<typename _Tp>
+ _Tp
+ __conf_hyperg_series(const _Tp __a, const _Tp __c, const _Tp __x)
+ {
+ const _Tp __eps = std::numeric_limits<_Tp>::epsilon();
+
+ _Tp __term = _Tp(1);
+ _Tp __Fac = _Tp(1);
+ const unsigned int __max_iter = 100000;
+ unsigned int __i;
+ for (__i = 0; __i < __max_iter; ++__i)
+ {
+ __term *= (__a + _Tp(__i)) * __x
+ / ((__c + _Tp(__i)) * _Tp(1 + __i));
+ if (std::abs(__term) < __eps)
+ {
+ break;
+ }
+ __Fac += __term;
+ }
+ if (__i == __max_iter)
+ std::__throw_runtime_error(__N("Series failed to converge "
+ "in __conf_hyperg_series."));
+
+ return __Fac;
+ }
+
+
+ /**
+ * @brief Return the hypogeometric function @f$ _2F_1(a,b;c;x) @f$
+ * by an iterative procedure described in
+ * Luke, Algorithms for the Computation of Mathematical Functions.
+ *
+ * Like the case of the 2F1 rational approximations, these are
+ * probably guaranteed to converge for x < 0, barring gross
+ * numerical instability in the pre-asymptotic regime.
+ */
+ template<typename _Tp>
+ _Tp
+ __conf_hyperg_luke(const _Tp __a, const _Tp __c, const _Tp __xin)
+ {
+ const _Tp __big = std::pow(std::numeric_limits<_Tp>::max(), _Tp(0.16L));
+ const int __nmax = 20000;
+ const _Tp __eps = std::numeric_limits<_Tp>::epsilon();
+ const _Tp __x = -__xin;
+ const _Tp __x3 = __x * __x * __x;
+ const _Tp __t0 = __a / __c;
+ const _Tp __t1 = (__a + _Tp(1)) / (_Tp(2) * __c);
+ const _Tp __t2 = (__a + _Tp(2)) / (_Tp(2) * (__c + _Tp(1)));
+ _Tp __F = _Tp(1);
+ _Tp __prec;
+
+ _Tp __Bnm3 = _Tp(1);
+ _Tp __Bnm2 = _Tp(1) + __t1 * __x;
+ _Tp __Bnm1 = _Tp(1) + __t2 * __x * (_Tp(1) + __t1 / _Tp(3) * __x);
+
+ _Tp __Anm3 = _Tp(1);
+ _Tp __Anm2 = __Bnm2 - __t0 * __x;
+ _Tp __Anm1 = __Bnm1 - __t0 * (_Tp(1) + __t2 * __x) * __x
+ + __t0 * __t1 * (__c / (__c + _Tp(1))) * __x * __x;
+
+ int __n = 3;
+ while(1)
+ {
+ _Tp __npam1 = _Tp(__n - 1) + __a;
+ _Tp __npcm1 = _Tp(__n - 1) + __c;
+ _Tp __npam2 = _Tp(__n - 2) + __a;
+ _Tp __npcm2 = _Tp(__n - 2) + __c;
+ _Tp __tnm1 = _Tp(2 * __n - 1);
+ _Tp __tnm3 = _Tp(2 * __n - 3);
+ _Tp __tnm5 = _Tp(2 * __n - 5);
+ _Tp __F1 = (_Tp(__n - 2) - __a) / (_Tp(2) * __tnm3 * __npcm1);
+ _Tp __F2 = (_Tp(__n) + __a) * __npam1
+ / (_Tp(4) * __tnm1 * __tnm3 * __npcm2 * __npcm1);
+ _Tp __F3 = -__npam2 * __npam1 * (_Tp(__n - 2) - __a)
+ / (_Tp(8) * __tnm3 * __tnm3 * __tnm5
+ * (_Tp(__n - 3) + __c) * __npcm2 * __npcm1);
+ _Tp __E = -__npam1 * (_Tp(__n - 1) - __c)
+ / (_Tp(2) * __tnm3 * __npcm2 * __npcm1);
+
+ _Tp __An = (_Tp(1) + __F1 * __x) * __Anm1
+ + (__E + __F2 * __x) * __x * __Anm2 + __F3 * __x3 * __Anm3;
+ _Tp __Bn = (_Tp(1) + __F1 * __x) * __Bnm1
+ + (__E + __F2 * __x) * __x * __Bnm2 + __F3 * __x3 * __Bnm3;
+ _Tp __r = __An / __Bn;
+
+ __prec = std::abs((__F - __r) / __F);
+ __F = __r;
+
+ if (__prec < __eps || __n > __nmax)
+ break;
+
+ if (std::abs(__An) > __big || std::abs(__Bn) > __big)
+ {
+ __An /= __big;
+ __Bn /= __big;
+ __Anm1 /= __big;
+ __Bnm1 /= __big;
+ __Anm2 /= __big;
+ __Bnm2 /= __big;
+ __Anm3 /= __big;
+ __Bnm3 /= __big;
+ }
+ else if (std::abs(__An) < _Tp(1) / __big
+ || std::abs(__Bn) < _Tp(1) / __big)
+ {
+ __An *= __big;
+ __Bn *= __big;
+ __Anm1 *= __big;
+ __Bnm1 *= __big;
+ __Anm2 *= __big;
+ __Bnm2 *= __big;
+ __Anm3 *= __big;
+ __Bnm3 *= __big;
+ }
+
+ ++__n;
+ __Bnm3 = __Bnm2;
+ __Bnm2 = __Bnm1;
+ __Bnm1 = __Bn;
+ __Anm3 = __Anm2;
+ __Anm2 = __Anm1;
+ __Anm1 = __An;
+ }
+
+ if (__n >= __nmax)
+ std::__throw_runtime_error(__N("Iteration failed to converge "
+ "in __conf_hyperg_luke."));
+
+ return __F;
+ }
+
+
+ /**
+ * @brief Return the confluent hypogeometric function
+ * @f$ _1F_1(a;c;x) @f$.
+ *
+ * @todo Handle b == nonpositive integer blowup - return NaN.
+ *
+ * @param __a The "numerator" parameter.
+ * @param __c The "denominator" parameter.
+ * @param __x The argument of the confluent hypergeometric function.
+ * @return The confluent hypergeometric function.
+ */
+ template<typename _Tp>
+ inline _Tp
+ __conf_hyperg(const _Tp __a, const _Tp __c, const _Tp __x)
+ {
+#if _GLIBCXX_USE_C99_MATH_TR1
+ const _Tp __c_nint = std::_GLIBCXX_TR1::nearbyint(__c);
+#else
+ const _Tp __c_nint = static_cast<int>(__c + _Tp(0.5L));
+#endif
+ if (__isnan(__a) || __isnan(__c) || __isnan(__x))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (__c_nint == __c && __c_nint <= 0)
+ return std::numeric_limits<_Tp>::infinity();
+ else if (__a == _Tp(0))
+ return _Tp(1);
+ else if (__c == __a)
+ return std::exp(__x);
+ else if (__x < _Tp(0))
+ return __conf_hyperg_luke(__a, __c, __x);
+ else
+ return __conf_hyperg_series(__a, __c, __x);
+ }
+
+
+ /**
+ * @brief Return the hypogeometric function @f$ _2F_1(a,b;c;x) @f$
+ * by series expansion.
+ *
+ * The hypogeometric function is defined by
+ * @f[
+ * _2F_1(a,b;c;x) = \frac{\Gamma(c)}{\Gamma(a)\Gamma(b)}
+ * \sum_{n=0}^{\infty}
+ * \frac{\Gamma(a+n)\Gamma(b+n)}{\Gamma(c+n)}
+ * \frac{x^n}{n!}
+ * @f]
+ *
+ * This works and it's pretty fast.
+ *
+ * @param __a The first "numerator" parameter.
+ * @param __a The second "numerator" parameter.
+ * @param __c The "denominator" parameter.
+ * @param __x The argument of the confluent hypergeometric function.
+ * @return The confluent hypergeometric function.
+ */
+ template<typename _Tp>
+ _Tp
+ __hyperg_series(const _Tp __a, const _Tp __b,
+ const _Tp __c, const _Tp __x)
+ {
+ const _Tp __eps = std::numeric_limits<_Tp>::epsilon();
+
+ _Tp __term = _Tp(1);
+ _Tp __Fabc = _Tp(1);
+ const unsigned int __max_iter = 100000;
+ unsigned int __i;
+ for (__i = 0; __i < __max_iter; ++__i)
+ {
+ __term *= (__a + _Tp(__i)) * (__b + _Tp(__i)) * __x
+ / ((__c + _Tp(__i)) * _Tp(1 + __i));
+ if (std::abs(__term) < __eps)
+ {
+ break;
+ }
+ __Fabc += __term;
+ }
+ if (__i == __max_iter)
+ std::__throw_runtime_error(__N("Series failed to converge "
+ "in __hyperg_series."));
+
+ return __Fabc;
+ }
+
+
+ /**
+ * @brief Return the hypogeometric function @f$ _2F_1(a,b;c;x) @f$
+ * by an iterative procedure described in
+ * Luke, Algorithms for the Computation of Mathematical Functions.
+ */
+ template<typename _Tp>
+ _Tp
+ __hyperg_luke(const _Tp __a, const _Tp __b, const _Tp __c,
+ const _Tp __xin)
+ {
+ const _Tp __big = std::pow(std::numeric_limits<_Tp>::max(), _Tp(0.16L));
+ const int __nmax = 20000;
+ const _Tp __eps = std::numeric_limits<_Tp>::epsilon();
+ const _Tp __x = -__xin;
+ const _Tp __x3 = __x * __x * __x;
+ const _Tp __t0 = __a * __b / __c;
+ const _Tp __t1 = (__a + _Tp(1)) * (__b + _Tp(1)) / (_Tp(2) * __c);
+ const _Tp __t2 = (__a + _Tp(2)) * (__b + _Tp(2))
+ / (_Tp(2) * (__c + _Tp(1)));
+
+ _Tp __F = _Tp(1);
+
+ _Tp __Bnm3 = _Tp(1);
+ _Tp __Bnm2 = _Tp(1) + __t1 * __x;
+ _Tp __Bnm1 = _Tp(1) + __t2 * __x * (_Tp(1) + __t1 / _Tp(3) * __x);
+
+ _Tp __Anm3 = _Tp(1);
+ _Tp __Anm2 = __Bnm2 - __t0 * __x;
+ _Tp __Anm1 = __Bnm1 - __t0 * (_Tp(1) + __t2 * __x) * __x
+ + __t0 * __t1 * (__c / (__c + _Tp(1))) * __x * __x;
+
+ int __n = 3;
+ while (1)
+ {
+ const _Tp __npam1 = _Tp(__n - 1) + __a;
+ const _Tp __npbm1 = _Tp(__n - 1) + __b;
+ const _Tp __npcm1 = _Tp(__n - 1) + __c;
+ const _Tp __npam2 = _Tp(__n - 2) + __a;
+ const _Tp __npbm2 = _Tp(__n - 2) + __b;
+ const _Tp __npcm2 = _Tp(__n - 2) + __c;
+ const _Tp __tnm1 = _Tp(2 * __n - 1);
+ const _Tp __tnm3 = _Tp(2 * __n - 3);
+ const _Tp __tnm5 = _Tp(2 * __n - 5);
+ const _Tp __n2 = __n * __n;
+ const _Tp __F1 = (_Tp(3) * __n2 + (__a + __b - _Tp(6)) * __n
+ + _Tp(2) - __a * __b - _Tp(2) * (__a + __b))
+ / (_Tp(2) * __tnm3 * __npcm1);
+ const _Tp __F2 = -(_Tp(3) * __n2 - (__a + __b + _Tp(6)) * __n
+ + _Tp(2) - __a * __b) * __npam1 * __npbm1
+ / (_Tp(4) * __tnm1 * __tnm3 * __npcm2 * __npcm1);
+ const _Tp __F3 = (__npam2 * __npam1 * __npbm2 * __npbm1
+ * (_Tp(__n - 2) - __a) * (_Tp(__n - 2) - __b))
+ / (_Tp(8) * __tnm3 * __tnm3 * __tnm5
+ * (_Tp(__n - 3) + __c) * __npcm2 * __npcm1);
+ const _Tp __E = -__npam1 * __npbm1 * (_Tp(__n - 1) - __c)
+ / (_Tp(2) * __tnm3 * __npcm2 * __npcm1);
+
+ _Tp __An = (_Tp(1) + __F1 * __x) * __Anm1
+ + (__E + __F2 * __x) * __x * __Anm2 + __F3 * __x3 * __Anm3;
+ _Tp __Bn = (_Tp(1) + __F1 * __x) * __Bnm1
+ + (__E + __F2 * __x) * __x * __Bnm2 + __F3 * __x3 * __Bnm3;
+ const _Tp __r = __An / __Bn;
+
+ const _Tp __prec = std::abs((__F - __r) / __F);
+ __F = __r;
+
+ if (__prec < __eps || __n > __nmax)
+ break;
+
+ if (std::abs(__An) > __big || std::abs(__Bn) > __big)
+ {
+ __An /= __big;
+ __Bn /= __big;
+ __Anm1 /= __big;
+ __Bnm1 /= __big;
+ __Anm2 /= __big;
+ __Bnm2 /= __big;
+ __Anm3 /= __big;
+ __Bnm3 /= __big;
+ }
+ else if (std::abs(__An) < _Tp(1) / __big
+ || std::abs(__Bn) < _Tp(1) / __big)
+ {
+ __An *= __big;
+ __Bn *= __big;
+ __Anm1 *= __big;
+ __Bnm1 *= __big;
+ __Anm2 *= __big;
+ __Bnm2 *= __big;
+ __Anm3 *= __big;
+ __Bnm3 *= __big;
+ }
+
+ ++__n;
+ __Bnm3 = __Bnm2;
+ __Bnm2 = __Bnm1;
+ __Bnm1 = __Bn;
+ __Anm3 = __Anm2;
+ __Anm2 = __Anm1;
+ __Anm1 = __An;
+ }
+
+ if (__n >= __nmax)
+ std::__throw_runtime_error(__N("Iteration failed to converge "
+ "in __hyperg_luke."));
+
+ return __F;
+ }
+
+
+ /**
+ * @brief Return the hypogeometric function @f$ _2F_1(a,b;c;x) @f$ by the reflection
+ * formulae in Abramowitz & Stegun formula 15.3.6 for d = c - a - b not integral
+ * and formula 15.3.11 for d = c - a - b integral.
+ * This assumes a, b, c != negative integer.
+ *
+ * The hypogeometric function is defined by
+ * @f[
+ * _2F_1(a,b;c;x) = \frac{\Gamma(c)}{\Gamma(a)\Gamma(b)}
+ * \sum_{n=0}^{\infty}
+ * \frac{\Gamma(a+n)\Gamma(b+n)}{\Gamma(c+n)}
+ * \frac{x^n}{n!}
+ * @f]
+ *
+ * The reflection formula for nonintegral @f$ d = c - a - b @f$ is:
+ * @f[
+ * _2F_1(a,b;c;x) = \frac{\Gamma(c)\Gamma(d)}{\Gamma(c-a)\Gamma(c-b)}
+ * _2F_1(a,b;1-d;1-x)
+ * + \frac{\Gamma(c)\Gamma(-d)}{\Gamma(a)\Gamma(b)}
+ * _2F_1(c-a,c-b;1+d;1-x)
+ * @f]
+ *
+ * The reflection formula for integral @f$ m = c - a - b @f$ is:
+ * @f[
+ * _2F_1(a,b;a+b+m;x) = \frac{\Gamma(m)\Gamma(a+b+m)}{\Gamma(a+m)\Gamma(b+m)}
+ * \sum_{k=0}^{m-1} \frac{(m+a)_k(m+b)_k}{k!(1-m)_k}
+ * -
+ * @f]
+ */
+ template<typename _Tp>
+ _Tp
+ __hyperg_reflect(const _Tp __a, const _Tp __b, const _Tp __c,
+ const _Tp __x)
+ {
+ const _Tp __d = __c - __a - __b;
+ const int __intd = std::floor(__d + _Tp(0.5L));
+ const _Tp __eps = std::numeric_limits<_Tp>::epsilon();
+ const _Tp __toler = _Tp(1000) * __eps;
+ const _Tp __log_max = std::log(std::numeric_limits<_Tp>::max());
+ const bool __d_integer = (std::abs(__d - __intd) < __toler);
+
+ if (__d_integer)
+ {
+ const _Tp __ln_omx = std::log(_Tp(1) - __x);
+ const _Tp __ad = std::abs(__d);
+ _Tp __F1, __F2;
+
+ _Tp __d1, __d2;
+ if (__d >= _Tp(0))
+ {
+ __d1 = __d;
+ __d2 = _Tp(0);
+ }
+ else
+ {
+ __d1 = _Tp(0);
+ __d2 = __d;
+ }
+
+ const _Tp __lng_c = __log_gamma(__c);
+
+ // Evaluate F1.
+ if (__ad < __eps)
+ {
+ // d = c - a - b = 0.
+ __F1 = _Tp(0);
+ }
+ else
+ {
+
+ bool __ok_d1 = true;
+ _Tp __lng_ad, __lng_ad1, __lng_bd1;
+ try
+ {
+ __lng_ad = __log_gamma(__ad);
+ __lng_ad1 = __log_gamma(__a + __d1);
+ __lng_bd1 = __log_gamma(__b + __d1);
+ }
+ catch(...)
+ {
+ __ok_d1 = false;
+ }
+
+ if (__ok_d1)
+ {
+ /* Gamma functions in the denominator are ok.
+ * Proceed with evaluation.
+ */
+ _Tp __sum1 = _Tp(1);
+ _Tp __term = _Tp(1);
+ _Tp __ln_pre1 = __lng_ad + __lng_c + __d2 * __ln_omx
+ - __lng_ad1 - __lng_bd1;
+
+ /* Do F1 sum.
+ */
+ for (int __i = 1; __i < __ad; ++__i)
+ {
+ const int __j = __i - 1;
+ __term *= (__a + __d2 + __j) * (__b + __d2 + __j)
+ / (_Tp(1) + __d2 + __j) / __i * (_Tp(1) - __x);
+ __sum1 += __term;
+ }
+
+ if (__ln_pre1 > __log_max)
+ std::__throw_runtime_error(__N("Overflow of gamma functions "
+ "in __hyperg_luke."));
+ else
+ __F1 = std::exp(__ln_pre1) * __sum1;
+ }
+ else
+ {
+ // Gamma functions in the denominator were not ok.
+ // So the F1 term is zero.
+ __F1 = _Tp(0);
+ }
+ } // end F1 evaluation
+
+ // Evaluate F2.
+ bool __ok_d2 = true;
+ _Tp __lng_ad2, __lng_bd2;
+ try
+ {
+ __lng_ad2 = __log_gamma(__a + __d2);
+ __lng_bd2 = __log_gamma(__b + __d2);
+ }
+ catch(...)
+ {
+ __ok_d2 = false;
+ }
+
+ if (__ok_d2)
+ {
+ // Gamma functions in the denominator are ok.
+ // Proceed with evaluation.
+ const int __maxiter = 2000;
+ const _Tp __psi_1 = -__numeric_constants<_Tp>::__gamma_e();
+ const _Tp __psi_1pd = __psi(_Tp(1) + __ad);
+ const _Tp __psi_apd1 = __psi(__a + __d1);
+ const _Tp __psi_bpd1 = __psi(__b + __d1);
+
+ _Tp __psi_term = __psi_1 + __psi_1pd - __psi_apd1
+ - __psi_bpd1 - __ln_omx;
+ _Tp __fact = _Tp(1);
+ _Tp __sum2 = __psi_term;
+ _Tp __ln_pre2 = __lng_c + __d1 * __ln_omx
+ - __lng_ad2 - __lng_bd2;
+
+ // Do F2 sum.
+ int __j;
+ for (__j = 1; __j < __maxiter; ++__j)
+ {
+ // Values for psi functions use recurrence; Abramowitz & Stegun 6.3.5
+ const _Tp __term1 = _Tp(1) / _Tp(__j)
+ + _Tp(1) / (__ad + __j);
+ const _Tp __term2 = _Tp(1) / (__a + __d1 + _Tp(__j - 1))
+ + _Tp(1) / (__b + __d1 + _Tp(__j - 1));
+ __psi_term += __term1 - __term2;
+ __fact *= (__a + __d1 + _Tp(__j - 1))
+ * (__b + __d1 + _Tp(__j - 1))
+ / ((__ad + __j) * __j) * (_Tp(1) - __x);
+ const _Tp __delta = __fact * __psi_term;
+ __sum2 += __delta;
+ if (std::abs(__delta) < __eps * std::abs(__sum2))
+ break;
+ }
+ if (__j == __maxiter)
+ std::__throw_runtime_error(__N("Sum F2 failed to converge "
+ "in __hyperg_reflect"));
+
+ if (__sum2 == _Tp(0))
+ __F2 = _Tp(0);
+ else
+ __F2 = std::exp(__ln_pre2) * __sum2;
+ }
+ else
+ {
+ // Gamma functions in the denominator not ok.
+ // So the F2 term is zero.
+ __F2 = _Tp(0);
+ } // end F2 evaluation
+
+ const _Tp __sgn_2 = (__intd % 2 == 1 ? -_Tp(1) : _Tp(1));
+ const _Tp __F = __F1 + __sgn_2 * __F2;
+
+ return __F;
+ }
+ else
+ {
+ // d = c - a - b not an integer.
+
+ // These gamma functions appear in the denominator, so we
+ // catch their harmless domain errors and set the terms to zero.
+ bool __ok1 = true;
+ _Tp __sgn_g1ca = _Tp(0), __ln_g1ca = _Tp(0);
+ _Tp __sgn_g1cb = _Tp(0), __ln_g1cb = _Tp(0);
+ try
+ {
+ __sgn_g1ca = __log_gamma_sign(__c - __a);
+ __ln_g1ca = __log_gamma(__c - __a);
+ __sgn_g1cb = __log_gamma_sign(__c - __b);
+ __ln_g1cb = __log_gamma(__c - __b);
+ }
+ catch (...)
+ {
+ __ok1 = false;
+ }
+
+ bool __ok2 = true;
+ _Tp __sgn_g2a = _Tp(0), __ln_g2a = _Tp(0);
+ _Tp __sgn_g2b = _Tp(0), __ln_g2b = _Tp(0);
+ try
+ {
+ __sgn_g2a = __log_gamma_sign(__a);
+ __ln_g2a = __log_gamma(__a);
+ __sgn_g2b = __log_gamma_sign(__b);
+ __ln_g2b = __log_gamma(__b);
+ }
+ catch (...)
+ {
+ __ok2 = false;
+ }
+
+ const _Tp __sgn_gc = __log_gamma_sign(__c);
+ const _Tp __ln_gc = __log_gamma(__c);
+ const _Tp __sgn_gd = __log_gamma_sign(__d);
+ const _Tp __ln_gd = __log_gamma(__d);
+ const _Tp __sgn_gmd = __log_gamma_sign(-__d);
+ const _Tp __ln_gmd = __log_gamma(-__d);
+
+ const _Tp __sgn1 = __sgn_gc * __sgn_gd * __sgn_g1ca * __sgn_g1cb;
+ const _Tp __sgn2 = __sgn_gc * __sgn_gmd * __sgn_g2a * __sgn_g2b;
+
+ _Tp __pre1, __pre2;
+ if (__ok1 && __ok2)
+ {
+ _Tp __ln_pre1 = __ln_gc + __ln_gd - __ln_g1ca - __ln_g1cb;
+ _Tp __ln_pre2 = __ln_gc + __ln_gmd - __ln_g2a - __ln_g2b
+ + __d * std::log(_Tp(1) - __x);
+ if (__ln_pre1 < __log_max && __ln_pre2 < __log_max)
+ {
+ __pre1 = std::exp(__ln_pre1);
+ __pre2 = std::exp(__ln_pre2);
+ __pre1 *= __sgn1;
+ __pre2 *= __sgn2;
+ }
+ else
+ {
+ std::__throw_runtime_error(__N("Overflow of gamma functions "
+ "in __hyperg_reflect"));
+ }
+ }
+ else if (__ok1 && !__ok2)
+ {
+ _Tp __ln_pre1 = __ln_gc + __ln_gd - __ln_g1ca - __ln_g1cb;
+ if (__ln_pre1 < __log_max)
+ {
+ __pre1 = std::exp(__ln_pre1);
+ __pre1 *= __sgn1;
+ __pre2 = _Tp(0);
+ }
+ else
+ {
+ std::__throw_runtime_error(__N("Overflow of gamma functions "
+ "in __hyperg_reflect"));
+ }
+ }
+ else if (!__ok1 && __ok2)
+ {
+ _Tp __ln_pre2 = __ln_gc + __ln_gmd - __ln_g2a - __ln_g2b
+ + __d * std::log(_Tp(1) - __x);
+ if (__ln_pre2 < __log_max)
+ {
+ __pre1 = _Tp(0);
+ __pre2 = std::exp(__ln_pre2);
+ __pre2 *= __sgn2;
+ }
+ else
+ {
+ std::__throw_runtime_error(__N("Overflow of gamma functions "
+ "in __hyperg_reflect"));
+ }
+ }
+ else
+ {
+ __pre1 = _Tp(0);
+ __pre2 = _Tp(0);
+ std::__throw_runtime_error(__N("Underflow of gamma functions "
+ "in __hyperg_reflect"));
+ }
+
+ const _Tp __F1 = __hyperg_series(__a, __b, _Tp(1) - __d,
+ _Tp(1) - __x);
+ const _Tp __F2 = __hyperg_series(__c - __a, __c - __b, _Tp(1) + __d,
+ _Tp(1) - __x);
+
+ const _Tp __F = __pre1 * __F1 + __pre2 * __F2;
+
+ return __F;
+ }
+ }
+
+
+ /*
+ * @brief Return the hypogeometric function @f$ _2F_1(a,b;c;x) @f$.
+ *
+ * The hypogeometric function is defined by
+ * @f[
+ * _2F_1(a,b;c;x) = \frac{\Gamma(c)}{\Gamma(a)\Gamma(b)}
+ * \sum_{n=0}^{\infty}
+ * \frac{\Gamma(a+n)\Gamma(b+n)}{\Gamma(c+n)}
+ * \frac{x^n}{n!}
+ * @f]
+ *
+ * @param __a The first "numerator" parameter.
+ * @param __a The second "numerator" parameter.
+ * @param __c The "denominator" parameter.
+ * @param __x The argument of the confluent hypergeometric function.
+ * @return The confluent hypergeometric function.
+ */
+ template<typename _Tp>
+ inline _Tp
+ __hyperg(const _Tp __a, const _Tp __b, const _Tp __c, const _Tp __x)
+ {
+#if _GLIBCXX_USE_C99_MATH_TR1
+ const _Tp __a_nint = std::_GLIBCXX_TR1::nearbyint(__a);
+ const _Tp __b_nint = std::_GLIBCXX_TR1::nearbyint(__b);
+ const _Tp __c_nint = std::_GLIBCXX_TR1::nearbyint(__c);
+#else
+ const _Tp __a_nint = static_cast<int>(__a + _Tp(0.5L));
+ const _Tp __b_nint = static_cast<int>(__b + _Tp(0.5L));
+ const _Tp __c_nint = static_cast<int>(__c + _Tp(0.5L));
+#endif
+ const _Tp __toler = _Tp(1000) * std::numeric_limits<_Tp>::epsilon();
+ if (std::abs(__x) >= _Tp(1))
+ std::__throw_domain_error(__N("Argument outside unit circle "
+ "in __hyperg."));
+ else if (__isnan(__a) || __isnan(__b)
+ || __isnan(__c) || __isnan(__x))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (__c_nint == __c && __c_nint <= _Tp(0))
+ return std::numeric_limits<_Tp>::infinity();
+ else if (std::abs(__c - __b) < __toler || std::abs(__c - __a) < __toler)
+ return std::pow(_Tp(1) - __x, __c - __a - __b);
+ else if (__a >= _Tp(0) && __b >= _Tp(0) && __c >= _Tp(0)
+ && __x >= _Tp(0) && __x < _Tp(0.995L))
+ return __hyperg_series(__a, __b, __c, __x);
+ else if (std::abs(__a) < _Tp(10) && std::abs(__b) < _Tp(10))
+ {
+ // For integer a and b the hypergeometric function is a finite polynomial.
+ if (__a < _Tp(0) && std::abs(__a - __a_nint) < __toler)
+ return __hyperg_series(__a_nint, __b, __c, __x);
+ else if (__b < _Tp(0) && std::abs(__b - __b_nint) < __toler)
+ return __hyperg_series(__a, __b_nint, __c, __x);
+ else if (__x < -_Tp(0.25L))
+ return __hyperg_luke(__a, __b, __c, __x);
+ else if (__x < _Tp(0.5L))
+ return __hyperg_series(__a, __b, __c, __x);
+ else
+ if (std::abs(__c) > _Tp(10))
+ return __hyperg_series(__a, __b, __c, __x);
+ else
+ return __hyperg_reflect(__a, __b, __c, __x);
+ }
+ else
+ return __hyperg_luke(__a, __b, __c, __x);
+ }
+
+ } // namespace std::tr1::__detail
+
+ /* @} */ // group tr1_math_spec_func
+
+_GLIBCXX_END_NAMESPACE
+}
+
+#endif // _TR1_HYPERGEOMETRIC_TCC
diff --git a/libstdc++-v3/include/tr1/legendre_function.tcc b/libstdc++-v3/include/tr1/legendre_function.tcc
new file mode 100644
index 00000000000..323bd18861c
--- /dev/null
+++ b/libstdc++-v3/include/tr1/legendre_function.tcc
@@ -0,0 +1,318 @@
+// Special functions -*- C++ -*-
+
+// Copyright (C) 2006-2007
+// Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+// USA.
+//
+// As a special exception, you may use this file as part of a free software
+// library without restriction. Specifically, if other files instantiate
+// templates or use macros or inline functions from this file, or you compile
+// this file and link it with other files to produce an executable, this
+// file does not by itself cause the resulting executable to be covered by
+// the GNU General Public License. This exception does not however
+// invalidate any other reasons why the executable file might be covered by
+// the GNU General Public License.
+
+/** @file tr1/legendre_function.tcc
+ * This is an internal header file, included by other library headers.
+ * You should not attempt to use it directly.
+ */
+
+//
+// ISO C++ 14882 TR1: 5.2 Special functions
+//
+
+// Written by Edward Smith-Rowland based on:
+// (1) Handbook of Mathematical Functions,
+// ed. Milton Abramowitz and Irene A. Stegun,
+// Dover Publications,
+// Section 8, pp. 331-341
+// (2) The Gnu Scientific Library, http://www.gnu.org/software/gsl
+// (3) Numerical Recipes in C, by W. H. Press, S. A. Teukolsky,
+// W. T. Vetterling, B. P. Flannery, Cambridge University Press (1992),
+// 2nd ed, pp. 252-254
+
+#ifndef _TR1_LEGENDRE_FUNCTION_TCC
+#define _TR1_LEGENDRE_FUNCTION_TCC 1
+
+#include "special_function_util.h"
+
+namespace std
+{
+_GLIBCXX_BEGIN_NAMESPACE(_GLIBCXX_TR1)
+
+ // [5.2] Special functions
+
+ /**
+ * @ingroup tr1_math_spec_func
+ * @{
+ */
+
+ //
+ // Implementation-space details.
+ //
+ namespace __detail
+ {
+
+ /**
+ * @brief Return the Legendre polynomial by recursion on order
+ * @f$ l @f$.
+ *
+ * The Legendre function of @f$ l @f$ and @f$ x @f$,
+ * @f$ P_l(x) @f$, is defined by:
+ * @f[
+ * P_l(x) = \frac{1}{2^l l!}\frac{d^l}{dx^l}(x^2 - 1)^{l}
+ * @f]
+ *
+ * @param l The order of the Legendre polynomial. @f$l >= 0@f$.
+ * @param x The argument of the Legendre polynomial. @f$|x| <= 1@f$.
+ */
+ template<typename _Tp>
+ _Tp
+ __poly_legendre_p(const unsigned int __l, const _Tp __x)
+ {
+
+ if ((__x < _Tp(-1)) || (__x > _Tp(+1)))
+ std::__throw_domain_error(__N("Argument out of range"
+ " in __poly_legendre_p."));
+ else if (__isnan(__x))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (__x == +_Tp(1))
+ return +_Tp(1);
+ else if (__x == -_Tp(1))
+ return (__l % 2 == 1 ? -_Tp(1) : +_Tp(1));
+ else
+ {
+ _Tp __p_lm2 = _Tp(1);
+ if (__l == 0)
+ return __p_lm2;
+
+ _Tp __p_lm1 = __x;
+ if (__l == 1)
+ return __p_lm1;
+
+ _Tp __p_l = 0;
+ for (unsigned int __ll = 2; __ll <= __l; ++__ll)
+ {
+ // This arrangement is supposed to be better for roundoff
+ // protection, Arfken, 2nd Ed, Eq 12.17a.
+ __p_l = _Tp(2) * __x * __p_lm1 - __p_lm2
+ - (__x * __p_lm1 - __p_lm2) / _Tp(__ll);
+ __p_lm2 = __p_lm1;
+ __p_lm1 = __p_l;
+ }
+
+ return __p_l;
+ }
+ }
+
+
+ /**
+ * @brief Return the associated Legendre function by recursion
+ * on @f$ l @f$.
+ *
+ * The associated Legendre function is derived from the Legendre function
+ * @f$ P_l(x) @f$ by the Rodruigez formula:
+ * @f[
+ * P_l^m(x) = (1 - x^2)^{m/2}\frac{d^m}{dx^m}P_l(x)
+ * @f]
+ *
+ * @param l The order of the associated Legendre function.
+ * @f$ l >= 0 @f$.
+ * @param m The order of the associated Legendre function.
+ * @f$ m <= l @f$.
+ * @param x The argument of the associated Legendre function.
+ * @f$ |x| <= 1 @f$.
+ */
+ template<typename _Tp>
+ _Tp
+ __assoc_legendre_p(const unsigned int __l, const unsigned int __m,
+ const _Tp __x)
+ {
+
+ if (__x < _Tp(-1) || __x > _Tp(+1))
+ std::__throw_domain_error(__N("Argument out of range"
+ " in __assoc_legendre_p."));
+ else if (__m > __l)
+ std::__throw_domain_error(__N("Degree out of range"
+ " in __assoc_legendre_p."));
+ else if (__isnan(__x))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (__m == 0)
+ return __poly_legendre_p(__l, __x);
+ else
+ {
+ _Tp __p_mm = _Tp(1);
+ if (__m > 0)
+ {
+ // Two square roots seem more accurate more of the time than just one.
+ _Tp __root = std::sqrt(_Tp(1) - __x) * std::sqrt(_Tp(1) + __x);
+ _Tp __fact = _Tp(1);
+ for (unsigned int __i = 1; __i <= __m; ++__i)
+ {
+ __p_mm *= -__fact * __root;
+ __fact += _Tp(2);
+ }
+ }
+ if (__l == __m)
+ return __p_mm;
+
+ _Tp __p_mp1m = _Tp(2 * __m + 1) * __x * __p_mm;
+ if (__l == __m + 1)
+ return __p_mp1m;
+
+ _Tp __p_lm2m = __p_mm;
+ _Tp __P_lm1m = __p_mp1m;
+ _Tp __p_lm = _Tp(0);
+ for (unsigned int __j = __m + 2; __j <= __l; ++__j)
+ {
+ __p_lm = (_Tp(2 * __j - 1) * __x * __P_lm1m
+ - _Tp(__j + __m - 1) * __p_lm2m) / _Tp(__j - __m);
+ __p_lm2m = __P_lm1m;
+ __P_lm1m = __p_lm;
+ }
+
+ return __p_lm;
+ }
+ }
+
+
+ /**
+ * @brief Return the spherical associated Legendre function.
+ *
+ * The spherical associated Legendre function of @f$ l @f$, @f$ m @f$,
+ * and @f$ \theta @f$ is defined as @f$ Y_l^m(\theta,0) @f$ where
+ * @f[
+ * Y_l^m(\theta,\phi) = (-1)^m[\frac{(2l+1)}{4\pi}
+ * \frac{(l-m)!}{(l+m)!}]
+ * P_l^m(\cos\theta) \exp^{im\phi}
+ * @f]
+ * is the spherical harmonic function and @f$ P_l^m(x) @f$ is the
+ * associated Legendre function.
+ *
+ * This function differs from the associated Legendre function by
+ * argument (@f$x = \cos(\theta)@f$) and by a normalization factor
+ * but this factor is rather large for large @f$ l @f$ and @f$ m @f$
+ * and so this function is stable for larger differences of @f$ l @f$
+ * and @f$ m @f$.
+ *
+ * @param l The order of the spherical associated Legendre function.
+ * @f$ l >= 0 @f$.
+ * @param m The order of the spherical associated Legendre function.
+ * @f$ m <= l @f$.
+ * @param theta The radian angle argument of the spherical associated
+ * Legendre function.
+ */
+ template <typename _Tp>
+ _Tp
+ __sph_legendre(const unsigned int __l, const unsigned int __m,
+ const _Tp __theta)
+ {
+ if (__isnan(__theta))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+
+ const _Tp __x = std::cos(__theta);
+
+ if (__l < __m)
+ {
+ std::__throw_domain_error(__N("Bad argument "
+ "in __sph_legendre."));
+ }
+ else if (__m == 0)
+ {
+ _Tp __P = __poly_legendre_p(__l, __x);
+ _Tp __fact = std::sqrt(_Tp(2 * __l + 1)
+ / (_Tp(4) * __numeric_constants<_Tp>::__pi()));
+ __P *= __fact;
+ return __P;
+ }
+ else if (__x == _Tp(1) || __x == -_Tp(1))
+ {
+ // m > 0 here
+ return _Tp(0);
+ }
+ else
+ {
+ // m > 0 and |x| < 1 here
+
+ // Starting value for recursion.
+ // Y_m^m(x) = sqrt( (2m+1)/(4pi m) gamma(m+1/2)/gamma(m) )
+ // (-1)^m (1-x^2)^(m/2) / pi^(1/4)
+ const _Tp __sgn = ( __m % 2 == 1 ? -_Tp(1) : _Tp(1));
+ const _Tp __y_mp1m_factor = __x * std::sqrt(_Tp(2 * __m + 3));
+#if _GLIBCXX_USE_C99_MATH_TR1
+ const _Tp __lncirc = std::_GLIBCXX_TR1::log1p(-__x * __x);
+#else
+ const _Tp __lncirc = std::log(_Tp(1) - __x * __x);
+#endif
+ // Gamma(m+1/2) / Gamma(m)
+#if _GLIBCXX_USE_C99_MATH_TR1
+ const _Tp __lnpoch = std::_GLIBCXX_TR1::lgamma(_Tp(__m + _Tp(0.5L)))
+ - std::_GLIBCXX_TR1::lgamma(_Tp(__m));
+#else
+ const _Tp __lnpoch = __log_gamma(_Tp(__m + _Tp(0.5L)))
+ - __log_gamma(_Tp(__m));
+#endif
+ const _Tp __lnpre_val =
+ -_Tp(0.25L) * __numeric_constants<_Tp>::__lnpi()
+ + _Tp(0.5L) * (__lnpoch + __m * __lncirc);
+ _Tp __sr = std::sqrt((_Tp(2) + _Tp(1) / __m)
+ / (_Tp(4) * __numeric_constants<_Tp>::__pi()));
+ _Tp __y_mm = __sgn * __sr * std::exp(__lnpre_val);
+ _Tp __y_mp1m = __y_mp1m_factor * __y_mm;
+
+ if (__l == __m)
+ {
+ return __y_mm;
+ }
+ else if (__l == __m + 1)
+ {
+ return __y_mp1m;
+ }
+ else
+ {
+ _Tp __y_lm = _Tp(0);
+
+ // Compute Y_l^m, l > m+1, upward recursion on l.
+ for ( int __ll = __m + 2; __ll <= __l; ++__ll)
+ {
+ const _Tp __rat1 = _Tp(__ll - __m) / _Tp(__ll + __m);
+ const _Tp __rat2 = _Tp(__ll - __m - 1) / _Tp(__ll + __m - 1);
+ const _Tp __fact1 = std::sqrt(__rat1 * _Tp(2 * __ll + 1)
+ * _Tp(2 * __ll - 1));
+ const _Tp __fact2 = std::sqrt(__rat1 * __rat2 * _Tp(2 * __ll + 1)
+ / _Tp(2 * __ll - 3));
+ __y_lm = (__x * __y_mp1m * __fact1
+ - (__ll + __m - 1) * __y_mm * __fact2) / _Tp(__ll - __m);
+ __y_mm = __y_mp1m;
+ __y_mp1m = __y_lm;
+ }
+
+ return __y_lm;
+ }
+ }
+ }
+
+ } // namespace std::tr1::__detail
+
+ /* @} */ // group tr1_math_spec_func
+
+_GLIBCXX_END_NAMESPACE
+}
+
+#endif // _TR1_LEGENDRE_FUNCTION_TCC
diff --git a/libstdc++-v3/include/tr1/math.h b/libstdc++-v3/include/tr1/math.h
index dcf75376326..0698cb2df9c 100644
--- a/libstdc++-v3/include/tr1/math.h
+++ b/libstdc++-v3/include/tr1/math.h
@@ -96,4 +96,96 @@ using std::_GLIBCXX_TR1::trunc;
#endif
+using std::_GLIBCXX_TR1::assoc_laguerref;
+using std::_GLIBCXX_TR1::assoc_laguerre;
+using std::_GLIBCXX_TR1::assoc_laguerrel;
+
+using std::_GLIBCXX_TR1::assoc_legendref;
+using std::_GLIBCXX_TR1::assoc_legendre;
+using std::_GLIBCXX_TR1::assoc_legendrel;
+
+using std::_GLIBCXX_TR1::betaf;
+using std::_GLIBCXX_TR1::beta;
+using std::_GLIBCXX_TR1::betal;
+
+using std::_GLIBCXX_TR1::comp_ellint_1f;
+using std::_GLIBCXX_TR1::comp_ellint_1;
+using std::_GLIBCXX_TR1::comp_ellint_1l;
+
+using std::_GLIBCXX_TR1::comp_ellint_2f;
+using std::_GLIBCXX_TR1::comp_ellint_2;
+using std::_GLIBCXX_TR1::comp_ellint_2l;
+
+using std::_GLIBCXX_TR1::comp_ellint_3f;
+using std::_GLIBCXX_TR1::comp_ellint_3;
+using std::_GLIBCXX_TR1::comp_ellint_3l;
+
+using std::_GLIBCXX_TR1::conf_hypergf;
+using std::_GLIBCXX_TR1::conf_hyperg;
+using std::_GLIBCXX_TR1::conf_hypergl;
+
+using std::_GLIBCXX_TR1::cyl_bessel_if;
+using std::_GLIBCXX_TR1::cyl_bessel_i;
+using std::_GLIBCXX_TR1::cyl_bessel_il;
+
+using std::_GLIBCXX_TR1::cyl_bessel_jf;
+using std::_GLIBCXX_TR1::cyl_bessel_j;
+using std::_GLIBCXX_TR1::cyl_bessel_jl;
+
+using std::_GLIBCXX_TR1::cyl_bessel_kf;
+using std::_GLIBCXX_TR1::cyl_bessel_k;
+using std::_GLIBCXX_TR1::cyl_bessel_kl;
+
+using std::_GLIBCXX_TR1::cyl_neumannf;
+using std::_GLIBCXX_TR1::cyl_neumann;
+using std::_GLIBCXX_TR1::cyl_neumannl;
+
+using std::_GLIBCXX_TR1::ellint_1f;
+using std::_GLIBCXX_TR1::ellint_1;
+using std::_GLIBCXX_TR1::ellint_1l;
+
+using std::_GLIBCXX_TR1::ellint_2f;
+using std::_GLIBCXX_TR1::ellint_2;
+using std::_GLIBCXX_TR1::ellint_2l;
+
+using std::_GLIBCXX_TR1::ellint_3f;
+using std::_GLIBCXX_TR1::ellint_3;
+using std::_GLIBCXX_TR1::ellint_3l;
+
+using std::_GLIBCXX_TR1::expintf;
+using std::_GLIBCXX_TR1::expint;
+using std::_GLIBCXX_TR1::expintl;
+
+using std::_GLIBCXX_TR1::hermitef;
+using std::_GLIBCXX_TR1::hermite;
+using std::_GLIBCXX_TR1::hermitel;
+
+using std::_GLIBCXX_TR1::hypergf;
+using std::_GLIBCXX_TR1::hyperg;
+using std::_GLIBCXX_TR1::hypergl;
+
+using std::_GLIBCXX_TR1::laguerref;
+using std::_GLIBCXX_TR1::laguerre;
+using std::_GLIBCXX_TR1::laguerrel;
+
+using std::_GLIBCXX_TR1::legendref;
+using std::_GLIBCXX_TR1::legendre;
+using std::_GLIBCXX_TR1::legendrel;
+
+using std::_GLIBCXX_TR1::riemann_zetaf;
+using std::_GLIBCXX_TR1::riemann_zeta;
+using std::_GLIBCXX_TR1::riemann_zetal;
+
+using std::_GLIBCXX_TR1::sph_besself;
+using std::_GLIBCXX_TR1::sph_bessel;
+using std::_GLIBCXX_TR1::sph_bessell;
+
+using std::_GLIBCXX_TR1::sph_legendref;
+using std::_GLIBCXX_TR1::sph_legendre;
+using std::_GLIBCXX_TR1::sph_legendrel;
+
+using std::_GLIBCXX_TR1::sph_neumannf;
+using std::_GLIBCXX_TR1::sph_neumann;
+using std::_GLIBCXX_TR1::sph_neumannl;
+
#endif
diff --git a/libstdc++-v3/include/tr1/modified_bessel_func.tcc b/libstdc++-v3/include/tr1/modified_bessel_func.tcc
new file mode 100644
index 00000000000..c7065a2251e
--- /dev/null
+++ b/libstdc++-v3/include/tr1/modified_bessel_func.tcc
@@ -0,0 +1,450 @@
+// Special functions -*- C++ -*-
+
+// Copyright (C) 2006-2007
+// Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+// USA.
+//
+// As a special exception, you may use this file as part of a free software
+// library without restriction. Specifically, if other files instantiate
+// templates or use macros or inline functions from this file, or you compile
+// this file and link it with other files to produce an executable, this
+// file does not by itself cause the resulting executable to be covered by
+// the GNU General Public License. This exception does not however
+// invalidate any other reasons why the executable file might be covered by
+// the GNU General Public License.
+
+/** @file tr1/modified_bessel_func.tcc
+ * This is an internal header file, included by other library headers.
+ * You should not attempt to use it directly.
+ */
+
+//
+// ISO C++ 14882 TR1: 5.2 Special functions
+//
+
+// Written by Edward Smith-Rowland.
+//
+// References:
+// (1) Handbook of Mathematical Functions,
+// Ed. Milton Abramowitz and Irene A. Stegun,
+// Dover Publications,
+// Section 9, pp. 355-434, Section 10 pp. 435-478
+// (2) The Gnu Scientific Library, http://www.gnu.org/software/gsl
+// (3) Numerical Recipes in C, by W. H. Press, S. A. Teukolsky,
+// W. T. Vetterling, B. P. Flannery, Cambridge University Press (1992),
+// 2nd ed, pp. 246-249.
+
+#ifndef _TR1_MODIFIED_BESSEL_FUNC_TCC
+#define _TR1_MODIFIED_BESSEL_FUNC_TCC 1
+
+#include "special_function_util.h"
+
+namespace std
+{
+_GLIBCXX_BEGIN_NAMESPACE(_GLIBCXX_TR1)
+
+ // [5.2] Special functions
+
+ /**
+ * @ingroup tr1_math_spec_func
+ * @{
+ */
+
+ //
+ // Implementation-space details.
+ //
+ namespace __detail
+ {
+
+ /**
+ * @brief Compute the modified Bessel functions @f$ I_\nu(x) @f$ and
+ * @f$ K_\nu(x) @f$ and their first derivatives
+ * @f$ I'_\nu(x) @f$ and @f$ K'_\nu(x) @f$ respectively.
+ * These four functions are computed together for numerical
+ * stability.
+ *
+ * @param __nu The order of the Bessel functions.
+ * @param __x The argument of the Bessel functions.
+ * @param __Inu The output regular modified Bessel function.
+ * @param __Knu The output irregular modified Bessel function.
+ * @param __Ipnu The output derivative of the regular
+ * modified Bessel function.
+ * @param __Kpnu The output derivative of the irregular
+ * modified Bessel function.
+ */
+ template <typename _Tp>
+ void
+ __bessel_ik(const _Tp __nu, const _Tp __x,
+ _Tp & __Inu, _Tp & __Knu, _Tp & __Ipnu, _Tp & __Kpnu)
+ {
+ if (__x == _Tp(0))
+ {
+ if (__nu == _Tp(0))
+ {
+ __Inu = _Tp(1);
+ __Ipnu = _Tp(0);
+ }
+ else if (__nu == _Tp(1))
+ {
+ __Inu = _Tp(0);
+ __Ipnu = _Tp(0.5L);
+ }
+ else
+ {
+ __Inu = _Tp(0);
+ __Ipnu = _Tp(0);
+ }
+ __Knu = std::numeric_limits<_Tp>::infinity();
+ __Kpnu = -std::numeric_limits<_Tp>::infinity();
+ return;
+ }
+
+ const _Tp __eps = std::numeric_limits<_Tp>::epsilon();
+ const _Tp __fp_min = _Tp(10) * std::numeric_limits<_Tp>::epsilon();
+ const int __max_iter = 15000;
+ const _Tp __x_min = _Tp(2);
+
+ const int __nl = static_cast<int>(__nu + _Tp(0.5L));
+
+ const _Tp __mu = __nu - __nl;
+ const _Tp __mu2 = __mu * __mu;
+ const _Tp __xi = _Tp(1) / __x;
+ const _Tp __xi2 = _Tp(2) * __xi;
+ _Tp __h = __nu * __xi;
+ if ( __h < __fp_min )
+ __h = __fp_min;
+ _Tp __b = __xi2 * __nu;
+ _Tp __d = _Tp(0);
+ _Tp __c = __h;
+ int __i;
+ for ( __i = 1; __i <= __max_iter; ++__i )
+ {
+ __b += __xi2;
+ __d = _Tp(1) / (__b + __d);
+ __c = __b + _Tp(1) / __c;
+ const _Tp __del = __c * __d;
+ __h *= __del;
+ if (std::abs(__del - _Tp(1)) < __eps)
+ break;
+ }
+ if (__i > __max_iter)
+ std::__throw_runtime_error(__N("Argument x too large "
+ "in __bessel_jn; "
+ "try asymptotic expansion."));
+ _Tp __Inul = __fp_min;
+ _Tp __Ipnul = __h * __Inul;
+ _Tp __Inul1 = __Inul;
+ _Tp __Ipnu1 = __Ipnul;
+ _Tp __fact = __nu * __xi;
+ for (int __l = __nl; __l >= 1; --__l)
+ {
+ const _Tp __Inutemp = __fact * __Inul + __Ipnul;
+ __fact -= __xi;
+ __Ipnul = __fact * __Inutemp + __Inul;
+ __Inul = __Inutemp;
+ }
+ _Tp __f = __Ipnul / __Inul;
+ _Tp __Kmu, __Knu1;
+ if (__x < __x_min)
+ {
+ const _Tp __x2 = __x / _Tp(2);
+ const _Tp __pimu = __numeric_constants<_Tp>::__pi() * __mu;
+ const _Tp __fact = (std::abs(__pimu) < __eps
+ ? _Tp(1) : __pimu / std::sin(__pimu));
+ _Tp __d = -std::log(__x2);
+ _Tp __e = __mu * __d;
+ const _Tp __fact2 = (std::abs(__e) < __eps
+ ? _Tp(1) : std::sinh(__e) / __e);
+ _Tp __gam1, __gam2, __gampl, __gammi;
+ __gamma_temme(__mu, __gam1, __gam2, __gampl, __gammi);
+ _Tp __ff = __fact
+ * (__gam1 * std::cosh(__e) + __gam2 * __fact2 * __d);
+ _Tp __sum = __ff;
+ __e = std::exp(__e);
+ _Tp __p = __e / (_Tp(2) * __gampl);
+ _Tp __q = _Tp(1) / (_Tp(2) * __e * __gammi);
+ _Tp __c = _Tp(1);
+ __d = __x2 * __x2;
+ _Tp __sum1 = __p;
+ int __i;
+ for (__i = 1; __i <= __max_iter; ++__i)
+ {
+ __ff = (__i * __ff + __p + __q) / (__i * __i - __mu2);
+ __c *= __d / __i;
+ __p /= __i - __mu;
+ __q /= __i + __mu;
+ const _Tp __del = __c * __ff;
+ __sum += __del;
+ const _Tp __del1 = __c * (__p - __i * __ff);
+ __sum1 += __del1;
+ if (std::abs(__del) < __eps * std::abs(__sum))
+ break;
+ }
+ if (__i > __max_iter)
+ std::__throw_runtime_error(__N("Bessel k series failed to converge "
+ "in __bessel_jn."));
+ __Kmu = __sum;
+ __Knu1 = __sum1 * __xi2;
+ }
+ else
+ {
+ _Tp __b = _Tp(2) * (_Tp(1) + __x);
+ _Tp __d = _Tp(1) / __b;
+ _Tp __delh = __d;
+ _Tp __h = __delh;
+ _Tp __q1 = _Tp(0);
+ _Tp __q2 = _Tp(1);
+ _Tp __a1 = _Tp(0.25L) - __mu2;
+ _Tp __q = __c = __a1;
+ _Tp __a = -__a1;
+ _Tp __s = _Tp(1) + __q * __delh;
+ int __i;
+ for (__i = 2; __i <= __max_iter; ++__i)
+ {
+ __a -= 2 * (__i - 1);
+ __c = -__a * __c / __i;
+ const _Tp __qnew = (__q1 - __b * __q2) / __a;
+ __q1 = __q2;
+ __q2 = __qnew;
+ __q += __c * __qnew;
+ __b += _Tp(2);
+ __d = _Tp(1) / (__b + __a * __d);
+ __delh = (__b * __d - _Tp(1)) * __delh;
+ __h += __delh;
+ const _Tp __dels = __q * __delh;
+ __s += __dels;
+ if ( std::abs(__dels / __s) < __eps )
+ break;
+ }
+ if (__i > __max_iter)
+ std::__throw_runtime_error(__N("Steed's method failed "
+ "in __bessel_jn."));
+ __h = __a1 * __h;
+ __Kmu = std::sqrt(__numeric_constants<_Tp>::__pi() / (_Tp(2) * __x))
+ * std::exp(-__x) / __s;
+ __Knu1 = __Kmu * (__mu + __x + _Tp(0.5L) - __h) * __xi;
+ }
+
+ _Tp __Kpmu = __mu * __xi * __Kmu - __Knu1;
+ _Tp __Inumu = __xi / (__f * __Kmu - __Kpmu);
+ __Inu = __Inumu * __Inul1 / __Inul;
+ __Ipnu = __Inumu * __Ipnu1 / __Inul;
+ for ( __i = 1; __i <= __nl; ++__i )
+ {
+ const _Tp __Knutemp = (__mu + __i) * __xi2 * __Knu1 + __Kmu;
+ __Kmu = __Knu1;
+ __Knu1 = __Knutemp;
+ }
+ __Knu = __Kmu;
+ __Kpnu = __nu * __xi * __Kmu - __Knu1;
+
+ return;
+ }
+
+
+ /**
+ * @brief Return the regular modified Bessel function of order
+ * \f$ \nu \f$: \f$ I_{\nu}(x) \f$.
+ *
+ * The regular modified cylindrical Bessel function is:
+ * @f[
+ * I_{\nu}(x) = \sum_{k=0}^{\infty}
+ * \frac{(x/2)^{\nu + 2k}}{k!\Gamma(\nu+k+1)}
+ * @f]
+ *
+ * @param __nu The order of the regular modified Bessel function.
+ * @param __x The argument of the regular modified Bessel function.
+ * @return The output regular modified Bessel function.
+ */
+ template<typename _Tp>
+ _Tp
+ __cyl_bessel_i(const _Tp __nu, const _Tp __x)
+ {
+ if (__nu < _Tp(0) || __x < _Tp(0))
+ std::__throw_domain_error(__N("Bad argument "
+ "in __cyl_bessel_i."));
+ else if (__isnan(__nu) || __isnan(__x))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (__x * __x < _Tp(10) * (__nu + _Tp(1)))
+ return __cyl_bessel_ij_series(__nu, __x, +_Tp(1), 200);
+ else
+ {
+ _Tp __I_nu, __K_nu, __Ip_nu, __Kp_nu;
+ __bessel_ik(__nu, __x, __I_nu, __K_nu, __Ip_nu, __Kp_nu);
+ return __I_nu;
+ }
+ }
+
+
+ /**
+ * @brief Return the irregular modified Bessel function
+ * \f$ K_{\nu}(x) \f$ of order \f$ \nu \f$.
+ *
+ * The irregular modified Bessel function is defined by:
+ * @f[
+ * K_{\nu}(x) = \frac{\pi}{2}
+ * \frac{I_{-\nu}(x) - I_{\nu}(x)}{\sin \nu\pi}
+ * @f]
+ * where for integral \f$ \nu = n \f$ a limit is taken:
+ * \f$ lim_{\nu \to n} \f$.
+ *
+ * @param __nu The order of the irregular modified Bessel function.
+ * @param __x The argument of the irregular modified Bessel function.
+ * @return The output irregular modified Bessel function.
+ */
+ template<typename _Tp>
+ _Tp
+ __cyl_bessel_k(const _Tp __nu, const _Tp __x)
+ {
+ if (__nu < _Tp(0) || __x < _Tp(0))
+ std::__throw_domain_error(__N("Bad argument "
+ "in __cyl_bessel_k."));
+ else if (__isnan(__nu) || __isnan(__x))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else
+ {
+ _Tp __I_nu, __K_nu, __Ip_nu, __Kp_nu;
+ __bessel_ik(__nu, __x, __I_nu, __K_nu, __Ip_nu, __Kp_nu);
+ return __K_nu;
+ }
+ }
+
+
+ /**
+ * @brief Compute the spherical modified Bessel functions
+ * @f$ i_n(x) @f$ and @f$ k_n(x) @f$ and their first
+ * derivatives @f$ i'_n(x) @f$ and @f$ k'_n(x) @f$
+ * respectively.
+ *
+ * @param __n The order of the modified spherical Bessel function.
+ * @param __x The argument of the modified spherical Bessel function.
+ * @param __i_n The output regular modified spherical Bessel function.
+ * @param __k_n The output irregular modified spherical
+ * Bessel function.
+ * @param __ip_n The output derivative of the regular modified
+ * spherical Bessel function.
+ * @param __kp_n The output derivative of the irregular modified
+ * spherical Bessel function.
+ */
+ template <typename _Tp>
+ void
+ __sph_bessel_ik(const unsigned int __n, const _Tp __x,
+ _Tp & __i_n, _Tp & __k_n, _Tp & __ip_n, _Tp & __kp_n)
+ {
+ const _Tp __nu = _Tp(__n) + _Tp(0.5L);
+
+ _Tp __I_nu, __Ip_nu, __K_nu, __Kp_nu;
+ __bessel_ik(__nu, __x, __I_nu, __K_nu, __Ip_nu, __Kp_nu);
+
+ const _Tp __factor = __numeric_constants<_Tp>::__sqrtpio2()
+ / std::sqrt(__x);
+
+ __i_n = __factor * __I_nu;
+ __k_n = __factor * __K_nu;
+ __ip_n = __factor * __Ip_nu - __i_n / (_Tp(2) * __x);
+ __kp_n = __factor * __Kp_nu - __k_n / (_Tp(2) * __x);
+
+ return;
+ }
+
+
+ /**
+ * @brief Compute the Airy functions
+ * @f$ Ai(x) @f$ and @f$ Bi(x) @f$ and their first
+ * derivatives @f$ Ai'(x) @f$ and @f$ Bi(x) @f$
+ * respectively.
+ *
+ * @param __n The order of the Airy functions.
+ * @param __x The argument of the Airy functions.
+ * @param __i_n The output Airy function.
+ * @param __k_n The output Airy function.
+ * @param __ip_n The output derivative of the Airy function.
+ * @param __kp_n The output derivative of the Airy function.
+ */
+ template <typename _Tp>
+ void
+ __airy(const _Tp __x,
+ _Tp & __Ai, _Tp & __Bi, _Tp & __Aip, _Tp & __Bip)
+ {
+ const _Tp __absx = std::abs(__x);
+ const _Tp __rootx = std::sqrt(__absx);
+ const _Tp __z = _Tp(2) * __absx * __rootx / _Tp(3);
+
+ if (__isnan(__x))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (__x > _Tp(0))
+ {
+ _Tp __I_nu, __Ip_nu, __K_nu, __Kp_nu;
+
+ __bessel_ik(_Tp(1) / _Tp(3), __z, __I_nu, __K_nu, __Ip_nu, __Kp_nu);
+ __Ai = __rootx * __K_nu
+ / (__numeric_constants<_Tp>::__sqrt3()
+ * __numeric_constants<_Tp>::__pi());
+ __Bi = __rootx * (__K_nu / __numeric_constants<_Tp>::__pi()
+ + _Tp(2) * __I_nu / __numeric_constants<_Tp>::__sqrt3());
+
+ __bessel_ik(_Tp(2) / _Tp(3), __z, __I_nu, __K_nu, __Ip_nu, __Kp_nu);
+ __Aip = -__x * __K_nu
+ / (__numeric_constants<_Tp>::__sqrt3()
+ * __numeric_constants<_Tp>::__pi());
+ __Bip = __x * (__K_nu / __numeric_constants<_Tp>::__pi()
+ + _Tp(2) * __I_nu
+ / __numeric_constants<_Tp>::__sqrt3());
+ }
+ else if (__x < _Tp(0))
+ {
+ _Tp __J_nu, __Jp_nu, __N_nu, __Np_nu;
+
+ __bessel_jn(_Tp(1) / _Tp(3), __z, __J_nu, __N_nu, __Jp_nu, __Np_nu);
+ __Ai = __rootx * (__J_nu
+ - __N_nu / __numeric_constants<_Tp>::__sqrt3()) / _Tp(2);
+ __Bi = -__rootx * (__N_nu
+ + __J_nu / __numeric_constants<_Tp>::__sqrt3()) / _Tp(2);
+
+ __bessel_jn(_Tp(2) / _Tp(3), __z, __J_nu, __N_nu, __Jp_nu, __Np_nu);
+ __Aip = __absx * (__N_nu / __numeric_constants<_Tp>::__sqrt3()
+ + __J_nu) / _Tp(2);
+ __Bip = __absx * (__J_nu / __numeric_constants<_Tp>::__sqrt3()
+ - __N_nu) / _Tp(2);
+ }
+ else
+ {
+ // Reference:
+ // Abramowitz & Stegun, page 446 section 10.4.4 on Airy functions.
+ // The number is Ai(0) = 3^{-2/3}/\Gamma(2/3).
+ __Ai = _Tp(0.35502805388781723926L);
+ __Bi = __Ai * __numeric_constants<_Tp>::__sqrt3();
+
+ // Reference:
+ // Abramowitz & Stegun, page 446 section 10.4.5 on Airy functions.
+ // The number is Ai'(0) = -3^{-1/3}/\Gamma(1/3).
+ __Aip = -_Tp(0.25881940379280679840L);
+ __Bip = -__Aip * __numeric_constants<_Tp>::__sqrt3();
+ }
+
+ return;
+ }
+
+ } // namespace std::tr1::__detail
+
+ /* @} */ // group tr1_math_spec_func
+
+_GLIBCXX_END_NAMESPACE
+}
+
+#endif // _TR1_MODIFIED_BESSEL_FUNC_TCC
diff --git a/libstdc++-v3/include/tr1/poly_hermite.tcc b/libstdc++-v3/include/tr1/poly_hermite.tcc
new file mode 100644
index 00000000000..3a7bf921833
--- /dev/null
+++ b/libstdc++-v3/include/tr1/poly_hermite.tcc
@@ -0,0 +1,138 @@
+// Special functions -*- C++ -*-
+
+// Copyright (C) 2006-2007
+// Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+// USA.
+//
+// As a special exception, you may use this file as part of a free software
+// library without restriction. Specifically, if other files instantiate
+// templates or use macros or inline functions from this file, or you compile
+// this file and link it with other files to produce an executable, this
+// file does not by itself cause the resulting executable to be covered by
+// the GNU General Public License. This exception does not however
+// invalidate any other reasons why the executable file might be covered by
+// the GNU General Public License.
+
+/** @file tr1/poly_hermite.tcc
+ * This is an internal header file, included by other library headers.
+ * You should not attempt to use it directly.
+ */
+
+//
+// ISO C++ 14882 TR1: 5.2 Special functions
+//
+
+// Written by Edward Smith-Rowland based on:
+// (1) Handbook of Mathematical Functions,
+// Ed. Milton Abramowitz and Irene A. Stegun,
+// Dover Publications, Section 22 pp. 773-802
+
+#ifndef _TR1_POLY_HERMITE_TCC
+#define _TR1_POLY_HERMITE_TCC 1
+
+namespace std
+{
+_GLIBCXX_BEGIN_NAMESPACE(_GLIBCXX_TR1)
+
+ // [5.2] Special functions
+
+ /**
+ * @ingroup tr1_math_spec_func
+ * @{
+ */
+
+ //
+ // Implementation-space details.
+ //
+ namespace __detail
+ {
+
+ /**
+ * @brief This routine returns the Hermite polynomial
+ * of order n: \f$ H_n(x) \f$ by recursion on n.
+ *
+ * The Hermite polynomial is defined by:
+ * @f[
+ * H_n(x) = (-1)^n e^{x^2} \frac{d^n}{dx^n} e^{-x^2}
+ * @f]
+ *
+ * @param __n The order of the Hermite polynomial.
+ * @param __x The argument of the Hermite polynomial.
+ * @return The value of the Hermite polynomial of order n
+ * and argument x.
+ */
+ template<typename _Tp>
+ _Tp
+ __poly_hermite_recursion(const unsigned int __n, const _Tp __x)
+ {
+ // Compute H_0.
+ _Tp __H_0 = 1;
+ if (__n == 0)
+ return __H_0;
+
+ // Compute H_1.
+ _Tp __H_1 = 2 * __x;
+ if (__n == 1)
+ return __H_1;
+
+ // Compute H_n.
+ _Tp __H_n, __H_nm1, __H_nm2;
+ unsigned int __i;
+ for (__H_nm2 = __H_0, __H_nm1 = __H_1, __i = 2; __i <= __n; ++__i)
+ {
+ __H_n = 2 * (__x * __H_nm1 + (__i - 1) * __H_nm2);
+ __H_nm2 = __H_nm1;
+ __H_nm1 = __H_n;
+ }
+
+ return __H_n;
+ }
+
+
+ /**
+ * @brief This routine returns the Hermite polynomial
+ * of order n: \f$ H_n(x) \f$.
+ *
+ * The Hermite polynomial is defined by:
+ * @f[
+ * H_n(x) = (-1)^n e^{x^2} \frac{d^n}{dx^n} e^{-x^2}
+ * @f]
+ *
+ * @param __n The order of the Hermite polynomial.
+ * @param __x The argument of the Hermite polynomial.
+ * @return The value of the Hermite polynomial of order n
+ * and argument x.
+ */
+ template<typename _Tp>
+ inline _Tp
+ __poly_hermite(const unsigned int __n, const _Tp __x)
+ {
+ if (__isnan(__x))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else
+ return __poly_hermite_recursion(__n, __x);
+ }
+
+ } // namespace std::tr1::__detail
+
+ /* @} */ // group tr1_math_spec_func
+
+_GLIBCXX_END_NAMESPACE
+}
+
+#endif // _TR1_POLY_HERMITE_TCC
diff --git a/libstdc++-v3/include/tr1/poly_laguerre.tcc b/libstdc++-v3/include/tr1/poly_laguerre.tcc
new file mode 100644
index 00000000000..5200cab79c0
--- /dev/null
+++ b/libstdc++-v3/include/tr1/poly_laguerre.tcc
@@ -0,0 +1,342 @@
+// Special functions -*- C++ -*-
+
+// Copyright (C) 2006-2007
+// Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+// USA.
+//
+// As a special exception, you may use this file as part of a free software
+// library without restriction. Specifically, if other files instantiate
+// templates or use macros or inline functions from this file, or you compile
+// this file and link it with other files to produce an executable, this
+// file does not by itself cause the resulting executable to be covered by
+// the GNU General Public License. This exception does not however
+// invalidate any other reasons why the executable file might be covered by
+// the GNU General Public License.
+
+/** @file tr1/poly_laguerre.tcc
+ * This is an internal header file, included by other library headers.
+ * You should not attempt to use it directly.
+ */
+
+//
+// ISO C++ 14882 TR1: 5.2 Special functions
+//
+
+// Written by Edward Smith-Rowland based on:
+// (1) Handbook of Mathematical Functions,
+// Ed. Milton Abramowitz and Irene A. Stegun,
+// Dover Publications,
+// Section 13, pp. 509-510, Section 22 pp. 773-802
+// (2) The Gnu Scientific Library, http://www.gnu.org/software/gsl
+
+#ifndef _TR1_POLY_LAGUERRE_TCC
+#define _TR1_POLY_LAGUERRE_TCC 1
+
+namespace std
+{
+_GLIBCXX_BEGIN_NAMESPACE(_GLIBCXX_TR1)
+
+ // [5.2] Special functions
+
+ /**
+ * @ingroup tr1_math_spec_func
+ * @{
+ */
+
+ //
+ // Implementation-space details.
+ //
+ namespace __detail
+ {
+
+
+ /**
+ * @brief This routine returns the associated Laguerre polynomial
+ * of order @f$ n @f$, degree @f$ \alpha @f$ for large n.
+ * Abramowitz & Stegun, 13.5.21
+ *
+ * @param __n The order of the Laguerre function.
+ * @param __alpha The degree of the Laguerre function.
+ * @param __x The argument of the Laguerre function.
+ * @return The value of the Laguerre function of order n,
+ * degree @f$ \alpha @f$, and argument x.
+ *
+ * This is from the GNU Scientific Library.
+ */
+ template<typename _Tpa, typename _Tp>
+ _Tp
+ __poly_laguerre_large_n(const unsigned __n, const _Tpa __alpha,
+ const _Tp __x)
+ {
+ const _Tp __a = -_Tp(__n);
+ const _Tp __b = _Tp(__alpha) + _Tp(1);
+ const _Tp __eta = _Tp(2) * __b - _Tp(4) * __a;
+ const _Tp __cos2th = __x / __eta;
+ const _Tp __sin2th = _Tp(1) - __cos2th;
+ const _Tp __th = std::acos(std::sqrt(__cos2th));
+ const _Tp __pre_h = __numeric_constants<_Tp>::__pi_2()
+ * __numeric_constants<_Tp>::__pi_2()
+ * __eta * __eta * __cos2th * __sin2th;
+
+#if _GLIBCXX_USE_C99_MATH_TR1
+ const _Tp __lg_b = std::_GLIBCXX_TR1::lgamma(_Tp(__n) + __b);
+ const _Tp __lnfact = std::_GLIBCXX_TR1::lgamma(_Tp(__n + 1));
+#else
+ const _Tp __lg_b = __log_gamma(_Tp(__n) + __b);
+ const _Tp __lnfact = __log_gamma(_Tp(__n + 1));
+#endif
+
+ _Tp __pre_term1 = _Tp(0.5L) * (_Tp(1) - __b)
+ * std::log(_Tp(0.25L) * __x * __eta);
+ _Tp __pre_term2 = _Tp(0.25L) * std::log(__pre_h);
+ _Tp __lnpre = __lg_b - __lnfact + _Tp(0.5L) * __x
+ + __pre_term1 - __pre_term2;
+ _Tp __ser_term1 = std::sin(__a * __numeric_constants<_Tp>::__pi());
+ _Tp __ser_term2 = std::sin(_Tp(0.25L) * __eta
+ * (_Tp(2) * __th
+ - std::sin(_Tp(2) * __th))
+ + __numeric_constants<_Tp>::__pi_4());
+ _Tp __ser = __ser_term1 + __ser_term2;
+
+ return std::exp(__lnpre) * __ser;
+ }
+
+
+ /**
+ * @brief Evaluate the polynomial based on the confluent hypergeometric
+ * function in a safe way, with no restriction on the arguments.
+ *
+ * The associated Laguerre function is defined by
+ * @f[
+ * L_n^\alpha(x) = \frac{(\alpha + 1)_n}{n!}
+ * _1F_1(-n; \alpha + 1; x)
+ * @f]
+ * where @f$ (\alpha)_n @f$ is the Pochhammer symbol and
+ * @f$ _1F_1(a; c; x) @f$ is the confluent hypergeometric function.
+ *
+ * This function assumes x != 0.
+ *
+ * This is from the GNU Scientific Library.
+ */
+ template<typename _Tpa, typename _Tp>
+ _Tp
+ __poly_laguerre_hyperg(const unsigned int __n, const _Tpa __alpha, const _Tp __x)
+ {
+ const _Tp __b = _Tp(__alpha) + _Tp(1);
+ const _Tp __mx = -__x;
+ const _Tp __tc_sgn = (__x < _Tp(0) ? _Tp(1)
+ : ((__n % 2 == 1) ? -_Tp(1) : _Tp(1)));
+ // Get |x|^n/n!
+ _Tp __tc = _Tp(1);
+ const _Tp __ax = std::abs(__x);
+ for (unsigned int __k = 1; __k <= __n; ++__k)
+ __tc *= (__ax / __k);
+
+ _Tp __term = __tc * __tc_sgn;
+ _Tp __sum = __term;
+ for (int __k = int(__n) - 1; __k >= 0; --__k)
+ {
+ __term *= ((__b + _Tp(__k)) / _Tp(int(__n) - __k))
+ * _Tp(__k + 1) / __mx;
+ __sum += __term;
+ }
+
+ return __sum;
+ }
+
+
+ /**
+ * @brief This routine returns the associated Laguerre polynomial
+ * of order @f$ n @f$, degree @f$ \alpha @f$: @f$ L_n^\alpha(x) @f$
+ * by recursion.
+ *
+ * The associated Laguerre function is defined by
+ * @f[
+ * L_n^\alpha(x) = \frac{(\alpha + 1)_n}{n!}
+ * _1F_1(-n; \alpha + 1; x)
+ * @f]
+ * where @f$ (\alpha)_n @f$ is the Pochhammer symbol and
+ * @f$ _1F_1(a; c; x) @f$ is the confluent hypergeometric function.
+ *
+ * The associated Laguerre polynomial is defined for integral
+ * @f$ \alpha = m @f$ by:
+ * @f[
+ * L_n^m(x) = (-1)^m \frac{d^m}{dx^m} L_{n + m}(x)
+ * @f]
+ * where the Laguerre polynomial is defined by:
+ * @f[
+ * L_n(x) = \frac{e^x}{n!} \frac{d^n}{dx^n} (x^ne^{-x})
+ * @f]
+ *
+ * @param __n The order of the Laguerre function.
+ * @param __alpha The degree of the Laguerre function.
+ * @param __x The argument of the Laguerre function.
+ * @return The value of the Laguerre function of order n,
+ * degree @f$ \alpha @f$, and argument x.
+ */
+ template<typename _Tpa, typename _Tp>
+ _Tp
+ __poly_laguerre_recursion(const unsigned int __n,
+ const _Tpa __alpha, const _Tp __x)
+ {
+ // Compute l_0.
+ _Tp __l_0 = _Tp(1);
+ if (__n == 0)
+ return __l_0;
+
+ // Compute l_1^alpha.
+ _Tp __l_1 = -__x + _Tp(1) + _Tp(__alpha);
+ if (__n == 1)
+ return __l_1;
+
+ // Compute l_n^alpha by recursion on n.
+ _Tp __l_n2 = __l_0;
+ _Tp __l_n1 = __l_1;
+ _Tp __l_n = _Tp(0);
+ for (unsigned int __nn = 2; __nn <= __n; ++__nn)
+ {
+ __l_n = (_Tp(2 * __nn - 1) + _Tp(__alpha) - __x)
+ * __l_n1 / _Tp(__nn)
+ - (_Tp(__nn - 1) + _Tp(__alpha)) * __l_n2 / _Tp(__nn);
+ __l_n2 = __l_n1;
+ __l_n1 = __l_n;
+ }
+
+ return __l_n;
+ }
+
+
+ /**
+ * @brief This routine returns the associated Laguerre polynomial
+ * of order n, degree @f$ \alpha @f$: @f$ L_n^alpha(x) @f$.
+ *
+ * The associated Laguerre function is defined by
+ * @f[
+ * L_n^\alpha(x) = \frac{(\alpha + 1)_n}{n!}
+ * _1F_1(-n; \alpha + 1; x)
+ * @f]
+ * where @f$ (\alpha)_n @f$ is the Pochhammer symbol and
+ * @f$ _1F_1(a; c; x) @f$ is the confluent hypergeometric function.
+ *
+ * The associated Laguerre polynomial is defined for integral
+ * @f$ \alpha = m @f$ by:
+ * @f[
+ * L_n^m(x) = (-1)^m \frac{d^m}{dx^m} L_{n + m}(x)
+ * @f]
+ * where the Laguerre polynomial is defined by:
+ * @f[
+ * L_n(x) = \frac{e^x}{n!} \frac{d^n}{dx^n} (x^ne^{-x})
+ * @f]
+ *
+ * @param __n The order of the Laguerre function.
+ * @param __alpha The degree of the Laguerre function.
+ * @param __x The argument of the Laguerre function.
+ * @return The value of the Laguerre function of order n,
+ * degree @f$ \alpha @f$, and argument x.
+ */
+ template<typename _Tpa, typename _Tp>
+ inline _Tp
+ __poly_laguerre(const unsigned int __n, const _Tpa __alpha,
+ const _Tp __x)
+ {
+ if (__x < _Tp(0))
+ std::__throw_domain_error(__N("Negative argument "
+ "in __poly_laguerre."));
+ // Return NaN on NaN input.
+ else if (__isnan(__x))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (__n == 0)
+ return _Tp(1);
+ else if (__n == 1)
+ return _Tp(1) + _Tp(__alpha) - __x;
+ else if (__x == _Tp(0))
+ {
+ _Tp __prod = _Tp(__alpha) + _Tp(1);
+ for (unsigned int __k = 2; __k <= __n; ++__k)
+ __prod *= (_Tp(__alpha) + _Tp(__k)) / _Tp(__k);
+ return __prod;
+ }
+ else if (__n > 10000000 && _Tp(__alpha) > -_Tp(1)
+ && __x < _Tp(2) * (_Tp(__alpha) + _Tp(1)) + _Tp(4 * __n))
+ return __poly_laguerre_large_n(__n, __alpha, __x);
+ else if (_Tp(__alpha) >= _Tp(0)
+ || (__x > _Tp(0) && _Tp(__alpha) < -_Tp(__n + 1)))
+ return __poly_laguerre_recursion(__n, __alpha, __x);
+ else
+ return __poly_laguerre_hyperg(__n, __alpha, __x);
+ }
+
+
+ /**
+ * @brief This routine returns the associated Laguerre polynomial
+ * of order n, degree m: @f$ L_n^m @f$.
+ *
+ * The associated Laguerre polynomial is defined for integral
+ * @f$ \alpha = m @f$ by:
+ * @f[
+ * L_n^m(x) = (-1)^m \frac{d^m}{dx^m} L_{n + m}(x)
+ * @f]
+ * where the Laguerre polynomial is defined by:
+ * @f[
+ * L_n(x) = \frac{e^x}{n!} \frac{d^n}{dx^n} (x^ne^{-x})
+ * @f]
+ *
+ * @param __n The order of the Laguerre polynomial.
+ * @param __m The degree of the Laguerre polynomial.
+ * @param __x The argument of the Laguerre polynomial.
+ * @return The value of the associated Laguerre polynomial of order n,
+ * degree m, and argument x.
+ */
+ template<typename _Tp>
+ inline _Tp
+ __assoc_laguerre(const unsigned int __n, const unsigned int __m,
+ const _Tp __x)
+ {
+ return __poly_laguerre<unsigned int, _Tp>(__n, __m, __x);
+ }
+
+
+ /**
+ * @brief This routine returns the associated Laguerre polynomial
+ * of order n: @f$ L_n(x) @f$.
+ *
+ * The Laguerre polynomial is defined by:
+ * @f[
+ * L_n(x) = \frac{e^x}{n!} \frac{d^n}{dx^n} (x^ne^{-x})
+ * @f]
+ *
+ * @param __n The order of the Laguerre polynomial.
+ * @param __x The argument of the Laguerre polynomial.
+ * @return The value of the Laguerre polynomial of order n
+ * and argument x.
+ */
+ template<typename _Tp>
+ inline _Tp
+ __laguerre(const unsigned int __n, const _Tp __x)
+ {
+ return __poly_laguerre<unsigned int, _Tp>(__n, 0, __x);
+ }
+
+ } // namespace std::tr1::__detail
+
+ /* @} */ // group tr1_math_spec_func
+
+_GLIBCXX_END_NAMESPACE
+}
+
+#endif // _TR1_POLY_LAGUERRE_TCC
diff --git a/libstdc++-v3/include/tr1/riemann_zeta.tcc b/libstdc++-v3/include/tr1/riemann_zeta.tcc
new file mode 100644
index 00000000000..598d73e6411
--- /dev/null
+++ b/libstdc++-v3/include/tr1/riemann_zeta.tcc
@@ -0,0 +1,449 @@
+// Special functions -*- C++ -*-
+
+// Copyright (C) 2006-2007
+// Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+// USA.
+//
+// As a special exception, you may use this file as part of a free software
+// library without restriction. Specifically, if other files instantiate
+// templates or use macros or inline functions from this file, or you compile
+// this file and link it with other files to produce an executable, this
+// file does not by itself cause the resulting executable to be covered by
+// the GNU General Public License. This exception does not however
+// invalidate any other reasons why the executable file might be covered by
+// the GNU General Public License.
+
+/** @file tr1/riemann_zeta.tcc
+ * This is an internal header file, included by other library headers.
+ * You should not attempt to use it directly.
+ */
+
+//
+// ISO C++ 14882 TR1: 5.2 Special functions
+//
+
+// Written by Edward Smith-Rowland based on:
+// (1) Handbook of Mathematical Functions,
+// Ed. by Milton Abramowitz and Irene A. Stegun,
+// Dover Publications, New-York, Section 5, pp. 807-808.
+// (2) The Gnu Scientific Library, http://www.gnu.org/software/gsl
+// (3) Gamma, Exploring Euler's Constant, Julian Havil,
+// Princeton, 2003.
+
+#ifndef _TR1_RIEMANN_ZETA_TCC
+#define _TR1_RIEMANN_ZETA_TCC 1
+
+#include "special_function_util.h"
+
+namespace std
+{
+_GLIBCXX_BEGIN_NAMESPACE(_GLIBCXX_TR1)
+
+ // [5.2] Special functions
+
+ /**
+ * @ingroup tr1_math_spec_func
+ * @{
+ */
+
+ //
+ // Implementation-space details.
+ //
+ namespace __detail
+ {
+
+ /**
+ * @brief Compute the Riemann zeta function @f$ \zeta(s) @f$
+ * by summation for s > 1.
+ *
+ * The Riemann zeta function is defined by:
+ * \f[
+ * \zeta(s) = \sum_{k=1}^{\infty} \frac{1}{k^{s}} for s > 1
+ * \f]
+ * For s < 1 use the reflection formula:
+ * \f[
+ * \zeta(s) = 2^s \pi^{s-1} \Gamma(1-s) \zeta(1-s)
+ * \f]
+ */
+ template<typename _Tp>
+ _Tp
+ __riemann_zeta_sum(const _Tp __s)
+ {
+ // A user shouldn't get to this.
+ if (__s < _Tp(1))
+ std::__throw_domain_error(__N("Bad argument in zeta sum."));
+
+ const unsigned int max_iter = 10000;
+ _Tp __zeta = _Tp(0);
+ for (unsigned int __k = 1; __k < max_iter; ++__k)
+ {
+ _Tp __term = std::pow(static_cast<_Tp>(__k), -__s);
+ if (__term < std::numeric_limits<_Tp>::epsilon())
+ {
+ break;
+ }
+ __zeta += __term;
+ }
+
+ return __zeta;
+ }
+
+
+ /**
+ * @brief Evaluate the Riemann zeta function @f$ \zeta(s) @f$
+ * by an alternate series for s > 0.
+ *
+ * The Riemann zeta function is defined by:
+ * \f[
+ * \zeta(s) = \sum_{k=1}^{\infty} \frac{1}{k^{s}} for s > 1
+ * \f]
+ * For s < 1 use the reflection formula:
+ * \f[
+ * \zeta(s) = 2^s \pi^{s-1} \Gamma(1-s) \zeta(1-s)
+ * \f]
+ */
+ template<typename _Tp>
+ _Tp
+ __riemann_zeta_alt(const _Tp __s)
+ {
+ _Tp __sgn = _Tp(1);
+ _Tp __zeta = _Tp(0);
+ for (unsigned int __i = 1; __i < 10000000; ++__i)
+ {
+ _Tp __term = __sgn / std::pow(__i, __s);
+ if (std::abs(__term) < std::numeric_limits<_Tp>::epsilon())
+ break;
+ __zeta += __term;
+ __sgn *= _Tp(-1);
+ }
+ __zeta /= _Tp(1) - std::pow(_Tp(2), _Tp(1) - __s);
+
+ return __zeta;
+ }
+
+
+ /**
+ * @brief Evaluate the Riemann zeta function by series for all s != 1.
+ * Convergence is great until largish negative numbers.
+ * Then the convergence of the > 0 sum gets better.
+ *
+ * The series is:
+ * \f[
+ * \zeta(s) = \frac{1}{1-2^{1-s}}
+ * \sum_{n=0}^{\infty} \frac{1}{2^{n+1}}
+ * \sum_{k=0}^{n} (-1)^k \frac{n!}{(n-k)!k!} (k+1)^{-s}
+ * \f]
+ * Havil 2003, p. 206.
+ *
+ * The Riemann zeta function is defined by:
+ * \f[
+ * \zeta(s) = \sum_{k=1}^{\infty} \frac{1}{k^{s}} for s > 1
+ * \f]
+ * For s < 1 use the reflection formula:
+ * \f[
+ * \zeta(s) = 2^s \pi^{s-1} \Gamma(1-s) \zeta(1-s)
+ * \f]
+ */
+ template<typename _Tp>
+ _Tp
+ __riemann_zeta_glob(const _Tp __s)
+ {
+ _Tp __zeta = _Tp(0);
+
+ const _Tp __eps = std::numeric_limits<_Tp>::epsilon();
+ // Max e exponent before overflow.
+ const _Tp __max_bincoeff = std::numeric_limits<_Tp>::max_exponent10
+ * std::log(_Tp(10)) - _Tp(1);
+
+ // This series works until the binomial coefficient blows up
+ // so use reflection.
+ if (__s < _Tp(0))
+ {
+#if _GLIBCXX_USE_C99_MATH_TR1
+ if (std::_GLIBCXX_TR1::fmod(__s,_Tp(2)) == _Tp(0))
+ return _Tp(0);
+ else
+#endif
+ {
+ _Tp __zeta = __riemann_zeta_glob(_Tp(1) - __s);
+ __zeta *= std::pow(_Tp(2)
+ * __numeric_constants<_Tp>::__pi(), __s)
+ * std::sin(__numeric_constants<_Tp>::__pi_2() * __s)
+#if _GLIBCXX_USE_C99_MATH_TR1
+ * std::exp(std::_GLIBCXX_TR1::lgamma(_Tp(1) - __s))
+#else
+ * std::exp(__log_gamma(_Tp(1) - __s))
+#endif
+ / __numeric_constants<_Tp>::__pi();
+ return __zeta;
+ }
+ }
+
+ _Tp __num = _Tp(0.5L);
+ const unsigned int __maxit = 10000;
+ for (unsigned int __i = 0; __i < __maxit; ++__i)
+ {
+ bool __punt = false;
+ _Tp __sgn = _Tp(1);
+ _Tp __term = _Tp(0);
+ for (unsigned int __j = 0; __j <= __i; ++__j)
+ {
+#if _GLIBCXX_USE_C99_MATH_TR1
+ _Tp __bincoeff = std::_GLIBCXX_TR1::lgamma(_Tp(1 + __i))
+ - std::_GLIBCXX_TR1::lgamma(_Tp(1 + __j))
+ - std::_GLIBCXX_TR1::lgamma(_Tp(1 + __i - __j));
+#else
+ _Tp __bincoeff = __log_gamma(_Tp(1 + __i))
+ - __log_gamma(_Tp(1 + __j))
+ - __log_gamma(_Tp(1 + __i - __j));
+#endif
+ if (__bincoeff > __max_bincoeff)
+ {
+ // This only gets hit for x << 0.
+ __punt = true;
+ break;
+ }
+ __bincoeff = std::exp(__bincoeff);
+ __term += __sgn * __bincoeff * std::pow(_Tp(1 + __j), -__s);
+ __sgn *= _Tp(-1);
+ }
+ if (__punt)
+ break;
+ __term *= __num;
+ __zeta += __term;
+ if (std::abs(__term/__zeta) < __eps)
+ break;
+ __num *= _Tp(0.5L);
+ }
+
+ __zeta /= _Tp(1) - std::pow(_Tp(2), _Tp(1) - __s);
+
+ return __zeta;
+ }
+
+
+ /**
+ * @brief Compute the Riemann zeta function @f$ \zeta(s) @f$
+ * using the product over prime factors.
+ * \f[
+ * \zeta(s) = \Pi_{i=1}^\infty \frac{1}{1 - p_i^{-s}}
+ * \f]
+ * where @f$ {p_i} @f$ are the prime numbers.
+ *
+ * The Riemann zeta function is defined by:
+ * \f[
+ * \zeta(s) = \sum_{k=1}^{\infty} \frac{1}{k^{s}} for s > 1
+ * \f]
+ * For s < 1 use the reflection formula:
+ * \f[
+ * \zeta(s) = 2^s \pi^{s-1} \Gamma(1-s) \zeta(1-s)
+ * \f]
+ */
+ template<typename _Tp>
+ _Tp
+ __riemann_zeta_product(const _Tp __s)
+ {
+ static const _Tp __prime[] = {
+ _Tp(2), _Tp(3), _Tp(5), _Tp(7), _Tp(11), _Tp(13), _Tp(17), _Tp(19),
+ _Tp(23), _Tp(29), _Tp(31), _Tp(37), _Tp(41), _Tp(43), _Tp(47),
+ _Tp(53), _Tp(59), _Tp(61), _Tp(67), _Tp(71), _Tp(73), _Tp(79),
+ _Tp(83), _Tp(89), _Tp(97), _Tp(101), _Tp(103), _Tp(107), _Tp(109)
+ };
+ static const unsigned int __num_primes = sizeof(__prime) / sizeof(_Tp);
+
+ _Tp __zeta = _Tp(1);
+ for (unsigned int __i = 0; __i < __num_primes; ++__i)
+ {
+ const _Tp __fact = _Tp(1) - std::pow(__prime[__i], -__s);
+ __zeta *= __fact;
+ if (_Tp(1) - __fact < std::numeric_limits<_Tp>::epsilon())
+ break;
+ }
+
+ __zeta = _Tp(1) / __zeta;
+
+ return __zeta;
+ }
+
+
+ /**
+ * @brief Return the Riemann zeta function @f$ \zeta(s) @f$.
+ *
+ * The Riemann zeta function is defined by:
+ * \f[
+ * \zeta(s) = \sum_{k=1}^{\infty} k^{-s} for s > 1
+ * \frac{(2\pi)^s}{pi} sin(\frac{\pi s}{2})
+ * \Gamma (1 - s) \zeta (1 - s) for s < 1
+ * \f]
+ * For s < 1 use the reflection formula:
+ * \f[
+ * \zeta(s) = 2^s \pi^{s-1} \Gamma(1-s) \zeta(1-s)
+ * \f]
+ */
+ template<typename _Tp>
+ _Tp
+ __riemann_zeta(const _Tp __s)
+ {
+ if (__isnan(__s))
+ return std::numeric_limits<_Tp>::quiet_NaN();
+ else if (__s == _Tp(1))
+ return std::numeric_limits<_Tp>::infinity();
+ else if (__s < -_Tp(19))
+ {
+ _Tp __zeta = __riemann_zeta_product(_Tp(1) - __s);
+ __zeta *= std::pow(_Tp(2) * __numeric_constants<_Tp>::__pi(), __s)
+ * std::sin(__numeric_constants<_Tp>::__pi_2() * __s)
+#if _GLIBCXX_USE_C99_MATH_TR1
+ * std::exp(std::_GLIBCXX_TR1::lgamma(_Tp(1) - __s))
+#else
+ * std::exp(__log_gamma(_Tp(1) - __s))
+#endif
+ / __numeric_constants<_Tp>::__pi();
+ return __zeta;
+ }
+ else if (__s < _Tp(20))
+ {
+ // Global double sum or McLaurin?
+ bool __glob = true;
+ if (__glob)
+ return __riemann_zeta_glob(__s);
+ else
+ {
+ if (__s > _Tp(1))
+ return __riemann_zeta_sum(__s);
+ else
+ {
+ _Tp __zeta = std::pow(_Tp(2)
+ * __numeric_constants<_Tp>::__pi(), __s)
+ * std::sin(__numeric_constants<_Tp>::__pi_2() * __s)
+#if _GLIBCXX_USE_C99_MATH_TR1
+ * std::_GLIBCXX_TR1::tgamma(_Tp(1) - __s)
+#else
+ * std::exp(__log_gamma(_Tp(1) - __s))
+#endif
+ * __riemann_zeta_sum(_Tp(1) - __s);
+ return __zeta;
+ }
+ }
+ }
+ else
+ return __riemann_zeta_product(__s);
+ }
+
+
+ /**
+ * @brief Return the Hurwitz zeta function @f$ \zeta(x,s) @f$
+ * for all s != 1 and x > -1.
+ *
+ * The Hurwitz zeta function is defined by:
+ * @f[
+ * \zeta(x,s) = \sum_{n=0}^{\infty} \frac{1}{(n + x)^s}
+ * @f]
+ * The Riemann zeta function is a special case:
+ * @f[
+ * \zeta(s) = \zeta(1,s)
+ * @f]
+ *
+ * This functions uses the double sum that converges for s != 1
+ * and x > -1:
+ * @f[
+ * \zeta(x,s) = \frac{1}{s-1}
+ * \sum_{n=0}^{\infty} \frac{1}{n + 1}
+ * \sum_{k=0}^{n} (-1)^k \frac{n!}{(n-k)!k!} (x+k)^{-s}
+ * @f]
+ */
+ template<typename _Tp>
+ _Tp
+ __hurwitz_zeta_glob(const _Tp __a, const _Tp __s)
+ {
+ _Tp __zeta = _Tp(0);
+
+ const _Tp __eps = std::numeric_limits<_Tp>::epsilon();
+ // Max e exponent before overflow.
+ const _Tp __max_bincoeff = std::numeric_limits<_Tp>::max_exponent10
+ * std::log(_Tp(10)) - _Tp(1);
+
+ const unsigned int __maxit = 10000;
+ for (unsigned int __i = 0; __i < __maxit; ++__i)
+ {
+ bool __punt = false;
+ _Tp __sgn = _Tp(1);
+ _Tp __term = _Tp(0);
+ for (unsigned int __j = 0; __j <= __i; ++__j)
+ {
+#if _GLIBCXX_USE_C99_MATH_TR1
+ _Tp __bincoeff = std::_GLIBCXX_TR1::lgamma(_Tp(1 + __i))
+ - std::_GLIBCXX_TR1::lgamma(_Tp(1 + __j))
+ - std::_GLIBCXX_TR1::lgamma(_Tp(1 + __i - __j));
+#else
+ _Tp __bincoeff = __log_gamma(_Tp(1 + __i))
+ - __log_gamma(_Tp(1 + __j))
+ - __log_gamma(_Tp(1 + __i - __j));
+#endif
+ if (__bincoeff > __max_bincoeff)
+ {
+ // This only gets hit for x << 0.
+ __punt = true;
+ break;
+ }
+ __bincoeff = std::exp(__bincoeff);
+ __term += __sgn * __bincoeff * std::pow(_Tp(__a + __j), -__s);
+ __sgn *= _Tp(-1);
+ }
+ if (__punt)
+ break;
+ __term /= _Tp(__i + 1);
+ if (std::abs(__term / __zeta) < __eps)
+ break;
+ __zeta += __term;
+ }
+
+ __zeta /= __s - _Tp(1);
+
+ return __zeta;
+ }
+
+
+ /**
+ * @brief Return the Hurwitz zeta function @f$ \zeta(x,s) @f$
+ * for all s != 1 and x > -1.
+ *
+ * The Hurwitz zeta function is defined by:
+ * @f[
+ * \zeta(x,s) = \sum_{n=0}^{\infty} \frac{1}{(n + x)^s}
+ * @f]
+ * The Riemann zeta function is a special case:
+ * @f[
+ * \zeta(s) = \zeta(1,s)
+ * @f]
+ */
+ template<typename _Tp>
+ inline _Tp
+ __hurwitz_zeta(const _Tp __a, const _Tp __s)
+ {
+ return __hurwitz_zeta_glob(__a, __s);
+ }
+
+ } // namespace std::tr1::__detail
+
+ /* @} */ // group tr1_math_spec_func
+
+_GLIBCXX_END_NAMESPACE
+}
+
+#endif // _TR1_RIEMANN_ZETA_TCC
diff --git a/libstdc++-v3/include/tr1/special_function_util.h b/libstdc++-v3/include/tr1/special_function_util.h
new file mode 100644
index 00000000000..ac55165b164
--- /dev/null
+++ b/libstdc++-v3/include/tr1/special_function_util.h
@@ -0,0 +1,155 @@
+// Special functions -*- C++ -*-
+
+// Copyright (C) 2006
+// Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
+// USA.
+
+// As a special exception, you may use this file as part of a free software
+// library without restriction. Specifically, if other files instantiate
+// templates or use macros or inline functions from this file, or you compile
+// this file and link it with other files to produce an executable, this
+// file does not by itself cause the resulting executable to be covered by
+// the GNU General Public License. This exception does not however
+// invalidate any other reasons why the executable file might be covered by
+// the GNU General Public License.
+
+/** @file tr1/special_function_util.h
+ * This is an internal header file, included by other library headers.
+ * You should not attempt to use it directly.
+ */
+
+//
+// ISO C++ 14882 TR1: 5.2 Special functions
+//
+
+// Written by Edward Smith-Rowland based on numerous mathematics books.
+
+#ifndef _TR1_SPECIAL_FUNCTION_UTIL_H
+#define _TR1_SPECIAL_FUNCTION_UTIL_H 1
+
+// namespace std::tr1
+namespace std
+{
+_GLIBCXX_BEGIN_NAMESPACE(_GLIBCXX_TR1)
+
+ namespace __detail
+ {
+
+ ///
+ /// @brief A class to encapsulate type dependent floating point
+ /// constants. Not everything will be able to be expressed
+ /// as type logic.
+ ///
+ template <typename _Tp>
+ struct __floating_point_constant
+ {
+ static const _Tp __value;
+ };
+
+
+ ///
+ /// @brief A structure for numeric constants.
+ ///
+ template<typename _Tp>
+ struct __numeric_constants
+ {
+ /// Constant @f$ \pi @f$.
+ static _Tp __pi() throw()
+ { return static_cast<_Tp>(3.1415926535897932384626433832795029L); }
+ /// Constant @f$ \pi / 2 @f$.
+ static _Tp __pi_2() throw()
+ { return static_cast<_Tp>(1.5707963267948966192313216916397514L); }
+ /// Constant @f$ \pi / 3 @f$.
+ static _Tp __pi_3() throw()
+ { return static_cast<_Tp>(1.0471975511965977461542144610931676L); }
+ /// Constant @f$ \pi / 4 @f$.
+ static _Tp __pi_4() throw()
+ { return static_cast<_Tp>(0.7853981633974483096156608458198757L); }
+ /// Constant @f$ 1 / \pi @f$.
+ static _Tp __1_pi() throw()
+ { return static_cast<_Tp>(0.3183098861837906715377675267450287L); }
+ /// Constant @f$ 2 / \sqrt(\pi) @f$.
+ static _Tp __2_sqrtpi() throw()
+ { return static_cast<_Tp>(1.1283791670955125738961589031215452L); }
+ /// Constant @f$ \sqrt(2) @f$.
+ static _Tp __sqrt2() throw()
+ { return static_cast<_Tp>(1.4142135623730950488016887242096981L); }
+ /// Constant @f$ \sqrt(3) @f$.
+ static _Tp __sqrt3() throw()
+ { return static_cast<_Tp>(1.7320508075688772935274463415058723L); }
+ /// Constant @f$ \sqrt(\pi/2) @f$.
+ static _Tp __sqrtpio2() throw()
+ { return static_cast<_Tp>(1.2533141373155002512078826424055226L); }
+ /// Constant @f$ 1 / sqrt(2) @f$.
+ static _Tp __sqrt1_2() throw()
+ { return static_cast<_Tp>(0.7071067811865475244008443621048490L); }
+ /// Constant @f$ \log(\pi) @f$.
+ static _Tp __lnpi() throw()
+ { return static_cast<_Tp>(1.1447298858494001741434273513530587L); }
+ /// Constant Euler's constant @f$ \gamma_E @f$.
+ static _Tp __gamma_e() throw()
+ { return static_cast<_Tp>(0.5772156649015328606065120900824024L); }
+ /// Constant Euler-Mascheroni @f$ e @f$
+ static _Tp __euler() throw()
+ { return static_cast<_Tp>(2.7182818284590452353602874713526625L); }
+ };
+
+
+ ///
+ /// @brief This is a wrapper for the isnan function.
+ /// Otherwise, for NaN, all comparisons result in false.
+ /// If/when we build a std::isnan out of intrinsics, this
+ /// will disappear completely in favor of std::isnan.
+ ///
+#if _GLIBCXX_USE_C99_MATH && !_GLIBCXX_USE_C99_FP_MACROS_DYNAMIC
+
+ template <typename _Tp>
+ inline bool __isnan(const _Tp __x)
+ {
+ return std::isnan(__x);
+ }
+
+#else
+
+ template <typename _Tp>
+ inline bool __isnan(const _Tp __x)
+ {
+ return __builtin_isnan(__x);
+ }
+
+ template <>
+ inline bool __isnan<float>(const float __x)
+ {
+ return __builtin_isnanf(__x);
+ }
+
+ template <>
+ inline bool __isnan<long double>(const long double __x)
+ {
+ return __builtin_isnanl(__x);
+ }
+
+#endif
+
+ } // namespace __detail
+
+_GLIBCXX_END_NAMESPACE
+}
+
+#endif // _TR1_SPECIAL_FUNCTION_UTIL_H
+
diff --git a/libstdc++-v3/testsuite/lib/dg-options.exp b/libstdc++-v3/testsuite/lib/dg-options.exp
index ccc3fb69e31..29943ce2a6b 100644
--- a/libstdc++-v3/testsuite/lib/dg-options.exp
+++ b/libstdc++-v3/testsuite/lib/dg-options.exp
@@ -1,6 +1,6 @@
# Handlers for additional dg-xxx keywords in tests.
-# Copyright (C) 2004, 2005 Free Software Foundation, Inc.
+# Copyright (C) 2004, 2005, 2006, 2007 Free Software Foundation, Inc.
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
@@ -14,11 +14,20 @@
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
-# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+# 02110-1301, USA.
+proc dg-require-c-std { args } {
+ if { ![ check_v3_target_c_std ] } {
+ upvar dg-do-what dg-do-what
+ set dg-do-what [list [lindex ${dg-do-what} 0] "N" "P"]
+ return
+ }
+ return
+}
-proc dg-require-namedlocale { args } {
- if { ![ check_v3_target_namedlocale ] } {
+proc dg-require-debug-mode { args } {
+ if { ![ check_v3_target_debug_mode ] } {
upvar dg-do-what dg-do-what
set dg-do-what [list [lindex ${dg-do-what} 0] "N" "P"]
return
@@ -35,8 +44,8 @@ proc dg-require-fileio { args } {
return
}
-proc dg-require-time { args } {
- if { ![ check_v3_target_time ] } {
+proc dg-require-namedlocale { args } {
+ if { ![ check_v3_target_namedlocale ] } {
upvar dg-do-what dg-do-what
set dg-do-what [list [lindex ${dg-do-what} 0] "N" "P"]
return
@@ -53,8 +62,8 @@ proc dg-require-sharedlib { args } {
return
}
-proc dg-require-debug-mode { args } {
- if { ![ check_v3_target_debug_mode ] } {
+proc dg-require-time { args } {
+ if { ![ check_v3_target_time ] } {
upvar dg-do-what dg-do-what
set dg-do-what [list [lindex ${dg-do-what} 0] "N" "P"]
return
diff --git a/libstdc++-v3/testsuite/lib/libstdc++.exp b/libstdc++-v3/testsuite/lib/libstdc++.exp
index 79cbd9b1e88..a8e8a31d955 100644
--- a/libstdc++-v3/testsuite/lib/libstdc++.exp
+++ b/libstdc++-v3/testsuite/lib/libstdc++.exp
@@ -579,6 +579,67 @@ proc check_v3_target_fileio { } {
return $et_fileio_saved
}
+proc check_v3_target_c_std { } {
+ global et_c_std_saved
+ global et_c_std_target_name
+ global tool
+
+ if { ![info exists et_c_std_target_name] } {
+ set et_c_std_target_name ""
+ }
+
+ # If the target has changed since we set the cached value, clear it.
+ set current_target [current_target_name]
+ if { $current_target != $et_c_std_target_name } {
+ verbose "check_v3_target_c_std: `$et_c_std_target_name'" 2
+ set et_c_std_target_name $current_target
+ if [info exists et_c_std_saved] {
+ verbose "check_v3_target_c_std: removing cached result" 2
+ unset et_c_std_saved
+ }
+ }
+
+ if [info exists et_c_std_saved] {
+ verbose "check_v3_target_c_std: using cached result" 2
+ } else {
+ set et_c_std_saved 0
+
+ # Set up, compile, and execute a C++ test program that tries to use
+ # C99 functionality.
+ set src fileio[pid].cc
+ set exe fileio[pid].x
+
+ set f [open $src "w"]
+ puts $f "#include <tr1/cmath>"
+ puts $f "int main ()"
+ puts $f "{"
+ puts $f " float f = 45.55;"
+ puts $f " int i = std::tr1::isnan(f);"
+ puts $f " return 0;"
+ puts $f "}"
+ close $f
+
+ set lines [v3_target_compile $src $exe executable ""]
+ file delete $src
+
+ if [string match "" $lines] {
+ # No error message, compilation succeeded.
+ set result [${tool}_load "./$exe" "" ""]
+ set status [lindex $result 0]
+ remote_file build delete $exe
+
+ verbose "check_v3_target_c_std: status is <$status>" 2
+
+ if { $status == "pass" } {
+ set et_c_std_saved 1
+ }
+ } else {
+ verbose "check_v3_target_c_std: compilation failed" 2
+ }
+ }
+ return $et_c_std_saved
+}
+
proc check_v3_target_sharedlib { } {
global v3-sharedlib
return ${v3-sharedlib}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/01_assoc_laguerre/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/01_assoc_laguerre/check_nan.cc
new file mode 100644
index 00000000000..98f174fa7b1
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/01_assoc_laguerre/check_nan.cc
@@ -0,0 +1,57 @@
+// { dg-require-c-std "" }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.1 assoc_laguerre
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+ float xf = std::numeric_limits<float>::quiet_NaN();
+ double xd = std::numeric_limits<double>::quiet_NaN();
+ long double xl = std::numeric_limits<long double>::quiet_NaN();
+ unsigned int n = 2, m = 1;
+
+ float a = std::tr1::assoc_laguerre(n, m, xf);
+ float b = std::tr1::assoc_laguerref(n, m, xf);
+ double c = std::tr1::assoc_laguerre(n, m, xd);
+ long double d = std::tr1::assoc_laguerre(n, m, xl);
+ long double e = std::tr1::assoc_laguerrel(n, m, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/01_assoc_laguerre/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/01_assoc_laguerre/check_value.cc
new file mode 100644
index 00000000000..b79b5c1fac0
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/01_assoc_laguerre/check_value.cc
@@ -0,0 +1,3566 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// assoc_laguerre
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for n=0, m=0.
+testcase_assoc_laguerre<double> data001[] = {
+ { 1.0000000000000000, 0, 0,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0, 0,
+ 10.000000000000000 },
+ { 1.0000000000000000, 0, 0,
+ 20.000000000000000 },
+ { 1.0000000000000000, 0, 0,
+ 30.000000000000000 },
+ { 1.0000000000000000, 0, 0,
+ 40.000000000000000 },
+ { 1.0000000000000000, 0, 0,
+ 50.000000000000000 },
+ { 1.0000000000000000, 0, 0,
+ 60.000000000000000 },
+ { 1.0000000000000000, 0, 0,
+ 70.000000000000000 },
+ { 1.0000000000000000, 0, 0,
+ 80.000000000000000 },
+ { 1.0000000000000000, 0, 0,
+ 90.000000000000000 },
+ { 1.0000000000000000, 0, 0,
+ 100.00000000000000 },
+};
+
+// Test function for n=0, m=0.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data001[i].n), Tp(data001[i].m),
+ Tp(data001[i].x));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=0, m=1.
+testcase_assoc_laguerre<double> data002[] = {
+ { 1.0000000000000000, 0, 1,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0, 1,
+ 10.000000000000000 },
+ { 1.0000000000000000, 0, 1,
+ 20.000000000000000 },
+ { 1.0000000000000000, 0, 1,
+ 30.000000000000000 },
+ { 1.0000000000000000, 0, 1,
+ 40.000000000000000 },
+ { 1.0000000000000000, 0, 1,
+ 50.000000000000000 },
+ { 1.0000000000000000, 0, 1,
+ 60.000000000000000 },
+ { 1.0000000000000000, 0, 1,
+ 70.000000000000000 },
+ { 1.0000000000000000, 0, 1,
+ 80.000000000000000 },
+ { 1.0000000000000000, 0, 1,
+ 90.000000000000000 },
+ { 1.0000000000000000, 0, 1,
+ 100.00000000000000 },
+};
+
+// Test function for n=0, m=1.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data002[i].n), Tp(data002[i].m),
+ Tp(data002[i].x));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=0, m=2.
+testcase_assoc_laguerre<double> data003[] = {
+ { 1.0000000000000000, 0, 2,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0, 2,
+ 10.000000000000000 },
+ { 1.0000000000000000, 0, 2,
+ 20.000000000000000 },
+ { 1.0000000000000000, 0, 2,
+ 30.000000000000000 },
+ { 1.0000000000000000, 0, 2,
+ 40.000000000000000 },
+ { 1.0000000000000000, 0, 2,
+ 50.000000000000000 },
+ { 1.0000000000000000, 0, 2,
+ 60.000000000000000 },
+ { 1.0000000000000000, 0, 2,
+ 70.000000000000000 },
+ { 1.0000000000000000, 0, 2,
+ 80.000000000000000 },
+ { 1.0000000000000000, 0, 2,
+ 90.000000000000000 },
+ { 1.0000000000000000, 0, 2,
+ 100.00000000000000 },
+};
+
+// Test function for n=0, m=2.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data003[i].n), Tp(data003[i].m),
+ Tp(data003[i].x));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=0, m=5.
+testcase_assoc_laguerre<double> data004[] = {
+ { 1.0000000000000000, 0, 5,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0, 5,
+ 10.000000000000000 },
+ { 1.0000000000000000, 0, 5,
+ 20.000000000000000 },
+ { 1.0000000000000000, 0, 5,
+ 30.000000000000000 },
+ { 1.0000000000000000, 0, 5,
+ 40.000000000000000 },
+ { 1.0000000000000000, 0, 5,
+ 50.000000000000000 },
+ { 1.0000000000000000, 0, 5,
+ 60.000000000000000 },
+ { 1.0000000000000000, 0, 5,
+ 70.000000000000000 },
+ { 1.0000000000000000, 0, 5,
+ 80.000000000000000 },
+ { 1.0000000000000000, 0, 5,
+ 90.000000000000000 },
+ { 1.0000000000000000, 0, 5,
+ 100.00000000000000 },
+};
+
+// Test function for n=0, m=5.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data004[i].n), Tp(data004[i].m),
+ Tp(data004[i].x));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=0, m=10.
+testcase_assoc_laguerre<double> data005[] = {
+ { 1.0000000000000000, 0, 10,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0, 10,
+ 10.000000000000000 },
+ { 1.0000000000000000, 0, 10,
+ 20.000000000000000 },
+ { 1.0000000000000000, 0, 10,
+ 30.000000000000000 },
+ { 1.0000000000000000, 0, 10,
+ 40.000000000000000 },
+ { 1.0000000000000000, 0, 10,
+ 50.000000000000000 },
+ { 1.0000000000000000, 0, 10,
+ 60.000000000000000 },
+ { 1.0000000000000000, 0, 10,
+ 70.000000000000000 },
+ { 1.0000000000000000, 0, 10,
+ 80.000000000000000 },
+ { 1.0000000000000000, 0, 10,
+ 90.000000000000000 },
+ { 1.0000000000000000, 0, 10,
+ 100.00000000000000 },
+};
+
+// Test function for n=0, m=10.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data005[i].n), Tp(data005[i].m),
+ Tp(data005[i].x));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=0, m=20.
+testcase_assoc_laguerre<double> data006[] = {
+ { 1.0000000000000000, 0, 20,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0, 20,
+ 10.000000000000000 },
+ { 1.0000000000000000, 0, 20,
+ 20.000000000000000 },
+ { 1.0000000000000000, 0, 20,
+ 30.000000000000000 },
+ { 1.0000000000000000, 0, 20,
+ 40.000000000000000 },
+ { 1.0000000000000000, 0, 20,
+ 50.000000000000000 },
+ { 1.0000000000000000, 0, 20,
+ 60.000000000000000 },
+ { 1.0000000000000000, 0, 20,
+ 70.000000000000000 },
+ { 1.0000000000000000, 0, 20,
+ 80.000000000000000 },
+ { 1.0000000000000000, 0, 20,
+ 90.000000000000000 },
+ { 1.0000000000000000, 0, 20,
+ 100.00000000000000 },
+};
+
+// Test function for n=0, m=20.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data006[i].n), Tp(data006[i].m),
+ Tp(data006[i].x));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=0, m=50.
+testcase_assoc_laguerre<double> data007[] = {
+ { 1.0000000000000000, 0, 50,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0, 50,
+ 10.000000000000000 },
+ { 1.0000000000000000, 0, 50,
+ 20.000000000000000 },
+ { 1.0000000000000000, 0, 50,
+ 30.000000000000000 },
+ { 1.0000000000000000, 0, 50,
+ 40.000000000000000 },
+ { 1.0000000000000000, 0, 50,
+ 50.000000000000000 },
+ { 1.0000000000000000, 0, 50,
+ 60.000000000000000 },
+ { 1.0000000000000000, 0, 50,
+ 70.000000000000000 },
+ { 1.0000000000000000, 0, 50,
+ 80.000000000000000 },
+ { 1.0000000000000000, 0, 50,
+ 90.000000000000000 },
+ { 1.0000000000000000, 0, 50,
+ 100.00000000000000 },
+};
+
+// Test function for n=0, m=50.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data007[i].n), Tp(data007[i].m),
+ Tp(data007[i].x));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=0, m=100.
+testcase_assoc_laguerre<double> data008[] = {
+ { 1.0000000000000000, 0, 100,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0, 100,
+ 10.000000000000000 },
+ { 1.0000000000000000, 0, 100,
+ 20.000000000000000 },
+ { 1.0000000000000000, 0, 100,
+ 30.000000000000000 },
+ { 1.0000000000000000, 0, 100,
+ 40.000000000000000 },
+ { 1.0000000000000000, 0, 100,
+ 50.000000000000000 },
+ { 1.0000000000000000, 0, 100,
+ 60.000000000000000 },
+ { 1.0000000000000000, 0, 100,
+ 70.000000000000000 },
+ { 1.0000000000000000, 0, 100,
+ 80.000000000000000 },
+ { 1.0000000000000000, 0, 100,
+ 90.000000000000000 },
+ { 1.0000000000000000, 0, 100,
+ 100.00000000000000 },
+};
+
+// Test function for n=0, m=100.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data008[i].n), Tp(data008[i].m),
+ Tp(data008[i].x));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=1, m=0.
+testcase_assoc_laguerre<double> data009[] = {
+ { 1.0000000000000000, 1, 0,
+ 0.0000000000000000 },
+ { -9.0000000000000000, 1, 0,
+ 10.000000000000000 },
+ { -19.000000000000000, 1, 0,
+ 20.000000000000000 },
+ { -29.000000000000000, 1, 0,
+ 30.000000000000000 },
+ { -39.000000000000000, 1, 0,
+ 40.000000000000000 },
+ { -49.000000000000000, 1, 0,
+ 50.000000000000000 },
+ { -59.000000000000000, 1, 0,
+ 60.000000000000000 },
+ { -69.000000000000000, 1, 0,
+ 70.000000000000000 },
+ { -79.000000000000000, 1, 0,
+ 80.000000000000000 },
+ { -89.000000000000000, 1, 0,
+ 90.000000000000000 },
+ { -99.000000000000000, 1, 0,
+ 100.00000000000000 },
+};
+
+// Test function for n=1, m=0.
+template <typename Tp>
+void test009()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data009)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data009[i].n), Tp(data009[i].m),
+ Tp(data009[i].x));
+ const Tp f0 = data009[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=1, m=1.
+testcase_assoc_laguerre<double> data010[] = {
+ { 2.0000000000000000, 1, 1,
+ 0.0000000000000000 },
+ { -8.0000000000000000, 1, 1,
+ 10.000000000000000 },
+ { -18.000000000000000, 1, 1,
+ 20.000000000000000 },
+ { -28.000000000000000, 1, 1,
+ 30.000000000000000 },
+ { -38.000000000000000, 1, 1,
+ 40.000000000000000 },
+ { -48.000000000000000, 1, 1,
+ 50.000000000000000 },
+ { -58.000000000000000, 1, 1,
+ 60.000000000000000 },
+ { -68.000000000000000, 1, 1,
+ 70.000000000000000 },
+ { -78.000000000000000, 1, 1,
+ 80.000000000000000 },
+ { -88.000000000000000, 1, 1,
+ 90.000000000000000 },
+ { -98.000000000000000, 1, 1,
+ 100.00000000000000 },
+};
+
+// Test function for n=1, m=1.
+template <typename Tp>
+void test010()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data010)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data010[i].n), Tp(data010[i].m),
+ Tp(data010[i].x));
+ const Tp f0 = data010[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=1, m=2.
+testcase_assoc_laguerre<double> data011[] = {
+ { 3.0000000000000000, 1, 2,
+ 0.0000000000000000 },
+ { -7.0000000000000000, 1, 2,
+ 10.000000000000000 },
+ { -17.000000000000000, 1, 2,
+ 20.000000000000000 },
+ { -27.000000000000000, 1, 2,
+ 30.000000000000000 },
+ { -37.000000000000000, 1, 2,
+ 40.000000000000000 },
+ { -47.000000000000000, 1, 2,
+ 50.000000000000000 },
+ { -57.000000000000000, 1, 2,
+ 60.000000000000000 },
+ { -67.000000000000000, 1, 2,
+ 70.000000000000000 },
+ { -77.000000000000000, 1, 2,
+ 80.000000000000000 },
+ { -87.000000000000000, 1, 2,
+ 90.000000000000000 },
+ { -97.000000000000000, 1, 2,
+ 100.00000000000000 },
+};
+
+// Test function for n=1, m=2.
+template <typename Tp>
+void test011()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data011)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data011[i].n), Tp(data011[i].m),
+ Tp(data011[i].x));
+ const Tp f0 = data011[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=1, m=5.
+testcase_assoc_laguerre<double> data012[] = {
+ { 6.0000000000000000, 1, 5,
+ 0.0000000000000000 },
+ { -4.0000000000000000, 1, 5,
+ 10.000000000000000 },
+ { -14.000000000000000, 1, 5,
+ 20.000000000000000 },
+ { -24.000000000000000, 1, 5,
+ 30.000000000000000 },
+ { -34.000000000000000, 1, 5,
+ 40.000000000000000 },
+ { -44.000000000000000, 1, 5,
+ 50.000000000000000 },
+ { -54.000000000000000, 1, 5,
+ 60.000000000000000 },
+ { -64.000000000000000, 1, 5,
+ 70.000000000000000 },
+ { -74.000000000000000, 1, 5,
+ 80.000000000000000 },
+ { -84.000000000000000, 1, 5,
+ 90.000000000000000 },
+ { -94.000000000000000, 1, 5,
+ 100.00000000000000 },
+};
+
+// Test function for n=1, m=5.
+template <typename Tp>
+void test012()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data012)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data012[i].n), Tp(data012[i].m),
+ Tp(data012[i].x));
+ const Tp f0 = data012[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=1, m=10.
+testcase_assoc_laguerre<double> data013[] = {
+ { 11.000000000000000, 1, 10,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 1, 10,
+ 10.000000000000000 },
+ { -9.0000000000000000, 1, 10,
+ 20.000000000000000 },
+ { -19.000000000000000, 1, 10,
+ 30.000000000000000 },
+ { -29.000000000000000, 1, 10,
+ 40.000000000000000 },
+ { -39.000000000000000, 1, 10,
+ 50.000000000000000 },
+ { -49.000000000000000, 1, 10,
+ 60.000000000000000 },
+ { -59.000000000000000, 1, 10,
+ 70.000000000000000 },
+ { -69.000000000000000, 1, 10,
+ 80.000000000000000 },
+ { -79.000000000000000, 1, 10,
+ 90.000000000000000 },
+ { -89.000000000000000, 1, 10,
+ 100.00000000000000 },
+};
+
+// Test function for n=1, m=10.
+template <typename Tp>
+void test013()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data013)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data013[i].n), Tp(data013[i].m),
+ Tp(data013[i].x));
+ const Tp f0 = data013[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=1, m=20.
+testcase_assoc_laguerre<double> data014[] = {
+ { 21.000000000000000, 1, 20,
+ 0.0000000000000000 },
+ { 11.000000000000000, 1, 20,
+ 10.000000000000000 },
+ { 1.0000000000000000, 1, 20,
+ 20.000000000000000 },
+ { -9.0000000000000000, 1, 20,
+ 30.000000000000000 },
+ { -19.000000000000000, 1, 20,
+ 40.000000000000000 },
+ { -29.000000000000000, 1, 20,
+ 50.000000000000000 },
+ { -39.000000000000000, 1, 20,
+ 60.000000000000000 },
+ { -49.000000000000000, 1, 20,
+ 70.000000000000000 },
+ { -59.000000000000000, 1, 20,
+ 80.000000000000000 },
+ { -69.000000000000000, 1, 20,
+ 90.000000000000000 },
+ { -79.000000000000000, 1, 20,
+ 100.00000000000000 },
+};
+
+// Test function for n=1, m=20.
+template <typename Tp>
+void test014()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data014)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data014[i].n), Tp(data014[i].m),
+ Tp(data014[i].x));
+ const Tp f0 = data014[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=1, m=50.
+testcase_assoc_laguerre<double> data015[] = {
+ { 51.000000000000000, 1, 50,
+ 0.0000000000000000 },
+ { 41.000000000000000, 1, 50,
+ 10.000000000000000 },
+ { 31.000000000000000, 1, 50,
+ 20.000000000000000 },
+ { 21.000000000000000, 1, 50,
+ 30.000000000000000 },
+ { 11.000000000000000, 1, 50,
+ 40.000000000000000 },
+ { 1.0000000000000000, 1, 50,
+ 50.000000000000000 },
+ { -9.0000000000000000, 1, 50,
+ 60.000000000000000 },
+ { -19.000000000000000, 1, 50,
+ 70.000000000000000 },
+ { -29.000000000000000, 1, 50,
+ 80.000000000000000 },
+ { -39.000000000000000, 1, 50,
+ 90.000000000000000 },
+ { -49.000000000000000, 1, 50,
+ 100.00000000000000 },
+};
+
+// Test function for n=1, m=50.
+template <typename Tp>
+void test015()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data015)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data015[i].n), Tp(data015[i].m),
+ Tp(data015[i].x));
+ const Tp f0 = data015[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=1, m=100.
+testcase_assoc_laguerre<double> data016[] = {
+ { 101.00000000000000, 1, 100,
+ 0.0000000000000000 },
+ { 91.000000000000000, 1, 100,
+ 10.000000000000000 },
+ { 81.000000000000000, 1, 100,
+ 20.000000000000000 },
+ { 71.000000000000000, 1, 100,
+ 30.000000000000000 },
+ { 61.000000000000000, 1, 100,
+ 40.000000000000000 },
+ { 51.000000000000000, 1, 100,
+ 50.000000000000000 },
+ { 41.000000000000000, 1, 100,
+ 60.000000000000000 },
+ { 31.000000000000000, 1, 100,
+ 70.000000000000000 },
+ { 21.000000000000000, 1, 100,
+ 80.000000000000000 },
+ { 11.000000000000000, 1, 100,
+ 90.000000000000000 },
+ { 1.0000000000000000, 1, 100,
+ 100.00000000000000 },
+};
+
+// Test function for n=1, m=100.
+template <typename Tp>
+void test016()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data016)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data016[i].n), Tp(data016[i].m),
+ Tp(data016[i].x));
+ const Tp f0 = data016[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=2, m=0.
+testcase_assoc_laguerre<double> data017[] = {
+ { 1.0000000000000000, 2, 0,
+ 0.0000000000000000 },
+ { 31.000000000000000, 2, 0,
+ 10.000000000000000 },
+ { 161.00000000000000, 2, 0,
+ 20.000000000000000 },
+ { 391.00000000000000, 2, 0,
+ 30.000000000000000 },
+ { 721.00000000000000, 2, 0,
+ 40.000000000000000 },
+ { 1151.0000000000000, 2, 0,
+ 50.000000000000000 },
+ { 1681.0000000000000, 2, 0,
+ 60.000000000000000 },
+ { 2311.0000000000000, 2, 0,
+ 70.000000000000000 },
+ { 3041.0000000000000, 2, 0,
+ 80.000000000000000 },
+ { 3871.0000000000000, 2, 0,
+ 90.000000000000000 },
+ { 4801.0000000000000, 2, 0,
+ 100.00000000000000 },
+};
+
+// Test function for n=2, m=0.
+template <typename Tp>
+void test017()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data017)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data017[i].n), Tp(data017[i].m),
+ Tp(data017[i].x));
+ const Tp f0 = data017[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=2, m=1.
+testcase_assoc_laguerre<double> data018[] = {
+ { 3.0000000000000000, 2, 1,
+ 0.0000000000000000 },
+ { 23.000000000000000, 2, 1,
+ 10.000000000000000 },
+ { 143.00000000000000, 2, 1,
+ 20.000000000000000 },
+ { 363.00000000000000, 2, 1,
+ 30.000000000000000 },
+ { 683.00000000000000, 2, 1,
+ 40.000000000000000 },
+ { 1103.0000000000000, 2, 1,
+ 50.000000000000000 },
+ { 1623.0000000000000, 2, 1,
+ 60.000000000000000 },
+ { 2243.0000000000000, 2, 1,
+ 70.000000000000000 },
+ { 2963.0000000000000, 2, 1,
+ 80.000000000000000 },
+ { 3783.0000000000000, 2, 1,
+ 90.000000000000000 },
+ { 4703.0000000000000, 2, 1,
+ 100.00000000000000 },
+};
+
+// Test function for n=2, m=1.
+template <typename Tp>
+void test018()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data018)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data018[i].n), Tp(data018[i].m),
+ Tp(data018[i].x));
+ const Tp f0 = data018[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=2, m=2.
+testcase_assoc_laguerre<double> data019[] = {
+ { 6.0000000000000000, 2, 2,
+ 0.0000000000000000 },
+ { 16.000000000000000, 2, 2,
+ 10.000000000000000 },
+ { 126.00000000000000, 2, 2,
+ 20.000000000000000 },
+ { 336.00000000000000, 2, 2,
+ 30.000000000000000 },
+ { 646.00000000000000, 2, 2,
+ 40.000000000000000 },
+ { 1056.0000000000000, 2, 2,
+ 50.000000000000000 },
+ { 1566.0000000000000, 2, 2,
+ 60.000000000000000 },
+ { 2176.0000000000000, 2, 2,
+ 70.000000000000000 },
+ { 2886.0000000000000, 2, 2,
+ 80.000000000000000 },
+ { 3696.0000000000000, 2, 2,
+ 90.000000000000000 },
+ { 4606.0000000000000, 2, 2,
+ 100.00000000000000 },
+};
+
+// Test function for n=2, m=2.
+template <typename Tp>
+void test019()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data019)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data019[i].n), Tp(data019[i].m),
+ Tp(data019[i].x));
+ const Tp f0 = data019[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=2, m=5.
+testcase_assoc_laguerre<double> data020[] = {
+ { 21.000000000000000, 2, 5,
+ 0.0000000000000000 },
+ { 0.99999999999999645, 2, 5,
+ 10.000000000000000 },
+ { 81.000000000000000, 2, 5,
+ 20.000000000000000 },
+ { 261.00000000000000, 2, 5,
+ 30.000000000000000 },
+ { 541.00000000000000, 2, 5,
+ 40.000000000000000 },
+ { 921.00000000000000, 2, 5,
+ 50.000000000000000 },
+ { 1401.0000000000000, 2, 5,
+ 60.000000000000000 },
+ { 1981.0000000000000, 2, 5,
+ 70.000000000000000 },
+ { 2661.0000000000000, 2, 5,
+ 80.000000000000000 },
+ { 3441.0000000000000, 2, 5,
+ 90.000000000000000 },
+ { 4321.0000000000000, 2, 5,
+ 100.00000000000000 },
+};
+
+// Test function for n=2, m=5.
+template <typename Tp>
+void test020()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data020)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data020[i].n), Tp(data020[i].m),
+ Tp(data020[i].x));
+ const Tp f0 = data020[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=2, m=10.
+testcase_assoc_laguerre<double> data021[] = {
+ { 66.000000000000000, 2, 10,
+ 0.0000000000000000 },
+ { -4.0000000000000089, 2, 10,
+ 10.000000000000000 },
+ { 25.999999999999964, 2, 10,
+ 20.000000000000000 },
+ { 156.00000000000000, 2, 10,
+ 30.000000000000000 },
+ { 386.00000000000000, 2, 10,
+ 40.000000000000000 },
+ { 716.00000000000000, 2, 10,
+ 50.000000000000000 },
+ { 1146.0000000000000, 2, 10,
+ 60.000000000000000 },
+ { 1676.0000000000000, 2, 10,
+ 70.000000000000000 },
+ { 2306.0000000000000, 2, 10,
+ 80.000000000000000 },
+ { 3036.0000000000000, 2, 10,
+ 90.000000000000000 },
+ { 3866.0000000000000, 2, 10,
+ 100.00000000000000 },
+};
+
+// Test function for n=2, m=10.
+template <typename Tp>
+void test021()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data021)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data021[i].n), Tp(data021[i].m),
+ Tp(data021[i].x));
+ const Tp f0 = data021[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=2, m=20.
+testcase_assoc_laguerre<double> data022[] = {
+ { 231.00000000000000, 2, 20,
+ 0.0000000000000000 },
+ { 61.000000000000206, 2, 20,
+ 10.000000000000000 },
+ { -8.9999999999999982, 2, 20,
+ 20.000000000000000 },
+ { 21.000000000000135, 2, 20,
+ 30.000000000000000 },
+ { 151.00000000000054, 2, 20,
+ 40.000000000000000 },
+ { 381.00000000000000, 2, 20,
+ 50.000000000000000 },
+ { 711.00000000000000, 2, 20,
+ 60.000000000000000 },
+ { 1141.0000000000000, 2, 20,
+ 70.000000000000000 },
+ { 1670.9999999999998, 2, 20,
+ 80.000000000000000 },
+ { 2301.0000000000000, 2, 20,
+ 90.000000000000000 },
+ { 3031.0000000000000, 2, 20,
+ 100.00000000000000 },
+};
+
+// Test function for n=2, m=20.
+template <typename Tp>
+void test022()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data022)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data022[i].n), Tp(data022[i].m),
+ Tp(data022[i].x));
+ const Tp f0 = data022[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for n=2, m=50.
+testcase_assoc_laguerre<double> data023[] = {
+ { 1326.0000000000000, 2, 50,
+ 0.0000000000000000 },
+ { 855.99999999999716, 2, 50,
+ 10.000000000000000 },
+ { 485.99999999999829, 2, 50,
+ 20.000000000000000 },
+ { 215.99999999999935, 2, 50,
+ 30.000000000000000 },
+ { 45.999999999999787, 2, 50,
+ 40.000000000000000 },
+ { -23.999999999999684, 2, 50,
+ 50.000000000000000 },
+ { 6.0000000000001217, 2, 50,
+ 60.000000000000000 },
+ { 135.99999999999972, 2, 50,
+ 70.000000000000000 },
+ { 365.99999999999892, 2, 50,
+ 80.000000000000000 },
+ { 695.99999999999784, 2, 50,
+ 90.000000000000000 },
+ { 1125.9999999999964, 2, 50,
+ 100.00000000000000 },
+};
+
+// Test function for n=2, m=50.
+template <typename Tp>
+void test023()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data023)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data023[i].n), Tp(data023[i].m),
+ Tp(data023[i].x));
+ const Tp f0 = data023[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000015e-12));
+}
+
+// Test data for n=2, m=100.
+testcase_assoc_laguerre<double> data024[] = {
+ { 5151.0000000000000, 2, 100,
+ 0.0000000000000000 },
+ { 4181.0000000000655, 2, 100,
+ 10.000000000000000 },
+ { 3311.0000000000518, 2, 100,
+ 20.000000000000000 },
+ { 2541.0000000000400, 2, 100,
+ 30.000000000000000 },
+ { 1871.0000000000291, 2, 100,
+ 40.000000000000000 },
+ { 1301.0000000000207, 2, 100,
+ 50.000000000000000 },
+ { 831.00000000001364, 2, 100,
+ 60.000000000000000 },
+ { 461.00000000000682, 2, 100,
+ 70.000000000000000 },
+ { 191.00000000000227, 2, 100,
+ 80.000000000000000 },
+ { 21.000000000000128, 2, 100,
+ 90.000000000000000 },
+ { -49.000000000000369, 2, 100,
+ 100.00000000000000 },
+};
+
+// Test function for n=2, m=100.
+template <typename Tp>
+void test024()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data024)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data024[i].n), Tp(data024[i].m),
+ Tp(data024[i].x));
+ const Tp f0 = data024[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for n=5, m=0.
+testcase_assoc_laguerre<double> data025[] = {
+ { 1.0000000000000000, 5, 0,
+ 0.0000000000000000 },
+ { 34.333333333333329, 5, 0,
+ 10.000000000000000 },
+ { -4765.6666666666670, 5, 0,
+ 20.000000000000000 },
+ { -74399.000000000000, 5, 0,
+ 30.000000000000000 },
+ { -418865.66666666663, 5, 0,
+ 40.000000000000000 },
+ { -1498165.6666666665, 5, 0,
+ 50.000000000000000 },
+ { -4122299.0000000000, 5, 0,
+ 60.000000000000000 },
+ { -9551265.6666666679, 5, 0,
+ 70.000000000000000 },
+ { -19595065.666666664, 5, 0,
+ 80.000000000000000 },
+ { -36713699.000000000, 5, 0,
+ 90.000000000000000 },
+ { -64117165.666666664, 5, 0,
+ 100.00000000000000 },
+};
+
+// Test function for n=5, m=0.
+template <typename Tp>
+void test025()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data025)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data025[i].n), Tp(data025[i].m),
+ Tp(data025[i].x));
+ const Tp f0 = data025[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=5, m=1.
+testcase_assoc_laguerre<double> data026[] = {
+ { 6.0000000000000000, 5, 1,
+ 0.0000000000000000 },
+ { 22.666666666666661, 5, 1,
+ 10.000000000000000 },
+ { -2960.6666666666661, 5, 1,
+ 20.000000000000000 },
+ { -58944.000000000000, 5, 1,
+ 30.000000000000000 },
+ { -357927.33333333326, 5, 1,
+ 40.000000000000000 },
+ { -1329910.6666666665, 5, 1,
+ 50.000000000000000 },
+ { -3744894.0000000000, 5, 1,
+ 60.000000000000000 },
+ { -8812877.3333333321, 5, 1,
+ 70.000000000000000 },
+ { -18283860.666666664, 5, 1,
+ 80.000000000000000 },
+ { -34547844.000000000, 5, 1,
+ 90.000000000000000 },
+ { -60734827.333333336, 5, 1,
+ 100.00000000000000 },
+};
+
+// Test function for n=5, m=1.
+template <typename Tp>
+void test026()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data026)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data026[i].n), Tp(data026[i].m),
+ Tp(data026[i].x));
+ const Tp f0 = data026[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=5, m=2.
+testcase_assoc_laguerre<double> data027[] = {
+ { 21.000000000000000, 5, 2,
+ 0.0000000000000000 },
+ { 4.3333333333333339, 5, 2,
+ 10.000000000000000 },
+ { -1679.0000000000000, 5, 2,
+ 20.000000000000000 },
+ { -46029.000000000000, 5, 2,
+ 30.000000000000000 },
+ { -304045.66666666669, 5, 2,
+ 40.000000000000000 },
+ { -1176729.0000000002, 5, 2,
+ 50.000000000000000 },
+ { -3395079.0000000000, 5, 2,
+ 60.000000000000000 },
+ { -8120095.6666666660, 5, 2,
+ 70.000000000000000 },
+ { -17042778.999999996, 5, 2,
+ 80.000000000000000 },
+ { -32484129.000000000, 5, 2,
+ 90.000000000000000 },
+ { -57495145.666666664, 5, 2,
+ 100.00000000000000 },
+};
+
+// Test function for n=5, m=2.
+template <typename Tp>
+void test027()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data027)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data027[i].n), Tp(data027[i].m),
+ Tp(data027[i].x));
+ const Tp f0 = data027[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=5, m=5.
+testcase_assoc_laguerre<double> data028[] = {
+ { 252.00000000000000, 5, 5,
+ 0.0000000000000000 },
+ { -14.666666666666657, 5, 5,
+ 10.000000000000000 },
+ { 51.999999999999957, 5, 5,
+ 20.000000000000000 },
+ { -19548.000000000000, 5, 5,
+ 30.000000000000000 },
+ { -178814.66666666660, 5, 5,
+ 40.000000000000000 },
+ { -797747.99999999977, 5, 5,
+ 50.000000000000000 },
+ { -2496348.0000000000, 5, 5,
+ 60.000000000000000 },
+ { -6294614.6666666660, 5, 5,
+ 70.000000000000000 },
+ { -13712547.999999996, 5, 5,
+ 80.000000000000000 },
+ { -26870147.999999993, 5, 5,
+ 90.000000000000000 },
+ { -48587414.666666672, 5, 5,
+ 100.00000000000000 },
+};
+
+// Test function for n=5, m=5.
+template <typename Tp>
+void test028()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data028)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data028[i].n), Tp(data028[i].m),
+ Tp(data028[i].x));
+ const Tp f0 = data028[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=5, m=10.
+testcase_assoc_laguerre<double> data029[] = {
+ { 3003.0000000000000, 5, 10,
+ 0.0000000000000000 },
+ { 19.666666666666668, 5, 10,
+ 10.000000000000000 },
+ { 36.333333333333272, 5, 10,
+ 20.000000000000000 },
+ { -1947.0000000000000, 5, 10,
+ 30.000000000000000 },
+ { -60930.333333333314, 5, 10,
+ 40.000000000000000 },
+ { -381913.66666666651, 5, 10,
+ 50.000000000000000 },
+ { -1419897.0000000000, 5, 10,
+ 60.000000000000000 },
+ { -3979880.3333333330, 5, 10,
+ 70.000000000000000 },
+ { -9316863.6666666642, 5, 10,
+ 80.000000000000000 },
+ { -19235847.000000000, 5, 10,
+ 90.000000000000000 },
+ { -36191830.333333328, 5, 10,
+ 100.00000000000000 },
+};
+
+// Test function for n=5, m=10.
+template <typename Tp>
+void test029()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data029)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data029[i].n), Tp(data029[i].m),
+ Tp(data029[i].x));
+ const Tp f0 = data029[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=5, m=20.
+testcase_assoc_laguerre<double> data030[] = {
+ { 53130.000000000000, 5, 20,
+ 0.0000000000000000 },
+ { 1213.3333333333335, 5, 20,
+ 10.000000000000000 },
+ { 129.99999999999963, 5, 20,
+ 20.000000000000000 },
+ { -119.99999999999974, 5, 20,
+ 30.000000000000000 },
+ { 463.33333333333320, 5, 20,
+ 40.000000000000000 },
+ { -48120.000000000015, 5, 20,
+ 50.000000000000000 },
+ { -345870.00000000017, 5, 20,
+ 60.000000000000000 },
+ { -1342786.6666666667, 5, 20,
+ 70.000000000000000 },
+ { -3838870.0000000009, 5, 20,
+ 80.000000000000000 },
+ { -9084120.0000000000, 5, 20,
+ 90.000000000000000 },
+ { -18878536.666666668, 5, 20,
+ 100.00000000000000 },
+};
+
+// Test function for n=5, m=20.
+template <typename Tp>
+void test030()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data030)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data030[i].n), Tp(data030[i].m),
+ Tp(data030[i].x));
+ const Tp f0 = data030[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=5, m=50.
+testcase_assoc_laguerre<double> data031[] = {
+ { 3478761.0000000000, 5, 50,
+ 0.0000000000000000 },
+ { 1154544.3333333335, 5, 50,
+ 10.000000000000000 },
+ { 264661.00000000006, 5, 50,
+ 20.000000000000000 },
+ { 24111.000000000000, 5, 50,
+ 30.000000000000000 },
+ { -2105.6666666666665, 5, 50,
+ 40.000000000000000 },
+ { 1011.0000000000000, 5, 50,
+ 50.000000000000000 },
+ { -1538.9999999999955, 5, 50,
+ 60.000000000000000 },
+ { 5244.3333333333449, 5, 50,
+ 70.000000000000000 },
+ { -13639.000000000015, 5, 50,
+ 80.000000000000000 },
+ { -243189.00000000006, 5, 50,
+ 90.000000000000000 },
+ { -1118405.6666666667, 5, 50,
+ 100.00000000000000 },
+};
+
+// Test function for n=5, m=50.
+template <typename Tp>
+void test031()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data031)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data031[i].n), Tp(data031[i].m),
+ Tp(data031[i].x));
+ const Tp f0 = data031[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=5, m=100.
+testcase_assoc_laguerre<double> data032[] = {
+ { 96560646.000000000, 5, 100,
+ 0.0000000000000000 },
+ { 57264262.666666649, 5, 100,
+ 10.000000000000000 },
+ { 31841379.333333332, 5, 100,
+ 20.000000000000000 },
+ { 16281996.000000000, 5, 100,
+ 30.000000000000000 },
+ { 7426112.6666666670, 5, 100,
+ 40.000000000000000 },
+ { 2863729.3333333330, 5, 100,
+ 50.000000000000000 },
+ { 834846.00000000000, 5, 100,
+ 60.000000000000000 },
+ { 129462.66666666663, 5, 100,
+ 70.000000000000000 },
+ { -12420.666666666666, 5, 100,
+ 80.000000000000000 },
+ { -804.00000000000000, 5, 100,
+ 90.000000000000000 },
+ { 4312.6666666666661, 5, 100,
+ 100.00000000000000 },
+};
+
+// Test function for n=5, m=100.
+template <typename Tp>
+void test032()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data032)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data032[i].n), Tp(data032[i].m),
+ Tp(data032[i].x));
+ const Tp f0 = data032[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=10, m=0.
+testcase_assoc_laguerre<double> data033[] = {
+ { 1.0000000000000000, 10, 0,
+ 0.0000000000000000 },
+ { 27.984126984126981, 10, 0,
+ 10.000000000000000 },
+ { 3227.8077601410932, 10, 0,
+ 20.000000000000000 },
+ { 15129.571428571489, 10, 0,
+ 30.000000000000000 },
+ { 79724066.608465582, 10, 0,
+ 40.000000000000000 },
+ { 2037190065.3738980, 10, 0,
+ 50.000000000000000 },
+ { 21804200401.000000, 10, 0,
+ 60.000000000000000 },
+ { 144688291819.51855, 10, 0,
+ 70.000000000000000 },
+ { 703324772760.08276, 10, 0,
+ 80.000000000000000 },
+ { 2741055412243.8569, 10, 0,
+ 90.000000000000000 },
+ { 9051283795429.5723, 10, 0,
+ 100.00000000000000 },
+};
+
+// Test function for n=10, m=0.
+template <typename Tp>
+void test033()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data033)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data033[i].n), Tp(data033[i].m),
+ Tp(data033[i].x));
+ const Tp f0 = data033[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for n=10, m=1.
+testcase_assoc_laguerre<double> data034[] = {
+ { 11.000000000000000, 10, 1,
+ 0.0000000000000000 },
+ { 14.791887125220455, 10, 1,
+ 10.000000000000000 },
+ { 2704.6507936507933, 10, 1,
+ 20.000000000000000 },
+ { -182924.71428571426, 10, 1,
+ 30.000000000000000 },
+ { 48066036.749559075, 10, 1,
+ 40.000000000000000 },
+ { 1486264192.2169311, 10, 1,
+ 50.000000000000000 },
+ { 17239562282.428574, 10, 1,
+ 60.000000000000000 },
+ { 119837491630.13579, 10, 1,
+ 70.000000000000000 },
+ { 600681375251.21167, 10, 1,
+ 80.000000000000000 },
+ { 2392908405632.4287, 10, 1,
+ 90.000000000000000 },
+ { 8033035722509.2373, 10, 1,
+ 100.00000000000000 },
+};
+
+// Test function for n=10, m=1.
+template <typename Tp>
+void test034()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data034)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data034[i].n), Tp(data034[i].m),
+ Tp(data034[i].x));
+ const Tp f0 = data034[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=10, m=2.
+testcase_assoc_laguerre<double> data035[] = {
+ { 66.000000000000000, 10, 2,
+ 0.0000000000000000 },
+ { -14.511463844797174, 10, 2,
+ 10.000000000000000 },
+ { 1064.5890652557318, 10, 2,
+ 20.000000000000000 },
+ { -194569.71428571426, 10, 2,
+ 30.000000000000000 },
+ { 27343569.350970022, 10, 2,
+ 40.000000000000000 },
+ { 1067807661.6790125, 10, 2,
+ 50.000000000000000 },
+ { 13529451580.285713, 10, 2,
+ 60.000000000000000 },
+ { 98812724224.641937, 10, 2,
+ 70.000000000000000 },
+ { 511482736187.34021, 10, 2,
+ 80.000000000000000 },
+ { 2084478393087.4285, 10, 2,
+ 90.000000000000000 },
+ { 7117724862237.0752, 10, 2,
+ 100.00000000000000 },
+};
+
+// Test function for n=10, m=2.
+template <typename Tp>
+void test035()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data035)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data035[i].n), Tp(data035[i].m),
+ Tp(data035[i].x));
+ const Tp f0 = data035[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=10, m=5.
+testcase_assoc_laguerre<double> data036[] = {
+ { 3003.0000000000000, 10, 5,
+ 0.0000000000000000 },
+ { 11.641975308642024, 10, 5,
+ 10.000000000000000 },
+ { -1137.5643738977069, 10, 5,
+ 20.000000000000000 },
+ { -9254.1428571428605, 10, 5,
+ 30.000000000000000 },
+ { 2121878.8377425023, 10, 5,
+ 40.000000000000000 },
+ { 352060171.43033499, 10, 5,
+ 50.000000000000000 },
+ { 6212028560.1428576, 10, 5,
+ 60.000000000000000 },
+ { 53782171674.604919, 10, 5,
+ 70.000000000000000 },
+ { 309720255837.56775, 10, 5,
+ 80.000000000000000 },
+ { 1359043035731.5713, 10, 5,
+ 90.000000000000000 },
+ { 4900625954398.9434, 10, 5,
+ 100.00000000000000 },
+};
+
+// Test function for n=10, m=5.
+template <typename Tp>
+void test036()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data036)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data036[i].n), Tp(data036[i].m),
+ Tp(data036[i].x));
+ const Tp f0 = data036[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=10, m=10.
+testcase_assoc_laguerre<double> data037[] = {
+ { 184756.00000000000, 10, 10,
+ 0.0000000000000000 },
+ { -210.84303350970018, 10, 10,
+ 10.000000000000000 },
+ { 508.38095238095184, 10, 10,
+ 20.000000000000000 },
+ { 2098.8571428571431, 10, 10,
+ 30.000000000000000 },
+ { -536338.88536155189, 10, 10,
+ 40.000000000000000 },
+ { 24865988.804232784, 10, 10,
+ 50.000000000000000 },
+ { 1343756013.1428571, 10, 10,
+ 60.000000000000000 },
+ { 17298791247.358025, 10, 10,
+ 70.000000000000000 },
+ { 124528450897.79892, 10, 10,
+ 80.000000000000000 },
+ { 632674413641.71423, 10, 10,
+ 90.000000000000000 },
+ { 2533008935405.0298, 10, 10,
+ 100.00000000000000 },
+};
+
+// Test function for n=10, m=10.
+template <typename Tp>
+void test037()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data037)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data037[i].n), Tp(data037[i].m),
+ Tp(data037[i].x));
+ const Tp f0 = data037[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=10, m=20.
+testcase_assoc_laguerre<double> data038[] = {
+ { 30045014.999999993, 10, 20,
+ 0.0000000000000000 },
+ { -23087.733686067022, 10, 20,
+ 10.000000000000000 },
+ { 207.23985890652347, 10, 20,
+ 20.000000000000000 },
+ { 1407.8571428571497, 10, 20,
+ 30.000000000000000 },
+ { -44618.156966490329, 10, 20,
+ 40.000000000000000 },
+ { 158690.04409171085, 10, 20,
+ 50.000000000000000 },
+ { -6870413.5714285728, 10, 20,
+ 60.000000000000000 },
+ { 793841351.41975331, 10, 20,
+ 70.000000000000000 },
+ { 13358288958.562618, 10, 20,
+ 80.000000000000000 },
+ { 106073722407.85715, 10, 20,
+ 90.000000000000000 },
+ { 566337213392.42493, 10, 20,
+ 100.00000000000000 },
+};
+
+// Test function for n=10, m=20.
+template <typename Tp>
+void test038()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data038)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data038[i].n), Tp(data038[i].m),
+ Tp(data038[i].x));
+ const Tp f0 = data038[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for n=10, m=50.
+testcase_assoc_laguerre<double> data039[] = {
+ { 75394027566.000000, 10, 50,
+ 0.0000000000000000 },
+ { 8048106183.3721361, 10, 50,
+ 10.000000000000000 },
+ { 328045023.84832466, 10, 50,
+ 20.000000000000000 },
+ { -2568769.7142857141, 10, 50,
+ 30.000000000000000 },
+ { 6971.9964726631733, 10, 50,
+ 40.000000000000000 },
+ { 136111.41446208110, 10, 50,
+ 50.000000000000000 },
+ { -62462.571428570242, 10, 50,
+ 60.000000000000000 },
+ { -248167.95061728527, 10, 50,
+ 70.000000000000000 },
+ { 1941270.4091710777, 10, 50,
+ 80.000000000000000 },
+ { -8643512.5714285783, 10, 50,
+ 90.000000000000000 },
+ { -140863522.18342155, 10, 50,
+ 100.00000000000000 },
+};
+
+// Test function for n=10, m=50.
+template <typename Tp>
+void test039()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data039)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data039[i].n), Tp(data039[i].m),
+ Tp(data039[i].x));
+ const Tp f0 = data039[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for n=10, m=100.
+testcase_assoc_laguerre<double> data040[] = {
+ { 46897636623981.000, 10, 100,
+ 0.0000000000000000 },
+ { 16444031323272.084, 10, 100,
+ 10.000000000000000 },
+ { 5020343986463.5391, 10, 100,
+ 20.000000000000000 },
+ { 1270977490645.2859, 10, 100,
+ 30.000000000000000 },
+ { 244835756822.62262, 10, 100,
+ 40.000000000000000 },
+ { 29786827693.962963, 10, 100,
+ 50.000000000000000 },
+ { 1127612095.2857144, 10, 100,
+ 60.000000000000000 },
+ { -66370555.419753075, 10, 100,
+ 70.000000000000000 },
+ { 10420852.957671957, 10, 100,
+ 80.000000000000000 },
+ { -3373097.5714285718, 10, 100,
+ 90.000000000000000 },
+ { 2065423.6807760142, 10, 100,
+ 100.00000000000000 },
+};
+
+// Test function for n=10, m=100.
+template <typename Tp>
+void test040()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data040)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data040[i].n), Tp(data040[i].m),
+ Tp(data040[i].x));
+ const Tp f0 = data040[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=20, m=0.
+testcase_assoc_laguerre<double> data041[] = {
+ { 1.0000000000000000, 20, 0,
+ 0.0000000000000000 },
+ { -11.961333867812119, 20, 0,
+ 10.000000000000000 },
+ { 2829.4728613531738, 20, 0,
+ 20.000000000000000 },
+ { -18439.424502520938, 20, 0,
+ 30.000000000000000 },
+ { 24799805.877530701, 20, 0,
+ 40.000000000000000 },
+ { 7551960453.7672529, 20, 0,
+ 50.000000000000000 },
+ { -1379223608444.9155, 20, 0,
+ 60.000000000000000 },
+ { 165423821874449.94, 20, 0,
+ 70.000000000000000 },
+ { 29500368536981676., 20, 0,
+ 80.000000000000000 },
+ { 1.1292309514432899e+18, 20, 0,
+ 90.000000000000000 },
+ { 2.2061882785931735e+19, 20, 0,
+ 100.00000000000000 },
+};
+
+// Test function for n=20, m=0.
+template <typename Tp>
+void test041()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data041)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data041[i].n), Tp(data041[i].m),
+ Tp(data041[i].x));
+ const Tp f0 = data041[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=20, m=1.
+testcase_assoc_laguerre<double> data042[] = {
+ { 21.000000000000000, 20, 1,
+ 0.0000000000000000 },
+ { 19.900488129734079, 20, 1,
+ 10.000000000000000 },
+ { 2208.0318569557589, 20, 1,
+ 20.000000000000000 },
+ { 263690.96303121914, 20, 1,
+ 30.000000000000000 },
+ { 40667285.630564235, 20, 1,
+ 40.000000000000000 },
+ { 1737442572.8115418, 20, 1,
+ 50.000000000000000 },
+ { -588280953643.28125, 20, 1,
+ 60.000000000000000 },
+ { 45617733778241.359, 20, 1,
+ 70.000000000000000 },
+ { 17293487114876860., 20, 1,
+ 80.000000000000000 },
+ { 7.6219135858585024e+17, 20, 1,
+ 90.000000000000000 },
+ { 1.6037288204336759e+19, 20, 1,
+ 100.00000000000000 },
+};
+
+// Test function for n=20, m=1.
+template <typename Tp>
+void test042()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data042)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data042[i].n), Tp(data042[i].m),
+ Tp(data042[i].x));
+ const Tp f0 = data042[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=20, m=2.
+testcase_assoc_laguerre<double> data043[] = {
+ { 231.00000000000003, 20, 2,
+ 0.0000000000000000 },
+ { 47.009338065112935, 20, 2,
+ 10.000000000000000 },
+ { -652.51305461728566, 20, 2,
+ 20.000000000000000 },
+ { 285388.25895069109, 20, 2,
+ 30.000000000000000 },
+ { 28664069.685624726, 20, 2,
+ 40.000000000000000 },
+ { -1399631966.3144732, 20, 2,
+ 50.000000000000000 },
+ { -115357373248.28198, 20, 2,
+ 60.000000000000000 },
+ { -3357730872975.8545, 20, 2,
+ 70.000000000000000 },
+ { 9765808962855122.0, 20, 2,
+ 80.000000000000000 },
+ { 5.0717292945559181e+17, 20, 2,
+ 90.000000000000000 },
+ { 1.1564665701334458e+19, 20, 2,
+ 100.00000000000000 },
+};
+
+// Test function for n=20, m=2.
+template <typename Tp>
+void test043()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data043)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data043[i].n), Tp(data043[i].m),
+ Tp(data043[i].x));
+ const Tp f0 = data043[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=20, m=5.
+testcase_assoc_laguerre<double> data044[] = {
+ { 53130.000000000000, 20, 5,
+ 0.0000000000000000 },
+ { -158.69554500944145, 20, 5,
+ 10.000000000000000 },
+ { 334.08012288038969, 20, 5,
+ 20.000000000000000 },
+ { -198372.47662554169, 20, 5,
+ 30.000000000000000 },
+ { -13627144.088579427, 20, 5,
+ 40.000000000000000 },
+ { -780579985.44731593, 20, 5,
+ 50.000000000000000 },
+ { 116648634237.73526, 20, 5,
+ 60.000000000000000 },
+ { -12347348707739.742, 20, 5,
+ 70.000000000000000 },
+ { 1199516248034090.8, 20, 5,
+ 80.000000000000000 },
+ { 1.3451503195078531e+17, 20, 5,
+ 90.000000000000000 },
+ { 4.1058904276111483e+18, 20, 5,
+ 100.00000000000000 },
+};
+
+// Test function for n=20, m=5.
+template <typename Tp>
+void test044()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data044)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data044[i].n), Tp(data044[i].m),
+ Tp(data044[i].x));
+ const Tp f0 = data044[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=20, m=10.
+testcase_assoc_laguerre<double> data045[] = {
+ { 30045015.000000000, 20, 10,
+ 0.0000000000000000 },
+ { -1755.6226861258590, 20, 10,
+ 10.000000000000000 },
+ { -9081.6726644737901, 20, 10,
+ 20.000000000000000 },
+ { 95771.650912113109, 20, 10,
+ 30.000000000000000 },
+ { 5089151.9272779226, 20, 10,
+ 40.000000000000000 },
+ { 97400399.450206712, 20, 10,
+ 50.000000000000000 },
+ { -16009352450.477026, 20, 10,
+ 60.000000000000000 },
+ { 842271286905.01038, 20, 10,
+ 70.000000000000000 },
+ { -79901725466796.938, 20, 10,
+ 80.000000000000000 },
+ { 7944103675858638.0, 20, 10,
+ 90.000000000000000 },
+ { 5.7429821893388288e+17, 20, 10,
+ 100.00000000000000 },
+};
+
+// Test function for n=20, m=10.
+template <typename Tp>
+void test045()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data045)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data045[i].n), Tp(data045[i].m),
+ Tp(data045[i].x));
+ const Tp f0 = data045[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=20, m=20.
+testcase_assoc_laguerre<double> data046[] = {
+ { 137846528819.99994, 20, 20,
+ 0.0000000000000000 },
+ { -136976.49571333214, 20, 20,
+ 10.000000000000000 },
+ { 113878.49908041637, 20, 20,
+ 20.000000000000000 },
+ { -342529.21778796182, 20, 20,
+ 30.000000000000000 },
+ { -350112.66981443466, 20, 20,
+ 40.000000000000000 },
+ { -10791735.172977794, 20, 20,
+ 50.000000000000000 },
+ { -1038073940.0811402, 20, 20,
+ 60.000000000000000 },
+ { 667312550.63616371, 20, 20,
+ 70.000000000000000 },
+ { 741537869902.29028, 20, 20,
+ 80.000000000000000 },
+ { -32378376755737.418, 20, 20,
+ 90.000000000000000 },
+ { -601760332167934.75, 20, 20,
+ 100.00000000000000 },
+};
+
+// Test function for n=20, m=20.
+template <typename Tp>
+void test046()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data046)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data046[i].n), Tp(data046[i].m),
+ Tp(data046[i].x));
+ const Tp f0 = data046[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for n=20, m=50.
+testcase_assoc_laguerre<double> data047[] = {
+ { 1.6188460366265789e+17, 20, 50,
+ 0.0000000000000000 },
+ { 1599011936804291.5, 20, 50,
+ 10.000000000000000 },
+ { -131273880831.42412, 20, 50,
+ 20.000000000000000 },
+ { -3133213093.6903501, 20, 50,
+ 30.000000000000000 },
+ { -213935628.04985175, 20, 50,
+ 40.000000000000000 },
+ { -47375578.495921209, 20, 50,
+ 50.000000000000000 },
+ { -115731015.14034875, 20, 50,
+ 60.000000000000000 },
+ { -737415147.29420292, 20, 50,
+ 70.000000000000000 },
+ { -2123455626.8621781, 20, 50,
+ 80.000000000000000 },
+ { 29801266858.608925, 20, 50,
+ 90.000000000000000 },
+ { -132886631026.82561, 20, 50,
+ 100.00000000000000 },
+};
+
+// Test function for n=20, m=50.
+template <typename Tp>
+void test047()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data047)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data047[i].n), Tp(data047[i].m),
+ Tp(data047[i].x));
+ const Tp f0 = data047[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for n=20, m=100.
+testcase_assoc_laguerre<double> data048[] = {
+ { 2.9462227291176643e+22, 20, 100,
+ 0.0000000000000000 },
+ { 3.5777890748701244e+21, 20, 100,
+ 10.000000000000000 },
+ { 3.1584925521456765e+20, 20, 100,
+ 20.000000000000000 },
+ { 1.7389599388424860e+19, 20, 100,
+ 30.000000000000000 },
+ { 4.1401342745980646e+17, 20, 100,
+ 40.000000000000000 },
+ { -79359706102062.672, 20, 100,
+ 50.000000000000000 },
+ { 22736203650743.145, 20, 100,
+ 60.000000000000000 },
+ { 65679006380.095215, 20, 100,
+ 70.000000000000000 },
+ { -236263257610.77969, 20, 100,
+ 80.000000000000000 },
+ { -38072644585.303085, 20, 100,
+ 90.000000000000000 },
+ { 68236474365.173950, 20, 100,
+ 100.00000000000000 },
+};
+
+// Test function for n=20, m=100.
+template <typename Tp>
+void test048()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data048)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data048[i].n), Tp(data048[i].m),
+ Tp(data048[i].x));
+ const Tp f0 = data048[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000015e-12));
+}
+
+// Test data for n=50, m=0.
+testcase_assoc_laguerre<double> data049[] = {
+ { 1.0000000000000000, 50, 0,
+ 0.0000000000000000 },
+ { 17.534183446338233, 50, 0,
+ 10.000000000000000 },
+ { 980.26961889790766, 50, 0,
+ 20.000000000000000 },
+ { 293000.50735962350, 50, 0,
+ 30.000000000000000 },
+ { -14896937.968694847, 50, 0,
+ 40.000000000000000 },
+ { 2513677852.6916885, 50, 0,
+ 50.000000000000000 },
+ { -883876565337.99207, 50, 0,
+ 60.000000000000000 },
+ { -80967880733583.219, 50, 0,
+ 70.000000000000000 },
+ { -8217471769564850.0, 50, 0,
+ 80.000000000000000 },
+ { -2.1140031308048906e+18, 50, 0,
+ 90.000000000000000 },
+ { -3.9710103487094673e+20, 50, 0,
+ 100.00000000000000 },
+};
+
+// Test function for n=50, m=0.
+template <typename Tp>
+void test049()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data049)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data049[i].n), Tp(data049[i].m),
+ Tp(data049[i].x));
+ const Tp f0 = data049[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=50, m=1.
+testcase_assoc_laguerre<double> data050[] = {
+ { 51.000000000000021, 50, 1,
+ 0.0000000000000000 },
+ { 1.4214573271640045, 50, 1,
+ 10.000000000000000 },
+ { -2574.8072295127863, 50, 1,
+ 20.000000000000000 },
+ { 35846.479728359256, 50, 1,
+ 30.000000000000000 },
+ { -48263698.768318526, 50, 1,
+ 40.000000000000000 },
+ { 6161525870.2738571, 50, 1,
+ 50.000000000000000 },
+ { -382655486658.47101, 50, 1,
+ 60.000000000000000 },
+ { -109635579833241.69, 50, 1,
+ 70.000000000000000 },
+ { -14623805817283476., 50, 1,
+ 80.000000000000000 },
+ { -2.0666847190878118e+18, 50, 1,
+ 90.000000000000000 },
+ { -1.4385187953997626e+20, 50, 1,
+ 100.00000000000000 },
+};
+
+// Test function for n=50, m=1.
+template <typename Tp>
+void test050()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data050)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data050[i].n), Tp(data050[i].m),
+ Tp(data050[i].x));
+ const Tp f0 = data050[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000029e-12));
+}
+
+// Test data for n=50, m=2.
+testcase_assoc_laguerre<double> data051[] = {
+ { 1326.0000000000000, 50, 2,
+ 0.0000000000000000 },
+ { -87.860732516444671, 50, 2,
+ 10.000000000000000 },
+ { -5203.2351191780890, 50, 2,
+ 20.000000000000000 },
+ { -461059.50012538873, 50, 2,
+ 30.000000000000000 },
+ { -30476695.327440601, 50, 2,
+ 40.000000000000000 },
+ { 3720804977.9338136, 50, 2,
+ 50.000000000000000 },
+ { 362262002434.51440, 50, 2,
+ 60.000000000000000 },
+ { -52210917867820.273, 50, 2,
+ 70.000000000000000 },
+ { -9567965136901918.0, 50, 2,
+ 80.000000000000000 },
+ { -8.9171277517712806e+17, 50, 2,
+ 90.000000000000000 },
+ { 5.7231129448807039e+19, 50, 2,
+ 100.00000000000000 },
+};
+
+// Test function for n=50, m=2.
+template <typename Tp>
+void test051()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data051)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data051[i].n), Tp(data051[i].m),
+ Tp(data051[i].x));
+ const Tp f0 = data051[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=50, m=5.
+testcase_assoc_laguerre<double> data052[] = {
+ { 3478761.0000000000, 50, 5,
+ 0.0000000000000000 },
+ { 1055.8381917651493, 50, 5,
+ 10.000000000000000 },
+ { 15264.646660345048, 50, 5,
+ 20.000000000000000 },
+ { 1229651.8966600855, 50, 5,
+ 30.000000000000000 },
+ { 39270451.823656857, 50, 5,
+ 40.000000000000000 },
+ { -4424062601.1152067, 50, 5,
+ 50.000000000000000 },
+ { -186017434284.19220, 50, 5,
+ 60.000000000000000 },
+ { 50972853949302.602, 50, 5,
+ 70.000000000000000 },
+ { 6530702754012518.0, 50, 5,
+ 80.000000000000000 },
+ { 6.8387592714678016e+17, 50, 5,
+ 90.000000000000000 },
+ { 3.9198742504338366e+19, 50, 5,
+ 100.00000000000000 },
+};
+
+// Test function for n=50, m=5.
+template <typename Tp>
+void test052()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data052)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data052[i].n), Tp(data052[i].m),
+ Tp(data052[i].x));
+ const Tp f0 = data052[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=50, m=10.
+testcase_assoc_laguerre<double> data053[] = {
+ { 75394027565.999985, 50, 10,
+ 0.0000000000000000 },
+ { 91833.924098770134, 50, 10,
+ 10.000000000000000 },
+ { 330501.87929778261, 50, 10,
+ 20.000000000000000 },
+ { 3625088.1635972545, 50, 10,
+ 30.000000000000000 },
+ { 213954727.28632003, 50, 10,
+ 40.000000000000000 },
+ { -9381006937.7517643, 50, 10,
+ 50.000000000000000 },
+ { 535333683777.48627, 50, 10,
+ 60.000000000000000 },
+ { 18824406573722.156, 50, 10,
+ 70.000000000000000 },
+ { -533858276780012.81, 50, 10,
+ 80.000000000000000 },
+ { -52995774666704024., 50, 10,
+ 90.000000000000000 },
+ { 6.0504182862448855e+18, 50, 10,
+ 100.00000000000000 },
+};
+
+// Test function for n=50, m=10.
+template <typename Tp>
+void test053()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data053)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data053[i].n), Tp(data053[i].m),
+ Tp(data053[i].x));
+ const Tp f0 = data053[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=50, m=20.
+testcase_assoc_laguerre<double> data054[] = {
+ { 1.6188460366265779e+17, 50, 20,
+ 0.0000000000000000 },
+ { -307637087.25169420, 50, 20,
+ 10.000000000000000 },
+ { 12524651.102974579, 50, 20,
+ 20.000000000000000 },
+ { -315460483.86210549, 50, 20,
+ 30.000000000000000 },
+ { -1889683587.3459976, 50, 20,
+ 40.000000000000000 },
+ { 37457044404.200340, 50, 20,
+ 50.000000000000000 },
+ { -843831858224.71826, 50, 20,
+ 60.000000000000000 },
+ { -92231643172.313248, 50, 20,
+ 70.000000000000000 },
+ { 904211757769501.25, 50, 20,
+ 80.000000000000000 },
+ { 46508193600283288., 50, 20,
+ 90.000000000000000 },
+ { 2.3216887928162714e+18, 50, 20,
+ 100.00000000000000 },
+};
+
+// Test function for n=50, m=20.
+template <typename Tp>
+void test054()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data054)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data054[i].n), Tp(data054[i].m),
+ Tp(data054[i].x));
+ const Tp f0 = data054[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000015e-12));
+}
+
+// Test data for n=50, m=50.
+testcase_assoc_laguerre<double> data055[] = {
+ { 1.0089134454556417e+29, 50, 50,
+ 0.0000000000000000 },
+ { 1.3822795753070569e+23, 50, 50,
+ 10.000000000000000 },
+ { 95817260381628416., 50, 50,
+ 20.000000000000000 },
+ { -910798580856013.88, 50, 50,
+ 30.000000000000000 },
+ { 50513254049166.719, 50, 50,
+ 40.000000000000000 },
+ { 84159703903349.859, 50, 50,
+ 50.000000000000000 },
+ { -138805244691822.69, 50, 50,
+ 60.000000000000000 },
+ { 181046391269246.25, 50, 50,
+ 70.000000000000000 },
+ { 2086884905317107.2, 50, 50,
+ 80.000000000000000 },
+ { -2765620139862432.5, 50, 50,
+ 90.000000000000000 },
+ { -1.3706751678146291e+17, 50, 50,
+ 100.00000000000000 },
+};
+
+// Test function for n=50, m=50.
+template <typename Tp>
+void test055()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data055)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data055[i].n), Tp(data055[i].m),
+ Tp(data055[i].x));
+ const Tp f0 = data055[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for n=50, m=100.
+testcase_assoc_laguerre<double> data056[] = {
+ { 2.0128660909731929e+40, 50, 100,
+ 0.0000000000000000 },
+ { 9.3675094807695474e+37, 50, 100,
+ 10.000000000000000 },
+ { 1.3009321481877196e+35, 50, 100,
+ 20.000000000000000 },
+ { 7.3720026893233823e+30, 50, 100,
+ 30.000000000000000 },
+ { -6.0824679079634607e+25, 50, 100,
+ 40.000000000000000 },
+ { -6.0053188793543624e+23, 50, 100,
+ 50.000000000000000 },
+ { 1.4178129287264701e+22, 50, 100,
+ 60.000000000000000 },
+ { -5.4652099341566765e+20, 50, 100,
+ 70.000000000000000 },
+ { -1.0817271759263398e+20, 50, 100,
+ 80.000000000000000 },
+ { 3.8058734007924187e+19, 50, 100,
+ 90.000000000000000 },
+ { 4.7439240848028353e+19, 50, 100,
+ 100.00000000000000 },
+};
+
+// Test function for n=50, m=100.
+template <typename Tp>
+void test056()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data056)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data056[i].n), Tp(data056[i].m),
+ Tp(data056[i].x));
+ const Tp f0 = data056[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000015e-12));
+}
+
+// Test data for n=100, m=0.
+testcase_assoc_laguerre<double> data057[] = {
+ { 1.0000000000000000, 100, 0,
+ 0.0000000000000000 },
+ { 13.277662844303402, 100, 0,
+ 10.000000000000000 },
+ { 1854.0367283243393, 100, 0,
+ 20.000000000000000 },
+ { 170141.86987046539, 100, 0,
+ 30.000000000000000 },
+ { -7272442.3156007063, 100, 0,
+ 40.000000000000000 },
+ { 4847420871.2690468, 100, 0,
+ 50.000000000000000 },
+ { 693492765740.29736, 100, 0,
+ 60.000000000000000 },
+ { 17125518672239.707, 100, 0,
+ 70.000000000000000 },
+ { -13763178176383754., 100, 0,
+ 80.000000000000000 },
+ { 2.1307220490380198e+18, 100, 0,
+ 90.000000000000000 },
+ { -2.6292260693068920e+20, 100, 0,
+ 100.00000000000000 },
+};
+
+// Test function for n=100, m=0.
+template <typename Tp>
+void test057()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data057)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data057[i].n), Tp(data057[i].m),
+ Tp(data057[i].x));
+ const Tp f0 = data057[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=100, m=1.
+testcase_assoc_laguerre<double> data058[] = {
+ { 101.00000000000003, 100, 1,
+ 0.0000000000000000 },
+ { -14.650661983680466, 100, 1,
+ 10.000000000000000 },
+ { 1626.5010939361609, 100, 1,
+ 20.000000000000000 },
+ { 417884.77658268705, 100, 1,
+ 30.000000000000000 },
+ { -55617646.951649830, 100, 1,
+ 40.000000000000000 },
+ { 884829874.26626098, 100, 1,
+ 50.000000000000000 },
+ { 154466082750.32114, 100, 1,
+ 60.000000000000000 },
+ { -101423973484646.05, 100, 1,
+ 70.000000000000000 },
+ { -1388352348671755.5, 100, 1,
+ 80.000000000000000 },
+ { 7.8048705513268326e+17, 100, 1,
+ 90.000000000000000 },
+ { 1.6948925059042787e+19, 100, 1,
+ 100.00000000000000 },
+};
+
+// Test function for n=100, m=1.
+template <typename Tp>
+void test058()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data058)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data058[i].n), Tp(data058[i].m),
+ Tp(data058[i].x));
+ const Tp f0 = data058[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for n=100, m=2.
+testcase_assoc_laguerre<double> data059[] = {
+ { 5151.0000000000055, 100, 2,
+ 0.0000000000000000 },
+ { -150.22012290951341, 100, 2,
+ 10.000000000000000 },
+ { -7655.0593294049440, 100, 2,
+ 20.000000000000000 },
+ { -140996.69276179170, 100, 2,
+ 30.000000000000000 },
+ { -38645171.278549291, 100, 2,
+ 40.000000000000000 },
+ { -8889263688.2118778, 100, 2,
+ 50.000000000000000 },
+ { -1010338971533.3397, 100, 2,
+ 60.000000000000000 },
+ { -127582564332943.91, 100, 2,
+ 70.000000000000000 },
+ { 15970305694654336., 100, 2,
+ 80.000000000000000 },
+ { -1.6019844992862840e+18, 100, 2,
+ 90.000000000000000 },
+ { 2.8267024730962919e+20, 100, 2,
+ 100.00000000000000 },
+};
+
+// Test function for n=100, m=2.
+template <typename Tp>
+void test059()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data059)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data059[i].n), Tp(data059[i].m),
+ Tp(data059[i].x));
+ const Tp f0 = data059[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=100, m=5.
+testcase_assoc_laguerre<double> data060[] = {
+ { 96560646.000000030, 100, 5,
+ 0.0000000000000000 },
+ { 2430.6732236677576, 100, 5,
+ 10.000000000000000 },
+ { 111162.32026994640, 100, 5,
+ 20.000000000000000 },
+ { 4036708.2599413753, 100, 5,
+ 30.000000000000000 },
+ { -34055982.664405435, 100, 5,
+ 40.000000000000000 },
+ { 30110688343.562344, 100, 5,
+ 50.000000000000000 },
+ { 2651429940558.2920, 100, 5,
+ 60.000000000000000 },
+ { 192108556058942.84, 100, 5,
+ 70.000000000000000 },
+ { -25410533973455528., 100, 5,
+ 80.000000000000000 },
+ { 2.1072955633564431e+18, 100, 5,
+ 90.000000000000000 },
+ { -2.9434005355877260e+20, 100, 5,
+ 100.00000000000000 },
+};
+
+// Test function for n=100, m=5.
+template <typename Tp>
+void test060()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data060)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data060[i].n), Tp(data060[i].m),
+ Tp(data060[i].x));
+ const Tp f0 = data060[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for n=100, m=10.
+testcase_assoc_laguerre<double> data061[] = {
+ { 46897636623981.039, 100, 10,
+ 0.0000000000000000 },
+ { 529208.11550990446, 100, 10,
+ 10.000000000000000 },
+ { 7402892.1748803742, 100, 10,
+ 20.000000000000000 },
+ { 88369632.083243459, 100, 10,
+ 30.000000000000000 },
+ { 822187797.59096730, 100, 10,
+ 40.000000000000000 },
+ { 180231446033.06866, 100, 10,
+ 50.000000000000000 },
+ { 7922942703798.1309, 100, 10,
+ 60.000000000000000 },
+ { 784424250559043.38, 100, 10,
+ 70.000000000000000 },
+ { -16325634720239362., 100, 10,
+ 80.000000000000000 },
+ { -1.0879588307443181e+18, 100, 10,
+ 90.000000000000000 },
+ { 3.0114394463610495e+19, 100, 10,
+ 100.00000000000000 },
+};
+
+// Test function for n=100, m=10.
+template <typename Tp>
+void test061()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data061)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data061[i].n), Tp(data061[i].m),
+ Tp(data061[i].x));
+ const Tp f0 = data061[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for n=100, m=20.
+testcase_assoc_laguerre<double> data062[] = {
+ { 2.9462227291176614e+22, 100, 20,
+ 0.0000000000000000 },
+ { 313694958939.90436, 100, 20,
+ 10.000000000000000 },
+ { 45396489338.096252, 100, 20,
+ 20.000000000000000 },
+ { -7215826758.0078783, 100, 20,
+ 30.000000000000000 },
+ { 825949194005.88831, 100, 20,
+ 40.000000000000000 },
+ { -2764742119971.0747, 100, 20,
+ 50.000000000000000 },
+ { -219802198273516.03, 100, 20,
+ 60.000000000000000 },
+ { -1699053306145266.0, 100, 20,
+ 70.000000000000000 },
+ { 3.5495709345023853e+17, 100, 20,
+ 80.000000000000000 },
+ { -9.6128675110292439e+18, 100, 20,
+ 90.000000000000000 },
+ { 4.3619868422072153e+20, 100, 20,
+ 100.00000000000000 },
+};
+
+// Test function for n=100, m=20.
+template <typename Tp>
+void test062()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data062)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data062[i].n), Tp(data062[i].m),
+ Tp(data062[i].x));
+ const Tp f0 = data062[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=100, m=50.
+testcase_assoc_laguerre<double> data063[] = {
+ { 2.0128660909731931e+40, 100, 50,
+ 0.0000000000000000 },
+ { -4.0151443913473681e+28, 100, 50,
+ 10.000000000000000 },
+ { 3.2199632594552201e+22, 100, 50,
+ 20.000000000000000 },
+ { -2.7568702092659717e+20, 100, 50,
+ 30.000000000000000 },
+ { 7.5553066015421530e+19, 100, 50,
+ 40.000000000000000 },
+ { -2.7651625252388041e+19, 100, 50,
+ 50.000000000000000 },
+ { -5.8963680147283821e+19, 100, 50,
+ 60.000000000000000 },
+ { -1.8082798163033126e+20, 100, 50,
+ 70.000000000000000 },
+ { -3.9044276986817249e+20, 100, 50,
+ 80.000000000000000 },
+ { 6.9926310700401904e+21, 100, 50,
+ 90.000000000000000 },
+ { -5.5727272809923697e+22, 100, 50,
+ 100.00000000000000 },
+};
+
+// Test function for n=100, m=50.
+template <typename Tp>
+void test063()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data063)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data063[i].n), Tp(data063[i].m),
+ Tp(data063[i].x));
+ const Tp f0 = data063[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for n=100, m=100.
+testcase_assoc_laguerre<double> data064[] = {
+ { 9.0548514656103225e+58, 100, 100,
+ 0.0000000000000000 },
+ { 1.3334078033060576e+54, 100, 100,
+ 10.000000000000000 },
+ { 2.1002639254211231e+46, 100, 100,
+ 20.000000000000000 },
+ { -1.1073158068796240e+39, 100, 100,
+ 30.000000000000000 },
+ { -8.3640937363981405e+35, 100, 100,
+ 40.000000000000000 },
+ { -6.5879339429312671e+32, 100, 100,
+ 50.000000000000000 },
+ { -2.4190645077698453e+30, 100, 100,
+ 60.000000000000000 },
+ { -7.9224960465662002e+29, 100, 100,
+ 70.000000000000000 },
+ { -2.8605772478408853e+29, 100, 100,
+ 80.000000000000000 },
+ { 2.4149589189610125e+28, 100, 100,
+ 90.000000000000000 },
+ { 5.1146476014859003e+28, 100, 100,
+ 100.00000000000000 },
+};
+
+// Test function for n=100, m=100.
+template <typename Tp>
+void test064()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data064)
+ / sizeof(testcase_assoc_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_laguerre(Tp(data064[i].n), Tp(data064[i].m),
+ Tp(data064[i].x));
+ const Tp f0 = data064[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000015e-12));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ test009<double>();
+ test010<double>();
+ test011<double>();
+ test012<double>();
+ test013<double>();
+ test014<double>();
+ test015<double>();
+ test016<double>();
+ test017<double>();
+ test018<double>();
+ test019<double>();
+ test020<double>();
+ test021<double>();
+ test022<double>();
+ test023<double>();
+ test024<double>();
+ test025<double>();
+ test026<double>();
+ test027<double>();
+ test028<double>();
+ test029<double>();
+ test030<double>();
+ test031<double>();
+ test032<double>();
+ test033<double>();
+ test034<double>();
+ test035<double>();
+ test036<double>();
+ test037<double>();
+ test038<double>();
+ test039<double>();
+ test040<double>();
+ test041<double>();
+ test042<double>();
+ test043<double>();
+ test044<double>();
+ test045<double>();
+ test046<double>();
+ test047<double>();
+ test048<double>();
+ test049<double>();
+ test050<double>();
+ test051<double>();
+ test052<double>();
+ test053<double>();
+ test054<double>();
+ test055<double>();
+ test056<double>();
+ test057<double>();
+ test058<double>();
+ test059<double>();
+ test060<double>();
+ test061<double>();
+ test062<double>();
+ test063<double>();
+ test064<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/01_assoc_laguerre/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/01_assoc_laguerre/compile.cc
new file mode 100644
index 00000000000..3beffc10ee3
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/01_assoc_laguerre/compile.cc
@@ -0,0 +1,44 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.1 assoc_laguerre
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+ unsigned int n = 2, m = 1;
+
+ float a = std::tr1::assoc_laguerre(n, m, xf);
+ float b = std::tr1::assoc_laguerref(n, m, xf);
+ double c = std::tr1::assoc_laguerre(n, m, xd);
+ long double d = std::tr1::assoc_laguerre(n, m, xl);
+ long double e = std::tr1::assoc_laguerrel(n, m, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/01_assoc_laguerre/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/01_assoc_laguerre/compile_2.cc
new file mode 100644
index 00000000000..59cf17a332f
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/01_assoc_laguerre/compile_2.cc
@@ -0,0 +1,44 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.1 assoc_laguerre
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+ unsigned int n = 2, m = 1;
+
+ assoc_laguerre(n, m, xf);
+ assoc_laguerref(n, m, xf);
+ assoc_laguerre(n, m, xd);
+ assoc_laguerre(n, m, xl);
+ assoc_laguerrel(n, m, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/02_assoc_legendre/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/02_assoc_legendre/check_nan.cc
new file mode 100644
index 00000000000..174a43c791c
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/02_assoc_legendre/check_nan.cc
@@ -0,0 +1,59 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.2 assoc_legendre
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+
+ float xf = std::numeric_limits<float>::quiet_NaN();
+ double xd = std::numeric_limits<double>::quiet_NaN();
+ long double xl = std::numeric_limits<long double>::quiet_NaN();
+
+ unsigned int l = 2, m = 1;
+
+ float a = std::tr1::assoc_legendre(l, m, xf);
+ float b = std::tr1::assoc_legendref(l, m, xf);
+ double c = std::tr1::assoc_legendre(l, m, xd);
+ long double d = std::tr1::assoc_legendre(l, m, xl);
+ long double e = std::tr1::assoc_legendrel(l, m, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/02_assoc_legendre/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/02_assoc_legendre/check_value.cc
new file mode 100644
index 00000000000..8265137be22
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/02_assoc_legendre/check_value.cc
@@ -0,0 +1,2746 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// assoc_legendre
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for l=0, m=0.
+testcase_assoc_legendre<double> data001[] = {
+ { 1.0000000000000000, 0, 0,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0, 0,
+ -0.90000000000000002 },
+ { 1.0000000000000000, 0, 0,
+ -0.80000000000000004 },
+ { 1.0000000000000000, 0, 0,
+ -0.69999999999999996 },
+ { 1.0000000000000000, 0, 0,
+ -0.59999999999999998 },
+ { 1.0000000000000000, 0, 0,
+ -0.50000000000000000 },
+ { 1.0000000000000000, 0, 0,
+ -0.40000000000000002 },
+ { 1.0000000000000000, 0, 0,
+ -0.30000000000000004 },
+ { 1.0000000000000000, 0, 0,
+ -0.19999999999999996 },
+ { 1.0000000000000000, 0, 0,
+ -0.099999999999999978 },
+ { 1.0000000000000000, 0, 0,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0, 0,
+ 0.10000000000000009 },
+ { 1.0000000000000000, 0, 0,
+ 0.19999999999999996 },
+ { 1.0000000000000000, 0, 0,
+ 0.30000000000000004 },
+ { 1.0000000000000000, 0, 0,
+ 0.39999999999999991 },
+ { 1.0000000000000000, 0, 0,
+ 0.50000000000000000 },
+ { 1.0000000000000000, 0, 0,
+ 0.60000000000000009 },
+ { 1.0000000000000000, 0, 0,
+ 0.69999999999999996 },
+ { 1.0000000000000000, 0, 0,
+ 0.80000000000000004 },
+ { 1.0000000000000000, 0, 0,
+ 0.89999999999999991 },
+ { 1.0000000000000000, 0, 0,
+ 1.0000000000000000 },
+};
+
+// Test function for l=0, m=0.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data001[i].l), Tp(data001[i].m),
+ Tp(data001[i].x));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=1, m=0.
+testcase_assoc_legendre<double> data002[] = {
+ { -1.0000000000000000, 1, 0,
+ -1.0000000000000000 },
+ { -0.90000000000000002, 1, 0,
+ -0.90000000000000002 },
+ { -0.80000000000000004, 1, 0,
+ -0.80000000000000004 },
+ { -0.69999999999999996, 1, 0,
+ -0.69999999999999996 },
+ { -0.59999999999999998, 1, 0,
+ -0.59999999999999998 },
+ { -0.50000000000000000, 1, 0,
+ -0.50000000000000000 },
+ { -0.40000000000000002, 1, 0,
+ -0.40000000000000002 },
+ { -0.30000000000000004, 1, 0,
+ -0.30000000000000004 },
+ { -0.19999999999999996, 1, 0,
+ -0.19999999999999996 },
+ { -0.099999999999999978, 1, 0,
+ -0.099999999999999978 },
+ { 0.0000000000000000, 1, 0,
+ 0.0000000000000000 },
+ { 0.10000000000000009, 1, 0,
+ 0.10000000000000009 },
+ { 0.19999999999999996, 1, 0,
+ 0.19999999999999996 },
+ { 0.30000000000000004, 1, 0,
+ 0.30000000000000004 },
+ { 0.39999999999999991, 1, 0,
+ 0.39999999999999991 },
+ { 0.50000000000000000, 1, 0,
+ 0.50000000000000000 },
+ { 0.60000000000000009, 1, 0,
+ 0.60000000000000009 },
+ { 0.69999999999999996, 1, 0,
+ 0.69999999999999996 },
+ { 0.80000000000000004, 1, 0,
+ 0.80000000000000004 },
+ { 0.89999999999999991, 1, 0,
+ 0.89999999999999991 },
+ { 1.0000000000000000, 1, 0,
+ 1.0000000000000000 },
+};
+
+// Test function for l=1, m=0.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data002[i].l), Tp(data002[i].m),
+ Tp(data002[i].x));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=1, m=1.
+testcase_assoc_legendre<double> data003[] = {
+ { -0.0000000000000000, 1, 1,
+ -1.0000000000000000 },
+ { -0.43588989435406728, 1, 1,
+ -0.90000000000000002 },
+ { -0.59999999999999987, 1, 1,
+ -0.80000000000000004 },
+ { -0.71414284285428509, 1, 1,
+ -0.69999999999999996 },
+ { -0.80000000000000004, 1, 1,
+ -0.59999999999999998 },
+ { -0.86602540378443860, 1, 1,
+ -0.50000000000000000 },
+ { -0.91651513899116799, 1, 1,
+ -0.40000000000000002 },
+ { -0.95393920141694577, 1, 1,
+ -0.30000000000000004 },
+ { -0.97979589711327120, 1, 1,
+ -0.19999999999999996 },
+ { -0.99498743710661997, 1, 1,
+ -0.099999999999999978 },
+ { -1.0000000000000000, 1, 1,
+ 0.0000000000000000 },
+ { -0.99498743710661997, 1, 1,
+ 0.10000000000000009 },
+ { -0.97979589711327120, 1, 1,
+ 0.19999999999999996 },
+ { -0.95393920141694577, 1, 1,
+ 0.30000000000000004 },
+ { -0.91651513899116799, 1, 1,
+ 0.39999999999999991 },
+ { -0.86602540378443860, 1, 1,
+ 0.50000000000000000 },
+ { -0.79999999999999993, 1, 1,
+ 0.60000000000000009 },
+ { -0.71414284285428509, 1, 1,
+ 0.69999999999999996 },
+ { -0.59999999999999987, 1, 1,
+ 0.80000000000000004 },
+ { -0.43588989435406750, 1, 1,
+ 0.89999999999999991 },
+ { -0.0000000000000000, 1, 1,
+ 1.0000000000000000 },
+};
+
+// Test function for l=1, m=1.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data003[i].l), Tp(data003[i].m),
+ Tp(data003[i].x));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=2, m=0.
+testcase_assoc_legendre<double> data004[] = {
+ { 1.0000000000000000, 2, 0,
+ -1.0000000000000000 },
+ { 0.71500000000000008, 2, 0,
+ -0.90000000000000002 },
+ { 0.46000000000000019, 2, 0,
+ -0.80000000000000004 },
+ { 0.23499999999999982, 2, 0,
+ -0.69999999999999996 },
+ { 0.039999999999999925, 2, 0,
+ -0.59999999999999998 },
+ { -0.12500000000000000, 2, 0,
+ -0.50000000000000000 },
+ { -0.25999999999999995, 2, 0,
+ -0.40000000000000002 },
+ { -0.36499999999999994, 2, 0,
+ -0.30000000000000004 },
+ { -0.44000000000000000, 2, 0,
+ -0.19999999999999996 },
+ { -0.48499999999999999, 2, 0,
+ -0.099999999999999978 },
+ { -0.50000000000000000, 2, 0,
+ 0.0000000000000000 },
+ { -0.48499999999999999, 2, 0,
+ 0.10000000000000009 },
+ { -0.44000000000000000, 2, 0,
+ 0.19999999999999996 },
+ { -0.36499999999999994, 2, 0,
+ 0.30000000000000004 },
+ { -0.26000000000000012, 2, 0,
+ 0.39999999999999991 },
+ { -0.12500000000000000, 2, 0,
+ 0.50000000000000000 },
+ { 0.040000000000000160, 2, 0,
+ 0.60000000000000009 },
+ { 0.23499999999999982, 2, 0,
+ 0.69999999999999996 },
+ { 0.46000000000000019, 2, 0,
+ 0.80000000000000004 },
+ { 0.71499999999999975, 2, 0,
+ 0.89999999999999991 },
+ { 1.0000000000000000, 2, 0,
+ 1.0000000000000000 },
+};
+
+// Test function for l=2, m=0.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data004[i].l), Tp(data004[i].m),
+ Tp(data004[i].x));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=2, m=1.
+testcase_assoc_legendre<double> data005[] = {
+ { 0.0000000000000000, 2, 1,
+ -1.0000000000000000 },
+ { 1.1769027147559816, 2, 1,
+ -0.90000000000000002 },
+ { 1.4399999999999999, 2, 1,
+ -0.80000000000000004 },
+ { 1.4996999699939983, 2, 1,
+ -0.69999999999999996 },
+ { 1.4399999999999999, 2, 1,
+ -0.59999999999999998 },
+ { 1.2990381056766580, 2, 1,
+ -0.50000000000000000 },
+ { 1.0998181667894018, 2, 1,
+ -0.40000000000000002 },
+ { 0.85854528127525132, 2, 1,
+ -0.30000000000000004 },
+ { 0.58787753826796263, 2, 1,
+ -0.19999999999999996 },
+ { 0.29849623113198592, 2, 1,
+ -0.099999999999999978 },
+ { -0.0000000000000000, 2, 1,
+ 0.0000000000000000 },
+ { -0.29849623113198626, 2, 1,
+ 0.10000000000000009 },
+ { -0.58787753826796263, 2, 1,
+ 0.19999999999999996 },
+ { -0.85854528127525132, 2, 1,
+ 0.30000000000000004 },
+ { -1.0998181667894014, 2, 1,
+ 0.39999999999999991 },
+ { -1.2990381056766580, 2, 1,
+ 0.50000000000000000 },
+ { -1.4400000000000002, 2, 1,
+ 0.60000000000000009 },
+ { -1.4996999699939983, 2, 1,
+ 0.69999999999999996 },
+ { -1.4399999999999999, 2, 1,
+ 0.80000000000000004 },
+ { -1.1769027147559821, 2, 1,
+ 0.89999999999999991 },
+ { -0.0000000000000000, 2, 1,
+ 1.0000000000000000 },
+};
+
+// Test function for l=2, m=1.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data005[i].l), Tp(data005[i].m),
+ Tp(data005[i].x));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=2, m=2.
+testcase_assoc_legendre<double> data006[] = {
+ { 0.0000000000000000, 2, 2,
+ -1.0000000000000000 },
+ { 0.56999999999999984, 2, 2,
+ -0.90000000000000002 },
+ { 1.0799999999999996, 2, 2,
+ -0.80000000000000004 },
+ { 1.5300000000000005, 2, 2,
+ -0.69999999999999996 },
+ { 1.9200000000000004, 2, 2,
+ -0.59999999999999998 },
+ { 2.2500000000000000, 2, 2,
+ -0.50000000000000000 },
+ { 2.5200000000000000, 2, 2,
+ -0.40000000000000002 },
+ { 2.7300000000000004, 2, 2,
+ -0.30000000000000004 },
+ { 2.8799999999999999, 2, 2,
+ -0.19999999999999996 },
+ { 2.9700000000000002, 2, 2,
+ -0.099999999999999978 },
+ { 3.0000000000000000, 2, 2,
+ 0.0000000000000000 },
+ { 2.9700000000000002, 2, 2,
+ 0.10000000000000009 },
+ { 2.8799999999999999, 2, 2,
+ 0.19999999999999996 },
+ { 2.7300000000000004, 2, 2,
+ 0.30000000000000004 },
+ { 2.5200000000000000, 2, 2,
+ 0.39999999999999991 },
+ { 2.2500000000000000, 2, 2,
+ 0.50000000000000000 },
+ { 1.9199999999999997, 2, 2,
+ 0.60000000000000009 },
+ { 1.5300000000000005, 2, 2,
+ 0.69999999999999996 },
+ { 1.0799999999999996, 2, 2,
+ 0.80000000000000004 },
+ { 0.57000000000000040, 2, 2,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 2, 2,
+ 1.0000000000000000 },
+};
+
+// Test function for l=2, m=2.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data006[i].l), Tp(data006[i].m),
+ Tp(data006[i].x));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=5, m=0.
+testcase_assoc_legendre<double> data007[] = {
+ { -1.0000000000000000, 5, 0,
+ -1.0000000000000000 },
+ { 0.041141249999999997, 5, 0,
+ -0.90000000000000002 },
+ { 0.39951999999999993, 5, 0,
+ -0.80000000000000004 },
+ { 0.36519874999999991, 5, 0,
+ -0.69999999999999996 },
+ { 0.15263999999999994, 5, 0,
+ -0.59999999999999998 },
+ { -0.089843750000000000, 5, 0,
+ -0.50000000000000000 },
+ { -0.27063999999999988, 5, 0,
+ -0.40000000000000002 },
+ { -0.34538624999999995, 5, 0,
+ -0.30000000000000004 },
+ { -0.30751999999999996, 5, 0,
+ -0.19999999999999996 },
+ { -0.17882874999999995, 5, 0,
+ -0.099999999999999978 },
+ { 0.0000000000000000, 5, 0,
+ 0.0000000000000000 },
+ { 0.17882875000000015, 5, 0,
+ 0.10000000000000009 },
+ { 0.30751999999999996, 5, 0,
+ 0.19999999999999996 },
+ { 0.34538624999999995, 5, 0,
+ 0.30000000000000004 },
+ { 0.27064000000000010, 5, 0,
+ 0.39999999999999991 },
+ { 0.089843750000000000, 5, 0,
+ 0.50000000000000000 },
+ { -0.15264000000000022, 5, 0,
+ 0.60000000000000009 },
+ { -0.36519874999999991, 5, 0,
+ 0.69999999999999996 },
+ { -0.39951999999999993, 5, 0,
+ 0.80000000000000004 },
+ { -0.041141250000000407, 5, 0,
+ 0.89999999999999991 },
+ { 1.0000000000000000, 5, 0,
+ 1.0000000000000000 },
+};
+
+// Test function for l=5, m=0.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data007[i].l), Tp(data007[i].m),
+ Tp(data007[i].x));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=5, m=1.
+testcase_assoc_legendre<double> data008[] = {
+ { 0.0000000000000000, 5, 1,
+ -1.0000000000000000 },
+ { -2.8099369608350973, 5, 1,
+ -0.90000000000000002 },
+ { -0.72180000000000089, 5, 1,
+ -0.80000000000000004 },
+ { 1.0951826834447254, 5, 1,
+ -0.69999999999999996 },
+ { 1.9775999999999998, 5, 1,
+ -0.59999999999999998 },
+ { 1.9282596881137892, 5, 1,
+ -0.50000000000000000 },
+ { 1.2070504380513685, 5, 1,
+ -0.40000000000000002 },
+ { 0.16079837663884430, 5, 1,
+ -0.30000000000000004 },
+ { -0.87005875663658538, 5, 1,
+ -0.19999999999999996 },
+ { -1.6083350053680323, 5, 1,
+ -0.099999999999999978 },
+ { -1.8750000000000000, 5, 1,
+ 0.0000000000000000 },
+ { -1.6083350053680314, 5, 1,
+ 0.10000000000000009 },
+ { -0.87005875663658538, 5, 1,
+ 0.19999999999999996 },
+ { 0.16079837663884430, 5, 1,
+ 0.30000000000000004 },
+ { 1.2070504380513674, 5, 1,
+ 0.39999999999999991 },
+ { 1.9282596881137892, 5, 1,
+ 0.50000000000000000 },
+ { 1.9775999999999996, 5, 1,
+ 0.60000000000000009 },
+ { 1.0951826834447254, 5, 1,
+ 0.69999999999999996 },
+ { -0.72180000000000089, 5, 1,
+ 0.80000000000000004 },
+ { -2.8099369608350959, 5, 1,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 5, 1,
+ 1.0000000000000000 },
+};
+
+// Test function for l=5, m=1.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data008[i].l), Tp(data008[i].m),
+ Tp(data008[i].x));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=5, m=2.
+testcase_assoc_legendre<double> data009[] = {
+ { 0.0000000000000000, 5, 2,
+ -1.0000000000000000 },
+ { -12.837824999999995, 5, 2,
+ -0.90000000000000002 },
+ { -13.910399999999997, 5, 2,
+ -0.80000000000000004 },
+ { -8.8089749999999984, 5, 2,
+ -0.69999999999999996 },
+ { -1.6128000000000009, 5, 2,
+ -0.59999999999999998 },
+ { 4.9218750000000000, 5, 2,
+ -0.50000000000000000 },
+ { 9.1728000000000005, 5, 2,
+ -0.40000000000000002 },
+ { 10.462725000000001, 5, 2,
+ -0.30000000000000004 },
+ { 8.8703999999999983, 5, 2,
+ -0.19999999999999996 },
+ { 5.0415749999999999, 5, 2,
+ -0.099999999999999978 },
+ { -0.0000000000000000, 5, 2,
+ 0.0000000000000000 },
+ { -5.0415750000000044, 5, 2,
+ 0.10000000000000009 },
+ { -8.8703999999999983, 5, 2,
+ 0.19999999999999996 },
+ { -10.462725000000001, 5, 2,
+ 0.30000000000000004 },
+ { -9.1728000000000005, 5, 2,
+ 0.39999999999999991 },
+ { -4.9218750000000000, 5, 2,
+ 0.50000000000000000 },
+ { 1.6128000000000071, 5, 2,
+ 0.60000000000000009 },
+ { 8.8089749999999984, 5, 2,
+ 0.69999999999999996 },
+ { 13.910399999999997, 5, 2,
+ 0.80000000000000004 },
+ { 12.837825000000004, 5, 2,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 5, 2,
+ 1.0000000000000000 },
+};
+
+// Test function for l=5, m=2.
+template <typename Tp>
+void test009()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data009)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data009[i].l), Tp(data009[i].m),
+ Tp(data009[i].x));
+ const Tp f0 = data009[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=5, m=5.
+testcase_assoc_legendre<double> data010[] = {
+ { -0.0000000000000000, 5, 5,
+ -1.0000000000000000 },
+ { -14.870165800941818, 5, 5,
+ -0.90000000000000002 },
+ { -73.483199999999925, 5, 5,
+ -0.80000000000000004 },
+ { -175.53238298794764, 5, 5,
+ -0.69999999999999996 },
+ { -309.65760000000006, 5, 5,
+ -0.59999999999999998 },
+ { -460.34662869916559, 5, 5,
+ -0.50000000000000000 },
+ { -611.12496255819883, 5, 5,
+ -0.40000000000000002 },
+ { -746.50941479523760, 5, 5,
+ -0.30000000000000004 },
+ { -853.31600434671316, 5, 5,
+ -0.19999999999999996 },
+ { -921.55189181724734, 5, 5,
+ -0.099999999999999978 },
+ { -945.00000000000000, 5, 5,
+ 0.0000000000000000 },
+ { -921.55189181724734, 5, 5,
+ 0.10000000000000009 },
+ { -853.31600434671316, 5, 5,
+ 0.19999999999999996 },
+ { -746.50941479523760, 5, 5,
+ 0.30000000000000004 },
+ { -611.12496255819883, 5, 5,
+ 0.39999999999999991 },
+ { -460.34662869916559, 5, 5,
+ 0.50000000000000000 },
+ { -309.65759999999989, 5, 5,
+ 0.60000000000000009 },
+ { -175.53238298794764, 5, 5,
+ 0.69999999999999996 },
+ { -73.483199999999925, 5, 5,
+ 0.80000000000000004 },
+ { -14.870165800941855, 5, 5,
+ 0.89999999999999991 },
+ { -0.0000000000000000, 5, 5,
+ 1.0000000000000000 },
+};
+
+// Test function for l=5, m=5.
+template <typename Tp>
+void test010()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data010)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data010[i].l), Tp(data010[i].m),
+ Tp(data010[i].x));
+ const Tp f0 = data010[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=10, m=0.
+testcase_assoc_legendre<double> data011[] = {
+ { 1.0000000000000000, 10, 0,
+ -1.0000000000000000 },
+ { -0.26314561785585977, 10, 0,
+ -0.90000000000000002 },
+ { 0.30052979559999998, 10, 0,
+ -0.80000000000000004 },
+ { 0.085805795531640333, 10, 0,
+ -0.69999999999999996 },
+ { -0.24366274560000006, 10, 0,
+ -0.59999999999999998 },
+ { -0.18822860717773438, 10, 0,
+ -0.50000000000000000 },
+ { 0.096839064399999869, 10, 0,
+ -0.40000000000000002 },
+ { 0.25147634951601561, 10, 0,
+ -0.30000000000000004 },
+ { 0.12907202559999989, 10, 0,
+ -0.19999999999999996 },
+ { -0.12212499738710947, 10, 0,
+ -0.099999999999999978 },
+ { -0.24609375000000000, 10, 0,
+ 0.0000000000000000 },
+ { -0.12212499738710922, 10, 0,
+ 0.10000000000000009 },
+ { 0.12907202559999989, 10, 0,
+ 0.19999999999999996 },
+ { 0.25147634951601561, 10, 0,
+ 0.30000000000000004 },
+ { 0.096839064400000258, 10, 0,
+ 0.39999999999999991 },
+ { -0.18822860717773438, 10, 0,
+ 0.50000000000000000 },
+ { -0.24366274559999987, 10, 0,
+ 0.60000000000000009 },
+ { 0.085805795531640333, 10, 0,
+ 0.69999999999999996 },
+ { 0.30052979559999998, 10, 0,
+ 0.80000000000000004 },
+ { -0.26314561785585888, 10, 0,
+ 0.89999999999999991 },
+ { 1.0000000000000000, 10, 0,
+ 1.0000000000000000 },
+};
+
+// Test function for l=10, m=0.
+template <typename Tp>
+void test011()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data011)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data011[i].l), Tp(data011[i].m),
+ Tp(data011[i].x));
+ const Tp f0 = data011[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=10, m=1.
+testcase_assoc_legendre<double> data012[] = {
+ { -0.0000000000000000, 10, 1,
+ -1.0000000000000000 },
+ { -3.0438748781479061, 10, 1,
+ -0.90000000000000002 },
+ { -0.87614260800000199, 10, 1,
+ -0.80000000000000004 },
+ { 2.9685359952934522, 10, 1,
+ -0.69999999999999996 },
+ { 1.2511825919999990, 10, 1,
+ -0.59999999999999998 },
+ { -2.0066877394361260, 10, 1,
+ -0.50000000000000000 },
+ { -2.4822196173476661, 10, 1,
+ -0.40000000000000002 },
+ { -0.12309508907433941, 10, 1,
+ -0.30000000000000004 },
+ { 2.2468221751958408, 10, 1,
+ -0.19999999999999996 },
+ { 2.2472659777983512, 10, 1,
+ -0.099999999999999978 },
+ { -0.0000000000000000, 10, 1,
+ 0.0000000000000000 },
+ { -2.2472659777983530, 10, 1,
+ 0.10000000000000009 },
+ { -2.2468221751958408, 10, 1,
+ 0.19999999999999996 },
+ { 0.12309508907433941, 10, 1,
+ 0.30000000000000004 },
+ { 2.4822196173476643, 10, 1,
+ 0.39999999999999991 },
+ { 2.0066877394361260, 10, 1,
+ 0.50000000000000000 },
+ { -1.2511825920000037, 10, 1,
+ 0.60000000000000009 },
+ { -2.9685359952934522, 10, 1,
+ 0.69999999999999996 },
+ { 0.87614260800000199, 10, 1,
+ 0.80000000000000004 },
+ { 3.0438748781479110, 10, 1,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 10, 1,
+ 1.0000000000000000 },
+};
+
+// Test function for l=10, m=1.
+template <typename Tp>
+void test012()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data012)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data012[i].l), Tp(data012[i].m),
+ Tp(data012[i].x));
+ const Tp f0 = data012[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=10, m=2.
+testcase_assoc_legendre<double> data013[] = {
+ { 0.0000000000000000, 10, 2,
+ -1.0000000000000000 },
+ { 16.376387762496122, 10, 2,
+ -0.90000000000000002 },
+ { -35.394657803999991, 10, 2,
+ -0.80000000000000004 },
+ { -3.6191429423788892, 10, 2,
+ -0.69999999999999996 },
+ { 28.679675904000010, 10, 2,
+ -0.59999999999999998 },
+ { 18.388023376464844, 10, 2,
+ -0.50000000000000000 },
+ { -12.818955995999996, 10, 2,
+ -0.40000000000000002 },
+ { -27.739821675972660, 10, 2,
+ -0.30000000000000004 },
+ { -13.280661503999987, 10, 2,
+ -0.19999999999999996 },
+ { 13.885467170308596, 10, 2,
+ -0.099999999999999978 },
+ { 27.070312500000000, 10, 2,
+ 0.0000000000000000 },
+ { 13.885467170308573, 10, 2,
+ 0.10000000000000009 },
+ { -13.280661503999987, 10, 2,
+ 0.19999999999999996 },
+ { -27.739821675972660, 10, 2,
+ 0.30000000000000004 },
+ { -12.818955996000019, 10, 2,
+ 0.39999999999999991 },
+ { 18.388023376464844, 10, 2,
+ 0.50000000000000000 },
+ { 28.679675903999982, 10, 2,
+ 0.60000000000000009 },
+ { -3.6191429423788892, 10, 2,
+ 0.69999999999999996 },
+ { -35.394657803999991, 10, 2,
+ 0.80000000000000004 },
+ { 16.376387762495984, 10, 2,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 10, 2,
+ 1.0000000000000000 },
+};
+
+// Test function for l=10, m=2.
+template <typename Tp>
+void test013()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data013)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data013[i].l), Tp(data013[i].m),
+ Tp(data013[i].x));
+ const Tp f0 = data013[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for l=10, m=5.
+testcase_assoc_legendre<double> data014[] = {
+ { 0.0000000000000000, 10, 5,
+ -1.0000000000000000 },
+ { 21343.618518164669, 10, 5,
+ -0.90000000000000002 },
+ { 40457.016407807983, 10, 5,
+ -0.80000000000000004 },
+ { 20321.279317331318, 10, 5,
+ -0.69999999999999996 },
+ { -14410.820616192013, 10, 5,
+ -0.59999999999999998 },
+ { -30086.169706116176, 10, 5,
+ -0.50000000000000000 },
+ { -17177.549337582859, 10, 5,
+ -0.40000000000000002 },
+ { 9272.5119495412346, 10, 5,
+ -0.30000000000000004 },
+ { 26591.511184414714, 10, 5,
+ -0.19999999999999996 },
+ { 21961.951238504211, 10, 5,
+ -0.099999999999999978 },
+ { -0.0000000000000000, 10, 5,
+ 0.0000000000000000 },
+ { -21961.951238504229, 10, 5,
+ 0.10000000000000009 },
+ { -26591.511184414714, 10, 5,
+ 0.19999999999999996 },
+ { -9272.5119495412346, 10, 5,
+ 0.30000000000000004 },
+ { 17177.549337582830, 10, 5,
+ 0.39999999999999991 },
+ { 30086.169706116176, 10, 5,
+ 0.50000000000000000 },
+ { 14410.820616191975, 10, 5,
+ 0.60000000000000009 },
+ { -20321.279317331318, 10, 5,
+ 0.69999999999999996 },
+ { -40457.016407807983, 10, 5,
+ 0.80000000000000004 },
+ { -21343.618518164698, 10, 5,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 10, 5,
+ 1.0000000000000000 },
+};
+
+// Test function for l=10, m=5.
+template <typename Tp>
+void test014()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data014)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data014[i].l), Tp(data014[i].m),
+ Tp(data014[i].x));
+ const Tp f0 = data014[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=10, m=10.
+testcase_assoc_legendre<double> data015[] = {
+ { 0.0000000000000000, 10, 10,
+ -1.0000000000000000 },
+ { 162117.40078784220, 10, 10,
+ -0.90000000000000002 },
+ { 3958896.3481267113, 10, 10,
+ -0.80000000000000004 },
+ { 22589806.343887307, 10, 10,
+ -0.69999999999999996 },
+ { 70300999.121633321, 10, 10,
+ -0.59999999999999998 },
+ { 155370278.54003900, 10, 10,
+ -0.50000000000000000 },
+ { 273815518.20150518, 10, 10,
+ -0.40000000000000002 },
+ { 408571989.13158917, 10, 10,
+ -0.30000000000000004 },
+ { 533848212.07990247, 10, 10,
+ -0.19999999999999996 },
+ { 622640835.70523083, 10, 10,
+ -0.099999999999999978 },
+ { 654729075.00000000, 10, 10,
+ 0.0000000000000000 },
+ { 622640835.70523083, 10, 10,
+ 0.10000000000000009 },
+ { 533848212.07990247, 10, 10,
+ 0.19999999999999996 },
+ { 408571989.13158917, 10, 10,
+ 0.30000000000000004 },
+ { 273815518.20150518, 10, 10,
+ 0.39999999999999991 },
+ { 155370278.54003900, 10, 10,
+ 0.50000000000000000 },
+ { 70300999.121633217, 10, 10,
+ 0.60000000000000009 },
+ { 22589806.343887307, 10, 10,
+ 0.69999999999999996 },
+ { 3958896.3481267113, 10, 10,
+ 0.80000000000000004 },
+ { 162117.40078784304, 10, 10,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 10, 10,
+ 1.0000000000000000 },
+};
+
+// Test function for l=10, m=10.
+template <typename Tp>
+void test015()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data015)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data015[i].l), Tp(data015[i].m),
+ Tp(data015[i].x));
+ const Tp f0 = data015[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=20, m=0.
+testcase_assoc_legendre<double> data016[] = {
+ { 1.0000000000000000, 20, 0,
+ -1.0000000000000000 },
+ { -0.14930823530984821, 20, 0,
+ -0.90000000000000002 },
+ { 0.22420460541741344, 20, 0,
+ -0.80000000000000004 },
+ { -0.20457394463834172, 20, 0,
+ -0.69999999999999996 },
+ { 0.15916752910098114, 20, 0,
+ -0.59999999999999998 },
+ { -0.048358381067373557, 20, 0,
+ -0.50000000000000000 },
+ { -0.10159261558628156, 20, 0,
+ -0.40000000000000002 },
+ { 0.18028715947998047, 20, 0,
+ -0.30000000000000004 },
+ { -0.098042194344594741, 20, 0,
+ -0.19999999999999996 },
+ { -0.082077130944527649, 20, 0,
+ -0.099999999999999978 },
+ { 0.17619705200195312, 20, 0,
+ 0.0000000000000000 },
+ { -0.082077130944528037, 20, 0,
+ 0.10000000000000009 },
+ { -0.098042194344594741, 20, 0,
+ 0.19999999999999996 },
+ { 0.18028715947998047, 20, 0,
+ 0.30000000000000004 },
+ { -0.10159261558628112, 20, 0,
+ 0.39999999999999991 },
+ { -0.048358381067373557, 20, 0,
+ 0.50000000000000000 },
+ { 0.15916752910098084, 20, 0,
+ 0.60000000000000009 },
+ { -0.20457394463834172, 20, 0,
+ 0.69999999999999996 },
+ { 0.22420460541741344, 20, 0,
+ 0.80000000000000004 },
+ { -0.14930823530984949, 20, 0,
+ 0.89999999999999991 },
+ { 1.0000000000000000, 20, 0,
+ 1.0000000000000000 },
+};
+
+// Test function for l=20, m=0.
+template <typename Tp>
+void test016()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data016)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data016[i].l), Tp(data016[i].m),
+ Tp(data016[i].x));
+ const Tp f0 = data016[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=20, m=1.
+testcase_assoc_legendre<double> data017[] = {
+ { 0.0000000000000000, 20, 1,
+ -1.0000000000000000 },
+ { 4.3838334818220490, 20, 1,
+ -0.90000000000000002 },
+ { -0.63138296146340556, 20, 1,
+ -0.80000000000000004 },
+ { 0.72274871413391228, 20, 1,
+ -0.69999999999999996 },
+ { -2.3203528743824893, 20, 1,
+ -0.59999999999999998 },
+ { 3.7399919228791405, 20, 1,
+ -0.50000000000000000 },
+ { -3.1692202279270028, 20, 1,
+ -0.40000000000000002 },
+ { 0.15804468835344049, 20, 1,
+ -0.30000000000000004 },
+ { 3.0366182393271162, 20, 1,
+ -0.19999999999999996 },
+ { -3.2115523815580209, 20, 1,
+ -0.099999999999999978 },
+ { 0.0000000000000000, 20, 1,
+ 0.0000000000000000 },
+ { 3.2115523815580160, 20, 1,
+ 0.10000000000000009 },
+ { -3.0366182393271162, 20, 1,
+ 0.19999999999999996 },
+ { -0.15804468835344049, 20, 1,
+ 0.30000000000000004 },
+ { 3.1692202279270076, 20, 1,
+ 0.39999999999999991 },
+ { -3.7399919228791405, 20, 1,
+ 0.50000000000000000 },
+ { 2.3203528743825008, 20, 1,
+ 0.60000000000000009 },
+ { -0.72274871413391228, 20, 1,
+ 0.69999999999999996 },
+ { 0.63138296146340556, 20, 1,
+ 0.80000000000000004 },
+ { -4.3838334818220304, 20, 1,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 20, 1,
+ 1.0000000000000000 },
+};
+
+// Test function for l=20, m=1.
+template <typename Tp>
+void test017()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data017)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data017[i].l), Tp(data017[i].m),
+ Tp(data017[i].x));
+ const Tp f0 = data017[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for l=20, m=2.
+testcase_assoc_legendre<double> data018[] = {
+ { 0.0000000000000000, 20, 2,
+ -1.0000000000000000 },
+ { 80.812425587310116, 20, 2,
+ -0.90000000000000002 },
+ { -95.849622172549317, 20, 2,
+ -0.80000000000000004 },
+ { 87.337927630325510, 20, 2,
+ -0.69999999999999996 },
+ { -70.330891533985834, 20, 2,
+ -0.59999999999999998 },
+ { 24.629090735179489, 20, 2,
+ -0.50000000000000000 },
+ { 39.902576338912418, 20, 2,
+ -0.40000000000000002 },
+ { -75.621201471396589, 20, 2,
+ -0.30000000000000004 },
+ { 42.417415829726487, 20, 2,
+ -0.19999999999999996 },
+ { 33.826848678871301, 20, 2,
+ -0.099999999999999978 },
+ { -74.002761840820312, 20, 2,
+ 0.0000000000000000 },
+ { 33.826848678871457, 20, 2,
+ 0.10000000000000009 },
+ { 42.417415829726487, 20, 2,
+ 0.19999999999999996 },
+ { -75.621201471396589, 20, 2,
+ 0.30000000000000004 },
+ { 39.902576338912240, 20, 2,
+ 0.39999999999999991 },
+ { 24.629090735179489, 20, 2,
+ 0.50000000000000000 },
+ { -70.330891533985664, 20, 2,
+ 0.60000000000000009 },
+ { 87.337927630325510, 20, 2,
+ 0.69999999999999996 },
+ { -95.849622172549317, 20, 2,
+ 0.80000000000000004 },
+ { 80.812425587310585, 20, 2,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 20, 2,
+ 1.0000000000000000 },
+};
+
+// Test function for l=20, m=2.
+template <typename Tp>
+void test018()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data018)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data018[i].l), Tp(data018[i].m),
+ Tp(data018[i].x));
+ const Tp f0 = data018[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=20, m=5.
+testcase_assoc_legendre<double> data019[] = {
+ { -0.0000000000000000, 20, 5,
+ -1.0000000000000000 },
+ { -315702.32715134107, 20, 5,
+ -0.90000000000000002 },
+ { 503060.91484852595, 20, 5,
+ -0.80000000000000004 },
+ { -298127.28360361949, 20, 5,
+ -0.69999999999999996 },
+ { -114444.61447464002, 20, 5,
+ -0.59999999999999998 },
+ { 543428.40914592857, 20, 5,
+ -0.50000000000000000 },
+ { -613842.07728185481, 20, 5,
+ -0.40000000000000002 },
+ { 143765.42411270953, 20, 5,
+ -0.30000000000000004 },
+ { 472600.45321372297, 20, 5,
+ -0.19999999999999996 },
+ { -563861.76771496492, 20, 5,
+ -0.099999999999999978 },
+ { 0.0000000000000000, 20, 5,
+ 0.0000000000000000 },
+ { 563861.76771496458, 20, 5,
+ 0.10000000000000009 },
+ { -472600.45321372297, 20, 5,
+ 0.19999999999999996 },
+ { -143765.42411270953, 20, 5,
+ 0.30000000000000004 },
+ { 613842.07728185505, 20, 5,
+ 0.39999999999999991 },
+ { -543428.40914592857, 20, 5,
+ 0.50000000000000000 },
+ { 114444.61447464184, 20, 5,
+ 0.60000000000000009 },
+ { 298127.28360361949, 20, 5,
+ 0.69999999999999996 },
+ { -503060.91484852595, 20, 5,
+ 0.80000000000000004 },
+ { 315702.32715134590, 20, 5,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 20, 5,
+ 1.0000000000000000 },
+};
+
+// Test function for l=20, m=5.
+template <typename Tp>
+void test019()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data019)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data019[i].l), Tp(data019[i].m),
+ Tp(data019[i].x));
+ const Tp f0 = data019[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=20, m=10.
+testcase_assoc_legendre<double> data020[] = {
+ { -0.0000000000000000, 20, 10,
+ -1.0000000000000000 },
+ { 990017476694.99084, 20, 10,
+ -0.90000000000000002 },
+ { 2392757933281.0503, 20, 10,
+ -0.80000000000000004 },
+ { -1548364524949.5808, 20, 10,
+ -0.69999999999999996 },
+ { -424471915195.05609, 20, 10,
+ -0.59999999999999998 },
+ { 1744502295946.2065, 20, 10,
+ -0.50000000000000000 },
+ { -899973487310.55212, 20, 10,
+ -0.40000000000000002 },
+ { -1092420454297.7164, 20, 10,
+ -0.30000000000000004 },
+ { 1466609267659.8816, 20, 10,
+ -0.19999999999999996 },
+ { 356041756390.71661, 20, 10,
+ -0.099999999999999978 },
+ { -1612052956674.3164, 20, 10,
+ 0.0000000000000000 },
+ { 356041756390.71985, 20, 10,
+ 0.10000000000000009 },
+ { 1466609267659.8816, 20, 10,
+ 0.19999999999999996 },
+ { -1092420454297.7164, 20, 10,
+ 0.30000000000000004 },
+ { -899973487310.55469, 20, 10,
+ 0.39999999999999991 },
+ { 1744502295946.2065, 20, 10,
+ 0.50000000000000000 },
+ { -424471915195.05914, 20, 10,
+ 0.60000000000000009 },
+ { -1548364524949.5808, 20, 10,
+ 0.69999999999999996 },
+ { 2392757933281.0503, 20, 10,
+ 0.80000000000000004 },
+ { 990017476694.99353, 20, 10,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 20, 10,
+ 1.0000000000000000 },
+};
+
+// Test function for l=20, m=10.
+template <typename Tp>
+void test020()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data020)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data020[i].l), Tp(data020[i].m),
+ Tp(data020[i].x));
+ const Tp f0 = data020[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=20, m=20.
+testcase_assoc_legendre<double> data021[] = {
+ { 0.0000000000000000, 20, 20,
+ -1.0000000000000000 },
+ { 19609049712023808., 20, 20,
+ -0.90000000000000002 },
+ { 1.1693527616833221e+19, 20, 20,
+ -0.80000000000000004 },
+ { 3.8073455880620691e+20, 20, 20,
+ -0.69999999999999996 },
+ { 3.6874002249007927e+21, 20, 20,
+ -0.59999999999999998 },
+ { 1.8010806978179592e+22, 20, 20,
+ -0.50000000000000000 },
+ { 5.5938832584012466e+22, 20, 20,
+ -0.40000000000000002 },
+ { 1.2454734132297811e+23, 20, 20,
+ -0.30000000000000004 },
+ { 2.1263407800797497e+23, 20, 20,
+ -0.19999999999999996 },
+ { 2.8924941146976873e+23, 20, 20,
+ -0.099999999999999978 },
+ { 3.1983098677287775e+23, 20, 20,
+ 0.0000000000000000 },
+ { 2.8924941146976873e+23, 20, 20,
+ 0.10000000000000009 },
+ { 2.1263407800797497e+23, 20, 20,
+ 0.19999999999999996 },
+ { 1.2454734132297811e+23, 20, 20,
+ 0.30000000000000004 },
+ { 5.5938832584012466e+22, 20, 20,
+ 0.39999999999999991 },
+ { 1.8010806978179592e+22, 20, 20,
+ 0.50000000000000000 },
+ { 3.6874002249007807e+21, 20, 20,
+ 0.60000000000000009 },
+ { 3.8073455880620691e+20, 20, 20,
+ 0.69999999999999996 },
+ { 1.1693527616833221e+19, 20, 20,
+ 0.80000000000000004 },
+ { 19609049712024020., 20, 20,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 20, 20,
+ 1.0000000000000000 },
+};
+
+// Test function for l=20, m=20.
+template <typename Tp>
+void test021()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data021)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data021[i].l), Tp(data021[i].m),
+ Tp(data021[i].x));
+ const Tp f0 = data021[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=50, m=0.
+testcase_assoc_legendre<double> data022[] = {
+ { 1.0000000000000000, 50, 0,
+ -1.0000000000000000 },
+ { -0.17003765994383685, 50, 0,
+ -0.90000000000000002 },
+ { 0.13879737345093118, 50, 0,
+ -0.80000000000000004 },
+ { -0.014572731645892805, 50, 0,
+ -0.69999999999999996 },
+ { -0.058860798844002173, 50, 0,
+ -0.59999999999999998 },
+ { -0.031059099239609828, 50, 0,
+ -0.50000000000000000 },
+ { 0.041569033381825368, 50, 0,
+ -0.40000000000000002 },
+ { 0.10911051574714808, 50, 0,
+ -0.30000000000000004 },
+ { 0.083432272204197466, 50, 0,
+ -0.19999999999999996 },
+ { -0.038205812661313579, 50, 0,
+ -0.099999999999999978 },
+ { -0.11227517265921705, 50, 0,
+ 0.0000000000000000 },
+ { -0.038205812661314169, 50, 0,
+ 0.10000000000000009 },
+ { 0.083432272204197466, 50, 0,
+ 0.19999999999999996 },
+ { 0.10911051574714808, 50, 0,
+ 0.30000000000000004 },
+ { 0.041569033381824647, 50, 0,
+ 0.39999999999999991 },
+ { -0.031059099239609828, 50, 0,
+ 0.50000000000000000 },
+ { -0.058860798844001430, 50, 0,
+ 0.60000000000000009 },
+ { -0.014572731645892805, 50, 0,
+ 0.69999999999999996 },
+ { 0.13879737345093118, 50, 0,
+ 0.80000000000000004 },
+ { -0.17003765994383663, 50, 0,
+ 0.89999999999999991 },
+ { 1.0000000000000000, 50, 0,
+ 1.0000000000000000 },
+};
+
+// Test function for l=50, m=0.
+template <typename Tp>
+void test022()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data022)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data022[i].l), Tp(data022[i].m),
+ Tp(data022[i].x));
+ const Tp f0 = data022[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=50, m=1.
+testcase_assoc_legendre<double> data023[] = {
+ { 0.0000000000000000, 50, 1,
+ -1.0000000000000000 },
+ { -0.13424149984450387, 50, 1,
+ -0.90000000000000002 },
+ { 2.2011219672413085, 50, 1,
+ -0.80000000000000004 },
+ { 6.6622414993232013, 50, 1,
+ -0.69999999999999996 },
+ { 5.5772846936919231, 50, 1,
+ -0.59999999999999998 },
+ { 5.8787148815607617, 50, 1,
+ -0.50000000000000000 },
+ { 5.5473459458634000, 50, 1,
+ -0.40000000000000002 },
+ { 1.8444956647619912, 50, 1,
+ -0.30000000000000004 },
+ { -3.8722014306642150, 50, 1,
+ -0.19999999999999996 },
+ { -5.3488751322285593, 50, 1,
+ -0.099999999999999978 },
+ { -0.0000000000000000, 50, 1,
+ 0.0000000000000000 },
+ { 5.3488751322285459, 50, 1,
+ 0.10000000000000009 },
+ { 3.8722014306642150, 50, 1,
+ 0.19999999999999996 },
+ { -1.8444956647619912, 50, 1,
+ 0.30000000000000004 },
+ { -5.5473459458634098, 50, 1,
+ 0.39999999999999991 },
+ { -5.8787148815607617, 50, 1,
+ 0.50000000000000000 },
+ { -5.5772846936919489, 50, 1,
+ 0.60000000000000009 },
+ { -6.6622414993232013, 50, 1,
+ 0.69999999999999996 },
+ { -2.2011219672413085, 50, 1,
+ 0.80000000000000004 },
+ { 0.13424149984460862, 50, 1,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 50, 1,
+ 1.0000000000000000 },
+};
+
+// Test function for l=50, m=1.
+template <typename Tp>
+void test023()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data023)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data023[i].l), Tp(data023[i].m),
+ Tp(data023[i].x));
+ const Tp f0 = data023[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000029e-12));
+}
+
+// Test data for l=50, m=2.
+testcase_assoc_legendre<double> data024[] = {
+ { 0.0000000000000000, 50, 2,
+ -1.0000000000000000 },
+ { 433.04168483713448, 50, 2,
+ -0.90000000000000002 },
+ { -348.06364372056390, 50, 2,
+ -0.80000000000000004 },
+ { 50.221071418108465, 50, 2,
+ -0.69999999999999996 },
+ { 158.46096409274341, 50, 2,
+ -0.59999999999999998 },
+ { 85.988858299721414, 50, 2,
+ -0.50000000000000000 },
+ { -101.15891460879277, 50, 2,
+ -0.40000000000000002 },
+ { -277.07168105316612, 50, 2,
+ -0.30000000000000004 },
+ { -214.33311373510401, 50, 2,
+ -0.19999999999999996 },
+ { 96.349657930951722, 50, 2,
+ -0.099999999999999978 },
+ { 286.30169028100346, 50, 2,
+ 0.0000000000000000 },
+ { 96.349657930953285, 50, 2,
+ 0.10000000000000009 },
+ { -214.33311373510401, 50, 2,
+ 0.19999999999999996 },
+ { -277.07168105316612, 50, 2,
+ 0.30000000000000004 },
+ { -101.15891460879106, 50, 2,
+ 0.39999999999999991 },
+ { 85.988858299721414, 50, 2,
+ 0.50000000000000000 },
+ { 158.46096409274131, 50, 2,
+ 0.60000000000000009 },
+ { 50.221071418108465, 50, 2,
+ 0.69999999999999996 },
+ { -348.06364372056390, 50, 2,
+ 0.80000000000000004 },
+ { 433.04168483713414, 50, 2,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 50, 2,
+ 1.0000000000000000 },
+};
+
+// Test function for l=50, m=2.
+template <typename Tp>
+void test024()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data024)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data024[i].l), Tp(data024[i].m),
+ Tp(data024[i].x));
+ const Tp f0 = data024[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=50, m=5.
+testcase_assoc_legendre<double> data025[] = {
+ { -0.0000000000000000, 50, 5,
+ -1.0000000000000000 },
+ { -27340473.952132788, 50, 5,
+ -0.90000000000000002 },
+ { 27753716.768532373, 50, 5,
+ -0.80000000000000004 },
+ { 40808153.913493626, 50, 5,
+ -0.69999999999999996 },
+ { 32071189.035790101, 50, 5,
+ -0.59999999999999998 },
+ { 36265736.218529105, 50, 5,
+ -0.50000000000000000 },
+ { 37089596.700204894, 50, 5,
+ -0.40000000000000002 },
+ { 14562029.629244510, 50, 5,
+ -0.30000000000000004 },
+ { -23686895.217517227, 50, 5,
+ -0.19999999999999996 },
+ { -34878992.965676002, 50, 5,
+ -0.099999999999999978 },
+ { -0.0000000000000000, 50, 5,
+ 0.0000000000000000 },
+ { 34878992.965675950, 50, 5,
+ 0.10000000000000009 },
+ { 23686895.217517227, 50, 5,
+ 0.19999999999999996 },
+ { -14562029.629244510, 50, 5,
+ 0.30000000000000004 },
+ { -37089596.700204931, 50, 5,
+ 0.39999999999999991 },
+ { -36265736.218529105, 50, 5,
+ 0.50000000000000000 },
+ { -32071189.035790265, 50, 5,
+ 0.60000000000000009 },
+ { -40808153.913493626, 50, 5,
+ 0.69999999999999996 },
+ { -27753716.768532373, 50, 5,
+ 0.80000000000000004 },
+ { 27340473.952133406, 50, 5,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 50, 5,
+ 1.0000000000000000 },
+};
+
+// Test function for l=50, m=5.
+template <typename Tp>
+void test025()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data025)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data025[i].l), Tp(data025[i].m),
+ Tp(data025[i].x));
+ const Tp f0 = data025[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=50, m=10.
+testcase_assoc_legendre<double> data026[] = {
+ { -0.0000000000000000, 50, 10,
+ -1.0000000000000000 },
+ { -8994661710093158.0, 50, 10,
+ -0.90000000000000002 },
+ { 932311375306557.00, 50, 10,
+ -0.80000000000000004 },
+ { 12153535011507012., 50, 10,
+ -0.69999999999999996 },
+ { 12176690755542244., 50, 10,
+ -0.59999999999999998 },
+ { 9180035388465752.0, 50, 10,
+ -0.50000000000000000 },
+ { 889201701866911.12, 50, 10,
+ -0.40000000000000002 },
+ { -9451384032851600.0, 50, 10,
+ -0.30000000000000004 },
+ { -9926439446673564.0, 50, 10,
+ -0.19999999999999996 },
+ { 2794368162749970.5, 50, 10,
+ -0.099999999999999978 },
+ { 11452238249246346., 50, 10,
+ 0.0000000000000000 },
+ { 2794368162750031.0, 50, 10,
+ 0.10000000000000009 },
+ { -9926439446673564.0, 50, 10,
+ 0.19999999999999996 },
+ { -9451384032851600.0, 50, 10,
+ 0.30000000000000004 },
+ { 889201701866976.25, 50, 10,
+ 0.39999999999999991 },
+ { 9180035388465752.0, 50, 10,
+ 0.50000000000000000 },
+ { 12176690755542216., 50, 10,
+ 0.60000000000000009 },
+ { 12153535011507012., 50, 10,
+ 0.69999999999999996 },
+ { 932311375306557.00, 50, 10,
+ 0.80000000000000004 },
+ { -8994661710093322.0, 50, 10,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 50, 10,
+ 1.0000000000000000 },
+};
+
+// Test function for l=50, m=10.
+template <typename Tp>
+void test026()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data026)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data026[i].l), Tp(data026[i].m),
+ Tp(data026[i].x));
+ const Tp f0 = data026[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for l=50, m=20.
+testcase_assoc_legendre<double> data027[] = {
+ { 0.0000000000000000, 50, 20,
+ -1.0000000000000000 },
+ { 1.6630925158645460e+33, 50, 20,
+ -0.90000000000000002 },
+ { 1.0622676657892043e+33, 50, 20,
+ -0.80000000000000004 },
+ { 8.6022521164717170e+32, 50, 20,
+ -0.69999999999999996 },
+ { 4.0860128756808430e+32, 50, 20,
+ -0.59999999999999998 },
+ { -4.0169860814274409e+32, 50, 20,
+ -0.50000000000000000 },
+ { -8.2324325279774008e+32, 50, 20,
+ -0.40000000000000002 },
+ { -4.0054067236243299e+31, 50, 20,
+ -0.30000000000000004 },
+ { 7.9309266056434309e+32, 50, 20,
+ -0.19999999999999996 },
+ { 5.4151358290899148e+31, 50, 20,
+ -0.099999999999999978 },
+ { -7.8735935697332210e+32, 50, 20,
+ 0.0000000000000000 },
+ { 5.4151358290895032e+31, 50, 20,
+ 0.10000000000000009 },
+ { 7.9309266056434309e+32, 50, 20,
+ 0.19999999999999996 },
+ { -4.0054067236243299e+31, 50, 20,
+ 0.30000000000000004 },
+ { -8.2324325279773965e+32, 50, 20,
+ 0.39999999999999991 },
+ { -4.0169860814274409e+32, 50, 20,
+ 0.50000000000000000 },
+ { 4.0860128756807882e+32, 50, 20,
+ 0.60000000000000009 },
+ { 8.6022521164717170e+32, 50, 20,
+ 0.69999999999999996 },
+ { 1.0622676657892043e+33, 50, 20,
+ 0.80000000000000004 },
+ { 1.6630925158645483e+33, 50, 20,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 50, 20,
+ 1.0000000000000000 },
+};
+
+// Test function for l=50, m=20.
+template <typename Tp>
+void test027()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data027)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data027[i].l), Tp(data027[i].m),
+ Tp(data027[i].x));
+ const Tp f0 = data027[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for l=50, m=50.
+testcase_assoc_legendre<double> data028[] = {
+ { 0.0000000000000000, 50, 50,
+ -1.0000000000000000 },
+ { 2.5366994974431341e+60, 50, 50,
+ -0.90000000000000002 },
+ { 2.2028834403101213e+67, 50, 50,
+ -0.80000000000000004 },
+ { 1.3325496559566651e+71, 50, 50,
+ -0.69999999999999996 },
+ { 3.8898096431781969e+73, 50, 50,
+ -0.59999999999999998 },
+ { 2.0509760257037188e+75, 50, 50,
+ -0.50000000000000000 },
+ { 3.4866724533443283e+76, 50, 50,
+ -0.40000000000000002 },
+ { 2.5790740224150207e+77, 50, 50,
+ -0.30000000000000004 },
+ { 9.8222237931680989e+77, 50, 50,
+ -0.19999999999999996 },
+ { 2.1198682190366617e+78, 50, 50,
+ -0.099999999999999978 },
+ { 2.7253921397507295e+78, 50, 50,
+ 0.0000000000000000 },
+ { 2.1198682190366617e+78, 50, 50,
+ 0.10000000000000009 },
+ { 9.8222237931680989e+77, 50, 50,
+ 0.19999999999999996 },
+ { 2.5790740224150207e+77, 50, 50,
+ 0.30000000000000004 },
+ { 3.4866724533443283e+76, 50, 50,
+ 0.39999999999999991 },
+ { 2.0509760257037188e+75, 50, 50,
+ 0.50000000000000000 },
+ { 3.8898096431781724e+73, 50, 50,
+ 0.60000000000000009 },
+ { 1.3325496559566651e+71, 50, 50,
+ 0.69999999999999996 },
+ { 2.2028834403101213e+67, 50, 50,
+ 0.80000000000000004 },
+ { 2.5366994974431990e+60, 50, 50,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 50, 50,
+ 1.0000000000000000 },
+};
+
+// Test function for l=50, m=50.
+template <typename Tp>
+void test028()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data028)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data028[i].l), Tp(data028[i].m),
+ Tp(data028[i].x));
+ const Tp f0 = data028[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=100, m=0.
+testcase_assoc_legendre<double> data029[] = {
+ { 1.0000000000000000, 100, 0,
+ -1.0000000000000000 },
+ { 0.10226582055871908, 100, 0,
+ -0.90000000000000002 },
+ { 0.050861167913584124, 100, 0,
+ -0.80000000000000004 },
+ { -0.077132507199778780, 100, 0,
+ -0.69999999999999996 },
+ { -0.023747023905133110, 100, 0,
+ -0.59999999999999998 },
+ { -0.060518025961861198, 100, 0,
+ -0.50000000000000000 },
+ { -0.072258202125684429, 100, 0,
+ -0.40000000000000002 },
+ { 0.057127392202801719, 100, 0,
+ -0.30000000000000004 },
+ { 0.014681835355659636, 100, 0,
+ -0.19999999999999996 },
+ { -0.063895098434750303, 100, 0,
+ -0.099999999999999978 },
+ { 0.079589237387178727, 100, 0,
+ 0.0000000000000000 },
+ { -0.063895098434749775, 100, 0,
+ 0.10000000000000009 },
+ { 0.014681835355659636, 100, 0,
+ 0.19999999999999996 },
+ { 0.057127392202801719, 100, 0,
+ 0.30000000000000004 },
+ { -0.072258202125685012, 100, 0,
+ 0.39999999999999991 },
+ { -0.060518025961861198, 100, 0,
+ 0.50000000000000000 },
+ { -0.023747023905134217, 100, 0,
+ 0.60000000000000009 },
+ { -0.077132507199778780, 100, 0,
+ 0.69999999999999996 },
+ { 0.050861167913584124, 100, 0,
+ 0.80000000000000004 },
+ { 0.10226582055871723, 100, 0,
+ 0.89999999999999991 },
+ { 1.0000000000000000, 100, 0,
+ 1.0000000000000000 },
+};
+
+// Test function for l=100, m=0.
+template <typename Tp>
+void test029()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data029)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data029[i].l), Tp(data029[i].m),
+ Tp(data029[i].x));
+ const Tp f0 = data029[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=100, m=1.
+testcase_assoc_legendre<double> data030[] = {
+ { -0.0000000000000000, 100, 1,
+ -1.0000000000000000 },
+ { 6.5200167187780309, 100, 1,
+ -0.90000000000000002 },
+ { 9.0065170007027540, 100, 1,
+ -0.80000000000000004 },
+ { -5.4690908541181056, 100, 1,
+ -0.69999999999999996 },
+ { -8.6275439170430861, 100, 1,
+ -0.59999999999999998 },
+ { -6.0909031663448499, 100, 1,
+ -0.50000000000000000 },
+ { 4.1160338699561265, 100, 1,
+ -0.40000000000000002 },
+ { 5.8491043010758004, 100, 1,
+ -0.30000000000000004 },
+ { -7.9435138723089826, 100, 1,
+ -0.19999999999999996 },
+ { 4.7996285823989346, 100, 1,
+ -0.099999999999999978 },
+ { 0.0000000000000000, 100, 1,
+ 0.0000000000000000 },
+ { -4.7996285823990057, 100, 1,
+ 0.10000000000000009 },
+ { 7.9435138723089826, 100, 1,
+ 0.19999999999999996 },
+ { -5.8491043010758004, 100, 1,
+ 0.30000000000000004 },
+ { -4.1160338699560359, 100, 1,
+ 0.39999999999999991 },
+ { 6.0909031663448499, 100, 1,
+ 0.50000000000000000 },
+ { 8.6275439170430559, 100, 1,
+ 0.60000000000000009 },
+ { 5.4690908541181056, 100, 1,
+ 0.69999999999999996 },
+ { -9.0065170007027540, 100, 1,
+ 0.80000000000000004 },
+ { -6.5200167187783133, 100, 1,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 100, 1,
+ 1.0000000000000000 },
+};
+
+// Test function for l=100, m=1.
+template <typename Tp>
+void test030()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data030)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data030[i].l), Tp(data030[i].m),
+ Tp(data030[i].x));
+ const Tp f0 = data030[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for l=100, m=2.
+testcase_assoc_legendre<double> data031[] = {
+ { 0.0000000000000000, 100, 2,
+ -1.0000000000000000 },
+ { -1005.9604880761007, 100, 2,
+ -0.90000000000000002 },
+ { -489.68041725865896, 100, 2,
+ -0.80000000000000004 },
+ { 768.31676011669970, 100, 2,
+ -0.69999999999999996 },
+ { 226.90362556628003, 100, 2,
+ -0.59999999999999998 },
+ { 604.19889304940330, 100, 2,
+ -0.50000000000000000 },
+ { 733.40061037838029, 100, 2,
+ -0.40000000000000002 },
+ { -573.30774483996402, 100, 2,
+ -0.30000000000000004 },
+ { -151.52946305080897, 100, 2,
+ -0.19999999999999996 },
+ { 646.30525583588019, 100, 2,
+ -0.099999999999999978 },
+ { -803.85129761050518, 100, 2,
+ 0.0000000000000000 },
+ { 646.30525583587439, 100, 2,
+ 0.10000000000000009 },
+ { -151.52946305080897, 100, 2,
+ 0.19999999999999996 },
+ { -573.30774483996402, 100, 2,
+ 0.30000000000000004 },
+ { 733.40061037838507, 100, 2,
+ 0.39999999999999991 },
+ { 604.19889304940330, 100, 2,
+ 0.50000000000000000 },
+ { 226.90362556629168, 100, 2,
+ 0.60000000000000009 },
+ { 768.31676011669970, 100, 2,
+ 0.69999999999999996 },
+ { -489.68041725865896, 100, 2,
+ 0.80000000000000004 },
+ { -1005.9604880760811, 100, 2,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 100, 2,
+ 1.0000000000000000 },
+};
+
+// Test function for l=100, m=2.
+template <typename Tp>
+void test031()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data031)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data031[i].l), Tp(data031[i].m),
+ Tp(data031[i].x));
+ const Tp f0 = data031[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=100, m=5.
+testcase_assoc_legendre<double> data032[] = {
+ { 0.0000000000000000, 100, 5,
+ -1.0000000000000000 },
+ { 900551126.09653592, 100, 5,
+ -0.90000000000000002 },
+ { 988567431.55756044, 100, 5,
+ -0.80000000000000004 },
+ { -645646451.90344620, 100, 5,
+ -0.69999999999999996 },
+ { -897114585.29920745, 100, 5,
+ -0.59999999999999998 },
+ { -661710744.42483830, 100, 5,
+ -0.50000000000000000 },
+ { 380163158.51425594, 100, 5,
+ -0.40000000000000002 },
+ { 617391071.36632609, 100, 5,
+ -0.30000000000000004 },
+ { -805288801.85509181, 100, 5,
+ -0.19999999999999996 },
+ { 481041740.16728652, 100, 5,
+ -0.099999999999999978 },
+ { 0.0000000000000000, 100, 5,
+ 0.0000000000000000 },
+ { -481041740.16729414, 100, 5,
+ 0.10000000000000009 },
+ { 805288801.85509181, 100, 5,
+ 0.19999999999999996 },
+ { -617391071.36632609, 100, 5,
+ 0.30000000000000004 },
+ { -380163158.51424748, 100, 5,
+ 0.39999999999999991 },
+ { 661710744.42483830, 100, 5,
+ 0.50000000000000000 },
+ { 897114585.29920506, 100, 5,
+ 0.60000000000000009 },
+ { 645646451.90344620, 100, 5,
+ 0.69999999999999996 },
+ { -988567431.55756044, 100, 5,
+ 0.80000000000000004 },
+ { -900551126.09655809, 100, 5,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 100, 5,
+ 1.0000000000000000 },
+};
+
+// Test function for l=100, m=5.
+template <typename Tp>
+void test032()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data032)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data032[i].l), Tp(data032[i].m),
+ Tp(data032[i].x));
+ const Tp f0 = data032[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=100, m=10.
+testcase_assoc_legendre<double> data033[] = {
+ { 0.0000000000000000, 100, 10,
+ -1.0000000000000000 },
+ { 2.5643395957658915e+17, 100, 10,
+ -0.90000000000000002 },
+ { 1.5778673545673316e+18, 100, 10,
+ -0.80000000000000004 },
+ { 4.4355048487496776e+18, 100, 10,
+ -0.69999999999999996 },
+ { -9.5936111659124493e+17, 100, 10,
+ -0.59999999999999998 },
+ { 4.2387123021963372e+18, 100, 10,
+ -0.50000000000000000 },
+ { 8.2370834618426563e+18, 100, 10,
+ -0.40000000000000002 },
+ { -4.9089358388052890e+18, 100, 10,
+ -0.30000000000000004 },
+ { -2.3468810358091279e+18, 100, 10,
+ -0.19999999999999996 },
+ { 6.8627855225034568e+18, 100, 10,
+ -0.099999999999999978 },
+ { -8.2494597181670380e+18, 100, 10,
+ 0.0000000000000000 },
+ { 6.8627855225034056e+18, 100, 10,
+ 0.10000000000000009 },
+ { -2.3468810358091279e+18, 100, 10,
+ 0.19999999999999996 },
+ { -4.9089358388052890e+18, 100, 10,
+ 0.30000000000000004 },
+ { 8.2370834618426747e+18, 100, 10,
+ 0.39999999999999991 },
+ { 4.2387123021963372e+18, 100, 10,
+ 0.50000000000000000 },
+ { -9.5936111659112115e+17, 100, 10,
+ 0.60000000000000009 },
+ { 4.4355048487496776e+18, 100, 10,
+ 0.69999999999999996 },
+ { 1.5778673545673316e+18, 100, 10,
+ 0.80000000000000004 },
+ { 2.5643395957690282e+17, 100, 10,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 100, 10,
+ 1.0000000000000000 },
+};
+
+// Test function for l=100, m=10.
+template <typename Tp>
+void test033()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data033)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data033[i].l), Tp(data033[i].m),
+ Tp(data033[i].x));
+ const Tp f0 = data033[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000014e-11));
+}
+
+// Test data for l=100, m=20.
+testcase_assoc_legendre<double> data034[] = {
+ { 0.0000000000000000, 100, 20,
+ -1.0000000000000000 },
+ { 7.1604344878778576e+37, 100, 20,
+ -0.90000000000000002 },
+ { -8.3963895116962035e+38, 100, 20,
+ -0.80000000000000004 },
+ { 7.9022236853110024e+38, 100, 20,
+ -0.69999999999999996 },
+ { 8.2680005574120908e+38, 100, 20,
+ -0.59999999999999998 },
+ { 3.0750497039999469e+38, 100, 20,
+ -0.50000000000000000 },
+ { -7.6120586043843874e+38, 100, 20,
+ -0.40000000000000002 },
+ { 1.1474496891901873e+38, 100, 20,
+ -0.30000000000000004 },
+ { 4.3966251307444218e+38, 100, 20,
+ -0.19999999999999996 },
+ { -7.0503266451702621e+38, 100, 20,
+ -0.099999999999999978 },
+ { 7.7727439836159581e+38, 100, 20,
+ 0.0000000000000000 },
+ { -7.0503266451702213e+38, 100, 20,
+ 0.10000000000000009 },
+ { 4.3966251307444218e+38, 100, 20,
+ 0.19999999999999996 },
+ { 1.1474496891901873e+38, 100, 20,
+ 0.30000000000000004 },
+ { -7.6120586043843511e+38, 100, 20,
+ 0.39999999999999991 },
+ { 3.0750497039999469e+38, 100, 20,
+ 0.50000000000000000 },
+ { 8.2680005574120424e+38, 100, 20,
+ 0.60000000000000009 },
+ { 7.9022236853110024e+38, 100, 20,
+ 0.69999999999999996 },
+ { -8.3963895116962035e+38, 100, 20,
+ 0.80000000000000004 },
+ { 7.1604344878809460e+37, 100, 20,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 100, 20,
+ 1.0000000000000000 },
+};
+
+// Test function for l=100, m=20.
+template <typename Tp>
+void test034()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data034)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data034[i].l), Tp(data034[i].m),
+ Tp(data034[i].x));
+ const Tp f0 = data034[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000015e-12));
+}
+
+// Test data for l=100, m=50.
+testcase_assoc_legendre<double> data035[] = {
+ { 0.0000000000000000, 100, 50,
+ -1.0000000000000000 },
+ { 9.3231278516893773e+96, 100, 50,
+ -0.90000000000000002 },
+ { -1.1029797977454331e+98, 100, 50,
+ -0.80000000000000004 },
+ { 1.8089333903465883e+97, 100, 50,
+ -0.69999999999999996 },
+ { 5.9364045925669389e+97, 100, 50,
+ -0.59999999999999998 },
+ { -8.2252620339727163e+97, 100, 50,
+ -0.50000000000000000 },
+ { 7.1431385093739848e+97, 100, 50,
+ -0.40000000000000002 },
+ { -3.3520602067479374e+97, 100, 50,
+ -0.30000000000000004 },
+ { -2.7791149588121386e+97, 100, 50,
+ -0.19999999999999996 },
+ { 9.0119338550180433e+97, 100, 50,
+ -0.099999999999999978 },
+ { -1.1712145031578381e+98, 100, 50,
+ 0.0000000000000000 },
+ { 9.0119338550181176e+97, 100, 50,
+ 0.10000000000000009 },
+ { -2.7791149588121386e+97, 100, 50,
+ 0.19999999999999996 },
+ { -3.3520602067479374e+97, 100, 50,
+ 0.30000000000000004 },
+ { 7.1431385093740728e+97, 100, 50,
+ 0.39999999999999991 },
+ { -8.2252620339727163e+97, 100, 50,
+ 0.50000000000000000 },
+ { 5.9364045925668061e+97, 100, 50,
+ 0.60000000000000009 },
+ { 1.8089333903465883e+97, 100, 50,
+ 0.69999999999999996 },
+ { -1.1029797977454331e+98, 100, 50,
+ 0.80000000000000004 },
+ { 9.3231278516894892e+96, 100, 50,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 100, 50,
+ 1.0000000000000000 },
+};
+
+// Test function for l=100, m=50.
+template <typename Tp>
+void test035()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data035)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data035[i].l), Tp(data035[i].m),
+ Tp(data035[i].x));
+ const Tp f0 = data035[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for l=100, m=100.
+testcase_assoc_legendre<double> data036[] = {
+ { 0.0000000000000000, 100, 100,
+ -1.0000000000000000 },
+ { 5.7751792255758316e+150, 100, 100,
+ -0.90000000000000002 },
+ { 4.3552236041585515e+164, 100, 100,
+ -0.80000000000000004 },
+ { 1.5936546850595123e+172, 100, 100,
+ -0.69999999999999996 },
+ { 1.3579510590289176e+177, 100, 100,
+ -0.59999999999999998 },
+ { 3.7752749682889513e+180, 100, 100,
+ -0.50000000000000000 },
+ { 1.0910627330458913e+183, 100, 100,
+ -0.40000000000000002 },
+ { 5.9697347526822483e+184, 100, 100,
+ -0.30000000000000004 },
+ { 8.6585879147526714e+185, 100, 100,
+ -0.19999999999999996 },
+ { 4.0331571908057011e+186, 100, 100,
+ -0.099999999999999978 },
+ { 6.6663086700729543e+186, 100, 100,
+ 0.0000000000000000 },
+ { 4.0331571908057011e+186, 100, 100,
+ 0.10000000000000009 },
+ { 8.6585879147526714e+185, 100, 100,
+ 0.19999999999999996 },
+ { 5.9697347526822483e+184, 100, 100,
+ 0.30000000000000004 },
+ { 1.0910627330458913e+183, 100, 100,
+ 0.39999999999999991 },
+ { 3.7752749682889513e+180, 100, 100,
+ 0.50000000000000000 },
+ { 1.3579510590289000e+177, 100, 100,
+ 0.60000000000000009 },
+ { 1.5936546850595123e+172, 100, 100,
+ 0.69999999999999996 },
+ { 4.3552236041585515e+164, 100, 100,
+ 0.80000000000000004 },
+ { 5.7751792255761289e+150, 100, 100,
+ 0.89999999999999991 },
+ { 0.0000000000000000, 100, 100,
+ 1.0000000000000000 },
+};
+
+// Test function for l=100, m=100.
+template <typename Tp>
+void test036()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data036)
+ / sizeof(testcase_assoc_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::assoc_legendre(Tp(data036[i].l), Tp(data036[i].m),
+ Tp(data036[i].x));
+ const Tp f0 = data036[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ test009<double>();
+ test010<double>();
+ test011<double>();
+ test012<double>();
+ test013<double>();
+ test014<double>();
+ test015<double>();
+ test016<double>();
+ test017<double>();
+ test018<double>();
+ test019<double>();
+ test020<double>();
+ test021<double>();
+ test022<double>();
+ test023<double>();
+ test024<double>();
+ test025<double>();
+ test026<double>();
+ test027<double>();
+ test028<double>();
+ test029<double>();
+ test030<double>();
+ test031<double>();
+ test032<double>();
+ test033<double>();
+ test034<double>();
+ test035<double>();
+ test036<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/02_assoc_legendre/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/02_assoc_legendre/compile.cc
new file mode 100644
index 00000000000..a18b05f74a7
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/02_assoc_legendre/compile.cc
@@ -0,0 +1,44 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.2 assoc_legendre
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+ unsigned int l = 2, m = 1;
+
+ std::tr1::assoc_legendre(l, m, xf);
+ std::tr1::assoc_legendref(l, m, xf);
+ std::tr1::assoc_legendre(l, m, xd);
+ std::tr1::assoc_legendre(l, m, xl);
+ std::tr1::assoc_legendrel(l, m, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/02_assoc_legendre/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/02_assoc_legendre/compile_2.cc
new file mode 100644
index 00000000000..2fe173022d7
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/02_assoc_legendre/compile_2.cc
@@ -0,0 +1,44 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.2 assoc_legendre
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+ unsigned int l = 2, m = 1;
+
+ assoc_legendre(l, m, xf);
+ assoc_legendref(l, m, xf);
+ assoc_legendre(l, m, xd);
+ assoc_legendre(l, m, xl);
+ assoc_legendrel(l, m, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/03_beta/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/03_beta/check_nan.cc
new file mode 100644
index 00000000000..ca8246c4e72
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/03_beta/check_nan.cc
@@ -0,0 +1,87 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.3 beta
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+ float xf = std::numeric_limits<float>::quiet_NaN();
+ double xd = std::numeric_limits<double>::quiet_NaN();
+ long double xl = std::numeric_limits<long double>::quiet_NaN();
+
+ float yf = 0.0F;
+ double yd = 0.0;
+ long double yl = 0.0L;
+
+ float a = std::tr1::beta(xf, yf);
+ float b = std::tr1::betaf(xf, yf);
+ double c = std::tr1::beta(xd, yd);
+ long double d = std::tr1::beta(xl, yl);
+ long double e = std::tr1::betal(xl, yl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+void
+test02()
+{
+ float xf = 1.0F;
+ double xd = 1.0;
+ long double xl = 1.0L;
+
+ float yf = std::numeric_limits<float>::quiet_NaN();
+ double yd = std::numeric_limits<double>::quiet_NaN();
+ long double yl = std::numeric_limits<long double>::quiet_NaN();
+
+ float a = std::tr1::beta(xf, yf);
+ float b = std::tr1::betaf(xf, yf);
+ double c = std::tr1::beta(xd, yd);
+ long double d = std::tr1::beta(xl, yl);
+ long double e = std::tr1::betal(xl, yl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ test02();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/03_beta/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/03_beta/check_value.cc
new file mode 100644
index 00000000000..8f8a4a74a78
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/03_beta/check_value.cc
@@ -0,0 +1,466 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// beta
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for x=10.000000000000000.
+testcase_beta<double> data001[] = {
+ { 1.0825088224469029e-06, 10.000000000000000, 10.000000000000000 },
+ { 4.9925087406346778e-09, 10.000000000000000, 20.000000000000000 },
+ { 1.5729567312509485e-10, 10.000000000000000, 30.000000000000000 },
+ { 1.2168673582561288e-11, 10.000000000000000, 40.000000000000000 },
+ { 1.5916380099863291e-12, 10.000000000000000, 50.000000000000000 },
+ { 2.9408957938463963e-13, 10.000000000000000, 60.000000000000000 },
+ { 6.9411637980691676e-14, 10.000000000000000, 70.000000000000000 },
+ { 1.9665612972502651e-14, 10.000000000000000, 80.000000000000000 },
+ { 6.4187824828154399e-15, 10.000000000000000, 90.000000000000000 },
+ { 2.3455339739604842e-15, 10.000000000000000, 100.00000000000000 },
+};
+
+// Test function for x=10.000000000000000.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_beta<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::beta(Tp(data001[i].x), Tp(data001[i].y));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000029e-12));
+}
+
+// Test data for x=20.000000000000000.
+testcase_beta<double> data002[] = {
+ { 4.9925087406346778e-09, 20.000000000000000, 10.000000000000000 },
+ { 7.2544445519248436e-13, 20.000000000000000, 20.000000000000000 },
+ { 1.7681885473062028e-15, 20.000000000000000, 30.000000000000000 },
+ { 1.7891885039182335e-17, 20.000000000000000, 40.000000000000000 },
+ { 4.3240677875623635e-19, 20.000000000000000, 50.000000000000000 },
+ { 1.8857342309689050e-20, 20.000000000000000, 60.000000000000000 },
+ { 1.2609804003539998e-21, 20.000000000000000, 70.000000000000000 },
+ { 1.1660809542079041e-22, 20.000000000000000, 80.000000000000000 },
+ { 1.3907944279729071e-23, 20.000000000000000, 90.000000000000000 },
+ { 2.0365059099917614e-24, 20.000000000000000, 100.00000000000000 },
+};
+
+// Test function for x=20.000000000000000.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_beta<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::beta(Tp(data002[i].x), Tp(data002[i].y));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for x=30.000000000000000.
+testcase_beta<double> data003[] = {
+ { 1.5729567312509485e-10, 30.000000000000000, 10.000000000000000 },
+ { 1.7681885473062028e-15, 30.000000000000000, 20.000000000000000 },
+ { 5.6370779640482451e-19, 30.000000000000000, 30.000000000000000 },
+ { 1.0539424603796547e-21, 30.000000000000000, 40.000000000000000 },
+ { 6.0118197777273836e-24, 30.000000000000000, 50.000000000000000 },
+ { 7.4279528553260165e-26, 30.000000000000000, 60.000000000000000 },
+ { 1.6212207780604767e-27, 30.000000000000000, 70.000000000000000 },
+ { 5.4783729715317616e-29, 30.000000000000000, 80.000000000000000 },
+ { 2.6183005659681346e-30, 30.000000000000000, 90.000000000000000 },
+ { 1.6587948222122229e-31, 30.000000000000000, 100.00000000000000 },
+};
+
+// Test function for x=30.000000000000000.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_beta<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::beta(Tp(data003[i].x), Tp(data003[i].y));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for x=40.000000000000000.
+testcase_beta<double> data004[] = {
+ { 1.2168673582561288e-11, 40.000000000000000, 10.000000000000000 },
+ { 1.7891885039182335e-17, 40.000000000000000, 20.000000000000000 },
+ { 1.0539424603796547e-21, 40.000000000000000, 30.000000000000000 },
+ { 4.6508509140090659e-25, 40.000000000000000, 40.000000000000000 },
+ { 7.5161712118557719e-28, 40.000000000000000, 50.000000000000000 },
+ { 3.0311331979886071e-30, 40.000000000000000, 60.000000000000000 },
+ { 2.4175035070466313e-32, 40.000000000000000, 70.000000000000000 },
+ { 3.2734839142758369e-34, 40.000000000000000, 80.000000000000000 },
+ { 6.7690629601315579e-36, 40.000000000000000, 90.000000000000000 },
+ { 1.9797337118812366e-37, 40.000000000000000, 100.00000000000000 },
+};
+
+// Test function for x=40.000000000000000.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_beta<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::beta(Tp(data004[i].x), Tp(data004[i].y));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000015e-12));
+}
+
+// Test data for x=50.000000000000000.
+testcase_beta<double> data005[] = {
+ { 1.5916380099863291e-12, 50.000000000000000, 10.000000000000000 },
+ { 4.3240677875623635e-19, 50.000000000000000, 20.000000000000000 },
+ { 6.0118197777273836e-24, 50.000000000000000, 30.000000000000000 },
+ { 7.5161712118557719e-28, 50.000000000000000, 40.000000000000000 },
+ { 3.9646612085674138e-31, 50.000000000000000, 50.000000000000000 },
+ { 5.8425643906418403e-34, 50.000000000000000, 60.000000000000000 },
+ { 1.8672362180783552e-36, 50.000000000000000, 70.000000000000000 },
+ { 1.0939382296458962e-38, 50.000000000000000, 80.000000000000000 },
+ { 1.0442781609881063e-40, 50.000000000000000, 90.000000000000000 },
+ { 1.4904121110954370e-42, 50.000000000000000, 100.00000000000000 },
+};
+
+// Test function for x=50.000000000000000.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_beta<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::beta(Tp(data005[i].x), Tp(data005[i].y));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for x=60.000000000000000.
+testcase_beta<double> data006[] = {
+ { 2.9408957938463963e-13, 60.000000000000000, 10.000000000000000 },
+ { 1.8857342309689050e-20, 60.000000000000000, 20.000000000000000 },
+ { 7.4279528553260165e-26, 60.000000000000000, 30.000000000000000 },
+ { 3.0311331979886071e-30, 60.000000000000000, 40.000000000000000 },
+ { 5.8425643906418403e-34, 60.000000000000000, 50.000000000000000 },
+ { 3.4501231469782229e-37, 60.000000000000000, 60.000000000000000 },
+ { 4.7706855386086599e-40, 60.000000000000000, 70.000000000000000 },
+ { 1.2902663809722593e-42, 60.000000000000000, 80.000000000000000 },
+ { 6.0105571058570508e-45, 60.000000000000000, 90.000000000000000 },
+ { 4.3922898898347209e-47, 60.000000000000000, 100.00000000000000 },
+};
+
+// Test function for x=60.000000000000000.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_beta<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::beta(Tp(data006[i].x), Tp(data006[i].y));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for x=70.000000000000000.
+testcase_beta<double> data007[] = {
+ { 6.9411637980691676e-14, 70.000000000000000, 10.000000000000000 },
+ { 1.2609804003539998e-21, 70.000000000000000, 20.000000000000000 },
+ { 1.6212207780604767e-27, 70.000000000000000, 30.000000000000000 },
+ { 2.4175035070466313e-32, 70.000000000000000, 40.000000000000000 },
+ { 1.8672362180783552e-36, 70.000000000000000, 50.000000000000000 },
+ { 4.7706855386086599e-40, 70.000000000000000, 60.000000000000000 },
+ { 3.0453137143486369e-43, 70.000000000000000, 70.000000000000000 },
+ { 4.0192274082013779e-46, 70.000000000000000, 80.000000000000000 },
+ { 9.5865870063501807e-49, 70.000000000000000, 90.000000000000000 },
+ { 3.7409127305819802e-51, 70.000000000000000, 100.00000000000000 },
+};
+
+// Test function for x=70.000000000000000.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_beta<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::beta(Tp(data007[i].x), Tp(data007[i].y));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for x=80.000000000000000.
+testcase_beta<double> data008[] = {
+ { 1.9665612972502651e-14, 80.000000000000000, 10.000000000000000 },
+ { 1.1660809542079041e-22, 80.000000000000000, 20.000000000000000 },
+ { 5.4783729715317616e-29, 80.000000000000000, 30.000000000000000 },
+ { 3.2734839142758369e-34, 80.000000000000000, 40.000000000000000 },
+ { 1.0939382296458962e-38, 80.000000000000000, 50.000000000000000 },
+ { 1.2902663809722593e-42, 80.000000000000000, 60.000000000000000 },
+ { 4.0192274082013779e-46, 80.000000000000000, 70.000000000000000 },
+ { 2.7160590828669411e-49, 80.000000000000000, 80.000000000000000 },
+ { 3.4593773902125368e-52, 80.000000000000000, 90.000000000000000 },
+ { 7.4807039968503468e-55, 80.000000000000000, 100.00000000000000 },
+};
+
+// Test function for x=80.000000000000000.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_beta<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::beta(Tp(data008[i].x), Tp(data008[i].y));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000029e-12));
+}
+
+// Test data for x=90.000000000000000.
+testcase_beta<double> data009[] = {
+ { 6.4187824828154399e-15, 90.000000000000000, 10.000000000000000 },
+ { 1.3907944279729071e-23, 90.000000000000000, 20.000000000000000 },
+ { 2.6183005659681346e-30, 90.000000000000000, 30.000000000000000 },
+ { 6.7690629601315579e-36, 90.000000000000000, 40.000000000000000 },
+ { 1.0442781609881063e-40, 90.000000000000000, 50.000000000000000 },
+ { 6.0105571058570508e-45, 90.000000000000000, 60.000000000000000 },
+ { 9.5865870063501807e-49, 90.000000000000000, 70.000000000000000 },
+ { 3.4593773902125368e-52, 90.000000000000000, 80.000000000000000 },
+ { 2.4416737907558032e-55, 90.000000000000000, 90.000000000000000 },
+ { 3.0238531916564246e-58, 90.000000000000000, 100.00000000000000 },
+};
+
+// Test function for x=90.000000000000000.
+template <typename Tp>
+void test009()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data009)
+ / sizeof(testcase_beta<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::beta(Tp(data009[i].x), Tp(data009[i].y));
+ const Tp f0 = data009[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for x=100.00000000000000.
+testcase_beta<double> data010[] = {
+ { 2.3455339739604842e-15, 100.00000000000000, 10.000000000000000 },
+ { 2.0365059099917614e-24, 100.00000000000000, 20.000000000000000 },
+ { 1.6587948222122229e-31, 100.00000000000000, 30.000000000000000 },
+ { 1.9797337118812366e-37, 100.00000000000000, 40.000000000000000 },
+ { 1.4904121110954370e-42, 100.00000000000000, 50.000000000000000 },
+ { 4.3922898898347209e-47, 100.00000000000000, 60.000000000000000 },
+ { 3.7409127305819802e-51, 100.00000000000000, 70.000000000000000 },
+ { 7.4807039968503468e-55, 100.00000000000000, 80.000000000000000 },
+ { 3.0238531916564246e-58, 100.00000000000000, 90.000000000000000 },
+ { 2.2087606931991853e-61, 100.00000000000000, 100.00000000000000 },
+};
+
+// Test function for x=100.00000000000000.
+template <typename Tp>
+void test010()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data010)
+ / sizeof(testcase_beta<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::beta(Tp(data010[i].x), Tp(data010[i].y));
+ const Tp f0 = data010[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000029e-12));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ test009<double>();
+ test010<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/03_beta/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/03_beta/compile.cc
new file mode 100644
index 00000000000..a689c95a4aa
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/03_beta/compile.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.3 beta
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+
+ float xf = 0.5F, yf = 0.5F;
+ double xd = 0.5, yd = 0.5;
+ long double xl = 0.5L, yl = 0.5L;
+
+ std::tr1::beta(xf, yf);
+ std::tr1::betaf(xf, yf);
+ std::tr1::beta(xd, yd);
+ std::tr1::beta(xl, yl);
+ std::tr1::betal(xl, yl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/03_beta/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/03_beta/compile_2.cc
new file mode 100644
index 00000000000..68d5b20cfb3
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/03_beta/compile_2.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.3 beta
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+
+ float xf = 0.5F, yf = 0.5F;
+ double xd = 0.5, yd = 0.5;
+ long double xl = 0.5L, yl = 0.5L;
+
+ beta(xf, yf);
+ betaf(xf, yf);
+ beta(xd, yd);
+ beta(xl, yl);
+ betal(xl, yl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/04_comp_ellint_1/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/04_comp_ellint_1/check_nan.cc
new file mode 100644
index 00000000000..f5a0e9b74ca
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/04_comp_ellint_1/check_nan.cc
@@ -0,0 +1,57 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.4 comp_ellint_1
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+
+ float kf = std::numeric_limits<float>::quiet_NaN();
+ double kd = std::numeric_limits<double>::quiet_NaN();
+ long double kl = std::numeric_limits<long double>::quiet_NaN();
+
+ float a = std::tr1::comp_ellint_1(kf);
+ float b = std::tr1::comp_ellint_1f(kf);
+ double c = std::tr1::comp_ellint_1(kd);
+ long double d = std::tr1::comp_ellint_1(kl);
+ long double e = std::tr1::comp_ellint_1l(kl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/04_comp_ellint_1/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/04_comp_ellint_1/check_value.cc
new file mode 100644
index 00000000000..7fda191f00d
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/04_comp_ellint_1/check_value.cc
@@ -0,0 +1,97 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// comp_ellint_1
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data.
+testcase_comp_ellint_1<double> data001[] = {
+ { 2.2805491384227703, -0.90000000000000002 },
+ { 1.9953027776647296, -0.80000000000000004 },
+ { 1.8456939983747236, -0.69999999999999996 },
+ { 1.7507538029157526, -0.59999999999999998 },
+ { 1.6857503548125963, -0.50000000000000000 },
+ { 1.6399998658645112, -0.40000000000000002 },
+ { 1.6080486199305126, -0.30000000000000004 },
+ { 1.5868678474541664, -0.19999999999999996 },
+ { 1.5747455615173562, -0.099999999999999978 },
+ { 1.5707963267948966, 0.0000000000000000 },
+ { 1.5747455615173562, 0.10000000000000009 },
+ { 1.5868678474541664, 0.19999999999999996 },
+ { 1.6080486199305126, 0.30000000000000004 },
+ { 1.6399998658645112, 0.39999999999999991 },
+ { 1.6857503548125963, 0.50000000000000000 },
+ { 1.7507538029157526, 0.60000000000000009 },
+ { 1.8456939983747236, 0.69999999999999996 },
+ { 1.9953027776647296, 0.80000000000000004 },
+ { 2.2805491384227699, 0.89999999999999991 },
+};
+
+// Test function.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_comp_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_1(Tp(data001[i].k));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/04_comp_ellint_1/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/04_comp_ellint_1/compile.cc
new file mode 100644
index 00000000000..b72f5b64f83
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/04_comp_ellint_1/compile.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.4 comp_ellint_1
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+
+ float kf = 0.5F;
+ double kd = 0.5;
+ long double kl = 0.5L;
+
+ std::tr1::comp_ellint_1(kf);
+ std::tr1::comp_ellint_1f(kf);
+ std::tr1::comp_ellint_1(kd);
+ std::tr1::comp_ellint_1(kl);
+ std::tr1::comp_ellint_1l(kl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/04_comp_ellint_1/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/04_comp_ellint_1/compile_2.cc
new file mode 100644
index 00000000000..ec52fcb019e
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/04_comp_ellint_1/compile_2.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.4 comp_ellint_1
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+
+ float kf = 0.5F;
+ double kd = 0.5;
+ long double kl = 0.5L;
+
+ comp_ellint_1(kf);
+ comp_ellint_1f(kf);
+ comp_ellint_1(kd);
+ comp_ellint_1(kl);
+ comp_ellint_1l(kl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/05_comp_ellint_2/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/05_comp_ellint_2/check_nan.cc
new file mode 100644
index 00000000000..b30c77a7555
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/05_comp_ellint_2/check_nan.cc
@@ -0,0 +1,57 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.5 comp_ellint_2
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+
+ float kf = std::numeric_limits<float>::quiet_NaN();
+ double kd = std::numeric_limits<double>::quiet_NaN();
+ long double kl = std::numeric_limits<long double>::quiet_NaN();
+
+ float a = std::tr1::comp_ellint_2(kf);
+ float b = std::tr1::comp_ellint_2f(kf);
+ double c = std::tr1::comp_ellint_2(kd);
+ long double d = std::tr1::comp_ellint_2(kl);
+ long double e = std::tr1::comp_ellint_2l(kl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/05_comp_ellint_2/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/05_comp_ellint_2/check_value.cc
new file mode 100644
index 00000000000..9fd6a06b665
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/05_comp_ellint_2/check_value.cc
@@ -0,0 +1,97 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// comp_ellint_2
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data.
+testcase_comp_ellint_2<double> data001[] = {
+ { 1.1716970527816140, -0.90000000000000002 },
+ { 1.2763499431699066, -0.80000000000000004 },
+ { 1.3556611355719557, -0.69999999999999996 },
+ { 1.4180833944487243, -0.59999999999999998 },
+ { 1.4674622093394274, -0.50000000000000000 },
+ { 1.5059416123600402, -0.40000000000000002 },
+ { 1.5348334649232489, -0.30000000000000004 },
+ { 1.5549685462425296, -0.19999999999999996 },
+ { 1.5668619420216685, -0.099999999999999978 },
+ { 1.5707963267948966, 0.0000000000000000 },
+ { 1.5668619420216685, 0.10000000000000009 },
+ { 1.5549685462425296, 0.19999999999999996 },
+ { 1.5348334649232489, 0.30000000000000004 },
+ { 1.5059416123600404, 0.39999999999999991 },
+ { 1.4674622093394274, 0.50000000000000000 },
+ { 1.4180833944487241, 0.60000000000000009 },
+ { 1.3556611355719557, 0.69999999999999996 },
+ { 1.2763499431699066, 0.80000000000000004 },
+ { 1.1716970527816142, 0.89999999999999991 },
+};
+
+// Test function.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_comp_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_2(Tp(data001[i].k));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/05_comp_ellint_2/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/05_comp_ellint_2/compile.cc
new file mode 100644
index 00000000000..5ac3d2bf3c9
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/05_comp_ellint_2/compile.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.5 comp_ellint_2
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+
+ float kf = 0.5F;
+ double kd = 0.5;
+ long double kl = 0.5L;
+
+ std::tr1::comp_ellint_2(kf);
+ std::tr1::comp_ellint_2f(kf);
+ std::tr1::comp_ellint_2(kd);
+ std::tr1::comp_ellint_2(kl);
+ std::tr1::comp_ellint_2l(kl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/05_comp_ellint_2/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/05_comp_ellint_2/compile_2.cc
new file mode 100644
index 00000000000..7f2c0b8d03e
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/05_comp_ellint_2/compile_2.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.4 comp_ellint_2
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+
+ float kf = 0.5F;
+ double kd = 0.5;
+ long double kl = 0.5L;
+
+ comp_ellint_2(kf);
+ comp_ellint_2f(kf);
+ comp_ellint_2(kd);
+ comp_ellint_2(kl);
+ comp_ellint_2l(kl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/06_comp_ellint_3/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/06_comp_ellint_3/check_nan.cc
new file mode 100644
index 00000000000..b928eab7642
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/06_comp_ellint_3/check_nan.cc
@@ -0,0 +1,87 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.6 comp_ellint_3
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+ float kf = std::numeric_limits<float>::quiet_NaN();
+ double kd = std::numeric_limits<double>::quiet_NaN();
+ long double kl = std::numeric_limits<long double>::quiet_NaN();
+
+ float nuf = 0.0F;
+ double nud = 0.0;
+ long double nul = 0.0L;
+
+ float a = std::tr1::comp_ellint_3(kf, nuf);
+ float b = std::tr1::comp_ellint_3f(kf, nuf);
+ double c = std::tr1::comp_ellint_3(kd, nud);
+ long double d = std::tr1::comp_ellint_3(kl, nul);
+ long double e = std::tr1::comp_ellint_3l(kl, nul);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+void
+test02()
+{
+ float kf = 1.0F;
+ double kd = 1.0;
+ long double kl = 1.0L;
+
+ float nuf = std::numeric_limits<float>::quiet_NaN();
+ double nud = std::numeric_limits<double>::quiet_NaN();
+ long double nul = std::numeric_limits<long double>::quiet_NaN();
+
+ float a = std::tr1::comp_ellint_3(kf, nuf);
+ float b = std::tr1::comp_ellint_3f(kf, nuf);
+ double c = std::tr1::comp_ellint_3(kd, nud);
+ long double d = std::tr1::comp_ellint_3(kl, nul);
+ long double e = std::tr1::comp_ellint_3l(kl, nul);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ test02();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/06_comp_ellint_3/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/06_comp_ellint_3/check_value.cc
new file mode 100644
index 00000000000..4d4e78be662
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/06_comp_ellint_3/check_value.cc
@@ -0,0 +1,844 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// comp_ellint_3
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for k=-0.90000000000000002.
+testcase_comp_ellint_3<double> data001[] = {
+ { 2.2805491384227703, -0.90000000000000002, 0.0000000000000000 },
+ { 2.1537868513875287, -0.90000000000000002, 0.10000000000000001 },
+ { 2.0443194576468890, -0.90000000000000002, 0.20000000000000001 },
+ { 1.9486280260314426, -0.90000000000000002, 0.29999999999999999 },
+ { 1.8641114227238349, -0.90000000000000002, 0.40000000000000002 },
+ { 1.7888013241937861, -0.90000000000000002, 0.50000000000000000 },
+ { 1.7211781128919523, -0.90000000000000002, 0.59999999999999998 },
+ { 1.6600480747670938, -0.90000000000000002, 0.69999999999999996 },
+ { 1.6044591960982204, -0.90000000000000002, 0.80000000000000004 },
+ { 1.5536420236310946, -0.90000000000000002, 0.90000000000000002 },
+};
+
+// Test function for k=-0.90000000000000002.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data001[i].k), Tp(data001[i].nu));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.80000000000000004.
+testcase_comp_ellint_3<double> data002[] = {
+ { 1.9953027776647296, -0.80000000000000004, 0.0000000000000000 },
+ { 1.8910755418379521, -0.80000000000000004, 0.10000000000000001 },
+ { 1.8007226661734588, -0.80000000000000004, 0.20000000000000001 },
+ { 1.7214611048717301, -0.80000000000000004, 0.29999999999999999 },
+ { 1.6512267838651289, -0.80000000000000004, 0.40000000000000002 },
+ { 1.5884528947755532, -0.80000000000000004, 0.50000000000000000 },
+ { 1.5319262547427865, -0.80000000000000004, 0.59999999999999998 },
+ { 1.4806912324625332, -0.80000000000000004, 0.69999999999999996 },
+ { 1.4339837018309474, -0.80000000000000004, 0.80000000000000004 },
+ { 1.3911845406776222, -0.80000000000000004, 0.90000000000000002 },
+};
+
+// Test function for k=-0.80000000000000004.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data002[i].k), Tp(data002[i].nu));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.69999999999999996.
+testcase_comp_ellint_3<double> data003[] = {
+ { 1.8456939983747236, -0.69999999999999996, 0.0000000000000000 },
+ { 1.7528050171757608, -0.69999999999999996, 0.10000000000000001 },
+ { 1.6721098780092147, -0.69999999999999996, 0.20000000000000001 },
+ { 1.6011813647733213, -0.69999999999999996, 0.29999999999999999 },
+ { 1.5382162002954762, -0.69999999999999996, 0.40000000000000002 },
+ { 1.4818433192178544, -0.69999999999999996, 0.50000000000000000 },
+ { 1.4309994736080540, -0.69999999999999996, 0.59999999999999998 },
+ { 1.3848459188329196, -0.69999999999999996, 0.69999999999999996 },
+ { 1.3427110650397533, -0.69999999999999996, 0.80000000000000004 },
+ { 1.3040500499695911, -0.69999999999999996, 0.90000000000000002 },
+};
+
+// Test function for k=-0.69999999999999996.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data003[i].k), Tp(data003[i].nu));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.59999999999999998.
+testcase_comp_ellint_3<double> data004[] = {
+ { 1.7507538029157526, -0.59999999999999998, 0.0000000000000000 },
+ { 1.6648615773343014, -0.59999999999999998, 0.10000000000000001 },
+ { 1.5901418016279374, -0.59999999999999998, 0.20000000000000001 },
+ { 1.5243814243493585, -0.59999999999999998, 0.29999999999999999 },
+ { 1.4659345278069984, -0.59999999999999998, 0.40000000000000002 },
+ { 1.4135484285693078, -0.59999999999999998, 0.50000000000000000 },
+ { 1.3662507535812816, -0.59999999999999998, 0.59999999999999998 },
+ { 1.3232737468822811, -0.59999999999999998, 0.69999999999999996 },
+ { 1.2840021261752192, -0.59999999999999998, 0.80000000000000004 },
+ { 1.2479362973851875, -0.59999999999999998, 0.90000000000000002 },
+};
+
+// Test function for k=-0.59999999999999998.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data004[i].k), Tp(data004[i].nu));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.50000000000000000.
+testcase_comp_ellint_3<double> data005[] = {
+ { 1.6857503548125963, -0.50000000000000000, 0.0000000000000000 },
+ { 1.6045524936084892, -0.50000000000000000, 0.10000000000000001 },
+ { 1.5338490483665983, -0.50000000000000000, 0.20000000000000001 },
+ { 1.4715681939859637, -0.50000000000000000, 0.29999999999999999 },
+ { 1.4161679518465340, -0.50000000000000000, 0.40000000000000002 },
+ { 1.3664739530045971, -0.50000000000000000, 0.50000000000000000 },
+ { 1.3215740290190876, -0.50000000000000000, 0.59999999999999998 },
+ { 1.2807475181182502, -0.50000000000000000, 0.69999999999999996 },
+ { 1.2434165408189539, -0.50000000000000000, 0.80000000000000004 },
+ { 1.2091116095504744, -0.50000000000000000, 0.90000000000000002 },
+};
+
+// Test function for k=-0.50000000000000000.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data005[i].k), Tp(data005[i].nu));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.40000000000000002.
+testcase_comp_ellint_3<double> data006[] = {
+ { 1.6399998658645112, -0.40000000000000002, 0.0000000000000000 },
+ { 1.5620566886683604, -0.40000000000000002, 0.10000000000000001 },
+ { 1.4941414344266770, -0.40000000000000002, 0.20000000000000001 },
+ { 1.4342789859950078, -0.40000000000000002, 0.29999999999999999 },
+ { 1.3809986210732901, -0.40000000000000002, 0.40000000000000002 },
+ { 1.3331797176377398, -0.40000000000000002, 0.50000000000000000 },
+ { 1.2899514672527024, -0.40000000000000002, 0.59999999999999998 },
+ { 1.2506255923253344, -0.40000000000000002, 0.69999999999999996 },
+ { 1.2146499565727209, -0.40000000000000002, 0.80000000000000004 },
+ { 1.1815758115929846, -0.40000000000000002, 0.90000000000000002 },
+};
+
+// Test function for k=-0.40000000000000002.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data006[i].k), Tp(data006[i].nu));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.30000000000000004.
+testcase_comp_ellint_3<double> data007[] = {
+ { 1.6080486199305126, -0.30000000000000004, 0.0000000000000000 },
+ { 1.5323534693557526, -0.30000000000000004, 0.10000000000000001 },
+ { 1.4663658145259875, -0.30000000000000004, 0.20000000000000001 },
+ { 1.4081767433479089, -0.30000000000000004, 0.29999999999999999 },
+ { 1.3563643538969761, -0.30000000000000004, 0.40000000000000002 },
+ { 1.3098448759814960, -0.30000000000000004, 0.50000000000000000 },
+ { 1.2677758800420666, -0.30000000000000004, 0.59999999999999998 },
+ { 1.2294913236274980, -0.30000000000000004, 0.69999999999999996 },
+ { 1.1944567571590046, -0.30000000000000004, 0.80000000000000004 },
+ { 1.1622376896064912, -0.30000000000000004, 0.90000000000000002 },
+};
+
+// Test function for k=-0.30000000000000004.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data007[i].k), Tp(data007[i].nu));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.19999999999999996.
+testcase_comp_ellint_3<double> data008[] = {
+ { 1.5868678474541664, -0.19999999999999996, 0.0000000000000000 },
+ { 1.5126513474261092, -0.19999999999999996, 0.10000000000000001 },
+ { 1.4479323932249568, -0.19999999999999996, 0.20000000000000001 },
+ { 1.3908453514752481, -0.19999999999999996, 0.29999999999999999 },
+ { 1.3400002519661010, -0.19999999999999996, 0.40000000000000002 },
+ { 1.2943374404397376, -0.19999999999999996, 0.50000000000000000 },
+ { 1.2530330675914561, -0.19999999999999996, 0.59999999999999998 },
+ { 1.2154356555075867, -0.19999999999999996, 0.69999999999999996 },
+ { 1.1810223448909913, -0.19999999999999996, 0.80000000000000004 },
+ { 1.1493679916141863, -0.19999999999999996, 0.90000000000000002 },
+};
+
+// Test function for k=-0.19999999999999996.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data008[i].k), Tp(data008[i].nu));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.099999999999999978.
+testcase_comp_ellint_3<double> data009[] = {
+ { 1.5747455615173562, -0.099999999999999978, 0.0000000000000000 },
+ { 1.5013711111199950, -0.099999999999999978, 0.10000000000000001 },
+ { 1.4373749386463430, -0.099999999999999978, 0.20000000000000001 },
+ { 1.3809159606704959, -0.099999999999999978, 0.29999999999999999 },
+ { 1.3306223265207477, -0.099999999999999978, 0.40000000000000002 },
+ { 1.2854480708580160, -0.099999999999999978, 0.50000000000000000 },
+ { 1.2445798942989255, -0.099999999999999978, 0.59999999999999998 },
+ { 1.2073745911083187, -0.099999999999999978, 0.69999999999999996 },
+ { 1.1733158866987732, -0.099999999999999978, 0.80000000000000004 },
+ { 1.1419839485283374, -0.099999999999999978, 0.90000000000000002 },
+};
+
+// Test function for k=-0.099999999999999978.
+template <typename Tp>
+void test009()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data009)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data009[i].k), Tp(data009[i].nu));
+ const Tp f0 = data009[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.0000000000000000.
+testcase_comp_ellint_3<double> data010[] = {
+ { 1.5707963267948966, 0.0000000000000000, 0.0000000000000000 },
+ { 1.4976955329233277, 0.0000000000000000, 0.10000000000000001 },
+ { 1.4339343023863691, 0.0000000000000000, 0.20000000000000001 },
+ { 1.3776795151134889, 0.0000000000000000, 0.29999999999999999 },
+ { 1.3275651989026322, 0.0000000000000000, 0.40000000000000002 },
+ { 1.2825498301618641, 0.0000000000000000, 0.50000000000000000 },
+ { 1.2418235332245127, 0.0000000000000000, 0.59999999999999998 },
+ { 1.2047457872617382, 0.0000000000000000, 0.69999999999999996 },
+ { 1.1708024551734544, 0.0000000000000000, 0.80000000000000004 },
+ { 1.1395754288497419, 0.0000000000000000, 0.90000000000000002 },
+};
+
+// Test function for k=0.0000000000000000.
+template <typename Tp>
+void test010()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data010)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data010[i].k), Tp(data010[i].nu));
+ const Tp f0 = data010[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.10000000000000009.
+testcase_comp_ellint_3<double> data011[] = {
+ { 1.5747455615173562, 0.10000000000000009, 0.0000000000000000 },
+ { 1.5013711111199950, 0.10000000000000009, 0.10000000000000001 },
+ { 1.4373749386463430, 0.10000000000000009, 0.20000000000000001 },
+ { 1.3809159606704959, 0.10000000000000009, 0.29999999999999999 },
+ { 1.3306223265207477, 0.10000000000000009, 0.40000000000000002 },
+ { 1.2854480708580160, 0.10000000000000009, 0.50000000000000000 },
+ { 1.2445798942989255, 0.10000000000000009, 0.59999999999999998 },
+ { 1.2073745911083187, 0.10000000000000009, 0.69999999999999996 },
+ { 1.1733158866987732, 0.10000000000000009, 0.80000000000000004 },
+ { 1.1419839485283374, 0.10000000000000009, 0.90000000000000002 },
+};
+
+// Test function for k=0.10000000000000009.
+template <typename Tp>
+void test011()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data011)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data011[i].k), Tp(data011[i].nu));
+ const Tp f0 = data011[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.19999999999999996.
+testcase_comp_ellint_3<double> data012[] = {
+ { 1.5868678474541664, 0.19999999999999996, 0.0000000000000000 },
+ { 1.5126513474261092, 0.19999999999999996, 0.10000000000000001 },
+ { 1.4479323932249568, 0.19999999999999996, 0.20000000000000001 },
+ { 1.3908453514752481, 0.19999999999999996, 0.29999999999999999 },
+ { 1.3400002519661010, 0.19999999999999996, 0.40000000000000002 },
+ { 1.2943374404397376, 0.19999999999999996, 0.50000000000000000 },
+ { 1.2530330675914561, 0.19999999999999996, 0.59999999999999998 },
+ { 1.2154356555075867, 0.19999999999999996, 0.69999999999999996 },
+ { 1.1810223448909913, 0.19999999999999996, 0.80000000000000004 },
+ { 1.1493679916141863, 0.19999999999999996, 0.90000000000000002 },
+};
+
+// Test function for k=0.19999999999999996.
+template <typename Tp>
+void test012()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data012)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data012[i].k), Tp(data012[i].nu));
+ const Tp f0 = data012[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.30000000000000004.
+testcase_comp_ellint_3<double> data013[] = {
+ { 1.6080486199305126, 0.30000000000000004, 0.0000000000000000 },
+ { 1.5323534693557526, 0.30000000000000004, 0.10000000000000001 },
+ { 1.4663658145259875, 0.30000000000000004, 0.20000000000000001 },
+ { 1.4081767433479089, 0.30000000000000004, 0.29999999999999999 },
+ { 1.3563643538969761, 0.30000000000000004, 0.40000000000000002 },
+ { 1.3098448759814960, 0.30000000000000004, 0.50000000000000000 },
+ { 1.2677758800420666, 0.30000000000000004, 0.59999999999999998 },
+ { 1.2294913236274980, 0.30000000000000004, 0.69999999999999996 },
+ { 1.1944567571590046, 0.30000000000000004, 0.80000000000000004 },
+ { 1.1622376896064912, 0.30000000000000004, 0.90000000000000002 },
+};
+
+// Test function for k=0.30000000000000004.
+template <typename Tp>
+void test013()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data013)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data013[i].k), Tp(data013[i].nu));
+ const Tp f0 = data013[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.39999999999999991.
+testcase_comp_ellint_3<double> data014[] = {
+ { 1.6399998658645112, 0.39999999999999991, 0.0000000000000000 },
+ { 1.5620566886683604, 0.39999999999999991, 0.10000000000000001 },
+ { 1.4941414344266770, 0.39999999999999991, 0.20000000000000001 },
+ { 1.4342789859950078, 0.39999999999999991, 0.29999999999999999 },
+ { 1.3809986210732901, 0.39999999999999991, 0.40000000000000002 },
+ { 1.3331797176377398, 0.39999999999999991, 0.50000000000000000 },
+ { 1.2899514672527024, 0.39999999999999991, 0.59999999999999998 },
+ { 1.2506255923253344, 0.39999999999999991, 0.69999999999999996 },
+ { 1.2146499565727209, 0.39999999999999991, 0.80000000000000004 },
+ { 1.1815758115929846, 0.39999999999999991, 0.90000000000000002 },
+};
+
+// Test function for k=0.39999999999999991.
+template <typename Tp>
+void test014()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data014)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data014[i].k), Tp(data014[i].nu));
+ const Tp f0 = data014[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.50000000000000000.
+testcase_comp_ellint_3<double> data015[] = {
+ { 1.6857503548125963, 0.50000000000000000, 0.0000000000000000 },
+ { 1.6045524936084892, 0.50000000000000000, 0.10000000000000001 },
+ { 1.5338490483665983, 0.50000000000000000, 0.20000000000000001 },
+ { 1.4715681939859637, 0.50000000000000000, 0.29999999999999999 },
+ { 1.4161679518465340, 0.50000000000000000, 0.40000000000000002 },
+ { 1.3664739530045971, 0.50000000000000000, 0.50000000000000000 },
+ { 1.3215740290190876, 0.50000000000000000, 0.59999999999999998 },
+ { 1.2807475181182502, 0.50000000000000000, 0.69999999999999996 },
+ { 1.2434165408189539, 0.50000000000000000, 0.80000000000000004 },
+ { 1.2091116095504744, 0.50000000000000000, 0.90000000000000002 },
+};
+
+// Test function for k=0.50000000000000000.
+template <typename Tp>
+void test015()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data015)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data015[i].k), Tp(data015[i].nu));
+ const Tp f0 = data015[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.60000000000000009.
+testcase_comp_ellint_3<double> data016[] = {
+ { 1.7507538029157526, 0.60000000000000009, 0.0000000000000000 },
+ { 1.6648615773343014, 0.60000000000000009, 0.10000000000000001 },
+ { 1.5901418016279374, 0.60000000000000009, 0.20000000000000001 },
+ { 1.5243814243493585, 0.60000000000000009, 0.29999999999999999 },
+ { 1.4659345278069984, 0.60000000000000009, 0.40000000000000002 },
+ { 1.4135484285693078, 0.60000000000000009, 0.50000000000000000 },
+ { 1.3662507535812816, 0.60000000000000009, 0.59999999999999998 },
+ { 1.3232737468822811, 0.60000000000000009, 0.69999999999999996 },
+ { 1.2840021261752192, 0.60000000000000009, 0.80000000000000004 },
+ { 1.2479362973851875, 0.60000000000000009, 0.90000000000000002 },
+};
+
+// Test function for k=0.60000000000000009.
+template <typename Tp>
+void test016()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data016)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data016[i].k), Tp(data016[i].nu));
+ const Tp f0 = data016[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.69999999999999996.
+testcase_comp_ellint_3<double> data017[] = {
+ { 1.8456939983747236, 0.69999999999999996, 0.0000000000000000 },
+ { 1.7528050171757608, 0.69999999999999996, 0.10000000000000001 },
+ { 1.6721098780092147, 0.69999999999999996, 0.20000000000000001 },
+ { 1.6011813647733213, 0.69999999999999996, 0.29999999999999999 },
+ { 1.5382162002954762, 0.69999999999999996, 0.40000000000000002 },
+ { 1.4818433192178544, 0.69999999999999996, 0.50000000000000000 },
+ { 1.4309994736080540, 0.69999999999999996, 0.59999999999999998 },
+ { 1.3848459188329196, 0.69999999999999996, 0.69999999999999996 },
+ { 1.3427110650397533, 0.69999999999999996, 0.80000000000000004 },
+ { 1.3040500499695911, 0.69999999999999996, 0.90000000000000002 },
+};
+
+// Test function for k=0.69999999999999996.
+template <typename Tp>
+void test017()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data017)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data017[i].k), Tp(data017[i].nu));
+ const Tp f0 = data017[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.80000000000000004.
+testcase_comp_ellint_3<double> data018[] = {
+ { 1.9953027776647296, 0.80000000000000004, 0.0000000000000000 },
+ { 1.8910755418379521, 0.80000000000000004, 0.10000000000000001 },
+ { 1.8007226661734588, 0.80000000000000004, 0.20000000000000001 },
+ { 1.7214611048717301, 0.80000000000000004, 0.29999999999999999 },
+ { 1.6512267838651289, 0.80000000000000004, 0.40000000000000002 },
+ { 1.5884528947755532, 0.80000000000000004, 0.50000000000000000 },
+ { 1.5319262547427865, 0.80000000000000004, 0.59999999999999998 },
+ { 1.4806912324625332, 0.80000000000000004, 0.69999999999999996 },
+ { 1.4339837018309474, 0.80000000000000004, 0.80000000000000004 },
+ { 1.3911845406776222, 0.80000000000000004, 0.90000000000000002 },
+};
+
+// Test function for k=0.80000000000000004.
+template <typename Tp>
+void test018()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data018)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data018[i].k), Tp(data018[i].nu));
+ const Tp f0 = data018[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.89999999999999991.
+testcase_comp_ellint_3<double> data019[] = {
+ { 2.2805491384227699, 0.89999999999999991, 0.0000000000000000 },
+ { 2.1537868513875282, 0.89999999999999991, 0.10000000000000001 },
+ { 2.0443194576468890, 0.89999999999999991, 0.20000000000000001 },
+ { 1.9486280260314424, 0.89999999999999991, 0.29999999999999999 },
+ { 1.8641114227238347, 0.89999999999999991, 0.40000000000000002 },
+ { 1.7888013241937859, 0.89999999999999991, 0.50000000000000000 },
+ { 1.7211781128919521, 0.89999999999999991, 0.59999999999999998 },
+ { 1.6600480747670936, 0.89999999999999991, 0.69999999999999996 },
+ { 1.6044591960982200, 0.89999999999999991, 0.80000000000000004 },
+ { 1.5536420236310944, 0.89999999999999991, 0.90000000000000002 },
+};
+
+// Test function for k=0.89999999999999991.
+template <typename Tp>
+void test019()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data019)
+ / sizeof(testcase_comp_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::comp_ellint_3(Tp(data019[i].k), Tp(data019[i].nu));
+ const Tp f0 = data019[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ test009<double>();
+ test010<double>();
+ test011<double>();
+ test012<double>();
+ test013<double>();
+ test014<double>();
+ test015<double>();
+ test016<double>();
+ test017<double>();
+ test018<double>();
+ test019<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/06_comp_ellint_3/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/06_comp_ellint_3/compile.cc
new file mode 100644
index 00000000000..a4bbcb88b76
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/06_comp_ellint_3/compile.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.6 comp_ellint_3
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+
+ float kf = 0.5F, nuf = 0.5F;
+ double kd = 0.5, nud = 0.5;
+ long double kl = 0.5L, nul = 0.5L;
+
+ std::tr1::comp_ellint_3(kf, nuf);
+ std::tr1::comp_ellint_3f(kf, nuf);
+ std::tr1::comp_ellint_3(kd, nud);
+ std::tr1::comp_ellint_3(kl, nul);
+ std::tr1::comp_ellint_3l(kl, nul);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/06_comp_ellint_3/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/06_comp_ellint_3/compile_2.cc
new file mode 100644
index 00000000000..56319e537c3
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/06_comp_ellint_3/compile_2.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.6 comp_ellint_3
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+
+ float kf = 0.5F, nuf = 0.5F;
+ double kd = 0.5, nud = 0.5;
+ long double kl = 0.5L, nul = 0.5L;
+
+ comp_ellint_3(kf, nuf);
+ comp_ellint_3f(kf, nuf);
+ comp_ellint_3(kd, nud);
+ comp_ellint_3(kl, nul);
+ comp_ellint_3l(kl, nul);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/07_conf_hyperg/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/07_conf_hyperg/check_nan.cc
new file mode 100644
index 00000000000..1f2bb40bd0c
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/07_conf_hyperg/check_nan.cc
@@ -0,0 +1,126 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.7 conf_hyperg
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+ float af = std::numeric_limits<float>::quiet_NaN();
+ double ad = std::numeric_limits<double>::quiet_NaN();
+ long double al = std::numeric_limits<long double>::quiet_NaN();
+
+ float cf = 3.0F;
+ double cd = 3.0;
+ long double cl = 3.0L;
+
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+
+ float a = std::tr1::conf_hyperg(af, cf, xf);
+ float b = std::tr1::conf_hypergf(af, cf, xf);
+ double c = std::tr1::conf_hyperg(ad, cd, xd);
+ long double d = std::tr1::conf_hyperg(al, cl, xl);
+ long double e = std::tr1::conf_hypergl(al, cl, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+void
+test02()
+{
+ float af = 2.0F;
+ double ad = 2.0;
+ long double al = 2.0L;
+
+ float cf = std::numeric_limits<float>::quiet_NaN();
+ double cd = std::numeric_limits<double>::quiet_NaN();
+ long double cl = std::numeric_limits<long double>::quiet_NaN();
+
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+
+ float a = std::tr1::conf_hyperg(af, cf, xf);
+ float b = std::tr1::conf_hypergf(af, cf, xf);
+ double c = std::tr1::conf_hyperg(ad, cd, xd);
+ long double d = std::tr1::conf_hyperg(al, cl, xl);
+ long double e = std::tr1::conf_hypergl(al, cl, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+void
+test03()
+{
+ float af = 2.0F;
+ double ad = 2.0;
+ long double al = 2.0L;
+
+ float cf = 3.0F;
+ double cd = 3.0;
+ long double cl = 3.0L;
+
+ float xf = std::numeric_limits<float>::quiet_NaN();
+ double xd = std::numeric_limits<double>::quiet_NaN();
+ long double xl = std::numeric_limits<long double>::quiet_NaN();
+
+ float a = std::tr1::conf_hyperg(af, cf, xf);
+ float b = std::tr1::conf_hypergf(af, cf, xf);
+ double c = std::tr1::conf_hyperg(ad, cd, xd);
+ long double d = std::tr1::conf_hyperg(al, cl, xl);
+ long double e = std::tr1::conf_hypergl(al, cl, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ test02();
+ test03();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/07_conf_hyperg/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/07_conf_hyperg/check_value.cc
new file mode 100644
index 00000000000..a751448459c
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/07_conf_hyperg/check_value.cc
@@ -0,0 +1,5294 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// conf_hyperg
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for a=0.0000000000000000, c=1.0000000000000000.
+testcase_conf_hyperg<double> data001[] = {
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ -10.000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ -9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ -8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ -7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ -6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ -5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ -4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ -3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ -2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.0000000000000000, c=1.0000000000000000.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data001[i].a), Tp(data001[i].c),
+ Tp(data001[i].x));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, c=2.0000000000000000.
+testcase_conf_hyperg<double> data002[] = {
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ -10.000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ -9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ -8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ -7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ -6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ -5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ -4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ -3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ -2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data002[i].a), Tp(data002[i].c),
+ Tp(data002[i].x));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, c=3.0000000000000000.
+testcase_conf_hyperg<double> data003[] = {
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ -10.000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ -9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ -8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ -7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ -6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ -5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ -4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ -3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ -2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ 1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ 2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ 3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ 4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ 5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ 6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ 7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ 8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ 9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 3.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.0000000000000000, c=3.0000000000000000.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data003[i].a), Tp(data003[i].c),
+ Tp(data003[i].x));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, c=4.0000000000000000.
+testcase_conf_hyperg<double> data004[] = {
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ -10.000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ -9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ -8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ -7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ -6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ -5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ -4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ -3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ -2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ 1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ 2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ 3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ 4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ 5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ 6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ 7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ 8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ 9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 4.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data004[i].a), Tp(data004[i].c),
+ Tp(data004[i].x));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, c=5.0000000000000000.
+testcase_conf_hyperg<double> data005[] = {
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ -10.000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ -9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ -8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ -7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ -6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ -5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ -4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ -3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ -2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.0000000000000000, c=5.0000000000000000.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data005[i].a), Tp(data005[i].c),
+ Tp(data005[i].x));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, c=6.0000000000000000.
+testcase_conf_hyperg<double> data006[] = {
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ -10.000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ -9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ -8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ -7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ -6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ -5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ -4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ -3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ -2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ 1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ 2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ 3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ 4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ 5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ 6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ 7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ 8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ 9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 6.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data006[i].a), Tp(data006[i].c),
+ Tp(data006[i].x));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, c=7.0000000000000000.
+testcase_conf_hyperg<double> data007[] = {
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ -10.000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ -9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ -8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ -7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ -6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ -5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ -4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ -3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ -2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ 1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ 2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ 3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ 4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ 5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ 6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ 7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ 8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ 9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 7.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.0000000000000000, c=7.0000000000000000.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data007[i].a), Tp(data007[i].c),
+ Tp(data007[i].x));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, c=8.0000000000000000.
+testcase_conf_hyperg<double> data008[] = {
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ -10.000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ -9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ -8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ -7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ -6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ -5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ -4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ -3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ -2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ 1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ 2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ 3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ 4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ 5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ 6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ 7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ 8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ 9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 8.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data008[i].a), Tp(data008[i].c),
+ Tp(data008[i].x));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, c=9.0000000000000000.
+testcase_conf_hyperg<double> data009[] = {
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ -10.000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ -9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ -8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ -7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ -6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ -5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ -4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ -3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ -2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ 1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ 2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ 3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ 4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ 5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ 6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ 7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ 8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ 9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 9.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.0000000000000000, c=9.0000000000000000.
+template <typename Tp>
+void test009()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data009)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data009[i].a), Tp(data009[i].c),
+ Tp(data009[i].x));
+ const Tp f0 = data009[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, c=10.000000000000000.
+testcase_conf_hyperg<double> data010[] = {
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ -10.000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ -9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ -8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ -7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ -6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ -5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ -4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ -3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ -2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 1.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 3.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 5.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 7.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 9.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test010()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data010)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data010[i].a), Tp(data010[i].c),
+ Tp(data010[i].x));
+ const Tp f0 = data010[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, c=1.0000000000000000.
+testcase_conf_hyperg<double> data011[] = {
+ { 0.18354081260932853, 0.50000000000000000, 1.0000000000000000,
+ -10.000000000000000 },
+ { 0.19419827762834704, 0.50000000000000000, 1.0000000000000000,
+ -9.0000000000000000 },
+ { 0.20700192122398287, 0.50000000000000000, 1.0000000000000000,
+ -8.0000000000000000 },
+ { 0.22280243801078498, 0.50000000000000000, 1.0000000000000000,
+ -7.0000000000000000 },
+ { 0.24300035416182644, 0.50000000000000000, 1.0000000000000000,
+ -6.0000000000000000 },
+ { 0.27004644161220326, 0.50000000000000000, 1.0000000000000000,
+ -5.0000000000000000 },
+ { 0.30850832255367100, 0.50000000000000000, 1.0000000000000000,
+ -4.0000000000000000 },
+ { 0.36743360905415834, 0.50000000000000000, 1.0000000000000000,
+ -3.0000000000000000 },
+ { 0.46575960759364043, 0.50000000000000000, 1.0000000000000000,
+ -2.0000000000000000 },
+ { 0.64503527044915010, 0.50000000000000000, 1.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 1.0000000000000000,
+ 0.0000000000000000 },
+ { 1.7533876543770910, 0.50000000000000000, 1.0000000000000000,
+ 1.0000000000000000 },
+ { 3.4415238691253336, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000 },
+ { 7.3801013214774045, 0.50000000000000000, 1.0000000000000000,
+ 3.0000000000000000 },
+ { 16.843983681258987, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000 },
+ { 40.078445504076413, 0.50000000000000000, 1.0000000000000000,
+ 5.0000000000000000 },
+ { 98.033339697812551, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000 },
+ { 244.33254130132133, 0.50000000000000000, 1.0000000000000000,
+ 7.0000000000000000 },
+ { 617.06403040562418, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000 },
+ { 1573.6049422133683, 0.50000000000000000, 1.0000000000000000,
+ 9.0000000000000000 },
+ { 4042.7554308904046, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.50000000000000000, c=1.0000000000000000.
+template <typename Tp>
+void test011()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data011)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data011[i].a), Tp(data011[i].c),
+ Tp(data011[i].x));
+ const Tp f0 = data011[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-11));
+}
+
+// Test data for a=0.50000000000000000, c=2.0000000000000000.
+testcase_conf_hyperg<double> data012[] = {
+ { 0.34751307955387079, 0.50000000000000000, 2.0000000000000000,
+ -10.000000000000000 },
+ { 0.36515709992587503, 0.50000000000000000, 2.0000000000000000,
+ -9.0000000000000000 },
+ { 0.38575276072642301, 0.50000000000000000, 2.0000000000000000,
+ -8.0000000000000000 },
+ { 0.41020241461382889, 0.50000000000000000, 2.0000000000000000,
+ -7.0000000000000000 },
+ { 0.43982706745912625, 0.50000000000000000, 2.0000000000000000,
+ -6.0000000000000000 },
+ { 0.47663109114346930, 0.50000000000000000, 2.0000000000000000,
+ -5.0000000000000000 },
+ { 0.52377761180260862, 0.50000000000000000, 2.0000000000000000,
+ -4.0000000000000000 },
+ { 0.58647299647508400, 0.50000000000000000, 2.0000000000000000,
+ -3.0000000000000000 },
+ { 0.67367002294334866, 0.50000000000000000, 2.0000000000000000,
+ -2.0000000000000000 },
+ { 0.80145607363402172, 0.50000000000000000, 2.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 2.0000000000000000,
+ 0.0000000000000000 },
+ { 1.3281918274866849, 0.50000000000000000, 2.0000000000000000,
+ 1.0000000000000000 },
+ { 1.9052621465543667, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000 },
+ { 2.9805776178019903, 0.50000000000000000, 2.0000000000000000,
+ 3.0000000000000000 },
+ { 5.0906787293171654, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000 },
+ { 9.4185650450425964, 0.50000000000000000, 2.0000000000000000,
+ 5.0000000000000000 },
+ { 18.627776225141986, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000 },
+ { 38.823513069699615, 0.50000000000000000, 2.0000000000000000,
+ 7.0000000000000000 },
+ { 84.215287700426927, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000 },
+ { 188.31125697734240, 0.50000000000000000, 2.0000000000000000,
+ 9.0000000000000000 },
+ { 431.02590173952245, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.50000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test012()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data012)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data012[i].a), Tp(data012[i].c),
+ Tp(data012[i].x));
+ const Tp f0 = data012[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, c=3.0000000000000000.
+testcase_conf_hyperg<double> data013[] = {
+ { 0.44148780381255515, 0.50000000000000000, 3.0000000000000000,
+ -10.000000000000000 },
+ { 0.46154890030153722, 0.50000000000000000, 3.0000000000000000,
+ -9.0000000000000000 },
+ { 0.48454520771815751, 0.50000000000000000, 3.0000000000000000,
+ -8.0000000000000000 },
+ { 0.51124131917976301, 0.50000000000000000, 3.0000000000000000,
+ -7.0000000000000000 },
+ { 0.54269682032387934, 0.50000000000000000, 3.0000000000000000,
+ -6.0000000000000000 },
+ { 0.58041888164962119, 0.50000000000000000, 3.0000000000000000,
+ -5.0000000000000000 },
+ { 0.62661371932049892, 0.50000000000000000, 3.0000000000000000,
+ -4.0000000000000000 },
+ { 0.68461315644636744, 0.50000000000000000, 3.0000000000000000,
+ -3.0000000000000000 },
+ { 0.75961975369132639, 0.50000000000000000, 3.0000000000000000,
+ -2.0000000000000000 },
+ { 0.86004702726553350, 0.50000000000000000, 3.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 3.0000000000000000,
+ 0.0000000000000000 },
+ { 1.2039946674617061, 0.50000000000000000, 3.0000000000000000,
+ 1.0000000000000000 },
+ { 1.5161750470251780, 0.50000000000000000, 3.0000000000000000,
+ 2.0000000000000000 },
+ { 2.0187596221024697, 0.50000000000000000, 3.0000000000000000,
+ 3.0000000000000000 },
+ { 2.8698033217756134, 0.50000000000000000, 3.0000000000000000,
+ 4.0000000000000000 },
+ { 4.3821186043144440, 0.50000000000000000, 3.0000000000000000,
+ 5.0000000000000000 },
+ { 7.1913541951514128, 0.50000000000000000, 3.0000000000000000,
+ 6.0000000000000000 },
+ { 12.620107286909638, 0.50000000000000000, 3.0000000000000000,
+ 7.0000000000000000 },
+ { 23.478926483036350, 0.50000000000000000, 3.0000000000000000,
+ 8.0000000000000000 },
+ { 45.852981860749004, 0.50000000000000000, 3.0000000000000000,
+ 9.0000000000000000 },
+ { 93.137265099245667, 0.50000000000000000, 3.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.50000000000000000, c=3.0000000000000000.
+template <typename Tp>
+void test013()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data013)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data013[i].a), Tp(data013[i].c),
+ Tp(data013[i].x));
+ const Tp f0 = data013[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, c=4.0000000000000000.
+testcase_conf_hyperg<double> data014[] = {
+ { 0.50723143075298227, 0.50000000000000000, 4.0000000000000000,
+ -10.000000000000000 },
+ { 0.52815420026166782, 0.50000000000000000, 4.0000000000000000,
+ -9.0000000000000000 },
+ { 0.55181651516426766, 0.50000000000000000, 4.0000000000000000,
+ -8.0000000000000000 },
+ { 0.57884767287882366, 0.50000000000000000, 4.0000000000000000,
+ -7.0000000000000000 },
+ { 0.61008828324275399, 0.50000000000000000, 4.0000000000000000,
+ -6.0000000000000000 },
+ { 0.64668451853659259, 0.50000000000000000, 4.0000000000000000,
+ -5.0000000000000000 },
+ { 0.69023479867386495, 0.50000000000000000, 4.0000000000000000,
+ -4.0000000000000000 },
+ { 0.74302365975861406, 0.50000000000000000, 4.0000000000000000,
+ -3.0000000000000000 },
+ { 0.80840402753201868, 0.50000000000000000, 4.0000000000000000,
+ -2.0000000000000000 },
+ { 0.89143814400301236, 0.50000000000000000, 4.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 4.0000000000000000,
+ 0.0000000000000000 },
+ { 1.1467204168940972, 0.50000000000000000, 4.0000000000000000,
+ 1.0000000000000000 },
+ { 1.3525055369951857, 0.50000000000000000, 4.0000000000000000,
+ 2.0000000000000000 },
+ { 1.6530571499633475, 0.50000000000000000, 4.0000000000000000,
+ 3.0000000000000000 },
+ { 2.1112387416058045, 0.50000000000000000, 4.0000000000000000,
+ 4.0000000000000000 },
+ { 2.8410480336278194, 0.50000000000000000, 4.0000000000000000,
+ 5.0000000000000000 },
+ { 4.0550562221854669, 0.50000000000000000, 4.0000000000000000,
+ 6.0000000000000000 },
+ { 6.1601039044778592, 0.50000000000000000, 4.0000000000000000,
+ 7.0000000000000000 },
+ { 9.9538034144264458, 0.50000000000000000, 4.0000000000000000,
+ 8.0000000000000000 },
+ { 17.034704868473899, 0.50000000000000000, 4.0000000000000000,
+ 9.0000000000000000 },
+ { 30.671445325428369, 0.50000000000000000, 4.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.50000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test014()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data014)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data014[i].a), Tp(data014[i].c),
+ Tp(data014[i].x));
+ const Tp f0 = data014[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, c=5.0000000000000000.
+testcase_conf_hyperg<double> data015[] = {
+ { 0.55715239162383312, 0.50000000000000000, 5.0000000000000000,
+ -10.000000000000000 },
+ { 0.57823135269518977, 0.50000000000000000, 5.0000000000000000,
+ -9.0000000000000000 },
+ { 0.60181688556797253, 0.50000000000000000, 5.0000000000000000,
+ -8.0000000000000000 },
+ { 0.62842688147829928, 0.50000000000000000, 5.0000000000000000,
+ -7.0000000000000000 },
+ { 0.65873434489521876, 0.50000000000000000, 5.0000000000000000,
+ -6.0000000000000000 },
+ { 0.69362872731932568, 0.50000000000000000, 5.0000000000000000,
+ -5.0000000000000000 },
+ { 0.73430741618153195, 0.50000000000000000, 5.0000000000000000,
+ -4.0000000000000000 },
+ { 0.78241503593870543, 0.50000000000000000, 5.0000000000000000,
+ -3.0000000000000000 },
+ { 0.84026013345254857, 0.50000000000000000, 5.0000000000000000,
+ -2.0000000000000000 },
+ { 0.91115976433208690, 0.50000000000000000, 5.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 5.0000000000000000,
+ 0.0000000000000000 },
+ { 1.1141687602185972, 0.50000000000000000, 5.0000000000000000,
+ 1.0000000000000000 },
+ { 1.2651443108002267, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000 },
+ { 1.4712624889419719, 0.50000000000000000, 5.0000000000000000,
+ 3.0000000000000000 },
+ { 1.7626460645467978, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000 },
+ { 2.1901779328181084, 0.50000000000000000, 5.0000000000000000,
+ 5.0000000000000000 },
+ { 2.8421796979457072, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000 },
+ { 3.8760354586203549, 0.50000000000000000, 5.0000000000000000,
+ 7.0000000000000000 },
+ { 5.5792940156545505, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000 },
+ { 8.4898429002463196, 0.50000000000000000, 5.0000000000000000,
+ 9.0000000000000000 },
+ { 13.636227878037923, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.50000000000000000, c=5.0000000000000000.
+template <typename Tp>
+void test015()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data015)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data015[i].a), Tp(data015[i].c),
+ Tp(data015[i].x));
+ const Tp f0 = data015[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, c=6.0000000000000000.
+testcase_conf_hyperg<double> data016[] = {
+ { 0.59687111919499192, 0.50000000000000000, 6.0000000000000000,
+ -10.000000000000000 },
+ { 0.61774982278057033, 0.50000000000000000, 6.0000000000000000,
+ -9.0000000000000000 },
+ { 0.64090744485124451, 0.50000000000000000, 6.0000000000000000,
+ -8.0000000000000000 },
+ { 0.66677322792860194, 0.50000000000000000, 6.0000000000000000,
+ -7.0000000000000000 },
+ { 0.69589293014100995, 0.50000000000000000, 6.0000000000000000,
+ -6.0000000000000000 },
+ { 0.72897040032571048, 0.50000000000000000, 6.0000000000000000,
+ -5.0000000000000000 },
+ { 0.76692755408207181, 0.50000000000000000, 6.0000000000000000,
+ -4.0000000000000000 },
+ { 0.81099244559101891, 0.50000000000000000, 6.0000000000000000,
+ -3.0000000000000000 },
+ { 0.86283102401276535, 0.50000000000000000, 6.0000000000000000,
+ -2.0000000000000000 },
+ { 0.92474809223976406, 0.50000000000000000, 6.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 6.0000000000000000,
+ 0.0000000000000000 },
+ { 1.0932912594628821, 0.50000000000000000, 6.0000000000000000,
+ 1.0000000000000000 },
+ { 1.2115798426781204, 0.50000000000000000, 6.0000000000000000,
+ 2.0000000000000000 },
+ { 1.3654106750890422, 0.50000000000000000, 6.0000000000000000,
+ 3.0000000000000000 },
+ { 1.5711704305419896, 0.50000000000000000, 6.0000000000000000,
+ 4.0000000000000000 },
+ { 1.8549798357448213, 0.50000000000000000, 6.0000000000000000,
+ 5.0000000000000000 },
+ { 2.2595503871694818, 0.50000000000000000, 6.0000000000000000,
+ 6.0000000000000000 },
+ { 2.8565038772876936, 0.50000000000000000, 6.0000000000000000,
+ 7.0000000000000000 },
+ { 3.7689325736317811, 0.50000000000000000, 6.0000000000000000,
+ 8.0000000000000000 },
+ { 5.2134738554699460, 0.50000000000000000, 6.0000000000000000,
+ 9.0000000000000000 },
+ { 7.5801565545352725, 0.50000000000000000, 6.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.50000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test016()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data016)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data016[i].a), Tp(data016[i].c),
+ Tp(data016[i].x));
+ const Tp f0 = data016[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, c=7.0000000000000000.
+testcase_conf_hyperg<double> data017[] = {
+ { 0.62946736953754090, 0.50000000000000000, 7.0000000000000000,
+ -10.000000000000000 },
+ { 0.64995830964827050, 0.50000000000000000, 7.0000000000000000,
+ -9.0000000000000000 },
+ { 0.67251910396276349, 0.50000000000000000, 7.0000000000000000,
+ -8.0000000000000000 },
+ { 0.69750870596083636, 0.50000000000000000, 7.0000000000000000,
+ -7.0000000000000000 },
+ { 0.72537539174856436, 0.50000000000000000, 7.0000000000000000,
+ -6.0000000000000000 },
+ { 0.75668588434835504, 0.50000000000000000, 7.0000000000000000,
+ -5.0000000000000000 },
+ { 0.79216623458879654, 0.50000000000000000, 7.0000000000000000,
+ -4.0000000000000000 },
+ { 0.83276010491326891, 0.50000000000000000, 7.0000000000000000,
+ -3.0000000000000000 },
+ { 0.87971323375878940, 0.50000000000000000, 7.0000000000000000,
+ -2.0000000000000000 },
+ { 0.93469794840150233, 0.50000000000000000, 7.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 7.0000000000000000,
+ 0.0000000000000000 },
+ { 1.0788040971101556, 0.50000000000000000, 7.0000000000000000,
+ 1.0000000000000000 },
+ { 1.1756385516794761, 0.50000000000000000, 7.0000000000000000,
+ 2.0000000000000000 },
+ { 1.2970810749099917, 0.50000000000000000, 7.0000000000000000,
+ 3.0000000000000000 },
+ { 1.4529009687665237, 0.50000000000000000, 7.0000000000000000,
+ 4.0000000000000000 },
+ { 1.6579437149144023, 0.50000000000000000, 7.0000000000000000,
+ 5.0000000000000000 },
+ { 1.9353010489337750, 0.50000000000000000, 7.0000000000000000,
+ 6.0000000000000000 },
+ { 2.3217458547039813, 0.50000000000000000, 7.0000000000000000,
+ 7.0000000000000000 },
+ { 2.8772254607646004, 0.50000000000000000, 7.0000000000000000,
+ 8.0000000000000000 },
+ { 3.7017478151936545, 0.50000000000000000, 7.0000000000000000,
+ 9.0000000000000000 },
+ { 4.9659500648552148, 0.50000000000000000, 7.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.50000000000000000, c=7.0000000000000000.
+template <typename Tp>
+void test017()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data017)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data017[i].a), Tp(data017[i].c),
+ Tp(data017[i].x));
+ const Tp f0 = data017[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, c=8.0000000000000000.
+testcase_conf_hyperg<double> data018[] = {
+ { 0.65682574389601245, 0.50000000000000000, 8.0000000000000000,
+ -10.000000000000000 },
+ { 0.67683106084440448, 0.50000000000000000, 8.0000000000000000,
+ -9.0000000000000000 },
+ { 0.69871884883136481, 0.50000000000000000, 8.0000000000000000,
+ -8.0000000000000000 },
+ { 0.72279201131268422, 0.50000000000000000, 8.0000000000000000,
+ -7.0000000000000000 },
+ { 0.74942315553647221, 0.50000000000000000, 8.0000000000000000,
+ -6.0000000000000000 },
+ { 0.77907555763819503, 0.50000000000000000, 8.0000000000000000,
+ -5.0000000000000000 },
+ { 0.81233192258476394, 0.50000000000000000, 8.0000000000000000,
+ -4.0000000000000000 },
+ { 0.84993438521252052, 0.50000000000000000, 8.0000000000000000,
+ -3.0000000000000000 },
+ { 0.89284095871461888, 0.50000000000000000, 8.0000000000000000,
+ -2.0000000000000000 },
+ { 0.94230641231038748, 0.50000000000000000, 8.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 8.0000000000000000,
+ 0.0000000000000000 },
+ { 1.0681796709163929, 0.50000000000000000, 8.0000000000000000,
+ 1.0000000000000000 },
+ { 1.1499542693515108, 0.50000000000000000, 8.0000000000000000,
+ 2.0000000000000000 },
+ { 1.2496850956712680, 0.50000000000000000, 8.0000000000000000,
+ 3.0000000000000000 },
+ { 1.3736119127266571, 0.50000000000000000, 8.0000000000000000,
+ 4.0000000000000000 },
+ { 1.5308465522192733, 0.50000000000000000, 8.0000000000000000,
+ 5.0000000000000000 },
+ { 1.7349787653671500, 0.50000000000000000, 8.0000000000000000,
+ 6.0000000000000000 },
+ { 2.0067188996039378, 0.50000000000000000, 8.0000000000000000,
+ 7.0000000000000000 },
+ { 2.3783255204306930, 0.50000000000000000, 8.0000000000000000,
+ 8.0000000000000000 },
+ { 2.9011558746255721, 0.50000000000000000, 8.0000000000000000,
+ 9.0000000000000000 },
+ { 3.6587666457431167, 0.50000000000000000, 8.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.50000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test018()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data018)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data018[i].a), Tp(data018[i].c),
+ Tp(data018[i].x));
+ const Tp f0 = data018[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, c=9.0000000000000000.
+testcase_conf_hyperg<double> data019[] = {
+ { 0.68018654063475448, 0.50000000000000000, 9.0000000000000000,
+ -10.000000000000000 },
+ { 0.69965870094538662, 0.50000000000000000, 9.0000000000000000,
+ -9.0000000000000000 },
+ { 0.72084701020942776, 0.50000000000000000, 9.0000000000000000,
+ -8.0000000000000000 },
+ { 0.74400928635822572, 0.50000000000000000, 9.0000000000000000,
+ -7.0000000000000000 },
+ { 0.76945859319172982, 0.50000000000000000, 9.0000000000000000,
+ -6.0000000000000000 },
+ { 0.79757868270124699, 0.50000000000000000, 9.0000000000000000,
+ -5.0000000000000000 },
+ { 0.82884476649794248, 0.50000000000000000, 9.0000000000000000,
+ -4.0000000000000000 },
+ { 0.86385180214855140, 0.50000000000000000, 9.0000000000000000,
+ -3.0000000000000000 },
+ { 0.90335351612716308, 0.50000000000000000, 9.0000000000000000,
+ -2.0000000000000000 },
+ { 0.94831697594473685, 0.50000000000000000, 9.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 9.0000000000000000,
+ 0.0000000000000000 },
+ { 1.0600626000640645, 0.50000000000000000, 9.0000000000000000,
+ 1.0000000000000000 },
+ { 1.1307298999505393, 0.50000000000000000, 9.0000000000000000,
+ 2.0000000000000000 },
+ { 1.2150341092774180, 0.50000000000000000, 9.0000000000000000,
+ 3.0000000000000000 },
+ { 1.3171798023006840, 0.50000000000000000, 9.0000000000000000,
+ 4.0000000000000000 },
+ { 1.4431045594091672, 0.50000000000000000, 9.0000000000000000,
+ 5.0000000000000000 },
+ { 1.6013540635087158, 0.50000000000000000, 9.0000000000000000,
+ 6.0000000000000000 },
+ { 1.8044714074708206, 0.50000000000000000, 9.0000000000000000,
+ 7.0000000000000000 },
+ { 2.0712406108144252, 0.50000000000000000, 9.0000000000000000,
+ 8.0000000000000000 },
+ { 2.4303714711293125, 0.50000000000000000, 9.0000000000000000,
+ 9.0000000000000000 },
+ { 2.9266541358556246, 0.50000000000000000, 9.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.50000000000000000, c=9.0000000000000000.
+template <typename Tp>
+void test019()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data019)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data019[i].a), Tp(data019[i].c),
+ Tp(data019[i].x));
+ const Tp f0 = data019[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, c=10.000000000000000.
+testcase_conf_hyperg<double> data020[] = {
+ { 0.70040954461104077, 0.50000000000000000, 10.000000000000000,
+ -10.000000000000000 },
+ { 0.71933025737654377, 0.50000000000000000, 10.000000000000000,
+ -9.0000000000000000 },
+ { 0.73981995758615049, 0.50000000000000000, 10.000000000000000,
+ -8.0000000000000000 },
+ { 0.76209985272755054, 0.50000000000000000, 10.000000000000000,
+ -7.0000000000000000 },
+ { 0.78643553963087975, 0.50000000000000000, 10.000000000000000,
+ -6.0000000000000000 },
+ { 0.81314860510626796, 0.50000000000000000, 10.000000000000000,
+ -5.0000000000000000 },
+ { 0.84263196565226672, 0.50000000000000000, 10.000000000000000,
+ -4.0000000000000000 },
+ { 0.87537037798496642, 0.50000000000000000, 10.000000000000000,
+ -3.0000000000000000 },
+ { 0.91196818568151450, 0.50000000000000000, 10.000000000000000,
+ -2.0000000000000000 },
+ { 0.95318731786229316, 0.50000000000000000, 10.000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 10.000000000000000,
+ 0.0000000000000000 },
+ { 1.0536628587304602, 0.50000000000000000, 10.000000000000000,
+ 1.0000000000000000 },
+ { 1.1158225648376323, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000 },
+ { 1.1886686247111011, 0.50000000000000000, 10.000000000000000,
+ 3.0000000000000000 },
+ { 1.2751576744751334, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000 },
+ { 1.3793478044961116, 0.50000000000000000, 10.000000000000000,
+ 5.0000000000000000 },
+ { 1.5069047234443802, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000 },
+ { 1.6658803233122232, 0.50000000000000000, 10.000000000000000,
+ 7.0000000000000000 },
+ { 1.8679295659745196, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000 },
+ { 2.1302432955522042, 0.50000000000000000, 10.000000000000000,
+ 9.0000000000000000 },
+ { 2.4786679001777268, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=0.50000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test020()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data020)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data020[i].a), Tp(data020[i].c),
+ Tp(data020[i].x));
+ const Tp f0 = data020[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, c=1.0000000000000000.
+testcase_conf_hyperg<double> data021[] = {
+ { 4.5399929762484854e-05, 1.0000000000000000, 1.0000000000000000,
+ -10.000000000000000 },
+ { 0.00012340980408667956, 1.0000000000000000, 1.0000000000000000,
+ -9.0000000000000000 },
+ { 0.00033546262790251185, 1.0000000000000000, 1.0000000000000000,
+ -8.0000000000000000 },
+ { 0.00091188196555451624, 1.0000000000000000, 1.0000000000000000,
+ -7.0000000000000000 },
+ { 0.0024787521766663585, 1.0000000000000000, 1.0000000000000000,
+ -6.0000000000000000 },
+ { 0.0067379469990854670, 1.0000000000000000, 1.0000000000000000,
+ -5.0000000000000000 },
+ { 0.018315638888734179, 1.0000000000000000, 1.0000000000000000,
+ -4.0000000000000000 },
+ { 0.049787068367863944, 1.0000000000000000, 1.0000000000000000,
+ -3.0000000000000000 },
+ { 0.13533528323661270, 1.0000000000000000, 1.0000000000000000,
+ -2.0000000000000000 },
+ { 0.36787944117144233, 1.0000000000000000, 1.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 1.0000000000000000,
+ 0.0000000000000000 },
+ { 2.7182818284590451, 1.0000000000000000, 1.0000000000000000,
+ 1.0000000000000000 },
+ { 7.3890560989306504, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000 },
+ { 20.085536923187668, 1.0000000000000000, 1.0000000000000000,
+ 3.0000000000000000 },
+ { 54.598150033144236, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000 },
+ { 148.41315910257660, 1.0000000000000000, 1.0000000000000000,
+ 5.0000000000000000 },
+ { 403.42879349273511, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000 },
+ { 1096.6331584284585, 1.0000000000000000, 1.0000000000000000,
+ 7.0000000000000000 },
+ { 2980.9579870417283, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000 },
+ { 8103.0839275753842, 1.0000000000000000, 1.0000000000000000,
+ 9.0000000000000000 },
+ { 22026.465794806718, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=1.0000000000000000, c=1.0000000000000000.
+template <typename Tp>
+void test021()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data021)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data021[i].a), Tp(data021[i].c),
+ Tp(data021[i].x));
+ const Tp f0 = data021[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, c=2.0000000000000000.
+testcase_conf_hyperg<double> data022[] = {
+ { 0.099995460007023751, 1.0000000000000000, 2.0000000000000000,
+ -10.000000000000000 },
+ { 0.11109739891065704, 1.0000000000000000, 2.0000000000000000,
+ -9.0000000000000000 },
+ { 0.12495806717151219, 1.0000000000000000, 2.0000000000000000,
+ -8.0000000000000000 },
+ { 0.14272687400492079, 1.0000000000000000, 2.0000000000000000,
+ -7.0000000000000000 },
+ { 0.16625354130388895, 1.0000000000000000, 2.0000000000000000,
+ -6.0000000000000000 },
+ { 0.19865241060018290, 1.0000000000000000, 2.0000000000000000,
+ -5.0000000000000000 },
+ { 0.24542109027781644, 1.0000000000000000, 2.0000000000000000,
+ -4.0000000000000000 },
+ { 0.31673764387737868, 1.0000000000000000, 2.0000000000000000,
+ -3.0000000000000000 },
+ { 0.43233235838169365, 1.0000000000000000, 2.0000000000000000,
+ -2.0000000000000000 },
+ { 0.63212055882855767, 1.0000000000000000, 2.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 2.0000000000000000,
+ 0.0000000000000000 },
+ { 1.7182818284590451, 1.0000000000000000, 2.0000000000000000,
+ 1.0000000000000000 },
+ { 3.1945280494653252, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000 },
+ { 6.3618456410625557, 1.0000000000000000, 2.0000000000000000,
+ 3.0000000000000000 },
+ { 13.399537508286059, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000 },
+ { 29.482631820515319, 1.0000000000000000, 2.0000000000000000,
+ 5.0000000000000000 },
+ { 67.071465582122514, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000 },
+ { 156.51902263263693, 1.0000000000000000, 2.0000000000000000,
+ 7.0000000000000000 },
+ { 372.49474838021604, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000 },
+ { 900.23154750837602, 1.0000000000000000, 2.0000000000000000,
+ 9.0000000000000000 },
+ { 2202.5465794806719, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=1.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test022()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data022)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data022[i].a), Tp(data022[i].c),
+ Tp(data022[i].x));
+ const Tp f0 = data022[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, c=3.0000000000000000.
+testcase_conf_hyperg<double> data023[] = {
+ { 0.18000090799859525, 1.0000000000000000, 3.0000000000000000,
+ -10.000000000000000 },
+ { 0.19753391135318732, 1.0000000000000000, 3.0000000000000000,
+ -9.0000000000000000 },
+ { 0.21876048320712196, 1.0000000000000000, 3.0000000000000000,
+ -8.0000000000000000 },
+ { 0.24493517885573690, 1.0000000000000000, 3.0000000000000000,
+ -7.0000000000000000 },
+ { 0.27791548623203705, 1.0000000000000000, 3.0000000000000000,
+ -6.0000000000000000 },
+ { 0.32053903575992687, 1.0000000000000000, 3.0000000000000000,
+ -5.0000000000000000 },
+ { 0.37728945486109178, 1.0000000000000000, 3.0000000000000000,
+ -4.0000000000000000 },
+ { 0.45550823741508090, 1.0000000000000000, 3.0000000000000000,
+ -3.0000000000000000 },
+ { 0.56766764161830641, 1.0000000000000000, 3.0000000000000000,
+ -2.0000000000000000 },
+ { 0.73575888234288467, 1.0000000000000000, 3.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 3.0000000000000000,
+ 0.0000000000000000 },
+ { 1.4365636569180902, 1.0000000000000000, 3.0000000000000000,
+ 1.0000000000000000 },
+ { 2.1945280494653252, 1.0000000000000000, 3.0000000000000000,
+ 2.0000000000000000 },
+ { 3.5745637607083705, 1.0000000000000000, 3.0000000000000000,
+ 3.0000000000000000 },
+ { 6.1997687541430295, 1.0000000000000000, 3.0000000000000000,
+ 4.0000000000000000 },
+ { 11.393052728206127, 1.0000000000000000, 3.0000000000000000,
+ 5.0000000000000000 },
+ { 22.023821860707507, 1.0000000000000000, 3.0000000000000000,
+ 6.0000000000000000 },
+ { 44.434006466467693, 1.0000000000000000, 3.0000000000000000,
+ 7.0000000000000000 },
+ { 92.873687095054009, 1.0000000000000000, 3.0000000000000000,
+ 8.0000000000000000 },
+ { 199.82923277963911, 1.0000000000000000, 3.0000000000000000,
+ 9.0000000000000000 },
+ { 440.30931589613436, 1.0000000000000000, 3.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=1.0000000000000000, c=3.0000000000000000.
+template <typename Tp>
+void test023()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data023)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data023[i].a), Tp(data023[i].c),
+ Tp(data023[i].x));
+ const Tp f0 = data023[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, c=4.0000000000000000.
+testcase_conf_hyperg<double> data024[] = {
+ { 0.24599972760042146, 1.0000000000000000, 4.0000000000000000,
+ -10.000000000000000 },
+ { 0.26748869621560417, 1.0000000000000000, 4.0000000000000000,
+ -9.0000000000000000 },
+ { 0.29296481879732927, 1.0000000000000000, 4.0000000000000000,
+ -8.0000000000000000 },
+ { 0.32359920906182704, 1.0000000000000000, 4.0000000000000000,
+ -7.0000000000000000 },
+ { 0.36104225688398150, 1.0000000000000000, 4.0000000000000000,
+ -6.0000000000000000 },
+ { 0.40767657854404399, 1.0000000000000000, 4.0000000000000000,
+ -5.0000000000000000 },
+ { 0.46703290885418114, 1.0000000000000000, 4.0000000000000000,
+ -4.0000000000000000 },
+ { 0.54449176258491927, 1.0000000000000000, 4.0000000000000000,
+ -3.0000000000000000 },
+ { 0.64849853757254050, 1.0000000000000000, 4.0000000000000000,
+ -2.0000000000000000 },
+ { 0.79272335297134611, 1.0000000000000000, 4.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 4.0000000000000000,
+ 0.0000000000000000 },
+ { 1.3096909707542714, 1.0000000000000000, 4.0000000000000000,
+ 1.0000000000000000 },
+ { 1.7917920741979876, 1.0000000000000000, 4.0000000000000000,
+ 2.0000000000000000 },
+ { 2.5745637607083709, 1.0000000000000000, 4.0000000000000000,
+ 3.0000000000000000 },
+ { 3.8998265656072717, 1.0000000000000000, 4.0000000000000000,
+ 4.0000000000000000 },
+ { 6.2358316369236775, 1.0000000000000000, 4.0000000000000000,
+ 5.0000000000000000 },
+ { 10.511910930353745, 1.0000000000000000, 4.0000000000000000,
+ 6.0000000000000000 },
+ { 18.614574199914728, 1.0000000000000000, 4.0000000000000000,
+ 7.0000000000000000 },
+ { 34.452632660645271, 1.0000000000000000, 4.0000000000000000,
+ 8.0000000000000000 },
+ { 66.276410926546333, 1.0000000000000000, 4.0000000000000000,
+ 9.0000000000000000 },
+ { 131.79279476884014, 1.0000000000000000, 4.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=1.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test024()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data024)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data024[i].a), Tp(data024[i].c),
+ Tp(data024[i].x));
+ const Tp f0 = data024[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, c=5.0000000000000000.
+testcase_conf_hyperg<double> data025[] = {
+ { 0.30160010895983153, 1.0000000000000000, 5.0000000000000000,
+ -10.000000000000000 },
+ { 0.32556057945973144, 1.0000000000000000, 5.0000000000000000,
+ -9.0000000000000000 },
+ { 0.35351759060133547, 1.0000000000000000, 5.0000000000000000,
+ -8.0000000000000000 },
+ { 0.38651473767895589, 1.0000000000000000, 5.0000000000000000,
+ -7.0000000000000000 },
+ { 0.42597182874401224, 1.0000000000000000, 5.0000000000000000,
+ -6.0000000000000000 },
+ { 0.47385873716476495, 1.0000000000000000, 5.0000000000000000,
+ -5.0000000000000000 },
+ { 0.53296709114581886, 1.0000000000000000, 5.0000000000000000,
+ -4.0000000000000000 },
+ { 0.60734431655344123, 1.0000000000000000, 5.0000000000000000,
+ -3.0000000000000000 },
+ { 0.70300292485491900, 1.0000000000000000, 5.0000000000000000,
+ -2.0000000000000000 },
+ { 0.82910658811461568, 1.0000000000000000, 5.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 5.0000000000000000,
+ 0.0000000000000000 },
+ { 1.2387638830170857, 1.0000000000000000, 5.0000000000000000,
+ 1.0000000000000000 },
+ { 1.5835841483959754, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000 },
+ { 2.0994183476111612, 1.0000000000000000, 5.0000000000000000,
+ 3.0000000000000000 },
+ { 2.8998265656072721, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000 },
+ { 4.1886653095389432, 1.0000000000000000, 5.0000000000000000,
+ 5.0000000000000000 },
+ { 6.3412739535691678, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000 },
+ { 10.065470971379844, 1.0000000000000000, 5.0000000000000000,
+ 7.0000000000000000 },
+ { 16.726316330322632, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000 },
+ { 29.011738189576135, 1.0000000000000000, 5.0000000000000000,
+ 9.0000000000000000 },
+ { 52.317117907536058, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=1.0000000000000000, c=5.0000000000000000.
+template <typename Tp>
+void test025()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data025)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data025[i].a), Tp(data025[i].c),
+ Tp(data025[i].x));
+ const Tp f0 = data025[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, c=6.0000000000000000.
+testcase_conf_hyperg<double> data026[] = {
+ { 0.34919994552008432, 1.0000000000000000, 6.0000000000000000,
+ -10.000000000000000 },
+ { 0.37468856696681579, 1.0000000000000000, 6.0000000000000000,
+ -9.0000000000000000 },
+ { 0.40405150587416544, 1.0000000000000000, 6.0000000000000000,
+ -8.0000000000000000 },
+ { 0.43820375880074558, 1.0000000000000000, 6.0000000000000000,
+ -7.0000000000000000 },
+ { 0.47835680937998976, 1.0000000000000000, 6.0000000000000000,
+ -6.0000000000000000 },
+ { 0.52614126283523510, 1.0000000000000000, 6.0000000000000000,
+ -5.0000000000000000 },
+ { 0.58379113606772637, 1.0000000000000000, 6.0000000000000000,
+ -4.0000000000000000 },
+ { 0.65442613907759817, 1.0000000000000000, 6.0000000000000000,
+ -3.0000000000000000 },
+ { 0.74249268786270239, 1.0000000000000000, 6.0000000000000000,
+ -2.0000000000000000 },
+ { 0.85446705942692136, 1.0000000000000000, 6.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 6.0000000000000000,
+ 0.0000000000000000 },
+ { 1.1938194150854282, 1.0000000000000000, 6.0000000000000000,
+ 1.0000000000000000 },
+ { 1.4589603709899384, 1.0000000000000000, 6.0000000000000000,
+ 2.0000000000000000 },
+ { 1.8323639126852680, 1.0000000000000000, 6.0000000000000000,
+ 3.0000000000000000 },
+ { 2.3747832070090902, 1.0000000000000000, 6.0000000000000000,
+ 4.0000000000000000 },
+ { 3.1886653095389415, 1.0000000000000000, 6.0000000000000000,
+ 5.0000000000000000 },
+ { 4.4510616279743056, 1.0000000000000000, 6.0000000000000000,
+ 6.0000000000000000 },
+ { 6.4753364081284595, 1.0000000000000000, 6.0000000000000000,
+ 7.0000000000000000 },
+ { 9.8289477064516344, 1.0000000000000000, 6.0000000000000000,
+ 8.0000000000000000 },
+ { 15.562076771986721, 1.0000000000000000, 6.0000000000000000,
+ 9.0000000000000000 },
+ { 25.658558953767979, 1.0000000000000000, 6.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=1.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test026()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data026)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data026[i].a), Tp(data026[i].c),
+ Tp(data026[i].x));
+ const Tp f0 = data026[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, c=7.0000000000000000.
+testcase_conf_hyperg<double> data027[] = {
+ { 0.39048003268794951, 1.0000000000000000, 7.0000000000000000,
+ -10.000000000000000 },
+ { 0.41687428868878945, 1.0000000000000000, 7.0000000000000000,
+ -9.0000000000000000 },
+ { 0.44696137059437596, 1.0000000000000000, 7.0000000000000000,
+ -8.0000000000000000 },
+ { 0.48153963531364646, 1.0000000000000000, 7.0000000000000000,
+ -7.0000000000000000 },
+ { 0.52164319062001030, 1.0000000000000000, 7.0000000000000000,
+ -6.0000000000000000 },
+ { 0.56863048459771781, 1.0000000000000000, 7.0000000000000000,
+ -5.0000000000000000 },
+ { 0.62431329589841034, 1.0000000000000000, 7.0000000000000000,
+ -4.0000000000000000 },
+ { 0.69114772184480400, 1.0000000000000000, 7.0000000000000000,
+ -3.0000000000000000 },
+ { 0.77252193641189282, 1.0000000000000000, 7.0000000000000000,
+ -2.0000000000000000 },
+ { 0.87319764343847150, 1.0000000000000000, 7.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 7.0000000000000000,
+ 0.0000000000000000 },
+ { 1.1629164905125695, 1.0000000000000000, 7.0000000000000000,
+ 1.0000000000000000 },
+ { 1.3768811129698151, 1.0000000000000000, 7.0000000000000000,
+ 2.0000000000000000 },
+ { 1.6647278253705360, 1.0000000000000000, 7.0000000000000000,
+ 3.0000000000000000 },
+ { 2.0621748105136359, 1.0000000000000000, 7.0000000000000000,
+ 4.0000000000000000 },
+ { 2.6263983714467298, 1.0000000000000000, 7.0000000000000000,
+ 5.0000000000000000 },
+ { 3.4510616279743078, 1.0000000000000000, 7.0000000000000000,
+ 6.0000000000000000 },
+ { 4.6931454926815448, 1.0000000000000000, 7.0000000000000000,
+ 7.0000000000000000 },
+ { 6.6217107798387476, 1.0000000000000000, 7.0000000000000000,
+ 8.0000000000000000 },
+ { 9.7080511813245050, 1.0000000000000000, 7.0000000000000000,
+ 9.0000000000000000 },
+ { 14.795135372260793, 1.0000000000000000, 7.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=1.0000000000000000, c=7.0000000000000000.
+template <typename Tp>
+void test027()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data027)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data027[i].a), Tp(data027[i].c),
+ Tp(data027[i].x));
+ const Tp f0 = data027[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, c=8.0000000000000000.
+testcase_conf_hyperg<double> data028[] = {
+ { 0.42666397711843540, 1.0000000000000000, 8.0000000000000000,
+ -10.000000000000000 },
+ { 0.45354221990871918, 1.0000000000000000, 8.0000000000000000,
+ -9.0000000000000000 },
+ { 0.48390880072992104, 1.0000000000000000, 8.0000000000000000,
+ -8.0000000000000000 },
+ { 0.51846036468635348, 1.0000000000000000, 8.0000000000000000,
+ -7.0000000000000000 },
+ { 0.55808294427665472, 1.0000000000000000, 8.0000000000000000,
+ -6.0000000000000000 },
+ { 0.60391732156319489, 1.0000000000000000, 8.0000000000000000,
+ -5.0000000000000000 },
+ { 0.65745173217778197, 1.0000000000000000, 8.0000000000000000,
+ -4.0000000000000000 },
+ { 0.72065531569545760, 1.0000000000000000, 8.0000000000000000,
+ -3.0000000000000000 },
+ { 0.79617322255837530, 1.0000000000000000, 8.0000000000000000,
+ -2.0000000000000000 },
+ { 0.88761649593069913, 1.0000000000000000, 8.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 8.0000000000000000,
+ 0.0000000000000000 },
+ { 1.1404154335879861, 1.0000000000000000, 8.0000000000000000,
+ 1.0000000000000000 },
+ { 1.3190838953943527, 1.0000000000000000, 8.0000000000000000,
+ 2.0000000000000000 },
+ { 1.5510315925312508, 1.0000000000000000, 8.0000000000000000,
+ 3.0000000000000000 },
+ { 1.8588059183988628, 1.0000000000000000, 8.0000000000000000,
+ 4.0000000000000000 },
+ { 2.2769577200254218, 1.0000000000000000, 8.0000000000000000,
+ 5.0000000000000000 },
+ { 2.8595718993033583, 1.0000000000000000, 8.0000000000000000,
+ 6.0000000000000000 },
+ { 3.6931454926815368, 1.0000000000000000, 8.0000000000000000,
+ 7.0000000000000000 },
+ { 4.9189969323589020, 1.0000000000000000, 8.0000000000000000,
+ 8.0000000000000000 },
+ { 6.7729286965857218, 1.0000000000000000, 8.0000000000000000,
+ 9.0000000000000000 },
+ { 9.6565947605825802, 1.0000000000000000, 8.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=1.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test028()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data028)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data028[i].a), Tp(data028[i].c),
+ Tp(data028[i].x));
+ const Tp f0 = data028[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, c=9.0000000000000000.
+testcase_conf_hyperg<double> data029[] = {
+ { 0.45866881830525175, 1.0000000000000000, 9.0000000000000000,
+ -10.000000000000000 },
+ { 0.48574024897002721, 1.0000000000000000, 9.0000000000000000,
+ -9.0000000000000000 },
+ { 0.51609119927007907, 1.0000000000000000, 9.0000000000000000,
+ -8.0000000000000000 },
+ { 0.55033101178702437, 1.0000000000000000, 9.0000000000000000,
+ -7.0000000000000000 },
+ { 0.58922274096446048, 1.0000000000000000, 9.0000000000000000,
+ -6.0000000000000000 },
+ { 0.63373228549888783, 1.0000000000000000, 9.0000000000000000,
+ -5.0000000000000000 },
+ { 0.68509653564443607, 1.0000000000000000, 9.0000000000000000,
+ -4.0000000000000000 },
+ { 0.74491915814544640, 1.0000000000000000, 9.0000000000000000,
+ -3.0000000000000000 },
+ { 0.81530710976649901, 1.0000000000000000, 9.0000000000000000,
+ -2.0000000000000000 },
+ { 0.89906803255440670, 1.0000000000000000, 9.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 9.0000000000000000,
+ 0.0000000000000000 },
+ { 1.1233234687038898, 1.0000000000000000, 9.0000000000000000,
+ 1.0000000000000000 },
+ { 1.2763355815774109, 1.0000000000000000, 9.0000000000000000,
+ 2.0000000000000000 },
+ { 1.4694175800833353, 1.0000000000000000, 9.0000000000000000,
+ 3.0000000000000000 },
+ { 1.7176118367977251, 1.0000000000000000, 9.0000000000000000,
+ 4.0000000000000000 },
+ { 2.0431323520406752, 1.0000000000000000, 9.0000000000000000,
+ 5.0000000000000000 },
+ { 2.4794291990711450, 1.0000000000000000, 9.0000000000000000,
+ 6.0000000000000000 },
+ { 3.0778805630646140, 1.0000000000000000, 9.0000000000000000,
+ 7.0000000000000000 },
+ { 3.9189969323588896, 1.0000000000000000, 9.0000000000000000,
+ 8.0000000000000000 },
+ { 5.1314921747428537, 1.0000000000000000, 9.0000000000000000,
+ 9.0000000000000000 },
+ { 6.9252758084660462, 1.0000000000000000, 9.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=1.0000000000000000, c=9.0000000000000000.
+template <typename Tp>
+void test029()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data029)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data029[i].a), Tp(data029[i].c),
+ Tp(data029[i].x));
+ const Tp f0 = data029[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, c=10.000000000000000.
+testcase_conf_hyperg<double> data030[] = {
+ { 0.48719806352527339, 1.0000000000000000, 10.000000000000000,
+ -10.000000000000000 },
+ { 0.51425975102997279, 1.0000000000000000, 10.000000000000000,
+ -9.0000000000000000 },
+ { 0.54439740082116117, 1.0000000000000000, 10.000000000000000,
+ -8.0000000000000000 },
+ { 0.57814584198811125, 1.0000000000000000, 10.000000000000000,
+ -7.0000000000000000 },
+ { 0.61616588855330923, 1.0000000000000000, 10.000000000000000,
+ -6.0000000000000000 },
+ { 0.65928188610200156, 1.0000000000000000, 10.000000000000000,
+ -5.0000000000000000 },
+ { 0.70853279480001885, 1.0000000000000000, 10.000000000000000,
+ -4.0000000000000000 },
+ { 0.76524252556366068, 1.0000000000000000, 10.000000000000000,
+ -3.0000000000000000 },
+ { 0.83111800605075459, 1.0000000000000000, 10.000000000000000,
+ -2.0000000000000000 },
+ { 0.90838770701033944, 1.0000000000000000, 10.000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 10.000000000000000,
+ 0.0000000000000000 },
+ { 1.1099112183350075, 1.0000000000000000, 10.000000000000000,
+ 1.0000000000000000 },
+ { 1.2435101170983485, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000 },
+ { 1.4082527402500060, 1.0000000000000000, 10.000000000000000,
+ 3.0000000000000000 },
+ { 1.6146266327948817, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000 },
+ { 1.8776382336732149, 1.0000000000000000, 10.000000000000000,
+ 5.0000000000000000 },
+ { 2.2191437986067171, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000 },
+ { 2.6715607239402184, 1.0000000000000000, 10.000000000000000,
+ 7.0000000000000000 },
+ { 3.2838715489037504, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000 },
+ { 4.1314921747428679, 1.0000000000000000, 10.000000000000000,
+ 9.0000000000000000 },
+ { 5.3327482276194447, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=1.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test030()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data030)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data030[i].a), Tp(data030[i].c),
+ Tp(data030[i].x));
+ const Tp f0 = data030[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, c=1.0000000000000000.
+testcase_conf_hyperg<double> data031[] = {
+ { -0.00040859936786236367, 2.0000000000000000, 1.0000000000000000,
+ -10.000000000000000 },
+ { -0.00098727843269343649, 2.0000000000000000, 1.0000000000000000,
+ -9.0000000000000000 },
+ { -0.0023482383953175828, 2.0000000000000000, 1.0000000000000000,
+ -8.0000000000000000 },
+ { -0.0054712917933270972, 2.0000000000000000, 1.0000000000000000,
+ -7.0000000000000000 },
+ { -0.012393760883331793, 2.0000000000000000, 1.0000000000000000,
+ -6.0000000000000000 },
+ { -0.026951787996341868, 2.0000000000000000, 1.0000000000000000,
+ -5.0000000000000000 },
+ { -0.054946916666202536, 2.0000000000000000, 1.0000000000000000,
+ -4.0000000000000000 },
+ { -0.099574136735727889, 2.0000000000000000, 1.0000000000000000,
+ -3.0000000000000000 },
+ { -0.13533528323661270, 2.0000000000000000, 1.0000000000000000,
+ -2.0000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 1.0000000000000000,
+ 0.0000000000000000 },
+ { 5.4365636569180902, 2.0000000000000000, 1.0000000000000000,
+ 1.0000000000000000 },
+ { 22.167168296791949, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000 },
+ { 80.342147692750672, 2.0000000000000000, 1.0000000000000000,
+ 3.0000000000000000 },
+ { 272.99075016572118, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000 },
+ { 890.47895461545954, 2.0000000000000000, 1.0000000000000000,
+ 5.0000000000000000 },
+ { 2824.0015544491457, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000 },
+ { 8773.0652674276680, 2.0000000000000000, 1.0000000000000000,
+ 7.0000000000000000 },
+ { 26828.621883375556, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000 },
+ { 81030.839275753839, 2.0000000000000000, 1.0000000000000000,
+ 9.0000000000000000 },
+ { 242291.12374287390, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=2.0000000000000000, c=1.0000000000000000.
+template <typename Tp>
+void test031()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data031)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data031[i].a), Tp(data031[i].c),
+ Tp(data031[i].x));
+ const Tp f0 = data031[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for a=2.0000000000000000, c=2.0000000000000000.
+testcase_conf_hyperg<double> data032[] = {
+ { 4.5399929762484854e-05, 2.0000000000000000, 2.0000000000000000,
+ -10.000000000000000 },
+ { 0.00012340980408667956, 2.0000000000000000, 2.0000000000000000,
+ -9.0000000000000000 },
+ { 0.00033546262790251185, 2.0000000000000000, 2.0000000000000000,
+ -8.0000000000000000 },
+ { 0.00091188196555451624, 2.0000000000000000, 2.0000000000000000,
+ -7.0000000000000000 },
+ { 0.0024787521766663585, 2.0000000000000000, 2.0000000000000000,
+ -6.0000000000000000 },
+ { 0.0067379469990854670, 2.0000000000000000, 2.0000000000000000,
+ -5.0000000000000000 },
+ { 0.018315638888734179, 2.0000000000000000, 2.0000000000000000,
+ -4.0000000000000000 },
+ { 0.049787068367863944, 2.0000000000000000, 2.0000000000000000,
+ -3.0000000000000000 },
+ { 0.13533528323661270, 2.0000000000000000, 2.0000000000000000,
+ -2.0000000000000000 },
+ { 0.36787944117144233, 2.0000000000000000, 2.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 2.0000000000000000,
+ 0.0000000000000000 },
+ { 2.7182818284590451, 2.0000000000000000, 2.0000000000000000,
+ 1.0000000000000000 },
+ { 7.3890560989306504, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000 },
+ { 20.085536923187668, 2.0000000000000000, 2.0000000000000000,
+ 3.0000000000000000 },
+ { 54.598150033144236, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000 },
+ { 148.41315910257660, 2.0000000000000000, 2.0000000000000000,
+ 5.0000000000000000 },
+ { 403.42879349273511, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000 },
+ { 1096.6331584284585, 2.0000000000000000, 2.0000000000000000,
+ 7.0000000000000000 },
+ { 2980.9579870417283, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000 },
+ { 8103.0839275753842, 2.0000000000000000, 2.0000000000000000,
+ 9.0000000000000000 },
+ { 22026.465794806718, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=2.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test032()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data032)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data032[i].a), Tp(data032[i].c),
+ Tp(data032[i].x));
+ const Tp f0 = data032[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, c=3.0000000000000000.
+testcase_conf_hyperg<double> data033[] = {
+ { 0.019990012015452256, 2.0000000000000000, 3.0000000000000000,
+ -10.000000000000000 },
+ { 0.024660886468126749, 2.0000000000000000, 3.0000000000000000,
+ -9.0000000000000000 },
+ { 0.031155651135902421, 2.0000000000000000, 3.0000000000000000,
+ -8.0000000000000000 },
+ { 0.040518569154104643, 2.0000000000000000, 3.0000000000000000,
+ -7.0000000000000000 },
+ { 0.054591596375740861, 2.0000000000000000, 3.0000000000000000,
+ -6.0000000000000000 },
+ { 0.076765785440438966, 2.0000000000000000, 3.0000000000000000,
+ -5.0000000000000000 },
+ { 0.11355272569454113, 2.0000000000000000, 3.0000000000000000,
+ -4.0000000000000000 },
+ { 0.17796705033967650, 2.0000000000000000, 3.0000000000000000,
+ -3.0000000000000000 },
+ { 0.29699707514508100, 2.0000000000000000, 3.0000000000000000,
+ -2.0000000000000000 },
+ { 0.52848223531423066, 2.0000000000000000, 3.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 3.0000000000000000,
+ 0.0000000000000000 },
+ { 2.0000000000000000, 2.0000000000000000, 3.0000000000000000,
+ 1.0000000000000000 },
+ { 4.1945280494653261, 2.0000000000000000, 3.0000000000000000,
+ 2.0000000000000000 },
+ { 9.1491275214167409, 2.0000000000000000, 3.0000000000000000,
+ 3.0000000000000000 },
+ { 20.599306262429089, 2.0000000000000000, 3.0000000000000000,
+ 4.0000000000000000 },
+ { 47.572210912824517, 2.0000000000000000, 3.0000000000000000,
+ 5.0000000000000000 },
+ { 112.11910930353754, 2.0000000000000000, 3.0000000000000000,
+ 6.0000000000000000 },
+ { 268.60403879880613, 2.0000000000000000, 3.0000000000000000,
+ 7.0000000000000000 },
+ { 652.11580966537815, 2.0000000000000000, 3.0000000000000000,
+ 8.0000000000000000 },
+ { 1600.6338622371129, 2.0000000000000000, 3.0000000000000000,
+ 9.0000000000000000 },
+ { 3964.7838430652091, 2.0000000000000000, 3.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=2.0000000000000000, c=3.0000000000000000.
+template <typename Tp>
+void test033()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data033)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data033[i].a), Tp(data033[i].c),
+ Tp(data033[i].x));
+ const Tp f0 = data033[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, c=4.0000000000000000.
+testcase_conf_hyperg<double> data034[] = {
+ { 0.048003268794942940, 2.0000000000000000, 4.0000000000000000,
+ -10.000000000000000 },
+ { 0.057624341628353531, 2.0000000000000000, 4.0000000000000000,
+ -9.0000000000000000 },
+ { 0.070351812026707330, 2.0000000000000000, 4.0000000000000000,
+ -8.0000000000000000 },
+ { 0.087607118443556703, 2.0000000000000000, 4.0000000000000000,
+ -7.0000000000000000 },
+ { 0.11166194492814813, 2.0000000000000000, 4.0000000000000000,
+ -6.0000000000000000 },
+ { 0.14626395019169278, 2.0000000000000000, 4.0000000000000000,
+ -5.0000000000000000 },
+ { 0.19780254687491294, 2.0000000000000000, 4.0000000000000000,
+ -4.0000000000000000 },
+ { 0.27754118707540443, 2.0000000000000000, 4.0000000000000000,
+ -3.0000000000000000 },
+ { 0.40600584970983811, 2.0000000000000000, 4.0000000000000000,
+ -2.0000000000000000 },
+ { 0.62182994108596168, 2.0000000000000000, 4.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 4.0000000000000000,
+ 0.0000000000000000 },
+ { 1.6903090292457283, 2.0000000000000000, 4.0000000000000000,
+ 1.0000000000000000 },
+ { 3.0000000000000000, 2.0000000000000000, 4.0000000000000000,
+ 2.0000000000000000 },
+ { 5.5745637607083705, 2.0000000000000000, 4.0000000000000000,
+ 3.0000000000000000 },
+ { 10.799653131214550, 2.0000000000000000, 4.0000000000000000,
+ 4.0000000000000000 },
+ { 21.707494910771043, 2.0000000000000000, 4.0000000000000000,
+ 5.0000000000000000 },
+ { 45.047643721415056, 2.0000000000000000, 4.0000000000000000,
+ 6.0000000000000000 },
+ { 96.072870999573695, 2.0000000000000000, 4.0000000000000000,
+ 7.0000000000000000 },
+ { 209.71579596387159, 2.0000000000000000, 4.0000000000000000,
+ 8.0000000000000000 },
+ { 466.93487648582493, 2.0000000000000000, 4.0000000000000000,
+ 9.0000000000000000 },
+ { 1057.3423581507243, 2.0000000000000000, 4.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=2.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test034()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data034)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data034[i].a), Tp(data034[i].c),
+ Tp(data034[i].x));
+ const Tp f0 = data034[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, c=5.0000000000000000.
+testcase_conf_hyperg<double> data035[] = {
+ { 0.079198583522191404, 2.0000000000000000, 5.0000000000000000,
+ -10.000000000000000 },
+ { 0.093273046483222530, 2.0000000000000000, 5.0000000000000000,
+ -9.0000000000000000 },
+ { 0.11130650338531098, 2.0000000000000000, 5.0000000000000000,
+ -8.0000000000000000 },
+ { 0.13485262321044020, 2.0000000000000000, 5.0000000000000000,
+ -7.0000000000000000 },
+ { 0.16625354130388895, 2.0000000000000000, 5.0000000000000000,
+ -6.0000000000000000 },
+ { 0.20913010268188095, 2.0000000000000000, 5.0000000000000000,
+ -5.0000000000000000 },
+ { 0.26923036197926808, 2.0000000000000000, 5.0000000000000000,
+ -4.0000000000000000 },
+ { 0.35593410067935288, 2.0000000000000000, 5.0000000000000000,
+ -3.0000000000000000 },
+ { 0.48498537572540468, 2.0000000000000000, 5.0000000000000000,
+ -2.0000000000000000 },
+ { 0.68357364754153715, 2.0000000000000000, 5.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 5.0000000000000000,
+ 0.0000000000000000 },
+ { 1.5224722339658285, 2.0000000000000000, 5.0000000000000000,
+ 1.0000000000000000 },
+ { 2.4164158516040235, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000 },
+ { 4.0000000000000009, 2.0000000000000000, 5.0000000000000000,
+ 3.0000000000000000 },
+ { 6.8998265656072721, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000 },
+ { 12.377330619077886, 2.0000000000000000, 5.0000000000000000,
+ 5.0000000000000000 },
+ { 23.023821860707503, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000 },
+ { 44.261883885519374, 2.0000000000000000, 5.0000000000000000,
+ 7.0000000000000000 },
+ { 87.631581651613160, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000 },
+ { 178.07042913745681, 2.0000000000000000, 5.0000000000000000,
+ 9.0000000000000000 },
+ { 370.21982535275242, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=2.0000000000000000, c=5.0000000000000000.
+template <typename Tp>
+void test035()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data035)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data035[i].a), Tp(data035[i].c),
+ Tp(data035[i].x));
+ const Tp f0 = data035[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, c=6.0000000000000000.
+testcase_conf_hyperg<double> data036[] = {
+ { 0.11120076271882003, 2.0000000000000000, 6.0000000000000000,
+ -10.000000000000000 },
+ { 0.12904862943139384, 2.0000000000000000, 6.0000000000000000,
+ -9.0000000000000000 },
+ { 0.15138192951001525, 2.0000000000000000, 6.0000000000000000,
+ -8.0000000000000000 },
+ { 0.17975865319179699, 2.0000000000000000, 6.0000000000000000,
+ -7.0000000000000000 },
+ { 0.21643190620010283, 2.0000000000000000, 6.0000000000000000,
+ -6.0000000000000000 },
+ { 0.26472863448288397, 2.0000000000000000, 6.0000000000000000,
+ -5.0000000000000000 },
+ { 0.32967091145818839, 2.0000000000000000, 6.0000000000000000,
+ -4.0000000000000000 },
+ { 0.41901702645681349, 2.0000000000000000, 6.0000000000000000,
+ -3.0000000000000000 },
+ { 0.54504387282378575, 2.0000000000000000, 6.0000000000000000,
+ -2.0000000000000000 },
+ { 0.72766470286539298, 2.0000000000000000, 6.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 6.0000000000000000,
+ 0.0000000000000000 },
+ { 1.4185417547437151, 2.0000000000000000, 6.0000000000000000,
+ 1.0000000000000000 },
+ { 2.0820792580201224, 2.0000000000000000, 6.0000000000000000,
+ 2.0000000000000000 },
+ { 3.1676360873147318, 2.0000000000000000, 6.0000000000000000,
+ 3.0000000000000000 },
+ { 4.9999999999999982, 2.0000000000000000, 6.0000000000000000,
+ 4.0000000000000000 },
+ { 8.1886653095389406, 2.0000000000000000, 6.0000000000000000,
+ 5.0000000000000000 },
+ { 13.902123255948611, 2.0000000000000000, 6.0000000000000000,
+ 6.0000000000000000 },
+ { 24.426009224385378, 2.0000000000000000, 6.0000000000000000,
+ 7.0000000000000000 },
+ { 44.315790825806538, 2.0000000000000000, 6.0000000000000000,
+ 8.0000000000000000 },
+ { 82.810383859933609, 2.0000000000000000, 6.0000000000000000,
+ 9.0000000000000000 },
+ { 158.95135372260788, 2.0000000000000000, 6.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=2.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test036()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data036)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data036[i].a), Tp(data036[i].c),
+ Tp(data036[i].x));
+ const Tp f0 = data036[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, c=7.0000000000000000.
+testcase_conf_hyperg<double> data037[] = {
+ { 0.14279950968075858, 2.0000000000000000, 7.0000000000000000,
+ -10.000000000000000 },
+ { 0.16375995835694801, 2.0000000000000000, 7.0000000000000000,
+ -9.0000000000000000 },
+ { 0.18950218227311263, 2.0000000000000000, 7.0000000000000000,
+ -8.0000000000000000 },
+ { 0.22152437623624174, 2.0000000000000000, 7.0000000000000000,
+ -7.0000000000000000 },
+ { 0.26192490317988687, 2.0000000000000000, 7.0000000000000000,
+ -6.0000000000000000 },
+ { 0.31369515402282139, 2.0000000000000000, 7.0000000000000000,
+ -5.0000000000000000 },
+ { 0.38118033691430731, 2.0000000000000000, 7.0000000000000000,
+ -4.0000000000000000 },
+ { 0.47081822524156886, 2.0000000000000000, 7.0000000000000000,
+ -3.0000000000000000 },
+ { 0.59234644511675072, 2.0000000000000000, 7.0000000000000000,
+ -2.0000000000000000 },
+ { 0.76081413936917086, 2.0000000000000000, 7.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 7.0000000000000000,
+ 0.0000000000000000 },
+ { 1.3483340379497220, 2.0000000000000000, 7.0000000000000000,
+ 1.0000000000000000 },
+ { 1.8693566610905543, 2.0000000000000000, 7.0000000000000000,
+ 2.0000000000000000 },
+ { 2.6705443492589280, 2.0000000000000000, 7.0000000000000000,
+ 3.0000000000000000 },
+ { 3.9378251894863650, 2.0000000000000000, 7.0000000000000000,
+ 4.0000000000000000 },
+ { 6.0000000000000018, 2.0000000000000000, 7.0000000000000000,
+ 5.0000000000000000 },
+ { 9.4510616279743118, 2.0000000000000000, 7.0000000000000000,
+ 6.0000000000000000 },
+ { 15.386290985363090, 2.0000000000000000, 7.0000000000000000,
+ 7.0000000000000000 },
+ { 25.865132339516244, 2.0000000000000000, 7.0000000000000000,
+ 8.0000000000000000 },
+ { 44.832204725298020, 2.0000000000000000, 7.0000000000000000,
+ 9.0000000000000000 },
+ { 79.975676861303967, 2.0000000000000000, 7.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=2.0000000000000000, c=7.0000000000000000.
+template <typename Tp>
+void test037()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data037)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data037[i].a), Tp(data037[i].c),
+ Tp(data037[i].x));
+ const Tp f0 = data037[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, c=8.0000000000000000.
+testcase_conf_hyperg<double> data038[] = {
+ { 0.17337636610503362, 2.0000000000000000, 8.0000000000000000,
+ -10.000000000000000 },
+ { 0.19686670136921000, 2.0000000000000000, 8.0000000000000000,
+ -9.0000000000000000 },
+ { 0.22527678978110538, 2.0000000000000000, 8.0000000000000000,
+ -8.0000000000000000 },
+ { 0.26001525907740475, 2.0000000000000000, 8.0000000000000000,
+ -7.0000000000000000 },
+ { 0.30300466868014397, 2.0000000000000000, 8.0000000000000000,
+ -6.0000000000000000 },
+ { 0.35690946280485503, 2.0000000000000000, 8.0000000000000000,
+ -5.0000000000000000 },
+ { 0.42548267822218039, 2.0000000000000000, 8.0000000000000000,
+ -4.0000000000000000 },
+ { 0.51410215874088183, 2.0000000000000000, 8.0000000000000000,
+ -3.0000000000000000 },
+ { 0.63061421953299790, 2.0000000000000000, 8.0000000000000000,
+ -2.0000000000000000 },
+ { 0.78668452848510595, 2.0000000000000000, 8.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 8.0000000000000000,
+ 0.0000000000000000 },
+ { 1.2979228320600693, 2.0000000000000000, 8.0000000000000000,
+ 1.0000000000000000 },
+ { 1.7236644184225898, 2.0000000000000000, 8.0000000000000000,
+ 2.0000000000000000 },
+ { 2.3469052224062485, 2.0000000000000000, 8.0000000000000000,
+ 3.0000000000000000 },
+ { 3.2823881632022749, 2.0000000000000000, 8.0000000000000000,
+ 4.0000000000000000 },
+ { 4.7230422799745782, 2.0000000000000000, 8.0000000000000000,
+ 5.0000000000000000 },
+ { 7.0000000000000009, 2.0000000000000000, 8.0000000000000000,
+ 6.0000000000000000 },
+ { 10.693145492681536, 2.0000000000000000, 8.0000000000000000,
+ 7.0000000000000000 },
+ { 16.837993864717802, 2.0000000000000000, 8.0000000000000000,
+ 8.0000000000000000 },
+ { 27.318786089757165, 2.0000000000000000, 8.0000000000000000,
+ 9.0000000000000000 },
+ { 45.626379042330321, 2.0000000000000000, 8.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=2.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test038()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data038)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data038[i].a), Tp(data038[i].c),
+ Tp(data038[i].x));
+ const Tp f0 = data038[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, c=9.0000000000000000.
+testcase_conf_hyperg<double> data039[] = {
+ { 0.20263008881072142, 2.0000000000000000, 9.0000000000000000,
+ -10.000000000000000 },
+ { 0.22815601647956382, 2.0000000000000000, 9.0000000000000000,
+ -9.0000000000000000 },
+ { 0.25863201094881560, 2.0000000000000000, 9.0000000000000000,
+ -8.0000000000000000 },
+ { 0.29536583498165569, 2.0000000000000000, 9.0000000000000000,
+ -7.0000000000000000 },
+ { 0.34010436746201422, 2.0000000000000000, 9.0000000000000000,
+ -6.0000000000000000 },
+ { 0.39521257401334392, 2.0000000000000000, 9.0000000000000000,
+ -5.0000000000000000 },
+ { 0.46393810791120338, 2.0000000000000000, 9.0000000000000000,
+ -4.0000000000000000 },
+ { 0.55080841854553553, 2.0000000000000000, 9.0000000000000000,
+ -3.0000000000000000 },
+ { 0.66223601210150940, 2.0000000000000000, 9.0000000000000000,
+ -2.0000000000000000 },
+ { 0.80745573956474603, 2.0000000000000000, 9.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 9.0000000000000000,
+ 0.0000000000000000 },
+ { 1.2600591877766618, 2.0000000000000000, 9.0000000000000000,
+ 1.0000000000000000 },
+ { 1.6183220921129462, 2.0000000000000000, 9.0000000000000000,
+ 2.0000000000000000 },
+ { 2.1223296796666578, 2.0000000000000000, 9.0000000000000000,
+ 3.0000000000000000 },
+ { 2.8471644896068233, 2.0000000000000000, 9.0000000000000000,
+ 4.0000000000000000 },
+ { 3.9137352959186495, 2.0000000000000000, 9.0000000000000000,
+ 5.0000000000000000 },
+ { 5.5205708009288541, 2.0000000000000000, 9.0000000000000000,
+ 6.0000000000000000 },
+ { 7.9999999999999982, 2.0000000000000000, 9.0000000000000000,
+ 7.0000000000000000 },
+ { 11.918996932358892, 2.0000000000000000, 9.0000000000000000,
+ 8.0000000000000000 },
+ { 18.262984349485706, 2.0000000000000000, 9.0000000000000000,
+ 9.0000000000000000 },
+ { 28.775827425398138, 2.0000000000000000, 9.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=2.0000000000000000, c=9.0000000000000000.
+template <typename Tp>
+void test039()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data039)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data039[i].a), Tp(data039[i].c),
+ Tp(data039[i].x));
+ const Tp f0 = data039[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, c=10.000000000000000.
+testcase_conf_hyperg<double> data040[] = {
+ { 0.23043485654507717, 2.0000000000000000, 10.000000000000000,
+ -10.000000000000000 },
+ { 0.25758423249046342, 2.0000000000000000, 10.000000000000000,
+ -9.0000000000000000 },
+ { 0.28964158686142122, 2.0000000000000000, 10.000000000000000,
+ -8.0000000000000000 },
+ { 0.32781237017833142, 2.0000000000000000, 10.000000000000000,
+ -7.0000000000000000 },
+ { 0.37367756025366927, 2.0000000000000000, 10.000000000000000,
+ -6.0000000000000000 },
+ { 0.42933548067397925, 2.0000000000000000, 10.000000000000000,
+ -5.0000000000000000 },
+ { 0.49760646239977369, 2.0000000000000000, 10.000000000000000,
+ -4.0000000000000000 },
+ { 0.58233221879973318, 2.0000000000000000, 10.000000000000000,
+ -3.0000000000000000 },
+ { 0.68881993949245379, 2.0000000000000000, 10.000000000000000,
+ -2.0000000000000000 },
+ { 0.82451063690694526, 2.0000000000000000, 10.000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 10.000000000000000,
+ 0.0000000000000000 },
+ { 1.2306214716549471, 2.0000000000000000, 10.000000000000000,
+ 1.0000000000000000 },
+ { 1.5389392974099088, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000 },
+ { 1.9587362987499699, 2.0000000000000000, 10.000000000000000,
+ 3.0000000000000000 },
+ { 2.5414934688204727, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000 },
+ { 3.3670852989803555, 2.0000000000000000, 10.000000000000000,
+ 5.0000000000000000 },
+ { 4.5617124027865650, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000 },
+ { 6.3284392760597825, 2.0000000000000000, 10.000000000000000,
+ 7.0000000000000000 },
+ { 9.0000000000000036, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000 },
+ { 13.131492174742865, 2.0000000000000000, 10.000000000000000,
+ 9.0000000000000000 },
+ { 19.665496455238888, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=2.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test040()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data040)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data040[i].a), Tp(data040[i].c),
+ Tp(data040[i].x));
+ const Tp f0 = data040[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, c=1.0000000000000000.
+testcase_conf_hyperg<double> data041[] = {
+ { 0.00049939922738733355, 5.0000000000000000, 1.0000000000000000,
+ -10.000000000000000 },
+ { -0.00057077034390089253, 5.0000000000000000, 1.0000000000000000,
+ -9.0000000000000000 },
+ { -0.0032428054030576147, 5.0000000000000000, 1.0000000000000000,
+ -8.0000000000000000 },
+ { -0.0078649819529077025, 5.0000000000000000, 1.0000000000000000,
+ -7.0000000000000000 },
+ { -0.012393760883331793, 5.0000000000000000, 1.0000000000000000,
+ -6.0000000000000000 },
+ { -0.0087031815404853934, 5.0000000000000000, 1.0000000000000000,
+ -5.0000000000000000 },
+ { 0.018315638888832021, 5.0000000000000000, 1.0000000000000000,
+ -4.0000000000000000 },
+ { 0.068457219005814696, 5.0000000000000000, 1.0000000000000000,
+ -3.0000000000000000 },
+ { 0.045111761078875295, 5.0000000000000000, 1.0000000000000000,
+ -2.0000000000000000 },
+ { -0.22992465073215118, 5.0000000000000000, 1.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 1.0000000000000000,
+ 0.0000000000000000 },
+ { 23.671704256164183, 5.0000000000000000, 1.0000000000000000,
+ 1.0000000000000000 },
+ { 199.50451467112745, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000 },
+ { 1232.7498286606428, 5.0000000000000000, 1.0000000000000000,
+ 3.0000000000000000 },
+ { 6460.7810872554019, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000 },
+ { 30480.352550691667, 5.0000000000000000, 1.0000000000000000,
+ 5.0000000000000000 },
+ { 133534.93064609534, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000 },
+ { 553479.89366849652, 5.0000000000000000, 1.0000000000000000,
+ 7.0000000000000000 },
+ { 2196966.0364497532, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000 },
+ { 8422142.8572236635, 5.0000000000000000, 1.0000000000000000,
+ 9.0000000000000000 },
+ { 31373029.447069697, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=5.0000000000000000, c=1.0000000000000000.
+template <typename Tp>
+void test041()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data041)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data041[i].a), Tp(data041[i].c),
+ Tp(data041[i].x));
+ const Tp f0 = data041[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000034e-10));
+}
+
+// Test data for a=5.0000000000000000, c=2.0000000000000000.
+testcase_conf_hyperg<double> data042[] = {
+ { -0.00025726626865408083, 5.0000000000000000, 2.0000000000000000,
+ -10.000000000000000 },
+ { -0.00029309828470586396, 5.0000000000000000, 2.0000000000000000,
+ -9.0000000000000000 },
+ { -0.00011182087596750395, 5.0000000000000000, 2.0000000000000000,
+ -8.0000000000000000 },
+ { 0.00064591639226778245, 5.0000000000000000, 2.0000000000000000,
+ -7.0000000000000000 },
+ { 0.0024787521766663585, 5.0000000000000000, 2.0000000000000000,
+ -6.0000000000000000 },
+ { 0.0053342080409426616, 5.0000000000000000, 2.0000000000000000,
+ -5.0000000000000000 },
+ { 0.0061052129629022966, 5.0000000000000000, 2.0000000000000000,
+ -4.0000000000000000 },
+ { -0.0062233835459823200, 5.0000000000000000, 2.0000000000000000,
+ -3.0000000000000000 },
+ { -0.045111761078871798, 5.0000000000000000, 2.0000000000000000,
+ -2.0000000000000000 },
+ { -0.015328310048810216, 5.0000000000000000, 2.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 2.0000000000000000,
+ 0.0000000000000000 },
+ { 8.2681072282295975, 5.0000000000000000, 2.0000000000000000,
+ 1.0000000000000000 },
+ { 46.797355293227440, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000 },
+ { 223.45159827046285, 5.0000000000000000, 2.0000000000000000,
+ 3.0000000000000000 },
+ { 964.56731725221459, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000 },
+ { 3889.6615448133625, 5.0000000000000000, 2.0000000000000000,
+ 5.0000000000000000 },
+ { 14926.865359231202, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000 },
+ { 55151.509259297891, 5.0000000000000000, 2.0000000000000000,
+ 7.0000000000000000 },
+ { 197736.87980710136, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000 },
+ { 691800.79031674843, 5.0000000000000000, 2.0000000000000000,
+ 9.0000000000000000 },
+ { 2371516.1505741901, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=5.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test042()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data042)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data042[i].a), Tp(data042[i].c),
+ Tp(data042[i].x));
+ const Tp f0 = data042[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-10));
+}
+
+// Test data for a=5.0000000000000000, c=3.0000000000000000.
+testcase_conf_hyperg<double> data043[] = {
+ { 0.00012106647936662629, 5.0000000000000000, 3.0000000000000000,
+ -10.000000000000000 },
+ { 0.00021596715715168925, 5.0000000000000000, 3.0000000000000000,
+ -9.0000000000000000 },
+ { 0.00033546262790251185, 5.0000000000000000, 3.0000000000000000,
+ -8.0000000000000000 },
+ { 0.00037995081898104839, 5.0000000000000000, 3.0000000000000000,
+ -7.0000000000000000 },
+ { 0.0000000000000000, 5.0000000000000000, 3.0000000000000000,
+ -6.0000000000000000 },
+ { -0.0016844867497713672, 5.0000000000000000, 3.0000000000000000,
+ -5.0000000000000000 },
+ { -0.0061052129629113917, 5.0000000000000000, 3.0000000000000000,
+ -4.0000000000000000 },
+ { -0.012446767091965986, 5.0000000000000000, 3.0000000000000000,
+ -3.0000000000000000 },
+ { 7.5126173746727200e-18, 5.0000000000000000, 3.0000000000000000,
+ -2.0000000000000000 },
+ { 0.15328310048810098, 5.0000000000000000, 3.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 3.0000000000000000,
+ 0.0000000000000000 },
+ { 4.7569931998033290, 5.0000000000000000, 3.0000000000000000,
+ 1.0000000000000000 },
+ { 19.704149597148401, 5.0000000000000000, 3.0000000000000000,
+ 2.0000000000000000 },
+ { 75.320763461953760, 5.0000000000000000, 3.0000000000000000,
+ 3.0000000000000000 },
+ { 272.99075016572118, 5.0000000000000000, 3.0000000000000000,
+ 4.0000000000000000 },
+ { 952.31777090819992, 5.0000000000000000, 3.0000000000000000,
+ 5.0000000000000000 },
+ { 3227.4303479418809, 5.0000000000000000, 3.0000000000000000,
+ 6.0000000000000000 },
+ { 10692.173294677470, 5.0000000000000000, 3.0000000000000000,
+ 7.0000000000000000 },
+ { 34777.843182153498, 5.0000000000000000, 3.0000000000000000,
+ 8.0000000000000000 },
+ { 111417.40400416154, 5.0000000000000000, 3.0000000000000000,
+ 9.0000000000000000 },
+ { 352423.45271690749, 5.0000000000000000, 3.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=5.0000000000000000, c=3.0000000000000000.
+template <typename Tp>
+void test043()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data043)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data043[i].a), Tp(data043[i].c),
+ Tp(data043[i].x));
+ const Tp f0 = data043[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000028e-11));
+}
+
+// Test data for a=5.0000000000000000, c=4.0000000000000000.
+testcase_conf_hyperg<double> data044[] = {
+ { -6.8099894643727278e-05, 5.0000000000000000, 4.0000000000000000,
+ -10.000000000000000 },
+ { -0.00015426225510834944, 5.0000000000000000, 4.0000000000000000,
+ -9.0000000000000000 },
+ { -0.00033546262790251185, 5.0000000000000000, 4.0000000000000000,
+ -8.0000000000000000 },
+ { -0.00068391147416588716, 5.0000000000000000, 4.0000000000000000,
+ -7.0000000000000000 },
+ { -0.0012393760883331792, 5.0000000000000000, 4.0000000000000000,
+ -6.0000000000000000 },
+ { -0.0016844867497713668, 5.0000000000000000, 4.0000000000000000,
+ -5.0000000000000000 },
+ { 0.0000000000000000, 5.0000000000000000, 4.0000000000000000,
+ -4.0000000000000000 },
+ { 0.012446767091965986, 5.0000000000000000, 4.0000000000000000,
+ -3.0000000000000000 },
+ { 0.067667641618306351, 5.0000000000000000, 4.0000000000000000,
+ -2.0000000000000000 },
+ { 0.27590958087858175, 5.0000000000000000, 4.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 4.0000000000000000,
+ 0.0000000000000000 },
+ { 3.3978522855738063, 5.0000000000000000, 4.0000000000000000,
+ 1.0000000000000000 },
+ { 11.083584148395975, 5.0000000000000000, 4.0000000000000000,
+ 2.0000000000000000 },
+ { 35.149689615578417, 5.0000000000000000, 4.0000000000000000,
+ 3.0000000000000000 },
+ { 109.19630006628847, 5.0000000000000000, 4.0000000000000000,
+ 4.0000000000000000 },
+ { 333.92960798079736, 5.0000000000000000, 4.0000000000000000,
+ 5.0000000000000000 },
+ { 1008.5719837318378, 5.0000000000000000, 4.0000000000000000,
+ 6.0000000000000000 },
+ { 3015.7411856782610, 5.0000000000000000, 4.0000000000000000,
+ 7.0000000000000000 },
+ { 8942.8739611251840, 5.0000000000000000, 4.0000000000000000,
+ 8.0000000000000000 },
+ { 26335.022764620000, 5.0000000000000000, 4.0000000000000000,
+ 9.0000000000000000 },
+ { 77092.630281823513, 5.0000000000000000, 4.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=5.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test044()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data044)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data044[i].a), Tp(data044[i].c),
+ Tp(data044[i].x));
+ const Tp f0 = data044[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000014e-11));
+}
+
+// Test data for a=5.0000000000000000, c=5.0000000000000000.
+testcase_conf_hyperg<double> data045[] = {
+ { 4.5399929762484854e-05, 5.0000000000000000, 5.0000000000000000,
+ -10.000000000000000 },
+ { 0.00012340980408667956, 5.0000000000000000, 5.0000000000000000,
+ -9.0000000000000000 },
+ { 0.00033546262790251185, 5.0000000000000000, 5.0000000000000000,
+ -8.0000000000000000 },
+ { 0.00091188196555451624, 5.0000000000000000, 5.0000000000000000,
+ -7.0000000000000000 },
+ { 0.0024787521766663585, 5.0000000000000000, 5.0000000000000000,
+ -6.0000000000000000 },
+ { 0.0067379469990854670, 5.0000000000000000, 5.0000000000000000,
+ -5.0000000000000000 },
+ { 0.018315638888734179, 5.0000000000000000, 5.0000000000000000,
+ -4.0000000000000000 },
+ { 0.049787068367863944, 5.0000000000000000, 5.0000000000000000,
+ -3.0000000000000000 },
+ { 0.13533528323661270, 5.0000000000000000, 5.0000000000000000,
+ -2.0000000000000000 },
+ { 0.36787944117144233, 5.0000000000000000, 5.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 5.0000000000000000,
+ 0.0000000000000000 },
+ { 2.7182818284590451, 5.0000000000000000, 5.0000000000000000,
+ 1.0000000000000000 },
+ { 7.3890560989306504, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000 },
+ { 20.085536923187668, 5.0000000000000000, 5.0000000000000000,
+ 3.0000000000000000 },
+ { 54.598150033144236, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000 },
+ { 148.41315910257660, 5.0000000000000000, 5.0000000000000000,
+ 5.0000000000000000 },
+ { 403.42879349273511, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000 },
+ { 1096.6331584284585, 5.0000000000000000, 5.0000000000000000,
+ 7.0000000000000000 },
+ { 2980.9579870417283, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000 },
+ { 8103.0839275753842, 5.0000000000000000, 5.0000000000000000,
+ 9.0000000000000000 },
+ { 22026.465794806718, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=5.0000000000000000, c=5.0000000000000000.
+template <typename Tp>
+void test045()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data045)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data045[i].a), Tp(data045[i].c),
+ Tp(data045[i].x));
+ const Tp f0 = data045[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, c=6.0000000000000000.
+testcase_conf_hyperg<double> data046[] = {
+ { 0.0011648967743076431, 5.0000000000000000, 6.0000000000000000,
+ -10.000000000000000 },
+ { 0.0019205128456127479, 5.0000000000000000, 6.0000000000000000,
+ -9.0000000000000000 },
+ { 0.0032972446271226320, 5.0000000000000000, 6.0000000000000000,
+ -8.0000000000000000 },
+ { 0.0059047424914709006, 5.0000000000000000, 6.0000000000000000,
+ -7.0000000000000000 },
+ { 0.011033078698817415, 5.0000000000000000, 6.0000000000000000,
+ -6.0000000000000000 },
+ { 0.021485057853495842, 5.0000000000000000, 6.0000000000000000,
+ -5.0000000000000000 },
+ { 0.043495671658608563, 5.0000000000000000, 6.0000000000000000,
+ -4.0000000000000000 },
+ { 0.091228027395668113, 5.0000000000000000, 6.0000000000000000,
+ -3.0000000000000000 },
+ { 0.19744881503891684, 5.0000000000000000, 6.0000000000000000,
+ -2.0000000000000000 },
+ { 0.43918161928124549, 5.0000000000000000, 6.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 6.0000000000000000,
+ 0.0000000000000000 },
+ { 2.3226822806570353, 5.0000000000000000, 6.0000000000000000,
+ 1.0000000000000000 },
+ { 5.4863201236633126, 5.0000000000000000, 6.0000000000000000,
+ 2.0000000000000000 },
+ { 13.144500379942246, 5.0000000000000000, 6.0000000000000000,
+ 3.0000000000000000 },
+ { 31.873916035045447, 5.0000000000000000, 6.0000000000000000,
+ 4.0000000000000000 },
+ { 78.086286951596321, 5.0000000000000000, 6.0000000000000000,
+ 5.0000000000000000 },
+ { 192.98291046720354, 5.0000000000000000, 6.0000000000000000,
+ 6.0000000000000000 },
+ { 480.54877204888402, 5.0000000000000000, 6.0000000000000000,
+ 7.0000000000000000 },
+ { 1204.4605636118313, 5.0000000000000000, 6.0000000000000000,
+ 8.0000000000000000 },
+ { 3036.1329048350581, 5.0000000000000000, 6.0000000000000000,
+ 9.0000000000000000 },
+ { 7691.6406555465064, 5.0000000000000000, 6.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=5.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test046()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data046)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data046[i].a), Tp(data046[i].c),
+ Tp(data046[i].x));
+ const Tp f0 = data046[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-11));
+}
+
+// Test data for a=5.0000000000000000, c=7.0000000000000000.
+testcase_conf_hyperg<double> data047[] = {
+ { 0.0036308901122103932, 5.0000000000000000, 7.0000000000000000,
+ -10.000000000000000 },
+ { 0.0055327336019229401, 5.0000000000000000, 7.0000000000000000,
+ -9.0000000000000000 },
+ { 0.0086767852656603455, 5.0000000000000000, 7.0000000000000000,
+ -8.0000000000000000 },
+ { 0.014030481266326614, 5.0000000000000000, 7.0000000000000000,
+ -7.0000000000000000 },
+ { 0.023426839582149212, 5.0000000000000000, 7.0000000000000000,
+ -6.0000000000000000 },
+ { 0.040427681994512799, 5.0000000000000000, 7.0000000000000000,
+ -5.0000000000000000 },
+ { 0.072123784177593755, 5.0000000000000000, 7.0000000000000000,
+ -4.0000000000000000 },
+ { 0.13295857409596740, 5.0000000000000000, 7.0000000000000000,
+ -3.0000000000000000 },
+ { 0.25298991319893882, 5.0000000000000000, 7.0000000000000000,
+ -2.0000000000000000 },
+ { 0.49602437239337821, 5.0000000000000000, 7.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 7.0000000000000000,
+ 0.0000000000000000 },
+ { 2.0681072498819240, 5.0000000000000000, 7.0000000000000000,
+ 1.0000000000000000 },
+ { 4.3768811129698140, 5.0000000000000000, 7.0000000000000000,
+ 2.0000000000000000 },
+ { 9.4566368471992224, 5.0000000000000000, 7.0000000000000000,
+ 3.0000000000000000 },
+ { 20.811741224531826, 5.0000000000000000, 7.0000000000000000,
+ 4.0000000000000000 },
+ { 46.556488803696276, 5.0000000000000000, 7.0000000000000000,
+ 5.0000000000000000 },
+ { 105.66804767556316, 5.0000000000000000, 7.0000000000000000,
+ 6.0000000000000000 },
+ { 242.93097638084427, 5.0000000000000000, 7.0000000000000000,
+ 7.0000000000000000 },
+ { 564.89804380887358, 5.0000000000000000, 7.0000000000000000,
+ 8.0000000000000000 },
+ { 1326.9606865425994, 5.0000000000000000, 7.0000000000000000,
+ 9.0000000000000000 },
+ { 3145.3685154983909, 5.0000000000000000, 7.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=5.0000000000000000, c=7.0000000000000000.
+template <typename Tp>
+void test047()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data047)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data047[i].a), Tp(data047[i].c),
+ Tp(data047[i].x));
+ const Tp f0 = data047[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000029e-12));
+}
+
+// Test data for a=5.0000000000000000, c=8.0000000000000000.
+testcase_conf_hyperg<double> data048[] = {
+ { 0.0075295293831406122, 5.0000000000000000, 8.0000000000000000,
+ -10.000000000000000 },
+ { 0.010936052508673187, 5.0000000000000000, 8.0000000000000000,
+ -9.0000000000000000 },
+ { 0.016247454253649721, 5.0000000000000000, 8.0000000000000000,
+ -8.0000000000000000 },
+ { 0.024729468107576008, 5.0000000000000000, 8.0000000000000000,
+ -7.0000000000000000 },
+ { 0.038615775445860964, 5.0000000000000000, 8.0000000000000000,
+ -6.0000000000000000 },
+ { 0.061937865588523586, 5.0000000000000000, 8.0000000000000000,
+ -5.0000000000000000 },
+ { 0.10213565389690644, 5.0000000000000000, 8.0000000000000000,
+ -4.0000000000000000 },
+ { 0.17324118243379236, 5.0000000000000000, 8.0000000000000000,
+ -3.0000000000000000 },
+ { 0.30228316551605494, 5.0000000000000000, 8.0000000000000000,
+ -2.0000000000000000 },
+ { 0.54238748802203829, 5.0000000000000000, 8.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 8.0000000000000000,
+ 0.0000000000000000 },
+ { 1.8922997283093959, 5.0000000000000000, 8.0000000000000000,
+ 1.0000000000000000 },
+ { 3.6699742831126270, 5.0000000000000000, 8.0000000000000000,
+ 2.0000000000000000 },
+ { 7.2831842359960941, 5.0000000000000000, 8.0000000000000000,
+ 3.0000000000000000 },
+ { 14.764676530664770, 5.0000000000000000, 8.0000000000000000,
+ 4.0000000000000000 },
+ { 30.522558591756702, 5.0000000000000000, 8.0000000000000000,
+ 5.0000000000000000 },
+ { 64.236147093730224, 5.0000000000000000, 8.0000000000000000,
+ 6.0000000000000000 },
+ { 137.40503032883328, 5.0000000000000000, 8.0000000000000000,
+ 7.0000000000000000 },
+ { 298.29153884828759, 5.0000000000000000, 8.0000000000000000,
+ 8.0000000000000000 },
+ { 656.29389355002741, 5.0000000000000000, 8.0000000000000000,
+ 9.0000000000000000 },
+ { 1461.6183101433730, 5.0000000000000000, 8.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=5.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test048()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data048)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data048[i].a), Tp(data048[i].c),
+ Tp(data048[i].x));
+ const Tp f0 = data048[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000015e-12));
+}
+
+// Test data for a=5.0000000000000000, c=9.0000000000000000.
+testcase_conf_hyperg<double> data049[] = {
+ { 0.012801285049305222, 5.0000000000000000, 9.0000000000000000,
+ -10.000000000000000 },
+ { 0.017955923031350202, 5.0000000000000000, 9.0000000000000000,
+ -9.0000000000000000 },
+ { 0.025661650371090718, 5.0000000000000000, 9.0000000000000000,
+ -8.0000000000000000 },
+ { 0.037414616710204310, 5.0000000000000000, 9.0000000000000000,
+ -7.0000000000000000 },
+ { 0.055720934057414885, 5.0000000000000000, 9.0000000000000000,
+ -6.0000000000000000 },
+ { 0.084862956151755986, 5.0000000000000000, 9.0000000000000000,
+ -5.0000000000000000 },
+ { 0.13230635170162319, 5.0000000000000000, 9.0000000000000000,
+ -4.0000000000000000 },
+ { 0.21132914572142125, 5.0000000000000000, 9.0000000000000000,
+ -3.0000000000000000 },
+ { 0.34601808641639625, 5.0000000000000000, 9.0000000000000000,
+ -2.0000000000000000 },
+ { 0.58092180965710882, 5.0000000000000000, 9.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 9.0000000000000000,
+ 0.0000000000000000 },
+ { 1.7643922061378634, 5.0000000000000000, 9.0000000000000000,
+ 1.0000000000000000 },
+ { 3.1888010096332451, 5.0000000000000000, 9.0000000000000000,
+ 2.0000000000000000 },
+ { 5.8981194929479273, 5.0000000000000000, 9.0000000000000000,
+ 3.0000000000000000 },
+ { 11.152835510393174, 5.0000000000000000, 9.0000000000000000,
+ 4.0000000000000000 },
+ { 21.533483453443495, 5.0000000000000000, 9.0000000000000000,
+ 5.0000000000000000 },
+ { 42.397145995355721, 5.0000000000000000, 9.0000000000000000,
+ 6.0000000000000000 },
+ { 85.010891404859976, 5.0000000000000000, 9.0000000000000000,
+ 7.0000000000000000 },
+ { 173.36225868739959, 5.0000000000000000, 9.0000000000000000,
+ 8.0000000000000000 },
+ { 359.10444177844266, 5.0000000000000000, 9.0000000000000000,
+ 9.0000000000000000 },
+ { 754.64844371961385, 5.0000000000000000, 9.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=5.0000000000000000, c=9.0000000000000000.
+template <typename Tp>
+void test049()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data049)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data049[i].a), Tp(data049[i].c),
+ Tp(data049[i].x));
+ const Tp f0 = data049[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for a=5.0000000000000000, c=10.000000000000000.
+testcase_conf_hyperg<double> data050[] = {
+ { 0.019313731161840469, 5.0000000000000000, 10.000000000000000,
+ -10.000000000000000 },
+ { 0.026361085775183927, 5.0000000000000000, 10.000000000000000,
+ -9.0000000000000000 },
+ { 0.036556772070711910, 5.0000000000000000, 10.000000000000000,
+ -8.0000000000000000 },
+ { 0.051563934048344140, 5.0000000000000000, 10.000000000000000,
+ -7.0000000000000000 },
+ { 0.074056625794521824, 5.0000000000000000, 10.000000000000000,
+ -6.0000000000000000 },
+ { 0.10841132531381445, 5.0000000000000000, 10.000000000000000,
+ -5.0000000000000000 },
+ { 0.16192115120742598, 5.0000000000000000, 10.000000000000000,
+ -4.0000000000000000 },
+ { 0.24696279814742436, 5.0000000000000000, 10.000000000000000,
+ -3.0000000000000000 },
+ { 0.38492640633381947, 5.0000000000000000, 10.000000000000000,
+ -2.0000000000000000 },
+ { 0.61345628229723270, 5.0000000000000000, 10.000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 10.000000000000000,
+ 0.0000000000000000 },
+ { 1.6675470647226096, 5.0000000000000000, 10.000000000000000,
+ 1.0000000000000000 },
+ { 2.8442428103603667, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000 },
+ { 4.9603804008438397, 5.0000000000000000, 10.000000000000000,
+ 3.0000000000000000 },
+ { 8.8405953071624790, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000 },
+ { 16.089667272320334, 5.0000000000000000, 10.000000000000000,
+ 5.0000000000000000 },
+ { 29.876575194426895, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000 },
+ { 56.546719856432318, 5.0000000000000000, 10.000000000000000,
+ 7.0000000000000000 },
+ { 108.97420168465270, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000 },
+ { 213.60609045832913, 5.0000000000000000, 10.000000000000000,
+ 9.0000000000000000 },
+ { 425.41323880637168, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=5.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test050()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data050)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data050[i].a), Tp(data050[i].c),
+ Tp(data050[i].x));
+ const Tp f0 = data050[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for a=10.000000000000000, c=1.0000000000000000.
+testcase_conf_hyperg<double> data051[] = {
+ { 0.00067155063653961283, 10.000000000000000, 1.0000000000000000,
+ -10.000000000000000 },
+ { -0.00071555648905258641, 10.000000000000000, 1.0000000000000000,
+ -9.0000000000000000 },
+ { -0.0035372078786207375, 10.000000000000000, 1.0000000000000000,
+ -8.0000000000000000 },
+ { -0.0047884005574714370, 10.000000000000000, 1.0000000000000000,
+ -7.0000000000000000 },
+ { 0.0024787521766663585, 10.000000000000000, 1.0000000000000000,
+ -6.0000000000000000 },
+ { 0.018136827242522878, 10.000000000000000, 1.0000000000000000,
+ -5.0000000000000000 },
+ { 0.0099686175680129968, 10.000000000000000, 1.0000000000000000,
+ -4.0000000000000000 },
+ { -0.052832081031434205, 10.000000000000000, 1.0000000000000000,
+ -3.0000000000000000 },
+ { 0.0010979582061524211, 10.000000000000000, 1.0000000000000000,
+ -2.0000000000000000 },
+ { 0.11394854824644544, 10.000000000000000, 1.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 1.0000000000000000,
+ 0.0000000000000000 },
+ { 131.63017574352625, 10.000000000000000, 1.0000000000000000,
+ 1.0000000000000000 },
+ { 2431.2913698755492, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000 },
+ { 27127.328899791049, 10.000000000000000, 1.0000000000000000,
+ 3.0000000000000000 },
+ { 232066.49977835573, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000 },
+ { 1674401.3794931532, 10.000000000000000, 1.0000000000000000,
+ 5.0000000000000000 },
+ { 10707495.820386337, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000 },
+ { 62515499.242815509, 10.000000000000000, 1.0000000000000000,
+ 7.0000000000000000 },
+ { 339773485.00937450, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000 },
+ { 1742442474.2135217, 10.000000000000000, 1.0000000000000000,
+ 9.0000000000000000 },
+ { 8514625476.5462780, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=10.000000000000000, c=1.0000000000000000.
+template <typename Tp>
+void test051()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data051)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data051[i].a), Tp(data051[i].c),
+ Tp(data051[i].x));
+ const Tp f0 = data051[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000029e-12));
+}
+
+// Test data for a=10.000000000000000, c=2.0000000000000000.
+testcase_conf_hyperg<double> data052[] = {
+ { -0.00014116415550486912, 10.000000000000000, 2.0000000000000000,
+ -10.000000000000000 },
+ { -0.00016988130843806985, 10.000000000000000, 2.0000000000000000,
+ -9.0000000000000000 },
+ { 6.6619209703391391e-05, 10.000000000000000, 2.0000000000000000,
+ -8.0000000000000000 },
+ { 0.00072582919646365740, 10.000000000000000, 2.0000000000000000,
+ -7.0000000000000000 },
+ { 0.0012039653429522313, 10.000000000000000, 2.0000000000000000,
+ -6.0000000000000000 },
+ { -0.00061450715370021350, 10.000000000000000, 2.0000000000000000,
+ -5.0000000000000000 },
+ { -0.0053557899960354968, 10.000000000000000, 2.0000000000000000,
+ -4.0000000000000000 },
+ { -0.00078903612815141419, 10.000000000000000, 2.0000000000000000,
+ -3.0000000000000000 },
+ { 0.023725444715554326, 10.000000000000000, 2.0000000000000000,
+ -2.0000000000000000 },
+ { -0.057297669024384767, 10.000000000000000, 2.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 2.0000000000000000,
+ 0.0000000000000000 },
+ { 34.432116659636534, 10.000000000000000, 2.0000000000000000,
+ 1.0000000000000000 },
+ { 432.53475371634494, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000 },
+ { 3789.1768909683515, 10.000000000000000, 2.0000000000000000,
+ 3.0000000000000000 },
+ { 27089.676185774806, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000 },
+ { 169243.72183073507, 10.000000000000000, 2.0000000000000000,
+ 5.0000000000000000 },
+ { 959019.40135397331, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000 },
+ { 5043073.3458297960, 10.000000000000000, 2.0000000000000000,
+ 7.0000000000000000 },
+ { 24989309.819281481, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000 },
+ { 117948708.50540228, 10.000000000000000, 2.0000000000000000,
+ 9.0000000000000000 },
+ { 534524325.69810420, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=10.000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test052()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data052)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data052[i].a), Tp(data052[i].c),
+ Tp(data052[i].x));
+ const Tp f0 = data052[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000017e-10));
+}
+
+// Test data for a=10.000000000000000, c=3.0000000000000000.
+testcase_conf_hyperg<double> data053[] = {
+ { 1.4973169075105230e-05, 10.000000000000000, 3.0000000000000000,
+ -10.000000000000000 },
+ { 5.7627971015476259e-05, 10.000000000000000, 3.0000000000000000,
+ -9.0000000000000000 },
+ { 9.5964794084281178e-05, 10.000000000000000, 3.0000000000000000,
+ -8.0000000000000000 },
+ { 1.5479477810339013e-05, 10.000000000000000, 3.0000000000000000,
+ -7.0000000000000000 },
+ { -0.00035410745380947978, 10.000000000000000, 3.0000000000000000,
+ -6.0000000000000000 },
+ { -0.00078393993138610115, 10.000000000000000, 3.0000000000000000,
+ -5.0000000000000000 },
+ { 0.00038117202625584341, 10.000000000000000, 3.0000000000000000,
+ -4.0000000000000000 },
+ { 0.0045341794406447526, 10.000000000000000, 3.0000000000000000,
+ -3.0000000000000000 },
+ { -0.0031029253652133434, 10.000000000000000, 3.0000000000000000,
+ -2.0000000000000000 },
+ { -0.028487137061611361, 10.000000000000000, 3.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 3.0000000000000000,
+ 0.0000000000000000 },
+ { 15.691485606063281, 10.000000000000000, 3.0000000000000000,
+ 1.0000000000000000 },
+ { 141.71088859081422, 10.000000000000000, 3.0000000000000000,
+ 2.0000000000000000 },
+ { 997.55177799313742, 10.000000000000000, 3.0000000000000000,
+ 3.0000000000000000 },
+ { 6038.6324280926056, 10.000000000000000, 3.0000000000000000,
+ 4.0000000000000000 },
+ { 32946.952425437157, 10.000000000000000, 3.0000000000000000,
+ 5.0000000000000000 },
+ { 166431.66712118863, 10.000000000000000, 3.0000000000000000,
+ 6.0000000000000000 },
+ { 791818.30272061308, 10.000000000000000, 3.0000000000000000,
+ 7.0000000000000000 },
+ { 3589678.0198700386, 10.000000000000000, 3.0000000000000000,
+ 8.0000000000000000 },
+ { 15637649.698874988, 10.000000000000000, 3.0000000000000000,
+ 9.0000000000000000 },
+ { 65871447.346678361, 10.000000000000000, 3.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=10.000000000000000, c=3.0000000000000000.
+template <typename Tp>
+void test053()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data053)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data053[i].a), Tp(data053[i].c),
+ Tp(data053[i].x));
+ const Tp f0 = data053[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000013e-09));
+}
+
+// Test data for a=10.000000000000000, c=4.0000000000000000.
+testcase_conf_hyperg<double> data054[] = {
+ { 6.9661267889527031e-06, 10.000000000000000, 4.0000000000000000,
+ -10.000000000000000 },
+ { -3.0301514396282926e-06, 10.000000000000000, 4.0000000000000000,
+ -9.0000000000000000 },
+ { -3.7983599138168025e-05, 10.000000000000000, 4.0000000000000000,
+ -8.0000000000000000 },
+ { -9.3615660121163871e-05, 10.000000000000000, 4.0000000000000000,
+ -7.0000000000000000 },
+ { -7.0821490761895943e-05, 10.000000000000000, 4.0000000000000000,
+ -6.0000000000000000 },
+ { 0.00030692863727646260, 10.000000000000000, 4.0000000000000000,
+ -5.0000000000000000 },
+ { 0.0010659895649527829, 10.000000000000000, 4.0000000000000000,
+ -4.0000000000000000 },
+ { -0.00042230102633456065, 10.000000000000000, 4.0000000000000000,
+ -3.0000000000000000 },
+ { -0.010168047735237568, 10.000000000000000, 4.0000000000000000,
+ -2.0000000000000000 },
+ { 0.036903514708782073, 10.000000000000000, 4.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 4.0000000000000000,
+ 0.0000000000000000 },
+ { 9.3384756433214022, 10.000000000000000, 4.0000000000000000,
+ 1.0000000000000000 },
+ { 63.905561372021388, 10.000000000000000, 4.0000000000000000,
+ 2.0000000000000000 },
+ { 370.08498456728779, 10.000000000000000, 4.0000000000000000,
+ 3.0000000000000000 },
+ { 1922.9526217493540, 10.000000000000000, 4.0000000000000000,
+ 4.0000000000000000 },
+ { 9245.0380014351485, 10.000000000000000, 4.0000000000000000,
+ 5.0000000000000000 },
+ { 41898.961838459785, 10.000000000000000, 4.0000000000000000,
+ 6.0000000000000000 },
+ { 181211.14084739226, 10.000000000000000, 4.0000000000000000,
+ 7.0000000000000000 },
+ { 754384.25570692297, 10.000000000000000, 4.0000000000000000,
+ 8.0000000000000000 },
+ { 3042060.4915799876, 10.000000000000000, 4.0000000000000000,
+ 9.0000000000000000 },
+ { 11939626.424402930, 10.000000000000000, 4.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=10.000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test054()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data054)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data054[i].a), Tp(data054[i].c),
+ Tp(data054[i].x));
+ const Tp f0 = data054[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000026e-09));
+}
+
+// Test data for a=10.000000000000000, c=5.0000000000000000.
+testcase_conf_hyperg<double> data055[] = {
+ { -6.2454929831989742e-06, 10.000000000000000, 5.0000000000000000,
+ -10.000000000000000 },
+ { -1.1459481808048817e-05, 10.000000000000000, 5.0000000000000000,
+ -9.0000000000000000 },
+ { -8.1646988801669512e-06, 10.000000000000000, 5.0000000000000000,
+ -8.0000000000000000 },
+ { 3.1240400671775088e-05, 10.000000000000000, 5.0000000000000000,
+ -7.0000000000000000 },
+ { 0.00014164298152379191, 10.000000000000000, 5.0000000000000000,
+ -6.0000000000000000 },
+ { 0.00023172833594738379, 10.000000000000000, 5.0000000000000000,
+ -5.0000000000000000 },
+ { -0.00036825094062005220, 10.000000000000000, 5.0000000000000000,
+ -4.0000000000000000 },
+ { -0.0030227862937631683, 10.000000000000000, 5.0000000000000000,
+ -3.0000000000000000 },
+ { -0.00028642387986584615, 10.000000000000000, 5.0000000000000000,
+ -2.0000000000000000 },
+ { 0.10617896040159881, 10.000000000000000, 5.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 5.0000000000000000,
+ 0.0000000000000000 },
+ { 6.4803694966028260, 10.000000000000000, 5.0000000000000000,
+ 1.0000000000000000 },
+ { 35.201619637445276, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000 },
+ { 171.58787257237464, 10.000000000000000, 5.0000000000000000,
+ 3.0000000000000000 },
+ { 775.87148867205678, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000 },
+ { 3317.4071019773678, 10.000000000000000, 5.0000000000000000,
+ 5.0000000000000000 },
+ { 13578.260535269774, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000 },
+ { 53651.761875039716, 10.000000000000000, 5.0000000000000000,
+ 7.0000000000000000 },
+ { 205900.60390283042, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000 },
+ { 770979.49612334219, 10.000000000000000, 5.0000000000000000,
+ 9.0000000000000000 },
+ { 2826613.2348531331, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=10.000000000000000, c=5.0000000000000000.
+template <typename Tp>
+void test055()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data055)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data055[i].a), Tp(data055[i].c),
+ Tp(data055[i].x));
+ const Tp f0 = data055[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000013e-09));
+}
+
+// Test data for a=10.000000000000000, c=6.0000000000000000.
+testcase_conf_hyperg<double> data056[] = {
+ { 9.6084507433830306e-07, 10.000000000000000, 6.0000000000000000,
+ -10.000000000000000 },
+ { 7.7131127554174726e-06, 10.000000000000000, 6.0000000000000000,
+ -9.0000000000000000 },
+ { 2.3074149009167486e-05, 10.000000000000000, 6.0000000000000000,
+ -8.0000000000000000 },
+ { 4.0105919781332888e-05, 10.000000000000000, 6.0000000000000000,
+ -7.0000000000000000 },
+ { -7.7443012320393170e-21, 10.000000000000000, 6.0000000000000000,
+ -6.0000000000000000 },
+ { -0.00029188857701064686, 10.000000000000000, 6.0000000000000000,
+ -5.0000000000000000 },
+ { -0.0010659895649527829, 10.000000000000000, 6.0000000000000000,
+ -4.0000000000000000 },
+ { -0.00044452739614164190, 10.000000000000000, 6.0000000000000000,
+ -3.0000000000000000 },
+ { 0.020049671590609292, 10.000000000000000, 6.0000000000000000,
+ -2.0000000000000000 },
+ { 0.17092282236966813, 10.000000000000000, 6.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 6.0000000000000000,
+ 0.0000000000000000 },
+ { 4.9520550902714540, 10.000000000000000, 6.0000000000000000,
+ 1.0000000000000000 },
+ { 22.206263831706924, 10.000000000000000, 6.0000000000000000,
+ 2.0000000000000000 },
+ { 93.074943420842843, 10.000000000000000, 6.0000000000000000,
+ 3.0000000000000000 },
+ { 371.20964440523989, 10.000000000000000, 6.0000000000000000,
+ 4.0000000000000000 },
+ { 1424.6976175888544, 10.000000000000000, 6.0000000000000000,
+ 5.0000000000000000 },
+ { 5302.2070001902330, 10.000000000000000, 6.0000000000000000,
+ 6.0000000000000000 },
+ { 19239.311823447424, 10.000000000000000, 6.0000000000000000,
+ 7.0000000000000000 },
+ { 68341.221999215923, 10.000000000000000, 6.0000000000000000,
+ 8.0000000000000000 },
+ { 238389.83519072225, 10.000000000000000, 6.0000000000000000,
+ 9.0000000000000000 },
+ { 818592.04096678516, 10.000000000000000, 6.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=10.000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test056()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data056)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data056[i].a), Tp(data056[i].c),
+ Tp(data056[i].x));
+ const Tp f0 = data056[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000012e-08));
+}
+
+// Test data for a=10.000000000000000, c=7.0000000000000000.
+testcase_conf_hyperg<double> data057[] = {
+ { 3.9634859316455036e-06, 10.000000000000000, 7.0000000000000000,
+ -10.000000000000000 },
+ { 4.4074930030956985e-06, 10.000000000000000, 7.0000000000000000,
+ -9.0000000000000000 },
+ { -5.3248036175001926e-06, 10.000000000000000, 7.0000000000000000,
+ -8.0000000000000000 },
+ { -5.0660109197473119e-05, 10.000000000000000, 7.0000000000000000,
+ -7.0000000000000000 },
+ { -0.00017705372690473989, 10.000000000000000, 7.0000000000000000,
+ -6.0000000000000000 },
+ { -0.00034759250392107569, 10.000000000000000, 7.0000000000000000,
+ -5.0000000000000000 },
+ { 0.00029072442680530428, 10.000000000000000, 7.0000000000000000,
+ -4.0000000000000000 },
+ { 0.0071124383382662791, 10.000000000000000, 7.0000000000000000,
+ -3.0000000000000000 },
+ { 0.046185850628367831, 10.000000000000000, 7.0000000000000000,
+ -2.0000000000000000 },
+ { 0.22919473120601763, 10.000000000000000, 7.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 7.0000000000000000,
+ 0.0000000000000000 },
+ { 4.0342754120781059, 10.000000000000000, 7.0000000000000000,
+ 1.0000000000000000 },
+ { 15.423188523958421, 10.000000000000000, 7.0000000000000000,
+ 2.0000000000000000 },
+ { 56.669907747565212, 10.000000000000000, 7.0000000000000000,
+ 3.0000000000000000 },
+ { 201.92649139242229, 10.000000000000000, 7.0000000000000000,
+ 4.0000000000000000 },
+ { 702.01780019948944, 10.000000000000000, 7.0000000000000000,
+ 5.0000000000000000 },
+ { 2391.7564185640722, 10.000000000000000, 7.0000000000000000,
+ 6.0000000000000000 },
+ { 8011.5144629634615, 10.000000000000000, 7.0000000000000000,
+ 7.0000000000000000 },
+ { 26450.087535814702, 10.000000000000000, 7.0000000000000000,
+ 8.0000000000000000 },
+ { 86239.964657766584, 10.000000000000000, 7.0000000000000000,
+ 9.0000000000000000 },
+ { 278127.83396458323, 10.000000000000000, 7.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=10.000000000000000, c=7.0000000000000000.
+template <typename Tp>
+void test057()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data057)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data057[i].a), Tp(data057[i].c),
+ Tp(data057[i].x));
+ const Tp f0 = data057[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000004e-06));
+}
+
+// Test data for a=10.000000000000000, c=8.0000000000000000.
+testcase_conf_hyperg<double> data058[] = {
+ { -5.0444366402760924e-06, 10.000000000000000, 8.0000000000000000,
+ -10.000000000000000 },
+ { -1.5426225510834945e-05, 10.000000000000000, 8.0000000000000000,
+ -9.0000000000000000 },
+ { -3.7273625322501334e-05, 10.000000000000000, 8.0000000000000000,
+ -8.0000000000000000 },
+ { -6.3325136496841480e-05, 10.000000000000000, 8.0000000000000000,
+ -7.0000000000000000 },
+ { -2.7519677388747149e-19, 10.000000000000000, 8.0000000000000000,
+ -6.0000000000000000 },
+ { 0.00065507818046664273, 10.000000000000000, 8.0000000000000000,
+ -5.0000000000000000 },
+ { 0.0040701419752742617, 10.000000000000000, 8.0000000000000000,
+ -4.0000000000000000 },
+ { 0.018670150637948978, 10.000000000000000, 8.0000000000000000,
+ -3.0000000000000000 },
+ { 0.075186268464784836, 10.000000000000000, 8.0000000000000000,
+ -2.0000000000000000 },
+ { 0.28101901756151842, 10.000000000000000, 8.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 8.0000000000000000,
+ 0.0000000000000000 },
+ { 3.4356061998579595, 10.000000000000000, 8.0000000000000000,
+ 1.0000000000000000 },
+ { 11.494087265003234, 10.000000000000000, 8.0000000000000000,
+ 2.0000000000000000 },
+ { 37.660381730976880, 10.000000000000000, 8.0000000000000000,
+ 3.0000000000000000 },
+ { 121.32922229587608, 10.000000000000000, 8.0000000000000000,
+ 4.0000000000000000 },
+ { 385.46195489141422, 10.000000000000000, 8.0000000000000000,
+ 5.0000000000000000 },
+ { 1210.2863804782053, 10.000000000000000, 8.0000000000000000,
+ 6.0000000000000000 },
+ { 3762.0609740531836, 10.000000000000000, 8.0000000000000000,
+ 7.0000000000000000 },
+ { 11592.614394051165, 10.000000000000000, 8.0000000000000000,
+ 8.0000000000000000 },
+ { 35450.992183142305, 10.000000000000000, 8.0000000000000000,
+ 9.0000000000000000 },
+ { 107684.94388572175, 10.000000000000000, 8.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=10.000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test058()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data058)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data058[i].a), Tp(data058[i].c),
+ Tp(data058[i].x));
+ const Tp f0 = data058[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000013e-09));
+}
+
+// Test data for a=10.000000000000000, c=9.0000000000000000.
+testcase_conf_hyperg<double> data059[] = {
+ { -5.0444366402760974e-06, 10.000000000000000, 9.0000000000000000,
+ -10.000000000000000 },
+ { 0.0000000000000000, 10.000000000000000, 9.0000000000000000,
+ -9.0000000000000000 },
+ { 3.7273625322501334e-05, 10.000000000000000, 9.0000000000000000,
+ -8.0000000000000000 },
+ { 0.00020264043678989247, 10.000000000000000, 9.0000000000000000,
+ -7.0000000000000000 },
+ { 0.00082625072555545290, 10.000000000000000, 9.0000000000000000,
+ -6.0000000000000000 },
+ { 0.0029946431107046520, 10.000000000000000, 9.0000000000000000,
+ -5.0000000000000000 },
+ { 0.010175354938185655, 10.000000000000000, 9.0000000000000000,
+ -4.0000000000000000 },
+ { 0.033191378911909299, 10.000000000000000, 9.0000000000000000,
+ -3.0000000000000000 },
+ { 0.10526077585069878, 10.000000000000000, 9.0000000000000000,
+ -2.0000000000000000 },
+ { 0.32700394770794872, 10.000000000000000, 9.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 9.0000000000000000,
+ 0.0000000000000000 },
+ { 3.0203131427322725, 10.000000000000000, 9.0000000000000000,
+ 1.0000000000000000 },
+ { 9.0310685653596838, 10.000000000000000, 9.0000000000000000,
+ 2.0000000000000000 },
+ { 26.780715897583555, 10.000000000000000, 9.0000000000000000,
+ 3.0000000000000000 },
+ { 78.863994492319449, 10.000000000000000, 9.0000000000000000,
+ 4.0000000000000000 },
+ { 230.86491415956360, 10.000000000000000, 9.0000000000000000,
+ 5.0000000000000000 },
+ { 672.38132248789179, 10.000000000000000, 9.0000000000000000,
+ 6.0000000000000000 },
+ { 1949.5700594283705, 10.000000000000000, 9.0000000000000000,
+ 7.0000000000000000 },
+ { 5630.6984199677090, 10.000000000000000, 9.0000000000000000,
+ 8.0000000000000000 },
+ { 16206.167855150768, 10.000000000000000, 9.0000000000000000,
+ 9.0000000000000000 },
+ { 46500.316677925293, 10.000000000000000, 9.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=10.000000000000000, c=9.0000000000000000.
+template <typename Tp>
+void test059()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data059)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data059[i].a), Tp(data059[i].c),
+ Tp(data059[i].x));
+ const Tp f0 = data059[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000013e-09));
+}
+
+// Test data for a=10.000000000000000, c=10.000000000000000.
+testcase_conf_hyperg<double> data060[] = {
+ { 4.5399929762484854e-05, 10.000000000000000, 10.000000000000000,
+ -10.000000000000000 },
+ { 0.00012340980408667956, 10.000000000000000, 10.000000000000000,
+ -9.0000000000000000 },
+ { 0.00033546262790251185, 10.000000000000000, 10.000000000000000,
+ -8.0000000000000000 },
+ { 0.00091188196555451624, 10.000000000000000, 10.000000000000000,
+ -7.0000000000000000 },
+ { 0.0024787521766663585, 10.000000000000000, 10.000000000000000,
+ -6.0000000000000000 },
+ { 0.0067379469990854670, 10.000000000000000, 10.000000000000000,
+ -5.0000000000000000 },
+ { 0.018315638888734179, 10.000000000000000, 10.000000000000000,
+ -4.0000000000000000 },
+ { 0.049787068367863944, 10.000000000000000, 10.000000000000000,
+ -3.0000000000000000 },
+ { 0.13533528323661270, 10.000000000000000, 10.000000000000000,
+ -2.0000000000000000 },
+ { 0.36787944117144233, 10.000000000000000, 10.000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 10.000000000000000,
+ 0.0000000000000000 },
+ { 2.7182818284590451, 10.000000000000000, 10.000000000000000,
+ 1.0000000000000000 },
+ { 7.3890560989306504, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000 },
+ { 20.085536923187668, 10.000000000000000, 10.000000000000000,
+ 3.0000000000000000 },
+ { 54.598150033144236, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000 },
+ { 148.41315910257660, 10.000000000000000, 10.000000000000000,
+ 5.0000000000000000 },
+ { 403.42879349273511, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000 },
+ { 1096.6331584284585, 10.000000000000000, 10.000000000000000,
+ 7.0000000000000000 },
+ { 2980.9579870417283, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000 },
+ { 8103.0839275753842, 10.000000000000000, 10.000000000000000,
+ 9.0000000000000000 },
+ { 22026.465794806718, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=10.000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test060()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data060)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data060[i].a), Tp(data060[i].c),
+ Tp(data060[i].x));
+ const Tp f0 = data060[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, c=1.0000000000000000.
+testcase_conf_hyperg<double> data061[] = {
+ { 0.00018021852293239465, 20.000000000000000, 1.0000000000000000,
+ -10.000000000000000 },
+ { 0.0017726368057851861, 20.000000000000000, 1.0000000000000000,
+ -9.0000000000000000 },
+ { 0.00058280040382329248, 20.000000000000000, 1.0000000000000000,
+ -8.0000000000000000 },
+ { -0.0049657717020590141, 20.000000000000000, 1.0000000000000000,
+ -7.0000000000000000 },
+ { -0.0012360336087128597, 20.000000000000000, 1.0000000000000000,
+ -6.0000000000000000 },
+ { 0.014898894139255305, 20.000000000000000, 1.0000000000000000,
+ -5.0000000000000000 },
+ { -0.013800784612552089, 20.000000000000000, 1.0000000000000000,
+ -4.0000000000000000 },
+ { -0.012192213426039619, 20.000000000000000, 1.0000000000000000,
+ -3.0000000000000000 },
+ { 0.050311246773136239, 20.000000000000000, 1.0000000000000000,
+ -2.0000000000000000 },
+ { -0.025985814502838461, 20.000000000000000, 1.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 1.0000000000000000,
+ 0.0000000000000000 },
+ { 1563.6577385252015, 20.000000000000000, 1.0000000000000000,
+ 1.0000000000000000 },
+ { 86377.091910766278, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000 },
+ { 2216718.8789979252, 20.000000000000000, 1.0000000000000000,
+ 3.0000000000000000 },
+ { 38045018.520647161, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000 },
+ { 504376263.68346798, 20.000000000000000, 1.0000000000000000,
+ 5.0000000000000000 },
+ { 5565635666.7972031, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000 },
+ { 53451562646.544518, 20.000000000000000, 1.0000000000000000,
+ 7.0000000000000000 },
+ { 460009135340.33868, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000 },
+ { 3620401937301.4907, 20.000000000000000, 1.0000000000000000,
+ 9.0000000000000000 },
+ { 26446266822604.152, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=20.000000000000000, c=1.0000000000000000.
+template <typename Tp>
+void test061()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data061)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data061[i].a), Tp(data061[i].c),
+ Tp(data061[i].x));
+ const Tp f0 = data061[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000015e-12));
+}
+
+// Test data for a=20.000000000000000, c=2.0000000000000000.
+testcase_conf_hyperg<double> data062[] = {
+ { 6.6647681992684102e-05, 20.000000000000000, 2.0000000000000000,
+ -10.000000000000000 },
+ { -3.7248253270227178e-05, 20.000000000000000, 2.0000000000000000,
+ -9.0000000000000000 },
+ { -0.00024392611307344028, 20.000000000000000, 2.0000000000000000,
+ -8.0000000000000000 },
+ { 2.4034559592246216e-05, 20.000000000000000, 2.0000000000000000,
+ -7.0000000000000000 },
+ { 0.00081645960584843073, 20.000000000000000, 2.0000000000000000,
+ -6.0000000000000000 },
+ { -0.00051326387116462115, 20.000000000000000, 2.0000000000000000,
+ -5.0000000000000000 },
+ { -0.0021786279856333920, 20.000000000000000, 2.0000000000000000,
+ -4.0000000000000000 },
+ { 0.0061029380625179973, 20.000000000000000, 2.0000000000000000,
+ -3.0000000000000000 },
+ { -0.011834301617155171, 20.000000000000000, 2.0000000000000000,
+ -2.0000000000000000 },
+ { 0.037622016973681095, 20.000000000000000, 2.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 2.0000000000000000,
+ 0.0000000000000000 },
+ { 303.10954080179744, 20.000000000000000, 2.0000000000000000,
+ 1.0000000000000000 },
+ { 11508.923130556599, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000 },
+ { 234541.86023461280, 20.000000000000000, 2.0000000000000000,
+ 3.0000000000000000 },
+ { 3398931.2897027107, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000 },
+ { 39382712.287920594, 20.000000000000000, 2.0000000000000000,
+ 5.0000000000000000 },
+ { 388350500.37087941, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000 },
+ { 3385284070.5527201, 20.000000000000000, 2.0000000000000000,
+ 7.0000000000000000 },
+ { 26751585258.405773, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000 },
+ { 195061928138.27673, 20.000000000000000, 2.0000000000000000,
+ 9.0000000000000000 },
+ { 1329571695324.3132, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=20.000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test062()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data062)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data062[i].a), Tp(data062[i].c),
+ Tp(data062[i].x));
+ const Tp f0 = data062[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000017e-10));
+}
+
+// Test data for a=20.000000000000000, c=3.0000000000000000.
+testcase_conf_hyperg<double> data063[] = {
+ { -8.6671962318505729e-06, 20.000000000000000, 3.0000000000000000,
+ -10.000000000000000 },
+ { -1.8205565180535418e-05, 20.000000000000000, 3.0000000000000000,
+ -9.0000000000000000 },
+ { 1.5620588717927631e-05, 20.000000000000000, 3.0000000000000000,
+ -8.0000000000000000 },
+ { 7.6532767373103759e-05, 20.000000000000000, 3.0000000000000000,
+ -7.0000000000000000 },
+ { -5.2708600380172109e-05, 20.000000000000000, 3.0000000000000000,
+ -6.0000000000000000 },
+ { -0.00028546308121326264, 20.000000000000000, 3.0000000000000000,
+ -5.0000000000000000 },
+ { 0.00056490746026256289, 20.000000000000000, 3.0000000000000000,
+ -4.0000000000000000 },
+ { -5.0602588875468348e-07, 20.000000000000000, 3.0000000000000000,
+ -3.0000000000000000 },
+ { -0.0021376080642211705, 20.000000000000000, 3.0000000000000000,
+ -2.0000000000000000 },
+ { 0.0028873127225376070, 20.000000000000000, 3.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 3.0000000000000000,
+ 0.0000000000000000 },
+ { 106.38207299128953, 20.000000000000000, 3.0000000000000000,
+ 1.0000000000000000 },
+ { 2880.5734732831320, 20.000000000000000, 3.0000000000000000,
+ 2.0000000000000000 },
+ { 47353.756965165747, 20.000000000000000, 3.0000000000000000,
+ 3.0000000000000000 },
+ { 584732.27978148917, 20.000000000000000, 3.0000000000000000,
+ 4.0000000000000000 },
+ { 5957333.1101321029, 20.000000000000000, 3.0000000000000000,
+ 5.0000000000000000 },
+ { 52725595.633352734, 20.000000000000000, 3.0000000000000000,
+ 6.0000000000000000 },
+ { 418560160.03369552, 20.000000000000000, 3.0000000000000000,
+ 7.0000000000000000 },
+ { 3045067611.3150902, 20.000000000000000, 3.0000000000000000,
+ 8.0000000000000000 },
+ { 20614600690.354652, 20.000000000000000, 3.0000000000000000,
+ 9.0000000000000000 },
+ { 131344201933.74118, 20.000000000000000, 3.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=20.000000000000000, c=3.0000000000000000.
+template <typename Tp>
+void test063()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data063)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data063[i].a), Tp(data063[i].c),
+ Tp(data063[i].x));
+ const Tp f0 = data063[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000007e-09));
+}
+
+// Test data for a=20.000000000000000, c=4.0000000000000000.
+testcase_conf_hyperg<double> data064[] = {
+ { -1.1286669552452404e-06, 20.000000000000000, 4.0000000000000000,
+ -10.000000000000000 },
+ { 3.9595188785137704e-06, 20.000000000000000, 4.0000000000000000,
+ -9.0000000000000000 },
+ { 8.6940153052790034e-06, 20.000000000000000, 4.0000000000000000,
+ -8.0000000000000000 },
+ { -1.0858814018067509e-05, 20.000000000000000, 4.0000000000000000,
+ -7.0000000000000000 },
+ { -4.1826023828710966e-05, 20.000000000000000, 4.0000000000000000,
+ -6.0000000000000000 },
+ { 6.6455893622436357e-05, 20.000000000000000, 4.0000000000000000,
+ -5.0000000000000000 },
+ { 0.00014238710517977903, 20.000000000000000, 4.0000000000000000,
+ -4.0000000000000000 },
+ { -0.00071796294700866132, 20.000000000000000, 4.0000000000000000,
+ -3.0000000000000000 },
+ { 0.0020884061677332653, 20.000000000000000, 4.0000000000000000,
+ -2.0000000000000000 },
+ { -0.012768833157321986, 20.000000000000000, 4.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 4.0000000000000000,
+ 0.0000000000000000 },
+ { 50.659916934657751, 20.000000000000000, 4.0000000000000000,
+ 1.0000000000000000 },
+ { 1014.3134442335910, 20.000000000000000, 4.0000000000000000,
+ 2.0000000000000000 },
+ { 13665.584449611581, 20.000000000000000, 4.0000000000000000,
+ 3.0000000000000000 },
+ { 145123.62797278629, 20.000000000000000, 4.0000000000000000,
+ 4.0000000000000000 },
+ { 1308144.4519382305, 20.000000000000000, 4.0000000000000000,
+ 5.0000000000000000 },
+ { 10438124.578674613, 20.000000000000000, 4.0000000000000000,
+ 6.0000000000000000 },
+ { 75719160.524424642, 20.000000000000000, 4.0000000000000000,
+ 7.0000000000000000 },
+ { 508510905.96310234, 20.000000000000000, 4.0000000000000000,
+ 8.0000000000000000 },
+ { 3203200954.5618095, 20.000000000000000, 4.0000000000000000,
+ 9.0000000000000000 },
+ { 19111993543.124691, 20.000000000000000, 4.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=20.000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test064()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data064)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data064[i].a), Tp(data064[i].c),
+ Tp(data064[i].x));
+ const Tp f0 = data064[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000007e-09));
+}
+
+// Test data for a=20.000000000000000, c=5.0000000000000000.
+testcase_conf_hyperg<double> data065[] = {
+ { 8.4755643455670995e-07, 20.000000000000000, 5.0000000000000000,
+ -10.000000000000000 },
+ { 8.5721061862565634e-07, 20.000000000000000, 5.0000000000000000,
+ -9.0000000000000000 },
+ { -2.8228700837555599e-06, 20.000000000000000, 5.0000000000000000,
+ -8.0000000000000000 },
+ { -6.6486802159657585e-06, 20.000000000000000, 5.0000000000000000,
+ -7.0000000000000000 },
+ { 1.1816828026110384e-05, 20.000000000000000, 5.0000000000000000,
+ -6.0000000000000000 },
+ { 3.6173872819745767e-05, 20.000000000000000, 5.0000000000000000,
+ -5.0000000000000000 },
+ { -0.00011481934287296673, 20.000000000000000, 5.0000000000000000,
+ -4.0000000000000000 },
+ { 1.2650647218867087e-07, 20.000000000000000, 5.0000000000000000,
+ -3.0000000000000000 },
+ { 0.0010626537950495971, 20.000000000000000, 5.0000000000000000,
+ -2.0000000000000000 },
+ { -0.0085499011205641979, 20.000000000000000, 5.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 5.0000000000000000,
+ 0.0000000000000000 },
+ { 29.126637808809363, 20.000000000000000, 5.0000000000000000,
+ 1.0000000000000000 },
+ { 446.26914983518060, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000 },
+ { 5005.6470164856382, 20.000000000000000, 5.0000000000000000,
+ 3.0000000000000000 },
+ { 46145.715220935213, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000 },
+ { 370342.18574452243, 20.000000000000000, 5.0000000000000000,
+ 5.0000000000000000 },
+ { 2676402.7371661114, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000 },
+ { 17803174.102029990, 20.000000000000000, 5.0000000000000000,
+ 7.0000000000000000 },
+ { 110674464.63597310, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000 },
+ { 650149739.34228516, 20.000000000000000, 5.0000000000000000,
+ 9.0000000000000000 },
+ { 3639417243.5150661, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=20.000000000000000, c=5.0000000000000000.
+template <typename Tp>
+void test065()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data065)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data065[i].a), Tp(data065[i].c),
+ Tp(data065[i].x));
+ const Tp f0 = data065[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000005e-07));
+}
+
+// Test data for a=20.000000000000000, c=6.0000000000000000.
+testcase_conf_hyperg<double> data066[] = {
+ { -1.9022359545309947e-08, 20.000000000000000, 6.0000000000000000,
+ -10.000000000000000 },
+ { -7.4533809656234677e-07, 20.000000000000000, 6.0000000000000000,
+ -9.0000000000000000 },
+ { -9.7852420358724059e-07, 20.000000000000000, 6.0000000000000000,
+ -8.0000000000000000 },
+ { 3.0181569866746340e-06, 20.000000000000000, 6.0000000000000000,
+ -7.0000000000000000 },
+ { 7.9816910701457280e-06, 20.000000000000000, 6.0000000000000000,
+ -6.0000000000000000 },
+ { -2.0133163153966078e-05, 20.000000000000000, 6.0000000000000000,
+ -5.0000000000000000 },
+ { -4.7462368393259678e-05, 20.000000000000000, 6.0000000000000000,
+ -4.0000000000000000 },
+ { 0.00031910869938964821, 20.000000000000000, 6.0000000000000000,
+ -3.0000000000000000 },
+ { -0.0010380528468056445, 20.000000000000000, 6.0000000000000000,
+ -2.0000000000000000 },
+ { 0.0084752097558651162, 20.000000000000000, 6.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 6.0000000000000000,
+ 0.0000000000000000 },
+ { 19.002159564861387, 20.000000000000000, 6.0000000000000000,
+ 1.0000000000000000 },
+ { 229.93981298721295, 20.000000000000000, 6.0000000000000000,
+ 2.0000000000000000 },
+ { 2180.3120758940981, 20.000000000000000, 6.0000000000000000,
+ 3.0000000000000000 },
+ { 17610.732510305290, 20.000000000000000, 6.0000000000000000,
+ 4.0000000000000000 },
+ { 126633.20907014773, 20.000000000000000, 6.0000000000000000,
+ 5.0000000000000000 },
+ { 832692.83016874129, 20.000000000000000, 6.0000000000000000,
+ 6.0000000000000000 },
+ { 5097225.0940651651, 20.000000000000000, 6.0000000000000000,
+ 7.0000000000000000 },
+ { 29414585.342530537, 20.000000000000000, 6.0000000000000000,
+ 8.0000000000000000 },
+ { 161513229.88138971, 20.000000000000000, 6.0000000000000000,
+ 9.0000000000000000 },
+ { 849871092.10959554, 20.000000000000000, 6.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=20.000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test066()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data066)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data066[i].a), Tp(data066[i].c),
+ Tp(data066[i].x));
+ const Tp f0 = data066[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000019e-07));
+}
+
+// Test data for a=20.000000000000000, c=7.0000000000000000.
+testcase_conf_hyperg<double> data067[] = {
+ { -1.7754301607387143e-07, 20.000000000000000, 7.0000000000000000,
+ -10.000000000000000 },
+ { -6.2128605089471174e-08, 20.000000000000000, 7.0000000000000000,
+ -9.0000000000000000 },
+ { 9.1338873372533148e-07, 20.000000000000000, 7.0000000000000000,
+ -8.0000000000000000 },
+ { 1.6657400269273180e-06, 20.000000000000000, 7.0000000000000000,
+ -7.0000000000000000 },
+ { -4.7904165143355465e-06, 20.000000000000000, 7.0000000000000000,
+ -6.0000000000000000 },
+ { -1.5503088351319615e-05, 20.000000000000000, 7.0000000000000000,
+ -5.0000000000000000 },
+ { 5.6425108496954350e-05, 20.000000000000000, 7.0000000000000000,
+ -4.0000000000000000 },
+ { 9.1083552345479015e-05, 20.000000000000000, 7.0000000000000000,
+ -3.0000000000000000 },
+ { -0.0018058773247853399, 20.000000000000000, 7.0000000000000000,
+ -2.0000000000000000 },
+ { 0.032850147696977763, 20.000000000000000, 7.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 7.0000000000000000,
+ 0.0000000000000000 },
+ { 13.551527852090816, 20.000000000000000, 7.0000000000000000,
+ 1.0000000000000000 },
+ { 133.23579819973102, 20.000000000000000, 7.0000000000000000,
+ 2.0000000000000000 },
+ { 1083.6769250393436, 20.000000000000000, 7.0000000000000000,
+ 3.0000000000000000 },
+ { 7739.1410905637622, 20.000000000000000, 7.0000000000000000,
+ 4.0000000000000000 },
+ { 50175.328973240226, 20.000000000000000, 7.0000000000000000,
+ 5.0000000000000000 },
+ { 301599.46814102860, 20.000000000000000, 7.0000000000000000,
+ 6.0000000000000000 },
+ { 1705051.1866143674, 20.000000000000000, 7.0000000000000000,
+ 7.0000000000000000 },
+ { 9159788.2353733126, 20.000000000000000, 7.0000000000000000,
+ 8.0000000000000000 },
+ { 47122070.398665302, 20.000000000000000, 7.0000000000000000,
+ 9.0000000000000000 },
+ { 233529421.53991729, 20.000000000000000, 7.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=20.000000000000000, c=7.0000000000000000.
+template <typename Tp>
+void test067()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data067)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data067[i].a), Tp(data067[i].c),
+ Tp(data067[i].x));
+ const Tp f0 = data067[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000009e-07));
+}
+
+// Test data for a=20.000000000000000, c=8.0000000000000000.
+testcase_conf_hyperg<double> data068[] = {
+ { 4.4385719622857060e-08, 20.000000000000000, 8.0000000000000000,
+ -10.000000000000000 },
+ { 2.7870855352561929e-07, 20.000000000000000, 8.0000000000000000,
+ -9.0000000000000000 },
+ { 2.7221706037028333e-07, 20.000000000000000, 8.0000000000000000,
+ -8.0000000000000000 },
+ { -1.5211293805365477e-06, 20.000000000000000, 8.0000000000000000,
+ -7.0000000000000000 },
+ { -4.2978336531553922e-06, 20.000000000000000, 8.0000000000000000,
+ -6.0000000000000000 },
+ { 1.1339557446266738e-05, 20.000000000000000, 8.0000000000000000,
+ -5.0000000000000000 },
+ { 5.3526365220658982e-05, 20.000000000000000, 8.0000000000000000,
+ -4.0000000000000000 },
+ { -0.00029461053269513242, 20.000000000000000, 8.0000000000000000,
+ -3.0000000000000000 },
+ { -0.00026793636646740187, 20.000000000000000, 8.0000000000000000,
+ -2.0000000000000000 },
+ { 0.061061258434452835, 20.000000000000000, 8.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 8.0000000000000000,
+ 0.0000000000000000 },
+ { 10.312756690132913, 20.000000000000000, 8.0000000000000000,
+ 1.0000000000000000 },
+ { 84.471824856846425, 20.000000000000000, 8.0000000000000000,
+ 2.0000000000000000 },
+ { 597.47335666854985, 20.000000000000000, 8.0000000000000000,
+ 3.0000000000000000 },
+ { 3805.9786364107408, 20.000000000000000, 8.0000000000000000,
+ 4.0000000000000000 },
+ { 22386.068461641658, 20.000000000000000, 8.0000000000000000,
+ 5.0000000000000000 },
+ { 123573.63516975302, 20.000000000000000, 8.0000000000000000,
+ 6.0000000000000000 },
+ { 647514.24141570868, 20.000000000000000, 8.0000000000000000,
+ 7.0000000000000000 },
+ { 3247628.2434586394, 20.000000000000000, 8.0000000000000000,
+ 8.0000000000000000 },
+ { 15690070.625286423, 20.000000000000000, 8.0000000000000000,
+ 9.0000000000000000 },
+ { 73379158.893325061, 20.000000000000000, 8.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=20.000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test068()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data068)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data068[i].a), Tp(data068[i].c),
+ Tp(data068[i].x));
+ const Tp f0 = data068[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000005e-07));
+}
+
+// Test data for a=20.000000000000000, c=9.0000000000000000.
+testcase_conf_hyperg<double> data069[] = {
+ { 7.3976263576568592e-08, 20.000000000000000, 9.0000000000000000,
+ -10.000000000000000 },
+ { -9.0753238092548416e-09, 20.000000000000000, 9.0000000000000000,
+ -9.0000000000000000 },
+ { -5.5549484970396693e-07, 20.000000000000000, 9.0000000000000000,
+ -8.0000000000000000 },
+ { -1.1104933512848787e-06, 20.000000000000000, 9.0000000000000000,
+ -7.0000000000000000 },
+ { 3.2483424385770483e-06, 20.000000000000000, 9.0000000000000000,
+ -6.0000000000000000 },
+ { 1.7493431113569438e-05, 20.000000000000000, 9.0000000000000000,
+ -5.0000000000000000 },
+ { -3.9066110636117253e-05, 20.000000000000000, 9.0000000000000000,
+ -4.0000000000000000 },
+ { -0.00040356155493308509, 20.000000000000000, 9.0000000000000000,
+ -3.0000000000000000 },
+ { 0.0037671531470534567, 20.000000000000000, 9.0000000000000000,
+ -2.0000000000000000 },
+ { 0.090944344485248449, 20.000000000000000, 9.0000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 9.0000000000000000,
+ 0.0000000000000000 },
+ { 8.2390942957149722, 20.000000000000000, 9.0000000000000000,
+ 1.0000000000000000 },
+ { 57.468054562166706, 20.000000000000000, 9.0000000000000000,
+ 2.0000000000000000 },
+ { 358.00109079775746, 20.000000000000000, 9.0000000000000000,
+ 3.0000000000000000 },
+ { 2051.3704389046998, 20.000000000000000, 9.0000000000000000,
+ 4.0000000000000000 },
+ { 11012.597503064211, 20.000000000000000, 9.0000000000000000,
+ 5.0000000000000000 },
+ { 56082.113308934473, 20.000000000000000, 9.0000000000000000,
+ 6.0000000000000000 },
+ { 273348.46918863337, 20.000000000000000, 9.0000000000000000,
+ 7.0000000000000000 },
+ { 1283674.4996444662, 20.000000000000000, 9.0000000000000000,
+ 8.0000000000000000 },
+ { 5838026.8730425332, 20.000000000000000, 9.0000000000000000,
+ 9.0000000000000000 },
+ { 25817349.972859707, 20.000000000000000, 9.0000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=20.000000000000000, c=9.0000000000000000.
+template <typename Tp>
+void test069()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data069)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data069[i].a), Tp(data069[i].c),
+ Tp(data069[i].x));
+ const Tp f0 = data069[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000004e-06));
+}
+
+// Test data for a=20.000000000000000, c=10.000000000000000.
+testcase_conf_hyperg<double> data070[] = {
+ { -4.1157677792944940e-08, 20.000000000000000, 10.000000000000000,
+ -10.000000000000000 },
+ { -2.0187210039960906e-07, 20.000000000000000, 10.000000000000000,
+ -9.0000000000000000 },
+ { -2.2272304939386817e-07, 20.000000000000000, 10.000000000000000,
+ -8.0000000000000000 },
+ { 1.2925568212606171e-06, 20.000000000000000, 10.000000000000000,
+ -7.0000000000000000 },
+ { 5.5744573775996227e-06, 20.000000000000000, 10.000000000000000,
+ -6.0000000000000000 },
+ { -6.2568272011787340e-06, 20.000000000000000, 10.000000000000000,
+ -5.0000000000000000 },
+ { -0.00011955177906335608, 20.000000000000000, 10.000000000000000,
+ -4.0000000000000000 },
+ { 9.2475405516991078e-05, 20.000000000000000, 10.000000000000000,
+ -3.0000000000000000 },
+ { 0.010123531287569982, 20.000000000000000, 10.000000000000000,
+ -2.0000000000000000 },
+ { 0.12118937229909535, 20.000000000000000, 10.000000000000000,
+ -1.0000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 10.000000000000000,
+ 0.0000000000000000 },
+ { 6.8319857942415494, 20.000000000000000, 10.000000000000000,
+ 1.0000000000000000 },
+ { 41.356658140815220, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000 },
+ { 229.57496033810907, 20.000000000000000, 10.000000000000000,
+ 3.0000000000000000 },
+ { 1192.7830549969506, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000 },
+ { 5878.6003887215920, 20.000000000000000, 10.000000000000000,
+ 5.0000000000000000 },
+ { 27741.749322673899, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000 },
+ { 126220.54599305884, 20.000000000000000, 10.000000000000000,
+ 7.0000000000000000 },
+ { 556592.10886612453, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000 },
+ { 2388555.2873243922, 20.000000000000000, 10.000000000000000,
+ 9.0000000000000000 },
+ { 10008079.497419352, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000 },
+};
+
+// Test function for a=20.000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test070()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data070)
+ / sizeof(testcase_conf_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::conf_hyperg(Tp(data070[i].a), Tp(data070[i].c),
+ Tp(data070[i].x));
+ const Tp f0 = data070[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000009e-07));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ test009<double>();
+ test010<double>();
+ test011<double>();
+ test012<double>();
+ test013<double>();
+ test014<double>();
+ test015<double>();
+ test016<double>();
+ test017<double>();
+ test018<double>();
+ test019<double>();
+ test020<double>();
+ test021<double>();
+ test022<double>();
+ test023<double>();
+ test024<double>();
+ test025<double>();
+ test026<double>();
+ test027<double>();
+ test028<double>();
+ test029<double>();
+ test030<double>();
+ test031<double>();
+ test032<double>();
+ test033<double>();
+ test034<double>();
+ test035<double>();
+ test036<double>();
+ test037<double>();
+ test038<double>();
+ test039<double>();
+ test040<double>();
+ test041<double>();
+ test042<double>();
+ test043<double>();
+ test044<double>();
+ test045<double>();
+ test046<double>();
+ test047<double>();
+ test048<double>();
+ test049<double>();
+ test050<double>();
+ test051<double>();
+ test052<double>();
+ test053<double>();
+ test054<double>();
+ test055<double>();
+ test056<double>();
+ test057<double>();
+ test058<double>();
+ test059<double>();
+ test060<double>();
+ test061<double>();
+ test062<double>();
+ test063<double>();
+ test064<double>();
+ test065<double>();
+ test066<double>();
+ test067<double>();
+ test068<double>();
+ test069<double>();
+ test070<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/07_conf_hyperg/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/07_conf_hyperg/compile.cc
new file mode 100644
index 00000000000..1085952d7da
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/07_conf_hyperg/compile.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.7 conf_hyperg
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+
+ float af = 2.0F, cf = 3.0F, xf = 0.5F;
+ double ad = 2.0, cd = 3.0, xd = 0.5;
+ long double al = 2.0L, cl = 3.0L, xl = 0.5L;
+
+ std::tr1::conf_hyperg(af, cf, xf);
+ std::tr1::conf_hypergf(af, cf, xf);
+ std::tr1::conf_hyperg(ad, cd, xd);
+ std::tr1::conf_hyperg(al, cl, xl);
+ std::tr1::conf_hypergl(al, cl, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/07_conf_hyperg/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/07_conf_hyperg/compile_2.cc
new file mode 100644
index 00000000000..654bdf90316
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/07_conf_hyperg/compile_2.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.7 conf_hyperg
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+
+ float af = 2.0F, cf = 3.0F, xf = 0.5F;
+ double ad = 2.0, cd = 3.0, xd = 0.5;
+ long double al = 2.0L, cl = 3.0L, xl = 0.5L;
+
+ conf_hyperg(af, cf, xf);
+ conf_hypergf(af, cf, xf);
+ conf_hyperg(ad, cd, xd);
+ conf_hyperg(al, cl, xl);
+ conf_hypergl(al, cl, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/08_cyl_bessel_i/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/08_cyl_bessel_i/check_nan.cc
new file mode 100644
index 00000000000..4220f0236d5
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/08_cyl_bessel_i/check_nan.cc
@@ -0,0 +1,87 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.8 cyl_bessel_i
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+ float xf = std::numeric_limits<float>::quiet_NaN();
+ double xd = std::numeric_limits<double>::quiet_NaN();
+ long double xl = std::numeric_limits<long double>::quiet_NaN();
+
+ float nuf = 0.0F;
+ double nud = 0.0;
+ long double nul = 0.0L;
+
+ float a = std::tr1::cyl_bessel_i(nuf, xf);
+ float b = std::tr1::cyl_bessel_if(nuf, xf);
+ double c = std::tr1::cyl_bessel_i(nud, xd);
+ long double d = std::tr1::cyl_bessel_i(nul, xl);
+ long double e = std::tr1::cyl_bessel_il(nul, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+void
+test02()
+{
+ float xf = 1.0F;
+ double xd = 1.0;
+ long double xl = 1.0L;
+
+ float nuf = std::numeric_limits<float>::quiet_NaN();
+ double nud = std::numeric_limits<double>::quiet_NaN();
+ long double nul = std::numeric_limits<long double>::quiet_NaN();
+
+ float a = std::tr1::cyl_bessel_i(nuf, xf);
+ float b = std::tr1::cyl_bessel_if(nuf, xf);
+ double c = std::tr1::cyl_bessel_i(nud, xd);
+ long double d = std::tr1::cyl_bessel_i(nul, xl);
+ long double e = std::tr1::cyl_bessel_il(nul, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ test02();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/08_cyl_bessel_i/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/08_cyl_bessel_i/check_value.cc
new file mode 100644
index 00000000000..32f8af1c26a
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/08_cyl_bessel_i/check_value.cc
@@ -0,0 +1,629 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// cyl_bessel_i
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for nu=0.0000000000000000.
+testcase_cyl_bessel_i<double> data001[] = {
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000 },
+ { 27.239871823604439, 0.0000000000000000, 5.0000000000000000 },
+ { 2815.7166284662558, 0.0000000000000000, 10.000000000000000 },
+ { 339649.37329791381, 0.0000000000000000, 15.000000000000000 },
+ { 43558282.559553474, 0.0000000000000000, 20.000000000000000 },
+ { 5774560606.4663124, 0.0000000000000000, 25.000000000000000 },
+ { 781672297823.97925, 0.0000000000000000, 30.000000000000000 },
+ { 107338818494514.42, 0.0000000000000000, 35.000000000000000 },
+ { 14894774793419918., 0.0000000000000000, 40.000000000000000 },
+ { 2.0834140751773158e+18, 0.0000000000000000, 45.000000000000000 },
+ { 2.9325537838493463e+20, 0.0000000000000000, 50.000000000000000 },
+ { 4.1487895607332160e+22, 0.0000000000000000, 55.000000000000000 },
+ { 5.8940770556098216e+24, 0.0000000000000000, 60.000000000000000 },
+ { 8.4030398456255610e+26, 0.0000000000000000, 65.000000000000000 },
+ { 1.2015889579125422e+29, 0.0000000000000000, 70.000000000000000 },
+ { 1.7226390780357971e+31, 0.0000000000000000, 75.000000000000000 },
+ { 2.4751784043341670e+33, 0.0000000000000000, 80.000000000000000 },
+ { 3.5634776304081418e+35, 0.0000000000000000, 85.000000000000000 },
+ { 5.1392383455086475e+37, 0.0000000000000000, 90.000000000000000 },
+ { 7.4233258618752096e+39, 0.0000000000000000, 95.000000000000000 },
+ { 1.0737517071310986e+42, 0.0000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=0.0000000000000000.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_cyl_bessel_i<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_i(Tp(data001[i].nu), Tp(data001[i].x));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000015e-12));
+}
+
+// Test data for nu=0.33333333333333331.
+testcase_cyl_bessel_i<double> data002[] = {
+ { 0.0000000000000000, 0.33333333333333331, 0.0000000000000000 },
+ { 26.897553069268362, 0.33333333333333331, 5.0000000000000000 },
+ { 2799.2396097056790, 0.33333333333333331, 10.000000000000000 },
+ { 338348.63146593655, 0.33333333333333331, 15.000000000000000 },
+ { 43434263.927938439, 0.33333333333333331, 20.000000000000000 },
+ { 5761474759.6213636, 0.33333333333333331, 25.000000000000000 },
+ { 780201111830.30225, 0.33333333333333331, 30.000000000000000 },
+ { 107166066959051.92, 0.33333333333333331, 35.000000000000000 },
+ { 14873836574083760., 0.33333333333333331, 40.000000000000000 },
+ { 2.0808143020217085e+18, 0.33333333333333331, 45.000000000000000 },
+ { 2.9292639365644229e+20, 0.33333333333333331, 50.000000000000000 },
+ { 4.1445621624120489e+22, 0.33333333333333331, 55.000000000000000 },
+ { 5.8885758374365916e+24, 0.33333333333333331, 60.000000000000000 },
+ { 8.3958047021083955e+26, 0.33333333333333331, 65.000000000000000 },
+ { 1.2006287819446431e+29, 0.33333333333333331, 70.000000000000000 },
+ { 1.7213548977150022e+31, 0.33333333333333331, 75.000000000000000 },
+ { 2.4734492458444449e+33, 0.33333333333333331, 80.000000000000000 },
+ { 3.5611354547857122e+35, 0.33333333333333331, 85.000000000000000 },
+ { 5.1360491295551829e+37, 0.33333333333333331, 90.000000000000000 },
+ { 7.4189629097600431e+39, 0.33333333333333331, 95.000000000000000 },
+ { 1.0731523308358370e+42, 0.33333333333333331, 100.00000000000000 },
+};
+
+// Test function for nu=0.33333333333333331.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_cyl_bessel_i<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_i(Tp(data002[i].nu), Tp(data002[i].x));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for nu=0.50000000000000000.
+testcase_cyl_bessel_i<double> data003[] = {
+ { 0.0000000000000000, 0.50000000000000000, 0.0000000000000000 },
+ { 26.477547497559065, 0.50000000000000000, 5.0000000000000000 },
+ { 2778.7846038745711, 0.50000000000000000, 10.000000000000000 },
+ { 336729.88718706399, 0.50000000000000000, 15.000000000000000 },
+ { 43279746.272428922, 0.50000000000000000, 20.000000000000000 },
+ { 5745159748.3464680, 0.50000000000000000, 25.000000000000000 },
+ { 778366068840.44580, 0.50000000000000000, 30.000000000000000 },
+ { 106950522408567.66, 0.50000000000000000, 35.000000000000000 },
+ { 14847705549021962., 0.50000000000000000, 40.000000000000000 },
+ { 2.0775691824625661e+18, 0.50000000000000000, 45.000000000000000 },
+ { 2.9251568529912988e+20, 0.50000000000000000, 50.000000000000000 },
+ { 4.1392840094781220e+22, 0.50000000000000000, 55.000000000000000 },
+ { 5.8817065760751945e+24, 0.50000000000000000, 60.000000000000000 },
+ { 8.3867695787277231e+26, 0.50000000000000000, 65.000000000000000 },
+ { 1.1994296461653203e+29, 0.50000000000000000, 70.000000000000000 },
+ { 1.7197510246063332e+31, 0.50000000000000000, 75.000000000000000 },
+ { 2.4712895036230794e+33, 0.50000000000000000, 80.000000000000000 },
+ { 3.5582099086757769e+35, 0.50000000000000000, 85.000000000000000 },
+ { 5.1320654031231090e+37, 0.50000000000000000, 90.000000000000000 },
+ { 7.4135128383495227e+39, 0.50000000000000000, 95.000000000000000 },
+ { 1.0724035825423179e+42, 0.50000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=0.50000000000000000.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_cyl_bessel_i<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_i(Tp(data003[i].nu), Tp(data003[i].x));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for nu=0.66666666666666663.
+testcase_cyl_bessel_i<double> data004[] = {
+ { 0.0000000000000000, 0.66666666666666663, 0.0000000000000000 },
+ { 25.902310583215122, 0.66666666666666663, 5.0000000000000000 },
+ { 2750.4090423459315, 0.66666666666666663, 10.000000000000000 },
+ { 334476.98138574383, 0.66666666666666663, 15.000000000000000 },
+ { 43064361.686912313, 0.66666666666666663, 20.000000000000000 },
+ { 5722397441.9603882, 0.66666666666666663, 25.000000000000000 },
+ { 775804343498.02661, 0.66666666666666663, 30.000000000000000 },
+ { 106649495512800.89, 0.66666666666666663, 35.000000000000000 },
+ { 14811199896983756., 0.66666666666666663, 40.000000000000000 },
+ { 2.0730345814356961e+18, 0.66666666666666663, 45.000000000000000 },
+ { 2.9194166755257467e+20, 0.66666666666666663, 50.000000000000000 },
+ { 4.1319059569935366e+22, 0.66666666666666663, 55.000000000000000 },
+ { 5.8721031476386222e+24, 0.66666666666666663, 60.000000000000000 },
+ { 8.3741368248217830e+26, 0.66666666666666663, 65.000000000000000 },
+ { 1.1977528777008688e+29, 0.66666666666666663, 70.000000000000000 },
+ { 1.7175081240014333e+31, 0.66666666666666663, 75.000000000000000 },
+ { 2.4682690458513916e+33, 0.66666666666666663, 80.000000000000000 },
+ { 3.5541181975850724e+35, 0.66666666666666663, 85.000000000000000 },
+ { 5.1264933963228864e+37, 0.66666666666666663, 90.000000000000000 },
+ { 7.4058894880134064e+39, 0.66666666666666663, 95.000000000000000 },
+ { 1.0713562154788124e+42, 0.66666666666666663, 100.00000000000000 },
+};
+
+// Test function for nu=0.66666666666666663.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_cyl_bessel_i<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_i(Tp(data004[i].nu), Tp(data004[i].x));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for nu=1.0000000000000000.
+testcase_cyl_bessel_i<double> data005[] = {
+ { 0.0000000000000000, 1.0000000000000000, 0.0000000000000000 },
+ { 24.335642142450524, 1.0000000000000000, 5.0000000000000000 },
+ { 2670.9883037012560, 1.0000000000000000, 10.000000000000000 },
+ { 328124.92197020649, 1.0000000000000000, 15.000000000000000 },
+ { 42454973.385127775, 1.0000000000000000, 20.000000000000000 },
+ { 5657865129.8787022, 1.0000000000000000, 25.000000000000000 },
+ { 768532038938.95667, 1.0000000000000000, 30.000000000000000 },
+ { 105794126051896.17, 1.0000000000000000, 35.000000000000000 },
+ { 14707396163259354., 1.0000000000000000, 40.000000000000000 },
+ { 2.0601334620815775e+18, 1.0000000000000000, 45.000000000000000 },
+ { 2.9030785901035635e+20, 1.0000000000000000, 50.000000000000000 },
+ { 4.1108986452992812e+22, 1.0000000000000000, 55.000000000000000 },
+ { 5.8447515883904527e+24, 1.0000000000000000, 60.000000000000000 },
+ { 8.3381485471501302e+26, 1.0000000000000000, 65.000000000000000 },
+ { 1.1929750788892366e+29, 1.0000000000000000, 70.000000000000000 },
+ { 1.7111160152965384e+31, 1.0000000000000000, 75.000000000000000 },
+ { 2.4596595795675343e+33, 1.0000000000000000, 80.000000000000000 },
+ { 3.5424536064404024e+35, 1.0000000000000000, 85.000000000000000 },
+ { 5.1106068152566129e+37, 1.0000000000000000, 90.000000000000000 },
+ { 7.3841518091360157e+39, 1.0000000000000000, 95.000000000000000 },
+ { 1.0683693903381569e+42, 1.0000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=1.0000000000000000.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_cyl_bessel_i<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_i(Tp(data005[i].nu), Tp(data005[i].x));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for nu=2.0000000000000000.
+testcase_cyl_bessel_i<double> data006[] = {
+ { 0.0000000000000000, 2.0000000000000000, 0.0000000000000000 },
+ { 17.505614966624233, 2.0000000000000000, 5.0000000000000000 },
+ { 2281.5189677260046, 2.0000000000000000, 10.000000000000000 },
+ { 295899.38370188634, 2.0000000000000000, 15.000000000000000 },
+ { 39312785.221040756, 2.0000000000000000, 20.000000000000000 },
+ { 5321931396.0760136, 2.0000000000000000, 25.000000000000000 },
+ { 730436828561.38013, 2.0000000000000000, 30.000000000000000 },
+ { 101293439862977.19, 2.0000000000000000, 35.000000000000000 },
+ { 14159404985256920., 2.0000000000000000, 40.000000000000000 },
+ { 1.9918525879736883e+18, 2.0000000000000000, 45.000000000000000 },
+ { 2.8164306402451938e+20, 2.0000000000000000, 50.000000000000000 },
+ { 3.9993023372677515e+22, 2.0000000000000000, 55.000000000000000 },
+ { 5.6992520026634433e+24, 2.0000000000000000, 60.000000000000000 },
+ { 8.1464814287900378e+26, 2.0000000000000000, 65.000000000000000 },
+ { 1.1675039556585663e+29, 2.0000000000000000, 70.000000000000000 },
+ { 1.6770093176278926e+31, 2.0000000000000000, 75.000000000000000 },
+ { 2.4136869148449879e+33, 2.0000000000000000, 80.000000000000000 },
+ { 3.4801257808448186e+35, 2.0000000000000000, 85.000000000000000 },
+ { 5.0256693051696307e+37, 2.0000000000000000, 90.000000000000000 },
+ { 7.2678700343145842e+39, 2.0000000000000000, 95.000000000000000 },
+ { 1.0523843193243042e+42, 2.0000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=2.0000000000000000.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_cyl_bessel_i<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_i(Tp(data006[i].nu), Tp(data006[i].x));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for nu=5.0000000000000000.
+testcase_cyl_bessel_i<double> data007[] = {
+ { 0.0000000000000000, 5.0000000000000000, 0.0000000000000000 },
+ { 2.1579745473225476, 5.0000000000000000, 5.0000000000000000 },
+ { 777.18828640326012, 5.0000000000000000, 10.000000000000000 },
+ { 144572.01120063406, 5.0000000000000000, 15.000000000000000 },
+ { 23018392.213413671, 5.0000000000000000, 20.000000000000000 },
+ { 3472466208.7419176, 5.0000000000000000, 25.000000000000000 },
+ { 512151465476.93494, 5.0000000000000000, 30.000000000000000 },
+ { 74756743552251.531, 5.0000000000000000, 35.000000000000000 },
+ { 10858318337624276., 5.0000000000000000, 40.000000000000000 },
+ { 1.5736087399245906e+18, 5.0000000000000000, 45.000000000000000 },
+ { 2.2785483079112829e+20, 5.0000000000000000, 50.000000000000000 },
+ { 3.2989391052963687e+22, 5.0000000000000000, 55.000000000000000 },
+ { 4.7777652072561742e+24, 5.0000000000000000, 60.000000000000000 },
+ { 6.9232165147172671e+26, 5.0000000000000000, 65.000000000000000 },
+ { 1.0038643002095153e+29, 5.0000000000000000, 70.000000000000000 },
+ { 1.4566328222327068e+31, 5.0000000000000000, 75.000000000000000 },
+ { 2.1151488565944838e+33, 5.0000000000000000, 80.000000000000000 },
+ { 3.0735883450768236e+35, 5.0000000000000000, 85.000000000000000 },
+ { 4.4694790189230327e+37, 5.0000000000000000, 90.000000000000000 },
+ { 6.5037505570430971e+39, 5.0000000000000000, 95.000000000000000 },
+ { 9.4700938730355882e+41, 5.0000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=5.0000000000000000.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_cyl_bessel_i<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_i(Tp(data007[i].nu), Tp(data007[i].x));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for nu=10.000000000000000.
+testcase_cyl_bessel_i<double> data008[] = {
+ { 0.0000000000000000, 10.000000000000000, 0.0000000000000000 },
+ { 0.0045800444191760525, 10.000000000000000, 5.0000000000000000 },
+ { 21.891706163723381, 10.000000000000000, 10.000000000000000 },
+ { 12267.475049806462, 10.000000000000000, 15.000000000000000 },
+ { 3540200.2090195213, 10.000000000000000, 20.000000000000000 },
+ { 771298871.17072666, 10.000000000000000, 25.000000000000000 },
+ { 145831809975.96713, 10.000000000000000, 30.000000000000000 },
+ { 25449470018534.785, 10.000000000000000, 35.000000000000000 },
+ { 4228469210516757.5, 10.000000000000000, 40.000000000000000 },
+ { 6.8049404557505152e+17, 10.000000000000000, 45.000000000000000 },
+ { 1.0715971594776370e+20, 10.000000000000000, 50.000000000000000 },
+ { 1.6618215752886714e+22, 10.000000000000000, 55.000000000000000 },
+ { 2.5486246072566784e+24, 10.000000000000000, 60.000000000000000 },
+ { 3.8764628702155481e+26, 10.000000000000000, 65.000000000000000 },
+ { 5.8592538145409686e+28, 10.000000000000000, 70.000000000000000 },
+ { 8.8135370711317444e+30, 10.000000000000000, 75.000000000000000 },
+ { 1.3207418268325279e+33, 10.000000000000000, 80.000000000000000 },
+ { 1.9732791360862186e+35, 10.000000000000000, 85.000000000000000 },
+ { 2.9411893748384672e+37, 10.000000000000000, 90.000000000000000 },
+ { 4.3754494922439990e+39, 10.000000000000000, 95.000000000000000 },
+ { 6.4989755247201446e+41, 10.000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=10.000000000000000.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_cyl_bessel_i<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_i(Tp(data008[i].nu), Tp(data008[i].x));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for nu=20.000000000000000.
+testcase_cyl_bessel_i<double> data009[] = {
+ { 0.0000000000000000, 20.000000000000000, 0.0000000000000000 },
+ { 5.0242393579718066e-11, 20.000000000000000, 5.0000000000000000 },
+ { 0.00012507997356449481, 20.000000000000000, 10.000000000000000 },
+ { 1.6470152535015834, 20.000000000000000, 15.000000000000000 },
+ { 3188.7503288536154, 20.000000000000000, 20.000000000000000 },
+ { 2449840.5422952301, 20.000000000000000, 25.000000000000000 },
+ { 1126985104.4483771, 20.000000000000000, 30.000000000000000 },
+ { 379617876611.88586, 20.000000000000000, 35.000000000000000 },
+ { 104459633129479.89, 20.000000000000000, 40.000000000000000 },
+ { 25039579987216504., 20.000000000000000, 45.000000000000000 },
+ { 5.4420084027529964e+18, 20.000000000000000, 50.000000000000000 },
+ { 1.1007498584335492e+21, 20.000000000000000, 55.000000000000000 },
+ { 2.1091734863057236e+23, 20.000000000000000, 60.000000000000000 },
+ { 3.8763618091286899e+25, 20.000000000000000, 65.000000000000000 },
+ { 6.8946130527930859e+27, 20.000000000000000, 70.000000000000000 },
+ { 1.1946319948836447e+30, 20.000000000000000, 75.000000000000000 },
+ { 2.0265314377577580e+32, 20.000000000000000, 80.000000000000000 },
+ { 3.3784665214179971e+34, 20.000000000000000, 85.000000000000000 },
+ { 5.5516089411796670e+36, 20.000000000000000, 90.000000000000000 },
+ { 9.0129310795305151e+38, 20.000000000000000, 95.000000000000000 },
+ { 1.4483461256427176e+41, 20.000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=20.000000000000000.
+template <typename Tp>
+void test009()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data009)
+ / sizeof(testcase_cyl_bessel_i<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_i(Tp(data009[i].nu), Tp(data009[i].x));
+ const Tp f0 = data009[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for nu=50.000000000000000.
+testcase_cyl_bessel_i<double> data010[] = {
+ { 0.0000000000000000, 50.000000000000000, 0.0000000000000000 },
+ { 2.9314696468108517e-45, 50.000000000000000, 5.0000000000000000 },
+ { 4.7568945607268442e-30, 50.000000000000000, 10.000000000000000 },
+ { 5.5468372730667069e-21, 50.000000000000000, 15.000000000000000 },
+ { 2.2551205757604056e-14, 50.000000000000000, 20.000000000000000 },
+ { 4.5344251866130282e-09, 50.000000000000000, 25.000000000000000 },
+ { 0.00014590106916468937, 50.000000000000000, 30.000000000000000 },
+ { 1.3965549457254878, 50.000000000000000, 35.000000000000000 },
+ { 5726.8656631289878, 50.000000000000000, 40.000000000000000 },
+ { 12672593.113027776, 50.000000000000000, 45.000000000000000 },
+ { 17650802430.016705, 50.000000000000000, 50.000000000000000 },
+ { 17220231607789.926, 50.000000000000000, 55.000000000000000 },
+ { 12704607933652172., 50.000000000000000, 60.000000000000000 },
+ { 7.4989491942193766e+18, 50.000000000000000, 65.000000000000000 },
+ { 3.6944034898904901e+21, 50.000000000000000, 70.000000000000000 },
+ { 1.5691634774370194e+24, 50.000000000000000, 75.000000000000000 },
+ { 5.8927749458163587e+26, 50.000000000000000, 80.000000000000000 },
+ { 1.9958849054749339e+29, 50.000000000000000, 85.000000000000000 },
+ { 6.1946050361781518e+31, 50.000000000000000, 90.000000000000000 },
+ { 1.7845429728697110e+34, 50.000000000000000, 95.000000000000000 },
+ { 4.8219580855940813e+36, 50.000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=50.000000000000000.
+template <typename Tp>
+void test010()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data010)
+ / sizeof(testcase_cyl_bessel_i<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_i(Tp(data010[i].nu), Tp(data010[i].x));
+ const Tp f0 = data010[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000029e-12));
+}
+
+// Test data for nu=100.00000000000000.
+testcase_cyl_bessel_i<double> data011[] = {
+ { 0.0000000000000000, 100.00000000000000, 0.0000000000000000 },
+ { 7.0935514885313123e-119, 100.00000000000000, 5.0000000000000000 },
+ { 1.0823442017492018e-88, 100.00000000000000, 10.000000000000000 },
+ { 5.9887888536468904e-71, 100.00000000000000, 15.000000000000000 },
+ { 2.8703193216428771e-58, 100.00000000000000, 20.000000000000000 },
+ { 2.4426896913122370e-48, 100.00000000000000, 25.000000000000000 },
+ { 3.9476420053334271e-40, 100.00000000000000, 30.000000000000000 },
+ { 4.2836596180818801e-33, 100.00000000000000, 35.000000000000000 },
+ { 6.6249380222596129e-27, 100.00000000000000, 40.000000000000000 },
+ { 2.3702587262788881e-21, 100.00000000000000, 45.000000000000000 },
+ { 2.7278879470966907e-16, 100.00000000000000, 50.000000000000000 },
+ { 1.2763258878228088e-11, 100.00000000000000, 55.000000000000000 },
+ { 2.8832770906491951e-07, 100.00000000000000, 60.000000000000000 },
+ { 0.0035805902717061240, 100.00000000000000, 65.000000000000000 },
+ { 27.017219102595398, 100.00000000000000, 70.000000000000000 },
+ { 134001.44891209516, 100.00000000000000, 75.000000000000000 },
+ { 465194832.85061038, 100.00000000000000, 80.000000000000000 },
+ { 1189280653119.4819, 100.00000000000000, 85.000000000000000 },
+ { 2334119331258731.0, 100.00000000000000, 90.000000000000000 },
+ { 3.6399223078502380e+18, 100.00000000000000, 95.000000000000000 },
+ { 4.6415349416161989e+21, 100.00000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=100.00000000000000.
+template <typename Tp>
+void test011()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data011)
+ / sizeof(testcase_cyl_bessel_i<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_i(Tp(data011[i].nu), Tp(data011[i].x));
+ const Tp f0 = data011[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000014e-11));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ test009<double>();
+ test010<double>();
+ test011<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/08_cyl_bessel_i/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/08_cyl_bessel_i/compile.cc
new file mode 100644
index 00000000000..31d77980cd0
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/08_cyl_bessel_i/compile.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.8 cyl_bessel_i
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+
+ float nuf = 1.0F / 3.0F, xf = 0.5F;
+ double nud = 1.0 / 3.0, xd = 0.5;
+ long double nul = 1.0L / 3.0L, xl = 0.5L;
+
+ std::tr1::cyl_bessel_i(nuf, xf);
+ std::tr1::cyl_bessel_if(nuf, xf);
+ std::tr1::cyl_bessel_i(nud, xd);
+ std::tr1::cyl_bessel_i(nul, xl);
+ std::tr1::cyl_bessel_il(nul, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/08_cyl_bessel_i/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/08_cyl_bessel_i/compile_2.cc
new file mode 100644
index 00000000000..374d7ac41fb
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/08_cyl_bessel_i/compile_2.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.8 cyl_bessel_i
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+ float nuf = 1.0F / 3.0F, xf = 0.5F;
+ double nud = 1.0 / 3.0, xd = 0.5;
+ long double nul = 1.0L / 3.0L, xl = 0.5L;
+
+ cyl_bessel_i(nuf, xf);
+ cyl_bessel_if(nuf, xf);
+ cyl_bessel_i(nud, xd);
+ cyl_bessel_i(nul, xl);
+ cyl_bessel_il(nul, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/09_cyl_bessel_j/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/09_cyl_bessel_j/check_nan.cc
new file mode 100644
index 00000000000..606697a00b4
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/09_cyl_bessel_j/check_nan.cc
@@ -0,0 +1,87 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.9 cyl_bessel_j
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+ float xf = std::numeric_limits<float>::quiet_NaN();
+ double xd = std::numeric_limits<double>::quiet_NaN();
+ long double xl = std::numeric_limits<long double>::quiet_NaN();
+
+ float nuf = 0.0F;
+ double nud = 0.0;
+ long double nul = 0.0L;
+
+ float a = std::tr1::cyl_bessel_j(nuf, xf);
+ float b = std::tr1::cyl_bessel_jf(nuf, xf);
+ double c = std::tr1::cyl_bessel_j(nud, xd);
+ long double d = std::tr1::cyl_bessel_j(nul, xl);
+ long double e = std::tr1::cyl_bessel_jl(nul, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+void
+test02()
+{
+ float xf = 1.0F;
+ double xd = 1.0;
+ long double xl = 1.0L;
+
+ float nuf = std::numeric_limits<float>::quiet_NaN();
+ double nud = std::numeric_limits<double>::quiet_NaN();
+ long double nul = std::numeric_limits<long double>::quiet_NaN();
+
+ float a = std::tr1::cyl_bessel_j(nuf, xf);
+ float b = std::tr1::cyl_bessel_jf(nuf, xf);
+ double c = std::tr1::cyl_bessel_j(nud, xd);
+ long double d = std::tr1::cyl_bessel_j(nul, xl);
+ long double e = std::tr1::cyl_bessel_jl(nul, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ test02();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/09_cyl_bessel_j/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/09_cyl_bessel_j/check_value.cc
new file mode 100644
index 00000000000..5fa6e0cb4d0
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/09_cyl_bessel_j/check_value.cc
@@ -0,0 +1,629 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// cyl_bessel_j
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for nu=0.0000000000000000.
+testcase_cyl_bessel_j<double> data001[] = {
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000 },
+ { -0.17759677131433835, 0.0000000000000000, 5.0000000000000000 },
+ { -0.24593576445134832, 0.0000000000000000, 10.000000000000000 },
+ { -0.014224472826780788, 0.0000000000000000, 15.000000000000000 },
+ { 0.16702466434058319, 0.0000000000000000, 20.000000000000000 },
+ { 0.096266783275958140, 0.0000000000000000, 25.000000000000000 },
+ { -0.086367983581040184, 0.0000000000000000, 30.000000000000000 },
+ { -0.12684568275631256, 0.0000000000000000, 35.000000000000000 },
+ { 0.0073668905842372914, 0.0000000000000000, 40.000000000000000 },
+ { 0.11581867067325630, 0.0000000000000000, 45.000000000000000 },
+ { 0.055812327669251746, 0.0000000000000000, 50.000000000000000 },
+ { -0.074548302648236808, 0.0000000000000000, 55.000000000000000 },
+ { -0.091471804089061873, 0.0000000000000000, 60.000000000000000 },
+ { 0.018687343227677920, 0.0000000000000000, 65.000000000000000 },
+ { 0.094908726483013517, 0.0000000000000000, 70.000000000000000 },
+ { 0.034643913805097029, 0.0000000000000000, 75.000000000000000 },
+ { -0.069742165512210061, 0.0000000000000000, 80.000000000000000 },
+ { -0.070940394796273301, 0.0000000000000000, 85.000000000000000 },
+ { 0.026630016699969568, 0.0000000000000000, 90.000000000000000 },
+ { 0.081811967783384149, 0.0000000000000000, 95.000000000000000 },
+ { 0.019985850304223264, 0.0000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=0.0000000000000000.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_cyl_bessel_j<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_j(Tp(data001[i].nu), Tp(data001[i].x));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000014e-11));
+}
+
+// Test data for nu=0.33333333333333331.
+testcase_cyl_bessel_j<double> data002[] = {
+ { 0.0000000000000000, 0.33333333333333331, 0.0000000000000000 },
+ { -0.30642046380026405, 0.33333333333333331, 5.0000000000000000 },
+ { -0.18614516704869569, 0.33333333333333331, 10.000000000000000 },
+ { 0.089740004221152581, 0.33333333333333331, 15.000000000000000 },
+ { 0.17606058001293898, 0.33333333333333331, 20.000000000000000 },
+ { 0.020097162141383202, 0.33333333333333331, 25.000000000000000 },
+ { -0.13334053387426156, 0.33333333333333331, 30.000000000000000 },
+ { -0.087118009397765442, 0.33333333333333331, 35.000000000000000 },
+ { 0.069202942818858165, 0.33333333333333331, 40.000000000000000 },
+ { 0.11387616964518317, 0.33333333333333331, 45.000000000000000 },
+ { -0.00057226680771807741, 0.33333333333333331, 50.000000000000000 },
+ { -0.10331600929280821, 0.33333333333333331, 55.000000000000000 },
+ { -0.055618147270528023, 0.33333333333333331, 60.000000000000000 },
+ { 0.064711954014113920, 0.33333333333333331, 65.000000000000000 },
+ { 0.086879926462481619, 0.33333333333333331, 70.000000000000000 },
+ { -0.012614484229891070, 0.33333333333333331, 75.000000000000000 },
+ { -0.088199784400034537, 0.33333333333333331, 80.000000000000000 },
+ { -0.036703611076564557, 0.33333333333333331, 85.000000000000000 },
+ { 0.062916286828779533, 0.33333333333333331, 90.000000000000000 },
+ { 0.069465244416806071, 0.33333333333333331, 95.000000000000000 },
+ { -0.021271244853702295, 0.33333333333333331, 100.00000000000000 },
+};
+
+// Test function for nu=0.33333333333333331.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_cyl_bessel_j<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_j(Tp(data002[i].nu), Tp(data002[i].x));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000017e-10));
+}
+
+// Test data for nu=0.50000000000000000.
+testcase_cyl_bessel_j<double> data003[] = {
+ { 0.0000000000000000, 0.50000000000000000, 0.0000000000000000 },
+ { -0.34216798479816180, 0.50000000000000000, 5.0000000000000000 },
+ { -0.13726373575505049, 0.50000000000000000, 10.000000000000000 },
+ { 0.13396768882243942, 0.50000000000000000, 15.000000000000000 },
+ { 0.16288076385502981, 0.50000000000000000, 20.000000000000000 },
+ { -0.021120283599650416, 0.50000000000000000, 25.000000000000000 },
+ { -0.14392965337039987, 0.50000000000000000, 30.000000000000000 },
+ { -0.057747757589458860, 0.50000000000000000, 35.000000000000000 },
+ { 0.094000962389533579, 0.50000000000000000, 40.000000000000000 },
+ { 0.10120783324271412, 0.50000000000000000, 45.000000000000000 },
+ { -0.029605831888924662, 0.50000000000000000, 50.000000000000000 },
+ { -0.10756039213265806, 0.50000000000000000, 55.000000000000000 },
+ { -0.031397461182520445, 0.50000000000000000, 60.000000000000000 },
+ { 0.081827430775628568, 0.50000000000000000, 65.000000000000000 },
+ { 0.073802429539054637, 0.50000000000000000, 70.000000000000000 },
+ { -0.035727009681702594, 0.50000000000000000, 75.000000000000000 },
+ { -0.088661035811765446, 0.50000000000000000, 80.000000000000000 },
+ { -0.015238065106312407, 0.50000000000000000, 85.000000000000000 },
+ { 0.075189068550269425, 0.50000000000000000, 90.000000000000000 },
+ { 0.055932643481494140, 0.50000000000000000, 95.000000000000000 },
+ { -0.040402132716252113, 0.50000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=0.50000000000000000.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_cyl_bessel_j<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_j(Tp(data003[i].nu), Tp(data003[i].x));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000014e-11));
+}
+
+// Test data for nu=0.66666666666666663.
+testcase_cyl_bessel_j<double> data004[] = {
+ { 0.0000000000000000, 0.66666666666666663, 0.0000000000000000 },
+ { -0.35712533549168879, 0.66666666666666663, 5.0000000000000000 },
+ { -0.080149603304315822, 0.66666666666666663, 10.000000000000000 },
+ { 0.16918875175798076, 0.66666666666666663, 15.000000000000000 },
+ { 0.13904826122116526, 0.66666666666666663, 20.000000000000000 },
+ { -0.060770629698497579, 0.66666666666666663, 25.000000000000000 },
+ { -0.14489851974205059, 0.66666666666666663, 30.000000000000000 },
+ { -0.024604880159644467, 0.66666666666666663, 35.000000000000000 },
+ { 0.11243936464912015, 0.66666666666666663, 40.000000000000000 },
+ { 0.081776275512525379, 0.66666666666666663, 45.000000000000000 },
+ { -0.056589908749367770, 0.66666666666666663, 50.000000000000000 },
+ { -0.10455814523765933, 0.66666666666666663, 55.000000000000000 },
+ { -0.0051030148548608109, 0.66666666666666663, 60.000000000000000 },
+ { 0.093398227061639250, 0.66666666666666663, 65.000000000000000 },
+ { 0.055763883611864899, 0.66666666666666663, 70.000000000000000 },
+ { -0.056395322915757343, 0.66666666666666663, 75.000000000000000 },
+ { -0.083131347805783087, 0.66666666666666663, 80.000000000000000 },
+ { 0.0072315397874096309, 0.66666666666666663, 85.000000000000000 },
+ { 0.082362798520905264, 0.66666666666666663, 90.000000000000000 },
+ { 0.038630504403446168, 0.66666666666666663, 95.000000000000000 },
+ { -0.056778819380529706, 0.66666666666666663, 100.00000000000000 },
+};
+
+// Test function for nu=0.66666666666666663.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_cyl_bessel_j<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_j(Tp(data004[i].nu), Tp(data004[i].x));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-10));
+}
+
+// Test data for nu=1.0000000000000000.
+testcase_cyl_bessel_j<double> data005[] = {
+ { 0.0000000000000000, 1.0000000000000000, 0.0000000000000000 },
+ { -0.32757913759146523, 1.0000000000000000, 5.0000000000000000 },
+ { 0.043472746168861369, 1.0000000000000000, 10.000000000000000 },
+ { 0.20510403861352278, 1.0000000000000000, 15.000000000000000 },
+ { 0.066833124175850092, 1.0000000000000000, 20.000000000000000 },
+ { -0.12535024958028987, 1.0000000000000000, 25.000000000000000 },
+ { -0.11875106261662292, 1.0000000000000000, 30.000000000000000 },
+ { 0.043990942179625556, 1.0000000000000000, 35.000000000000000 },
+ { 0.12603831803758497, 1.0000000000000000, 40.000000000000000 },
+ { 0.028348854376424548, 1.0000000000000000, 45.000000000000000 },
+ { -0.097511828125175157, 1.0000000000000000, 50.000000000000000 },
+ { -0.078250038308684655, 1.0000000000000000, 55.000000000000000 },
+ { 0.046598383758166398, 1.0000000000000000, 60.000000000000000 },
+ { 0.097330172226126929, 1.0000000000000000, 65.000000000000000 },
+ { 0.0099877887848384625, 1.0000000000000000, 70.000000000000000 },
+ { -0.085139995044829109, 1.0000000000000000, 75.000000000000000 },
+ { -0.056057296675712610, 1.0000000000000000, 80.000000000000000 },
+ { 0.049151460334891116, 1.0000000000000000, 85.000000000000000 },
+ { 0.079925646708868064, 1.0000000000000000, 90.000000000000000 },
+ { -0.0023925612997268684, 1.0000000000000000, 95.000000000000000 },
+ { -0.077145352014112142, 1.0000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=1.0000000000000000.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_cyl_bessel_j<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_j(Tp(data005[i].nu), Tp(data005[i].x));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-10));
+}
+
+// Test data for nu=2.0000000000000000.
+testcase_cyl_bessel_j<double> data006[] = {
+ { 0.0000000000000000, 2.0000000000000000, 0.0000000000000000 },
+ { 0.046565116277751971, 2.0000000000000000, 5.0000000000000000 },
+ { 0.25463031368512062, 2.0000000000000000, 10.000000000000000 },
+ { 0.041571677975250479, 2.0000000000000000, 15.000000000000000 },
+ { -0.16034135192299817, 2.0000000000000000, 20.000000000000000 },
+ { -0.10629480324238134, 2.0000000000000000, 25.000000000000000 },
+ { 0.078451246073265340, 2.0000000000000000, 30.000000000000000 },
+ { 0.12935945088086262, 2.0000000000000000, 35.000000000000000 },
+ { -0.0010649746823580893, 2.0000000000000000, 40.000000000000000 },
+ { -0.11455872158985966, 2.0000000000000000, 45.000000000000000 },
+ { -0.059712800794258801, 2.0000000000000000, 50.000000000000000 },
+ { 0.071702846709739212, 2.0000000000000000, 55.000000000000000 },
+ { 0.093025083547667448, 2.0000000000000000, 60.000000000000000 },
+ { -0.015692568697643280, 2.0000000000000000, 65.000000000000000 },
+ { -0.094623361089160987, 2.0000000000000000, 70.000000000000000 },
+ { -0.036914313672959186, 2.0000000000000000, 75.000000000000000 },
+ { 0.068340733095317227, 2.0000000000000000, 80.000000000000000 },
+ { 0.072096899745329499, 2.0000000000000000, 85.000000000000000 },
+ { -0.024853891217550262, 2.0000000000000000, 90.000000000000000 },
+ { -0.081862337494957346, 2.0000000000000000, 95.000000000000000 },
+ { -0.021528757344505392, 2.0000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=2.0000000000000000.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_cyl_bessel_j<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_j(Tp(data006[i].nu), Tp(data006[i].x));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-10));
+}
+
+// Test data for nu=5.0000000000000000.
+testcase_cyl_bessel_j<double> data007[] = {
+ { 0.0000000000000000, 5.0000000000000000, 0.0000000000000000 },
+ { 0.26114054612017007, 5.0000000000000000, 5.0000000000000000 },
+ { -0.23406152818679365, 5.0000000000000000, 10.000000000000000 },
+ { 0.13045613456502966, 5.0000000000000000, 15.000000000000000 },
+ { 0.15116976798239504, 5.0000000000000000, 20.000000000000000 },
+ { -0.066007995398423044, 5.0000000000000000, 25.000000000000000 },
+ { -0.14324029551207709, 5.0000000000000000, 30.000000000000000 },
+ { -0.0015053072953907080, 5.0000000000000000, 35.000000000000000 },
+ { 0.12257346597711774, 5.0000000000000000, 40.000000000000000 },
+ { 0.057984499200954144, 5.0000000000000000, 45.000000000000000 },
+ { -0.081400247696569658, 5.0000000000000000, 50.000000000000000 },
+ { -0.092569895786432710, 5.0000000000000000, 55.000000000000000 },
+ { 0.027454744228344184, 5.0000000000000000, 60.000000000000000 },
+ { 0.099110527701539039, 5.0000000000000000, 65.000000000000000 },
+ { 0.026058129823895274, 5.0000000000000000, 70.000000000000000 },
+ { -0.078523977013751398, 5.0000000000000000, 75.000000000000000 },
+ { -0.065862349140031654, 5.0000000000000000, 80.000000000000000 },
+ { 0.038669072284680923, 5.0000000000000000, 85.000000000000000 },
+ { 0.082759319528415129, 5.0000000000000000, 90.000000000000000 },
+ { 0.0079423372702472905, 5.0000000000000000, 95.000000000000000 },
+ { -0.074195736964513911, 5.0000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=5.0000000000000000.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_cyl_bessel_j<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_j(Tp(data007[i].nu), Tp(data007[i].x));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000028e-11));
+}
+
+// Test data for nu=10.000000000000000.
+testcase_cyl_bessel_j<double> data008[] = {
+ { 0.0000000000000000, 10.000000000000000, 0.0000000000000000 },
+ { 0.0014678026473104744, 10.000000000000000, 5.0000000000000000 },
+ { 0.20748610663335865, 10.000000000000000, 10.000000000000000 },
+ { -0.090071811047659045, 10.000000000000000, 15.000000000000000 },
+ { 0.18648255802394512, 10.000000000000000, 20.000000000000000 },
+ { -0.075179843948523270, 10.000000000000000, 25.000000000000000 },
+ { -0.12987689399858882, 10.000000000000000, 30.000000000000000 },
+ { 0.063546391343962852, 10.000000000000000, 35.000000000000000 },
+ { 0.11938336278226093, 10.000000000000000, 40.000000000000000 },
+ { -0.026971402475010734, 10.000000000000000, 45.000000000000000 },
+ { -0.11384784914946940, 10.000000000000000, 50.000000000000000 },
+ { -0.015773790303746010, 10.000000000000000, 55.000000000000000 },
+ { 0.097177143328071106, 10.000000000000000, 60.000000000000000 },
+ { 0.054617389951112157, 10.000000000000000, 65.000000000000000 },
+ { -0.065870338561951874, 10.000000000000000, 70.000000000000000 },
+ { -0.080417867891894437, 10.000000000000000, 75.000000000000000 },
+ { 0.024043850978184754, 10.000000000000000, 80.000000000000000 },
+ { 0.086824832700067869, 10.000000000000000, 85.000000000000000 },
+ { 0.019554748856312278, 10.000000000000000, 90.000000000000000 },
+ { -0.072341598669443757, 10.000000000000000, 95.000000000000000 },
+ { -0.054732176935472103, 10.000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=10.000000000000000.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_cyl_bessel_j<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_j(Tp(data008[i].nu), Tp(data008[i].x));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000014e-11));
+}
+
+// Test data for nu=20.000000000000000.
+testcase_cyl_bessel_j<double> data009[] = {
+ { 0.0000000000000000, 20.000000000000000, 0.0000000000000000 },
+ { 2.7703300521289426e-11, 20.000000000000000, 5.0000000000000000 },
+ { 1.1513369247813403e-05, 20.000000000000000, 10.000000000000000 },
+ { 0.0073602340792234882, 20.000000000000000, 15.000000000000000 },
+ { 0.16474777377532657, 20.000000000000000, 20.000000000000000 },
+ { 0.051994049228303287, 20.000000000000000, 25.000000000000000 },
+ { 0.0048310199934041105, 20.000000000000000, 30.000000000000000 },
+ { -0.10927417397178038, 20.000000000000000, 35.000000000000000 },
+ { 0.12779393355084886, 20.000000000000000, 40.000000000000000 },
+ { 0.0047633437900312841, 20.000000000000000, 45.000000000000000 },
+ { -0.11670435275957974, 20.000000000000000, 50.000000000000000 },
+ { 0.025389204574566695, 20.000000000000000, 55.000000000000000 },
+ { 0.10266020557876331, 20.000000000000000, 60.000000000000000 },
+ { -0.023138582263434168, 20.000000000000000, 65.000000000000000 },
+ { -0.096058573489952323, 20.000000000000000, 70.000000000000000 },
+ { 0.0068961047221522270, 20.000000000000000, 75.000000000000000 },
+ { 0.090565405489918357, 20.000000000000000, 80.000000000000000 },
+ { 0.015985497599497155, 20.000000000000000, 85.000000000000000 },
+ { -0.080345344044422506, 20.000000000000000, 90.000000000000000 },
+ { -0.040253075701614051, 20.000000000000000, 95.000000000000000 },
+ { 0.062217458498338679, 20.000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=20.000000000000000.
+template <typename Tp>
+void test009()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data009)
+ / sizeof(testcase_cyl_bessel_j<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_j(Tp(data009[i].nu), Tp(data009[i].x));
+ const Tp f0 = data009[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-10));
+}
+
+// Test data for nu=50.000000000000000.
+testcase_cyl_bessel_j<double> data010[] = {
+ { 0.0000000000000000, 50.000000000000000, 0.0000000000000000 },
+ { 2.2942476159525415e-45, 50.000000000000000, 5.0000000000000000 },
+ { 1.7845136078715964e-30, 50.000000000000000, 10.000000000000000 },
+ { 6.1060519495338733e-22, 50.000000000000000, 15.000000000000000 },
+ { 4.4510392847006872e-16, 50.000000000000000, 20.000000000000000 },
+ { 9.7561594280229727e-12, 50.000000000000000, 25.000000000000000 },
+ { 2.0581656631564181e-08, 50.000000000000000, 30.000000000000000 },
+ { 7.6069951699272926e-06, 50.000000000000000, 35.000000000000000 },
+ { 0.00068185243531768255, 50.000000000000000, 40.000000000000000 },
+ { 0.017284343240791228, 50.000000000000000, 45.000000000000000 },
+ { 0.12140902189761522, 50.000000000000000, 50.000000000000000 },
+ { 0.13594720957176004, 50.000000000000000, 55.000000000000000 },
+ { -0.13798273148535209, 50.000000000000000, 60.000000000000000 },
+ { 0.12116217746619408, 50.000000000000000, 65.000000000000000 },
+ { -0.11394866738787141, 50.000000000000000, 70.000000000000000 },
+ { 0.094076799581573417, 50.000000000000000, 75.000000000000000 },
+ { -0.039457764590251236, 50.000000000000000, 80.000000000000000 },
+ { -0.040412060734136369, 50.000000000000000, 85.000000000000000 },
+ { 0.090802099838032252, 50.000000000000000, 90.000000000000000 },
+ { -0.055979156267280269, 50.000000000000000, 95.000000000000000 },
+ { -0.038698339728525460, 50.000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=50.000000000000000.
+template <typename Tp>
+void test010()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data010)
+ / sizeof(testcase_cyl_bessel_j<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_j(Tp(data010[i].nu), Tp(data010[i].x));
+ const Tp f0 = data010[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-11));
+}
+
+// Test data for nu=100.00000000000000.
+testcase_cyl_bessel_j<double> data011[] = {
+ { 0.0000000000000000, 100.00000000000000, 0.0000000000000000 },
+ { 6.2677893955418763e-119, 100.00000000000000, 5.0000000000000000 },
+ { 6.5973160641553816e-89, 100.00000000000000, 10.000000000000000 },
+ { 1.9660095611249536e-71, 100.00000000000000, 15.000000000000000 },
+ { 3.9617550943362524e-59, 100.00000000000000, 20.000000000000000 },
+ { 1.1064482655301687e-49, 100.00000000000000, 25.000000000000000 },
+ { 4.5788015281752354e-42, 100.00000000000000, 30.000000000000000 },
+ { 9.9210206714732606e-36, 100.00000000000000, 35.000000000000000 },
+ { 2.3866062996027414e-30, 100.00000000000000, 40.000000000000000 },
+ { 1.0329791804565538e-25, 100.00000000000000, 45.000000000000000 },
+ { 1.1159273690838340e-21, 100.00000000000000, 50.000000000000000 },
+ { 3.7899753451900682e-18, 100.00000000000000, 55.000000000000000 },
+ { 4.7832744078781205e-15, 100.00000000000000, 60.000000000000000 },
+ { 2.5375564579490517e-12, 100.00000000000000, 65.000000000000000 },
+ { 6.1982452141641260e-10, 100.00000000000000, 70.000000000000000 },
+ { 7.4479005905904457e-08, 100.00000000000000, 75.000000000000000 },
+ { 4.6065530648234948e-06, 100.00000000000000, 80.000000000000000 },
+ { 0.00015043869999501605, 100.00000000000000, 85.000000000000000 },
+ { 0.0026021305819963472, 100.00000000000000, 90.000000000000000 },
+ { 0.023150768009428162, 100.00000000000000, 95.000000000000000 },
+ { 0.096366673295861571, 100.00000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=100.00000000000000.
+template <typename Tp>
+void test011()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data011)
+ / sizeof(testcase_cyl_bessel_j<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_j(Tp(data011[i].nu), Tp(data011[i].x));
+ const Tp f0 = data011[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-11));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ test009<double>();
+ test010<double>();
+ test011<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/09_cyl_bessel_j/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/09_cyl_bessel_j/compile.cc
new file mode 100644
index 00000000000..c4054ebbe54
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/09_cyl_bessel_j/compile.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.9 cyl_bessel_j
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+ float nuf = 1.0F / 3.0F, xf = 0.5F;
+ double nud = 1.0 / 3.0, xd = 0.5;
+ long double nul = 1.0L / 3.0L, xl = 0.5L;
+
+ std::tr1::cyl_bessel_j(nuf, xf);
+ std::tr1::cyl_bessel_jf(nuf, xf);
+ std::tr1::cyl_bessel_j(nud, xd);
+ std::tr1::cyl_bessel_j(nul, xl);
+ std::tr1::cyl_bessel_jl(nul, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/09_cyl_bessel_j/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/09_cyl_bessel_j/compile_2.cc
new file mode 100644
index 00000000000..21589cf0225
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/09_cyl_bessel_j/compile_2.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.9 cyl_bessel_j
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+ float nuf = 1.0F / 3.0F, xf = 0.5F;
+ double nud = 1.0 / 3.0, xd = 0.5;
+ long double nul = 1.0L / 3.0L, xl = 0.5L;
+
+ cyl_bessel_j(nuf, xf);
+ cyl_bessel_jf(nuf, xf);
+ cyl_bessel_j(nud, xd);
+ cyl_bessel_j(nul, xl);
+ cyl_bessel_jl(nul, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/10_cyl_bessel_k/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/10_cyl_bessel_k/check_nan.cc
new file mode 100644
index 00000000000..72754a7dacd
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/10_cyl_bessel_k/check_nan.cc
@@ -0,0 +1,87 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.10 cyl_bessel_k
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+ float xf = std::numeric_limits<float>::quiet_NaN();
+ double xd = std::numeric_limits<double>::quiet_NaN();
+ long double xl = std::numeric_limits<long double>::quiet_NaN();
+
+ float nuf = 0.0F;
+ double nud = 0.0;
+ long double nul = 0.0L;
+
+ float a = std::tr1::cyl_bessel_k(nuf, xf);
+ float b = std::tr1::cyl_bessel_kf(nuf, xf);
+ double c = std::tr1::cyl_bessel_k(nud, xd);
+ long double d = std::tr1::cyl_bessel_k(nul, xl);
+ long double e = std::tr1::cyl_bessel_kl(nul, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+void
+test02()
+{
+ float xf = 1.0F;
+ double xd = 1.0;
+ long double xl = 1.0L;
+
+ float nuf = std::numeric_limits<float>::quiet_NaN();
+ double nud = std::numeric_limits<double>::quiet_NaN();
+ long double nul = std::numeric_limits<long double>::quiet_NaN();
+
+ float a = std::tr1::cyl_bessel_k(nuf, xf);
+ float b = std::tr1::cyl_bessel_kf(nuf, xf);
+ double c = std::tr1::cyl_bessel_k(nud, xd);
+ long double d = std::tr1::cyl_bessel_k(nul, xl);
+ long double e = std::tr1::cyl_bessel_kl(nul, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ test02();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/10_cyl_bessel_k/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/10_cyl_bessel_k/check_value.cc
new file mode 100644
index 00000000000..19405d0be4d
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/10_cyl_bessel_k/check_value.cc
@@ -0,0 +1,618 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// cyl_bessel_k
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for nu=0.0000000000000000.
+testcase_cyl_bessel_k<double> data001[] = {
+ { 0.0036910983340425947, 0.0000000000000000, 5.0000000000000000 },
+ { 1.7780062316167650e-05, 0.0000000000000000, 10.000000000000000 },
+ { 9.8195364823964333e-08, 0.0000000000000000, 15.000000000000000 },
+ { 5.7412378153365238e-10, 0.0000000000000000, 20.000000000000000 },
+ { 3.4641615622131151e-12, 0.0000000000000000, 25.000000000000000 },
+ { 2.1324774964630566e-14, 0.0000000000000000, 30.000000000000000 },
+ { 1.3310351491429464e-16, 0.0000000000000000, 35.000000000000000 },
+ { 8.3928611000995700e-19, 0.0000000000000000, 40.000000000000000 },
+ { 5.3334561226187255e-21, 0.0000000000000000, 45.000000000000000 },
+ { 3.4101677497894956e-23, 0.0000000000000000, 50.000000000000000 },
+ { 2.1913102183534147e-25, 0.0000000000000000, 55.000000000000000 },
+ { 1.4138978405591074e-27, 0.0000000000000000, 60.000000000000000 },
+ { 9.1544673210030045e-30, 0.0000000000000000, 65.000000000000000 },
+ { 5.9446613372925013e-32, 0.0000000000000000, 70.000000000000000 },
+ { 3.8701170455869113e-34, 0.0000000000000000, 75.000000000000000 },
+ { 2.5251198425054723e-36, 0.0000000000000000, 80.000000000000000 },
+ { 1.6507623579783908e-38, 0.0000000000000000, 85.000000000000000 },
+ { 1.0810242556984256e-40, 0.0000000000000000, 90.000000000000000 },
+ { 7.0901249699001278e-43, 0.0000000000000000, 95.000000000000000 },
+ { 4.6566282291759032e-45, 0.0000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=0.0000000000000000.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_cyl_bessel_k<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_k(Tp(data001[i].nu), Tp(data001[i].x));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for nu=0.33333333333333331.
+testcase_cyl_bessel_k<double> data002[] = {
+ { 0.0037288750960535887, 0.33333333333333331, 5.0000000000000000 },
+ { 1.7874608271055339e-05, 0.33333333333333331, 10.000000000000000 },
+ { 9.8548341568798317e-08, 0.33333333333333331, 15.000000000000000 },
+ { 5.7568278247790865e-10, 0.33333333333333331, 20.000000000000000 },
+ { 3.4717201424907059e-12, 0.33333333333333331, 25.000000000000000 },
+ { 2.1363664736611189e-14, 0.33333333333333331, 30.000000000000000 },
+ { 1.3331202314165813e-16, 0.33333333333333331, 35.000000000000000 },
+ { 8.4043837769480934e-19, 0.33333333333333331, 40.000000000000000 },
+ { 5.3399731261024948e-21, 0.33333333333333331, 45.000000000000000 },
+ { 3.4139217813583632e-23, 0.33333333333333331, 50.000000000000000 },
+ { 2.1935050179185627e-25, 0.33333333333333331, 55.000000000000000 },
+ { 1.4151968805623662e-27, 0.33333333333333331, 60.000000000000000 },
+ { 9.1622357217019043e-30, 0.33333333333333331, 65.000000000000000 },
+ { 5.9493479703461315e-32, 0.33333333333333331, 70.000000000000000 },
+ { 3.8729660011055947e-34, 0.33333333333333331, 75.000000000000000 },
+ { 2.5268631828013877e-36, 0.33333333333333331, 80.000000000000000 },
+ { 1.6518353676138867e-38, 0.33333333333333331, 85.000000000000000 },
+ { 1.0816880942511496e-40, 0.33333333333333331, 90.000000000000000 },
+ { 7.0942508599231512e-43, 0.33333333333333331, 95.000000000000000 },
+ { 4.6592031570213454e-45, 0.33333333333333331, 100.00000000000000 },
+};
+
+// Test function for nu=0.33333333333333331.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_cyl_bessel_k<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_k(Tp(data002[i].nu), Tp(data002[i].x));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for nu=0.50000000000000000.
+testcase_cyl_bessel_k<double> data003[] = {
+ { 0.0037766133746428825, 0.50000000000000000, 5.0000000000000000 },
+ { 1.7993478093705181e-05, 0.50000000000000000, 10.000000000000000 },
+ { 9.8991312032877236e-08, 0.50000000000000000, 15.000000000000000 },
+ { 5.7763739747074450e-10, 0.50000000000000000, 20.000000000000000 },
+ { 3.4811912768406949e-12, 0.50000000000000000, 25.000000000000000 },
+ { 2.1412375659560111e-14, 0.50000000000000000, 30.000000000000000 },
+ { 1.3357311366035824e-16, 0.50000000000000000, 35.000000000000000 },
+ { 8.4188091949489049e-19, 0.50000000000000000, 40.000000000000000 },
+ { 5.3481305002517408e-21, 0.50000000000000000, 45.000000000000000 },
+ { 3.4186200954570754e-23, 0.50000000000000000, 50.000000000000000 },
+ { 2.1962515908772453e-25, 0.50000000000000000, 55.000000000000000 },
+ { 1.4168223500353693e-27, 0.50000000000000000, 60.000000000000000 },
+ { 9.1719554473256892e-30, 0.50000000000000000, 65.000000000000000 },
+ { 5.9552114337788932e-32, 0.50000000000000000, 70.000000000000000 },
+ { 3.8765301321409432e-34, 0.50000000000000000, 75.000000000000000 },
+ { 2.5290440439442910e-36, 0.50000000000000000, 80.000000000000000 },
+ { 1.6531776067605980e-38, 0.50000000000000000, 85.000000000000000 },
+ { 1.0825184636529955e-40, 0.50000000000000000, 90.000000000000000 },
+ { 7.0994115873258822e-43, 0.50000000000000000, 95.000000000000000 },
+ { 4.6624238126346715e-45, 0.50000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=0.50000000000000000.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_cyl_bessel_k<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_k(Tp(data003[i].nu), Tp(data003[i].x));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for nu=0.66666666666666663.
+testcase_cyl_bessel_k<double> data004[] = {
+ { 0.0038444246344968226, 0.66666666666666663, 5.0000000000000000 },
+ { 1.8161187569530204e-05, 0.66666666666666663, 10.000000000000000 },
+ { 9.9614751542305571e-08, 0.66666666666666663, 15.000000000000000 },
+ { 5.8038484271925811e-10, 0.66666666666666663, 20.000000000000000 },
+ { 3.4944937498488603e-12, 0.66666666666666663, 25.000000000000000 },
+ { 2.1480755645577720e-14, 0.66666666666666663, 30.000000000000000 },
+ { 1.3393949190152161e-16, 0.66666666666666663, 35.000000000000000 },
+ { 8.4390460553642992e-19, 0.66666666666666663, 40.000000000000000 },
+ { 5.3595716143622089e-21, 0.66666666666666663, 45.000000000000000 },
+ { 3.4252085301433749e-23, 0.66666666666666663, 50.000000000000000 },
+ { 2.2001025377982308e-25, 0.66666666666666663, 55.000000000000000 },
+ { 1.4191011274172078e-27, 0.66666666666666663, 60.000000000000000 },
+ { 9.1855803020269763e-30, 0.66666666666666663, 65.000000000000000 },
+ { 5.9634299472578764e-32, 0.66666666666666663, 70.000000000000000 },
+ { 3.8815254026478500e-34, 0.66666666666666663, 75.000000000000000 },
+ { 2.5321003991943851e-36, 0.66666666666666663, 80.000000000000000 },
+ { 1.6550585670593067e-38, 0.66666666666666663, 85.000000000000000 },
+ { 1.0836820479428609e-40, 0.66666666666666663, 90.000000000000000 },
+ { 7.1066428916285356e-43, 0.66666666666666663, 95.000000000000000 },
+ { 4.6669364587280465e-45, 0.66666666666666663, 100.00000000000000 },
+};
+
+// Test function for nu=0.66666666666666663.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_cyl_bessel_k<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_k(Tp(data004[i].nu), Tp(data004[i].x));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for nu=1.0000000000000000.
+testcase_cyl_bessel_k<double> data005[] = {
+ { 0.0040446134454521655, 1.0000000000000000, 5.0000000000000000 },
+ { 1.8648773453825582e-05, 1.0000000000000000, 10.000000000000000 },
+ { 1.0141729369762091e-07, 1.0000000000000000, 15.000000000000000 },
+ { 5.8830579695570384e-10, 1.0000000000000000, 20.000000000000000 },
+ { 3.5327780731999345e-12, 1.0000000000000000, 25.000000000000000 },
+ { 2.1677320018915498e-14, 1.0000000000000000, 30.000000000000000 },
+ { 1.3499178340011053e-16, 1.0000000000000000, 35.000000000000000 },
+ { 8.4971319548610435e-19, 1.0000000000000000, 40.000000000000000 },
+ { 5.3923945937225050e-21, 1.0000000000000000, 45.000000000000000 },
+ { 3.4441022267175555e-23, 1.0000000000000000, 50.000000000000000 },
+ { 2.2111422716117463e-25, 1.0000000000000000, 55.000000000000000 },
+ { 1.4256320265171041e-27, 1.0000000000000000, 60.000000000000000 },
+ { 9.2246195278906156e-30, 1.0000000000000000, 65.000000000000000 },
+ { 5.9869736739138550e-32, 1.0000000000000000, 70.000000000000000 },
+ { 3.8958329467421912e-34, 1.0000000000000000, 75.000000000000000 },
+ { 2.5408531275211708e-36, 1.0000000000000000, 80.000000000000000 },
+ { 1.6604444948567571e-38, 1.0000000000000000, 85.000000000000000 },
+ { 1.0870134457498335e-40, 1.0000000000000000, 90.000000000000000 },
+ { 7.1273442329907240e-43, 1.0000000000000000, 95.000000000000000 },
+ { 4.6798537356369101e-45, 1.0000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=1.0000000000000000.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_cyl_bessel_k<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_k(Tp(data005[i].nu), Tp(data005[i].x));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for nu=2.0000000000000000.
+testcase_cyl_bessel_k<double> data006[] = {
+ { 0.0053089437122234608, 2.0000000000000000, 5.0000000000000000 },
+ { 2.1509817006932767e-05, 2.0000000000000000, 10.000000000000000 },
+ { 1.1171767065031378e-07, 2.0000000000000000, 15.000000000000000 },
+ { 6.3295436122922281e-10, 2.0000000000000000, 20.000000000000000 },
+ { 3.7467838080691102e-12, 2.0000000000000000, 25.000000000000000 },
+ { 2.2769929632558265e-14, 2.0000000000000000, 30.000000000000000 },
+ { 1.4081733110858665e-16, 2.0000000000000000, 35.000000000000000 },
+ { 8.8177176978426223e-19, 2.0000000000000000, 40.000000000000000 },
+ { 5.5731181045619477e-21, 2.0000000000000000, 45.000000000000000 },
+ { 3.5479318388581979e-23, 2.0000000000000000, 50.000000000000000 },
+ { 2.2717153918665688e-25, 2.0000000000000000, 55.000000000000000 },
+ { 1.4614189081096777e-27, 2.0000000000000000, 60.000000000000000 },
+ { 9.4383017680150234e-30, 2.0000000000000000, 65.000000000000000 },
+ { 6.1157177279757537e-32, 2.0000000000000000, 70.000000000000000 },
+ { 3.9740059241667034e-34, 2.0000000000000000, 75.000000000000000 },
+ { 2.5886411706935015e-36, 2.0000000000000000, 80.000000000000000 },
+ { 1.6898316402103145e-38, 2.0000000000000000, 85.000000000000000 },
+ { 1.1051801100484218e-40, 2.0000000000000000, 90.000000000000000 },
+ { 7.2401743221736176e-43, 2.0000000000000000, 95.000000000000000 },
+ { 4.7502253038886413e-45, 2.0000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=2.0000000000000000.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_cyl_bessel_k<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_k(Tp(data006[i].nu), Tp(data006[i].x));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for nu=5.0000000000000000.
+testcase_cyl_bessel_k<double> data007[] = {
+ { 0.032706273712031865, 5.0000000000000000, 5.0000000000000000 },
+ { 5.7541849985312275e-05, 5.0000000000000000, 10.000000000000000 },
+ { 2.1878261369258224e-07, 5.0000000000000000, 15.000000000000000 },
+ { 1.0538660139974233e-09, 5.0000000000000000, 20.000000000000000 },
+ { 5.6485921365284157e-12, 5.0000000000000000, 25.000000000000000 },
+ { 3.2103335105890266e-14, 5.0000000000000000, 30.000000000000000 },
+ { 1.8919208406439644e-16, 5.0000000000000000, 35.000000000000000 },
+ { 1.1423814375953188e-18, 5.0000000000000000, 40.000000000000000 },
+ { 7.0181216822204116e-21, 5.0000000000000000, 45.000000000000000 },
+ { 4.3671822541009859e-23, 5.0000000000000000, 50.000000000000000 },
+ { 2.7444967640357869e-25, 5.0000000000000000, 55.000000000000000 },
+ { 1.7382232741886986e-27, 5.0000000000000000, 60.000000000000000 },
+ { 1.1078474298959669e-29, 5.0000000000000000, 65.000000000000000 },
+ { 7.0974537081794416e-32, 5.0000000000000000, 70.000000000000000 },
+ { 4.5667269500061064e-34, 5.0000000000000000, 75.000000000000000 },
+ { 2.9491764420206150e-36, 5.0000000000000000, 80.000000000000000 },
+ { 1.9105685973117463e-38, 5.0000000000000000, 85.000000000000000 },
+ { 1.2411034311592645e-40, 5.0000000000000000, 90.000000000000000 },
+ { 8.0814211331379146e-43, 5.0000000000000000, 95.000000000000000 },
+ { 5.2732561132929509e-45, 5.0000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=5.0000000000000000.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_cyl_bessel_k<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_k(Tp(data007[i].nu), Tp(data007[i].x));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for nu=10.000000000000000.
+testcase_cyl_bessel_k<double> data008[] = {
+ { 9.7585628291778121, 10.000000000000000, 5.0000000000000000 },
+ { 0.0016142553003906700, 10.000000000000000, 10.000000000000000 },
+ { 2.2605303776606440e-06, 10.000000000000000, 15.000000000000000 },
+ { 6.3162145283215787e-09, 10.000000000000000, 20.000000000000000 },
+ { 2.4076769602801230e-11, 10.000000000000000, 25.000000000000000 },
+ { 1.0842816942222975e-13, 10.000000000000000, 30.000000000000000 },
+ { 5.3976770429777191e-16, 10.000000000000000, 35.000000000000000 },
+ { 2.8680293113671932e-18, 10.000000000000000, 40.000000000000000 },
+ { 1.5939871900169603e-20, 10.000000000000000, 45.000000000000000 },
+ { 9.1509882099879962e-23, 10.000000000000000, 50.000000000000000 },
+ { 5.3823846249592858e-25, 10.000000000000000, 55.000000000000000 },
+ { 3.2253408700563144e-27, 10.000000000000000, 60.000000000000000 },
+ { 1.9613367530075138e-29, 10.000000000000000, 65.000000000000000 },
+ { 1.2068471495933484e-31, 10.000000000000000, 70.000000000000000 },
+ { 7.4979152649449644e-34, 10.000000000000000, 75.000000000000000 },
+ { 4.6957285830490538e-36, 10.000000000000000, 80.000000000000000 },
+ { 2.9606323347034084e-38, 10.000000000000000, 85.000000000000000 },
+ { 1.8773542561131613e-40, 10.000000000000000, 90.000000000000000 },
+ { 1.1962899527846350e-42, 10.000000000000000, 95.000000000000000 },
+ { 7.6554279773881018e-45, 10.000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=10.000000000000000.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_cyl_bessel_k<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_k(Tp(data008[i].nu), Tp(data008[i].x));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for nu=20.000000000000000.
+testcase_cyl_bessel_k<double> data009[] = {
+ { 482700052.06214869, 20.000000000000000, 5.0000000000000000 },
+ { 178.74427820770549, 20.000000000000000, 10.000000000000000 },
+ { 0.012141257729731146, 20.000000000000000, 15.000000000000000 },
+ { 5.5431116361258155e-06, 20.000000000000000, 20.000000000000000 },
+ { 6.3744029330352105e-09, 20.000000000000000, 25.000000000000000 },
+ { 1.2304516475442478e-11, 20.000000000000000, 30.000000000000000 },
+ { 3.2673136479809012e-14, 20.000000000000000, 35.000000000000000 },
+ { 1.0703023799997383e-16, 20.000000000000000, 40.000000000000000 },
+ { 4.0549953175660486e-19, 20.000000000000000, 45.000000000000000 },
+ { 1.7061483797220352e-21, 20.000000000000000, 50.000000000000000 },
+ { 7.7617008115659413e-24, 20.000000000000000, 55.000000000000000 },
+ { 3.7482954006874725e-26, 20.000000000000000, 60.000000000000000 },
+ { 1.8966880763956578e-28, 20.000000000000000, 65.000000000000000 },
+ { 9.9615763479998882e-31, 20.000000000000000, 70.000000000000000 },
+ { 5.3921623063091066e-33, 20.000000000000000, 75.000000000000000 },
+ { 2.9920407657642272e-35, 20.000000000000000, 80.000000000000000 },
+ { 1.6948662723618263e-37, 20.000000000000000, 85.000000000000000 },
+ { 9.7689149642963025e-40, 20.000000000000000, 90.000000000000000 },
+ { 5.7143603019220823e-42, 20.000000000000000, 95.000000000000000 },
+ { 3.3852054148901700e-44, 20.000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=20.000000000000000.
+template <typename Tp>
+void test009()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data009)
+ / sizeof(testcase_cyl_bessel_k<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_k(Tp(data009[i].nu), Tp(data009[i].x));
+ const Tp f0 = data009[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for nu=50.000000000000000.
+testcase_cyl_bessel_k<double> data010[] = {
+ { 3.3943222434301628e+42, 50.000000000000000, 5.0000000000000000 },
+ { 2.0613737753892579e+27, 50.000000000000000, 10.000000000000000 },
+ { 1.7267736974519191e+18, 50.000000000000000, 15.000000000000000 },
+ { 411711209122.01794, 50.000000000000000, 20.000000000000000 },
+ { 1972478.7419813862, 50.000000000000000, 25.000000000000000 },
+ { 58.770686258007267, 50.000000000000000, 30.000000000000000 },
+ { 0.0058659391182535195, 50.000000000000000, 35.000000000000000 },
+ { 1.3634854128794103e-06, 50.000000000000000, 40.000000000000000 },
+ { 5.8652396362160840e-10, 50.000000000000000, 45.000000000000000 },
+ { 4.0060134766400903e-13, 50.000000000000000, 50.000000000000000 },
+ { 3.9062324485711016e-16, 50.000000000000000, 55.000000000000000 },
+ { 5.0389298085176520e-19, 50.000000000000000, 60.000000000000000 },
+ { 8.1305344250110396e-22, 50.000000000000000, 65.000000000000000 },
+ { 1.5732816234949002e-24, 50.000000000000000, 70.000000000000000 },
+ { 3.5349854993874397e-27, 50.000000000000000, 75.000000000000000 },
+ { 8.9940101003189485e-30, 50.000000000000000, 80.000000000000000 },
+ { 2.5403205503080723e-32, 50.000000000000000, 85.000000000000000 },
+ { 7.8397596486715711e-35, 50.000000000000000, 90.000000000000000 },
+ { 2.6098900651329550e-37, 50.000000000000000, 95.000000000000000 },
+ { 9.2745226536133274e-40, 50.000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=50.000000000000000.
+template <typename Tp>
+void test010()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data010)
+ / sizeof(testcase_cyl_bessel_k<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_k(Tp(data010[i].nu), Tp(data010[i].x));
+ const Tp f0 = data010[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for nu=100.00000000000000.
+testcase_cyl_bessel_k<double> data011[] = {
+ { 7.0398601930616797e+115, 100.00000000000000, 5.0000000000000000 },
+ { 4.5966740842695286e+85, 100.00000000000000, 10.000000000000000 },
+ { 8.2565552242653898e+67, 100.00000000000000, 15.000000000000000 },
+ { 1.7081356456876038e+55, 100.00000000000000, 20.000000000000000 },
+ { 1.9858028128780595e+45, 100.00000000000000, 25.000000000000000 },
+ { 1.2131584253026677e+37, 100.00000000000000, 30.000000000000000 },
+ { 1.1016916354696684e+30, 100.00000000000000, 35.000000000000000 },
+ { 7.0074023297775712e+23, 100.00000000000000, 40.000000000000000 },
+ { 1.9236643958470909e+18, 100.00000000000000, 45.000000000000000 },
+ { 16394035276269.254, 100.00000000000000, 50.000000000000000 },
+ { 343254952.89495456, 100.00000000000000, 55.000000000000000 },
+ { 14870.012754946305, 100.00000000000000, 60.000000000000000 },
+ { 1.1708099078572209, 100.00000000000000, 65.000000000000000 },
+ { 0.00015161193930722305, 100.00000000000000, 70.000000000000000 },
+ { 2.9850234381623436e-08, 100.00000000000000, 75.000000000000000 },
+ { 8.3928710724649065e-12, 100.00000000000000, 80.000000000000000 },
+ { 3.2033435630927728e-15, 100.00000000000000, 85.000000000000000 },
+ { 1.5922281431788077e-18, 100.00000000000000, 90.000000000000000 },
+ { 9.9589454577674300e-22, 100.00000000000000, 95.000000000000000 },
+ { 7.6171296304940858e-25, 100.00000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=100.00000000000000.
+template <typename Tp>
+void test011()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data011)
+ / sizeof(testcase_cyl_bessel_k<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_bessel_k(Tp(data011[i].nu), Tp(data011[i].x));
+ const Tp f0 = data011[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ test009<double>();
+ test010<double>();
+ test011<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/10_cyl_bessel_k/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/10_cyl_bessel_k/compile.cc
new file mode 100644
index 00000000000..03d6a0c5140
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/10_cyl_bessel_k/compile.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.10 cyl_bessel_k
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+ float nuf = 1.0F / 3.0F, xf = 0.5F;
+ double nud = 1.0 / 3.0, xd = 0.5;
+ long double nul = 1.0L / 3.0L, xl = 0.5L;
+
+ std::tr1::cyl_bessel_k(nuf, xf);
+ std::tr1::cyl_bessel_kf(nuf, xf);
+ std::tr1::cyl_bessel_k(nud, xd);
+ std::tr1::cyl_bessel_k(nul, xl);
+ std::tr1::cyl_bessel_kl(nul, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/10_cyl_bessel_k/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/10_cyl_bessel_k/compile_2.cc
new file mode 100644
index 00000000000..5be103f0fe2
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/10_cyl_bessel_k/compile_2.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.10 cyl_bessel_k
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+ float nuf = 1.0F / 3.0F, xf = 0.5F;
+ double nud = 1.0 / 3.0, xd = 0.5;
+ long double nul = 1.0L / 3.0L, xl = 0.5L;
+
+ cyl_bessel_k(nuf, xf);
+ cyl_bessel_kf(nuf, xf);
+ cyl_bessel_k(nud, xd);
+ cyl_bessel_k(nul, xl);
+ cyl_bessel_kl(nul, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/11_cyl_neumann/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/11_cyl_neumann/check_nan.cc
new file mode 100644
index 00000000000..6d631086928
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/11_cyl_neumann/check_nan.cc
@@ -0,0 +1,87 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.11 cyl_neumann
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+ float xf = std::numeric_limits<float>::quiet_NaN();
+ double xd = std::numeric_limits<double>::quiet_NaN();
+ long double xl = std::numeric_limits<long double>::quiet_NaN();
+
+ float nuf = 0.0F;
+ double nud = 0.0;
+ long double nul = 0.0L;
+
+ float a = std::tr1::cyl_neumann(nuf, xf);
+ float b = std::tr1::cyl_neumannf(nuf, xf);
+ double c = std::tr1::cyl_neumann(nud, xd);
+ long double d = std::tr1::cyl_neumann(nul, xl);
+ long double e = std::tr1::cyl_neumannl(nul, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+void
+test02()
+{
+ float xf = 1.0F;
+ double xd = 1.0;
+ long double xl = 1.0L;
+
+ float nuf = std::numeric_limits<float>::quiet_NaN();
+ double nud = std::numeric_limits<double>::quiet_NaN();
+ long double nul = std::numeric_limits<long double>::quiet_NaN();
+
+ float a = std::tr1::cyl_neumann(nuf, xf);
+ float b = std::tr1::cyl_neumannf(nuf, xf);
+ double c = std::tr1::cyl_neumann(nud, xd);
+ long double d = std::tr1::cyl_neumann(nul, xl);
+ long double e = std::tr1::cyl_neumannl(nul, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ test02();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/11_cyl_neumann/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/11_cyl_neumann/check_value.cc
new file mode 100644
index 00000000000..494f9893096
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/11_cyl_neumann/check_value.cc
@@ -0,0 +1,618 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// cyl_neumann
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for nu=0.0000000000000000.
+testcase_cyl_neumann<double> data001[] = {
+ { -0.30851762524903376, 0.0000000000000000, 5.0000000000000000 },
+ { 0.055671167283599395, 0.0000000000000000, 10.000000000000000 },
+ { 0.20546429603891825, 0.0000000000000000, 15.000000000000000 },
+ { 0.062640596809383955, 0.0000000000000000, 20.000000000000000 },
+ { -0.12724943226800620, 0.0000000000000000, 25.000000000000000 },
+ { -0.11729573168666411, 0.0000000000000000, 30.000000000000000 },
+ { 0.045797987195155640, 0.0000000000000000, 35.000000000000000 },
+ { 0.12593641705826095, 0.0000000000000000, 40.000000000000000 },
+ { 0.027060469763313322, 0.0000000000000000, 45.000000000000000 },
+ { -0.098064995470077104, 0.0000000000000000, 50.000000000000000 },
+ { -0.077569178730412622, 0.0000000000000000, 55.000000000000000 },
+ { 0.047358952209449412, 0.0000000000000000, 60.000000000000000 },
+ { 0.097183557740181933, 0.0000000000000000, 65.000000000000000 },
+ { 0.0093096664589410131, 0.0000000000000000, 70.000000000000000 },
+ { -0.085369047647775642, 0.0000000000000000, 75.000000000000000 },
+ { -0.055620339089769981, 0.0000000000000000, 80.000000000000000 },
+ { 0.049567884951494258, 0.0000000000000000, 85.000000000000000 },
+ { 0.079776475854877765, 0.0000000000000000, 90.000000000000000 },
+ { -0.0028230995861232323, 0.0000000000000000, 95.000000000000000 },
+ { -0.077244313365083112, 0.0000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=0.0000000000000000.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_cyl_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_neumann(Tp(data001[i].nu), Tp(data001[i].x));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-10));
+}
+
+// Test data for nu=0.33333333333333331.
+testcase_cyl_neumann<double> data002[] = {
+ { -0.18192321129343830, 0.33333333333333331, 5.0000000000000000 },
+ { 0.17020111788268769, 0.33333333333333331, 10.000000000000000 },
+ { 0.18540507541540799, 0.33333333333333331, 15.000000000000000 },
+ { -0.028777707635715091, 0.33333333333333331, 20.000000000000000 },
+ { -0.15829741864944166, 0.33333333333333331, 25.000000000000000 },
+ { -0.058645772316705216, 0.33333333333333331, 30.000000000000000 },
+ { 0.10294930308870620, 0.33333333333333331, 35.000000000000000 },
+ { 0.10547870367098920, 0.33333333333333331, 40.000000000000000 },
+ { -0.034334228816010864, 0.33333333333333331, 45.000000000000000 },
+ { -0.11283489933031278, 0.33333333333333331, 50.000000000000000 },
+ { -0.030007358986895123, 0.33333333333333331, 55.000000000000000 },
+ { 0.086699173295718093, 0.33333333333333331, 60.000000000000000 },
+ { 0.074875579668878672, 0.33333333333333331, 65.000000000000000 },
+ { -0.039323246374552645, 0.33333333333333331, 70.000000000000000 },
+ { -0.091263539574475222, 0.33333333333333331, 75.000000000000000 },
+ { -0.013358849535984282, 0.33333333333333331, 80.000000000000000 },
+ { 0.078373575537830184, 0.33333333333333331, 85.000000000000000 },
+ { 0.055812482883955974, 0.33333333333333331, 90.000000000000000 },
+ { -0.043310380106990579, 0.33333333333333331, 95.000000000000000 },
+ { -0.076900504962136587, 0.33333333333333331, 100.00000000000000 },
+};
+
+// Test function for nu=0.33333333333333331.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_cyl_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_neumann(Tp(data002[i].nu), Tp(data002[i].x));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000014e-11));
+}
+
+// Test data for nu=0.50000000000000000.
+testcase_cyl_neumann<double> data003[] = {
+ { -0.10121770918510843, 0.50000000000000000, 5.0000000000000000 },
+ { 0.21170886633139813, 0.50000000000000000, 10.000000000000000 },
+ { 0.15650551590730860, 0.50000000000000000, 15.000000000000000 },
+ { -0.072806904785061841, 0.50000000000000000, 20.000000000000000 },
+ { -0.15817308404205055, 0.50000000000000000, 25.000000000000000 },
+ { -0.022470290598831121, 0.50000000000000000, 30.000000000000000 },
+ { 0.12187835265849536, 0.50000000000000000, 35.000000000000000 },
+ { 0.084138655676395432, 0.50000000000000000, 40.000000000000000 },
+ { -0.062482641933003132, 0.50000000000000000, 45.000000000000000 },
+ { -0.10888475635053953, 0.50000000000000000, 50.000000000000000 },
+ { -0.0023805454010948804, 0.50000000000000000, 55.000000000000000 },
+ { 0.098104683735037904, 0.50000000000000000, 60.000000000000000 },
+ { 0.055663470218594434, 0.50000000000000000, 65.000000000000000 },
+ { -0.060396767883824809, 0.50000000000000000, 70.000000000000000 },
+ { -0.084922578922046868, 0.50000000000000000, 75.000000000000000 },
+ { 0.0098472271924441215, 0.50000000000000000, 80.000000000000000 },
+ { 0.085190643574343639, 0.50000000000000000, 85.000000000000000 },
+ { 0.037684970437156261, 0.50000000000000000, 90.000000000000000 },
+ { -0.059772904856097479, 0.50000000000000000, 95.000000000000000 },
+ { -0.068803091468728053, 0.50000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=0.50000000000000000.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_cyl_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_neumann(Tp(data003[i].nu), Tp(data003[i].x));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000028e-11));
+}
+
+// Test data for nu=0.66666666666666663.
+testcase_cyl_neumann<double> data004[] = {
+ { -0.016050662643389616, 0.66666666666666663, 5.0000000000000000 },
+ { 0.23937232657540730, 0.66666666666666663, 10.000000000000000 },
+ { 0.11762106604241242, 0.66666666666666663, 15.000000000000000 },
+ { -0.11182254014899563, 0.66666666666666663, 20.000000000000000 },
+ { -0.14756582982938804, 0.66666666666666663, 25.000000000000000 },
+ { 0.015078692908077665, 0.66666666666666663, 30.000000000000000 },
+ { 0.13260911815705798, 0.66666666666666663, 35.000000000000000 },
+ { 0.057217565989652795, 0.66666666666666663, 40.000000000000000 },
+ { -0.086373755152382048, 0.66666666666666663, 45.000000000000000 },
+ { -0.097624139208051630, 0.66666666666666663, 50.000000000000000 },
+ { 0.025354902147023434, 0.66666666666666663, 55.000000000000000 },
+ { 0.10288136476351209, 0.66666666666666663, 60.000000000000000 },
+ { 0.032728379560128203, 0.66666666666666663, 65.000000000000000 },
+ { -0.077363672735747777, 0.66666666666666663, 70.000000000000000 },
+ { -0.072855870458293975, 0.66666666666666663, 75.000000000000000 },
+ { 0.032358106046953494, 0.66666666666666663, 80.000000000000000 },
+ { 0.086240651537394228, 0.66666666666666663, 85.000000000000000 },
+ { 0.017029601697285159, 0.66666666666666663, 90.000000000000000 },
+ { -0.072173520560584709, 0.66666666666666663, 95.000000000000000 },
+ { -0.056057339204073985, 0.66666666666666663, 100.00000000000000 },
+};
+
+// Test function for nu=0.66666666666666663.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_cyl_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_neumann(Tp(data004[i].nu), Tp(data004[i].x));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000014e-11));
+}
+
+// Test data for nu=1.0000000000000000.
+testcase_cyl_neumann<double> data005[] = {
+ { 0.14786314339122689, 1.0000000000000000, 5.0000000000000000 },
+ { 0.24901542420695388, 1.0000000000000000, 10.000000000000000 },
+ { 0.021073628036873546, 1.0000000000000000, 15.000000000000000 },
+ { -0.16551161436252118, 1.0000000000000000, 20.000000000000000 },
+ { -0.098829964783237384, 1.0000000000000000, 25.000000000000000 },
+ { 0.084425570661747149, 1.0000000000000000, 30.000000000000000 },
+ { 0.12751273354559012, 1.0000000000000000, 35.000000000000000 },
+ { -0.0057935058215496330, 1.0000000000000000, 40.000000000000000 },
+ { -0.11552517964639945, 1.0000000000000000, 45.000000000000000 },
+ { -0.056795668562014713, 1.0000000000000000, 50.000000000000000 },
+ { 0.073846265432577940, 1.0000000000000000, 55.000000000000000 },
+ { 0.091869609369866906, 1.0000000000000000, 60.000000000000000 },
+ { -0.017940374275377303, 1.0000000000000000, 65.000000000000000 },
+ { -0.094844652625716244, 1.0000000000000000, 70.000000000000000 },
+ { -0.035213785160580456, 1.0000000000000000, 75.000000000000000 },
+ { 0.069395913784588051, 1.0000000000000000, 80.000000000000000 },
+ { 0.071233187582749782, 1.0000000000000000, 85.000000000000000 },
+ { -0.026187238607768282, 1.0000000000000000, 90.000000000000000 },
+ { -0.081827958724501229, 1.0000000000000000, 95.000000000000000 },
+ { -0.020372312002759942, 1.0000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=1.0000000000000000.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_cyl_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_neumann(Tp(data005[i].nu), Tp(data005[i].x));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000014e-11));
+}
+
+// Test data for nu=2.0000000000000000.
+testcase_cyl_neumann<double> data006[] = {
+ { 0.36766288260552449, 2.0000000000000000, 5.0000000000000000 },
+ { -0.0058680824422086154, 2.0000000000000000, 10.000000000000000 },
+ { -0.20265447896733510, 2.0000000000000000, 15.000000000000000 },
+ { -0.079191758245636068, 2.0000000000000000, 20.000000000000000 },
+ { 0.11934303508534720, 2.0000000000000000, 25.000000000000000 },
+ { 0.12292410306411393, 2.0000000000000000, 30.000000000000000 },
+ { -0.038511545278264774, 2.0000000000000000, 35.000000000000000 },
+ { -0.12622609234933843, 2.0000000000000000, 40.000000000000000 },
+ { -0.032194922192042189, 2.0000000000000000, 45.000000000000000 },
+ { 0.095793168727596509, 2.0000000000000000, 50.000000000000000 },
+ { 0.080254497473415454, 2.0000000000000000, 55.000000000000000 },
+ { -0.044296631897120513, 2.0000000000000000, 60.000000000000000 },
+ { -0.097735569256347382, 2.0000000000000000, 65.000000000000000 },
+ { -0.012019513676818619, 2.0000000000000000, 70.000000000000000 },
+ { 0.084430013376826832, 2.0000000000000000, 75.000000000000000 },
+ { 0.057355236934384685, 2.0000000000000000, 80.000000000000000 },
+ { -0.047891809949547205, 2.0000000000000000, 85.000000000000000 },
+ { -0.080358414490605948, 2.0000000000000000, 90.000000000000000 },
+ { 0.0011004057182389959, 2.0000000000000000, 95.000000000000000 },
+ { 0.076836867125027908, 2.0000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=2.0000000000000000.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_cyl_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_neumann(Tp(data006[i].nu), Tp(data006[i].x));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000017e-10));
+}
+
+// Test data for nu=5.0000000000000000.
+testcase_cyl_neumann<double> data007[] = {
+ { -0.45369482249110188, 5.0000000000000000, 5.0000000000000000 },
+ { 0.13540304768936232, 5.0000000000000000, 10.000000000000000 },
+ { 0.16717271575940021, 5.0000000000000000, 15.000000000000000 },
+ { -0.10003576788953225, 5.0000000000000000, 20.000000000000000 },
+ { -0.14705799311372267, 5.0000000000000000, 25.000000000000000 },
+ { 0.031627359289264322, 5.0000000000000000, 30.000000000000000 },
+ { 0.13554781474770031, 5.0000000000000000, 35.000000000000000 },
+ { 0.031869448780850372, 5.0000000000000000, 40.000000000000000 },
+ { -0.10426932700176872, 5.0000000000000000, 45.000000000000000 },
+ { -0.078548413913081608, 5.0000000000000000, 50.000000000000000 },
+ { 0.055257033062858382, 5.0000000000000000, 55.000000000000000 },
+ { 0.099464632840450901, 5.0000000000000000, 60.000000000000000 },
+ { 0.00023860469499600970, 5.0000000000000000, 65.000000000000000 },
+ { -0.091861802216406066, 5.0000000000000000, 70.000000000000000 },
+ { -0.048383671296970077, 5.0000000000000000, 75.000000000000000 },
+ { 0.060293667104896330, 5.0000000000000000, 80.000000000000000 },
+ { 0.077506166682734010, 5.0000000000000000, 85.000000000000000 },
+ { -0.015338764062239803, 5.0000000000000000, 90.000000000000000 },
+ { -0.081531504045514375, 5.0000000000000000, 95.000000000000000 },
+ { -0.029480196281662041, 5.0000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=5.0000000000000000.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_cyl_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_neumann(Tp(data007[i].nu), Tp(data007[i].x));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000013e-09));
+}
+
+// Test data for nu=10.000000000000000.
+testcase_cyl_neumann<double> data008[] = {
+ { -25.129110095610098, 10.000000000000000, 5.0000000000000000 },
+ { -0.35981415218340279, 10.000000000000000, 10.000000000000000 },
+ { 0.21997141360195582, 10.000000000000000, 15.000000000000000 },
+ { -0.043894653515658202, 10.000000000000000, 20.000000000000000 },
+ { -0.14871839049980651, 10.000000000000000, 25.000000000000000 },
+ { 0.075056702122397012, 10.000000000000000, 30.000000000000000 },
+ { 0.12222473135000553, 10.000000000000000, 35.000000000000000 },
+ { -0.046723877232677867, 10.000000000000000, 40.000000000000000 },
+ { -0.11739339009322178, 10.000000000000000, 45.000000000000000 },
+ { 0.0057238971820535740, 10.000000000000000, 50.000000000000000 },
+ { 0.10733910125831635, 10.000000000000000, 55.000000000000000 },
+ { 0.036290350559545506, 10.000000000000000, 60.000000000000000 },
+ { -0.083239127691715639, 10.000000000000000, 65.000000000000000 },
+ { -0.069639384138314872, 10.000000000000000, 70.000000000000000 },
+ { 0.045798335061325038, 10.000000000000000, 75.000000000000000 },
+ { 0.086269195064844428, 10.000000000000000, 80.000000000000000 },
+ { -0.0018234674126248629, 10.000000000000000, 85.000000000000000 },
+ { -0.082067762371231298, 10.000000000000000, 90.000000000000000 },
+ { -0.038798074754578075, 10.000000000000000, 95.000000000000000 },
+ { 0.058331574236414815, 10.000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=10.000000000000000.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_cyl_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_neumann(Tp(data008[i].nu), Tp(data008[i].x));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000017e-10));
+}
+
+// Test data for nu=20.000000000000000.
+testcase_cyl_neumann<double> data009[] = {
+ { -593396529.69143212, 20.000000000000000, 5.0000000000000000 },
+ { -1597.4838482696264, 20.000000000000000, 10.000000000000000 },
+ { -3.3087330924737630, 20.000000000000000, 15.000000000000000 },
+ { -0.28548945860020319, 20.000000000000000, 20.000000000000000 },
+ { 0.19804074776289243, 20.000000000000000, 25.000000000000000 },
+ { -0.16848153948742675, 20.000000000000000, 30.000000000000000 },
+ { 0.10102784152594022, 20.000000000000000, 35.000000000000000 },
+ { 0.045161820565805928, 20.000000000000000, 40.000000000000000 },
+ { -0.12556489308015448, 20.000000000000000, 45.000000000000000 },
+ { 0.016442633948115841, 20.000000000000000, 50.000000000000000 },
+ { 0.10853448778255187, 20.000000000000000, 55.000000000000000 },
+ { -0.026721408520664677, 20.000000000000000, 60.000000000000000 },
+ { -0.098780425256324203, 20.000000000000000, 65.000000000000000 },
+ { 0.016201957786018205, 20.000000000000000, 70.000000000000000 },
+ { 0.093591198265063735, 20.000000000000000, 75.000000000000000 },
+ { 0.0040484400737295740, 20.000000000000000, 80.000000000000000 },
+ { -0.086314929459920503, 20.000000000000000, 85.000000000000000 },
+ { -0.028274110097231495, 20.000000000000000, 90.000000000000000 },
+ { 0.072349520791638755, 20.000000000000000, 95.000000000000000 },
+ { 0.051247973076188565, 20.000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=20.000000000000000.
+template <typename Tp>
+void test009()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data009)
+ / sizeof(testcase_cyl_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_neumann(Tp(data009[i].nu), Tp(data009[i].x));
+ const Tp f0 = data009[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-10));
+}
+
+// Test data for nu=50.000000000000000.
+testcase_cyl_neumann<double> data010[] = {
+ { -2.7888370175838943e+42, 50.000000000000000, 5.0000000000000000 },
+ { -3.6410665018007421e+27, 50.000000000000000, 10.000000000000000 },
+ { -1.0929732912175405e+19, 50.000000000000000, 15.000000000000000 },
+ { -15606426801663.732, 50.000000000000000, 20.000000000000000 },
+ { -753573251.44662631, 50.000000000000000, 25.000000000000000 },
+ { -386759.32602734747, 50.000000000000000, 30.000000000000000 },
+ { -1172.8690492895341, 50.000000000000000, 35.000000000000000 },
+ { -15.615608873419953, 50.000000000000000, 40.000000000000000 },
+ { -0.87058346204176951, 50.000000000000000, 45.000000000000000 },
+ { -0.21031655464397736, 50.000000000000000, 50.000000000000000 },
+ { 0.093048240412999375, 50.000000000000000, 55.000000000000000 },
+ { 0.0086417699626745066, 50.000000000000000, 60.000000000000000 },
+ { -0.025019788459221974, 50.000000000000000, 65.000000000000000 },
+ { -0.0014815155191908913, 50.000000000000000, 70.000000000000000 },
+ { 0.050335774732164155, 50.000000000000000, 75.000000000000000 },
+ { -0.092924250967987204, 50.000000000000000, 80.000000000000000 },
+ { 0.087332463030205670, 50.000000000000000, 85.000000000000000 },
+ { -0.016164237701651891, 50.000000000000000, 90.000000000000000 },
+ { -0.068897613820457920, 50.000000000000000, 95.000000000000000 },
+ { 0.076505263944802962, 50.000000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=50.000000000000000.
+template <typename Tp>
+void test010()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data010)
+ / sizeof(testcase_cyl_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_neumann(Tp(data010[i].nu), Tp(data010[i].x));
+ const Tp f0 = data010[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000017e-10));
+}
+
+// Test data for nu=100.00000000000000.
+testcase_cyl_neumann<double> data011[] = {
+ { -5.0848639160196196e+115, 100.00000000000000, 5.0000000000000000 },
+ { -4.8491482711800245e+85, 100.00000000000000, 10.000000000000000 },
+ { -1.6375955323195320e+68, 100.00000000000000, 15.000000000000000 },
+ { -8.2002648144679137e+55, 100.00000000000000, 20.000000000000000 },
+ { -2.9712216432562373e+46, 100.00000000000000, 25.000000000000000 },
+ { -7.2875284708240766e+38, 100.00000000000000, 30.000000000000000 },
+ { -3.4251079902108953e+32, 100.00000000000000, 35.000000000000000 },
+ { -1.4552439438101799e+27, 100.00000000000000, 40.000000000000000 },
+ { -3.4506612476220073e+22, 100.00000000000000, 45.000000000000000 },
+ { -3.2938001882025948e+18, 100.00000000000000, 50.000000000000000 },
+ { -1005686182055527.4, 100.00000000000000, 55.000000000000000 },
+ { -831892881402.11377, 100.00000000000000, 60.000000000000000 },
+ { -1650863778.0598330, 100.00000000000000, 65.000000000000000 },
+ { -7192614.1976097804, 100.00000000000000, 70.000000000000000 },
+ { -64639.072261231602, 100.00000000000000, 75.000000000000000 },
+ { -1152.5905185698464, 100.00000000000000, 80.000000000000000 },
+ { -40.250761402102000, 100.00000000000000, 85.000000000000000 },
+ { -2.8307771387185459, 100.00000000000000, 90.000000000000000 },
+ { -0.45762200495904559, 100.00000000000000, 95.000000000000000 },
+ { -0.16692141141757649, 100.00000000000000, 100.00000000000000 },
+};
+
+// Test function for nu=100.00000000000000.
+template <typename Tp>
+void test011()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data011)
+ / sizeof(testcase_cyl_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::cyl_neumann(Tp(data011[i].nu), Tp(data011[i].x));
+ const Tp f0 = data011[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-11));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ test009<double>();
+ test010<double>();
+ test011<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/11_cyl_neumann/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/11_cyl_neumann/compile.cc
new file mode 100644
index 00000000000..0d948655513
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/11_cyl_neumann/compile.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.11 cyl_neumann
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+ float nuf = 1.0F / 3.0F, xf = 0.5F;
+ double nud = 1.0 / 3.0, xd = 0.5;
+ long double nul = 1.0L / 3.0L, xl = 0.5L;
+
+ std::tr1::cyl_neumann(nuf, xf);
+ std::tr1::cyl_neumannf(nuf, xf);
+ std::tr1::cyl_neumann(nud, xd);
+ std::tr1::cyl_neumann(nul, xl);
+ std::tr1::cyl_neumannl(nul, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/11_cyl_neumann/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/11_cyl_neumann/compile_2.cc
new file mode 100644
index 00000000000..39e0cac7ea5
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/11_cyl_neumann/compile_2.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.11 cyl_neumann
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+ float nuf = 1.0F / 3.0F, xf = 0.5F;
+ double nud = 1.0 / 3.0, xd = 0.5;
+ long double nul = 1.0L / 3.0L, xl = 0.5L;
+
+ cyl_neumann(nuf, xf);
+ cyl_neumannf(nuf, xf);
+ cyl_neumann(nud, xd);
+ cyl_neumann(nul, xl);
+ cyl_neumannl(nul, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/check_nan.cc
new file mode 100644
index 00000000000..d86c5b40f54
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/check_nan.cc
@@ -0,0 +1,87 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.12 ellint_1
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+ float kf = std::numeric_limits<float>::quiet_NaN();
+ double kd = std::numeric_limits<double>::quiet_NaN();
+ long double kl = std::numeric_limits<long double>::quiet_NaN();
+
+ float phif = std::atan2(1.0F, 1.0F);
+ double phid = std::atan2(1.0, 1.0);
+ long double phil = std::atan2(1.0L, 1.0L);
+
+ float a = std::tr1::ellint_1(kf, phif);
+ float b = std::tr1::ellint_1f(kf, phif);
+ double c = std::tr1::ellint_1(kd, phid);
+ long double d = std::tr1::ellint_1(kl, phil);
+ long double e = std::tr1::ellint_1l(kl, phil);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+void
+test02()
+{
+ float kf = 0.5F;
+ double kd = 0.5;
+ long double kl = 0.5L;
+
+ float phif = std::numeric_limits<float>::quiet_NaN();
+ double phid = std::numeric_limits<double>::quiet_NaN();
+ long double phil = std::numeric_limits<long double>::quiet_NaN();
+
+ float a = std::tr1::ellint_1(kf, phif);
+ float b = std::tr1::ellint_1f(kf, phif);
+ double c = std::tr1::ellint_1(kd, phid);
+ long double d = std::tr1::ellint_1(kl, phil);
+ long double e = std::tr1::ellint_1l(kl, phil);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ test02();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/check_value.cc
new file mode 100644
index 00000000000..8df6df02f30
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/check_value.cc
@@ -0,0 +1,844 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// ellint_1
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for k=-0.90000000000000002.
+testcase_ellint_1<double> data001[] = {
+ { -0.0000000000000000, -0.90000000000000002, 0.0000000000000000 },
+ { 0.17525427376115027, -0.90000000000000002, 0.17453292519943295 },
+ { 0.35492464591297446, -0.90000000000000002, 0.34906585039886590 },
+ { 0.54388221416157134, -0.90000000000000002, 0.52359877559829882 },
+ { 0.74797400423532523, -0.90000000000000002, 0.69813170079773179 },
+ { 0.97463898451966458, -0.90000000000000002, 0.87266462599716477 },
+ { 1.2334463254523440, -0.90000000000000002, 1.0471975511965976 },
+ { 1.5355247765594910, -0.90000000000000002, 1.2217304763960306 },
+ { 1.8882928567775124, -0.90000000000000002, 1.3962634015954636 },
+ { 2.2805491384227703, -0.90000000000000002, 1.5707963267948966 },
+};
+
+// Test function for k=-0.90000000000000002.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data001[i].k), Tp(data001[i].phi));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.80000000000000004.
+testcase_ellint_1<double> data002[] = {
+ { -0.0000000000000000, -0.80000000000000004, 0.0000000000000000 },
+ { 0.17510154241338902, -0.80000000000000004, 0.17453292519943295 },
+ { 0.35365068839779390, -0.80000000000000004, 0.34906585039886590 },
+ { 0.53926804409084561, -0.80000000000000004, 0.52359877559829882 },
+ { 0.73587926028070383, -0.80000000000000004, 0.69813170079773179 },
+ { 0.94770942970071170, -0.80000000000000004, 0.87266462599716477 },
+ { 1.1789022995388239, -0.80000000000000004, 1.0471975511965976 },
+ { 1.4323027881876009, -0.80000000000000004, 1.2217304763960306 },
+ { 1.7069629739121674, -0.80000000000000004, 1.3962634015954636 },
+ { 1.9953027776647296, -0.80000000000000004, 1.5707963267948966 },
+};
+
+// Test function for k=-0.80000000000000004.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data002[i].k), Tp(data002[i].phi));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.69999999999999996.
+testcase_ellint_1<double> data003[] = {
+ { -0.0000000000000000, -0.69999999999999996, 0.0000000000000000 },
+ { 0.17496737466916720, -0.69999999999999996, 0.17453292519943295 },
+ { 0.35254687535677925, -0.69999999999999996, 0.34906585039886590 },
+ { 0.53536740275997130, -0.69999999999999996, 0.52359877559829882 },
+ { 0.72603797651684465, -0.69999999999999996, 0.69813170079773179 },
+ { 0.92698296348313458, -0.69999999999999996, 0.87266462599716477 },
+ { 1.1400447527693316, -0.69999999999999996, 1.0471975511965976 },
+ { 1.3657668117194071, -0.69999999999999996, 1.2217304763960306 },
+ { 1.6024686895959159, -0.69999999999999996, 1.3962634015954636 },
+ { 1.8456939983747236, -0.69999999999999996, 1.5707963267948966 },
+};
+
+// Test function for k=-0.69999999999999996.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data003[i].k), Tp(data003[i].phi));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.59999999999999998.
+testcase_ellint_1<double> data004[] = {
+ { -0.0000000000000000, -0.59999999999999998, 0.0000000000000000 },
+ { 0.17485154362988362, -0.59999999999999998, 0.17453292519943295 },
+ { 0.35160509865544326, -0.59999999999999998, 0.34906585039886590 },
+ { 0.53210652578446160, -0.59999999999999998, 0.52359877559829882 },
+ { 0.71805304664485670, -0.59999999999999998, 0.69813170079773179 },
+ { 0.91082759030195970, -0.59999999999999998, 0.87266462599716477 },
+ { 1.1112333229323361, -0.59999999999999998, 1.0471975511965976 },
+ { 1.3191461190365270, -0.59999999999999998, 1.2217304763960306 },
+ { 1.5332022105084773, -0.59999999999999998, 1.3962634015954636 },
+ { 1.7507538029157526, -0.59999999999999998, 1.5707963267948966 },
+};
+
+// Test function for k=-0.59999999999999998.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data004[i].k), Tp(data004[i].phi));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.50000000000000000.
+testcase_ellint_1<double> data005[] = {
+ { -0.0000000000000000, -0.50000000000000000, 0.0000000000000000 },
+ { 0.17475385514035785, -0.50000000000000000, 0.17453292519943295 },
+ { 0.35081868470101585, -0.50000000000000000, 0.34906585039886590 },
+ { 0.52942862705190585, -0.50000000000000000, 0.52359877559829882 },
+ { 0.71164727562630326, -0.50000000000000000, 0.69813170079773179 },
+ { 0.89824523594227768, -0.50000000000000000, 0.87266462599716477 },
+ { 1.0895506700518851, -0.50000000000000000, 1.0471975511965976 },
+ { 1.2853005857432933, -0.50000000000000000, 1.2217304763960306 },
+ { 1.4845545520549484, -0.50000000000000000, 1.3962634015954636 },
+ { 1.6857503548125963, -0.50000000000000000, 1.5707963267948966 },
+};
+
+// Test function for k=-0.50000000000000000.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data005[i].k), Tp(data005[i].phi));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.40000000000000002.
+testcase_ellint_1<double> data006[] = {
+ { -0.0000000000000000, -0.40000000000000002, 0.0000000000000000 },
+ { 0.17467414669441531, -0.40000000000000002, 0.17453292519943295 },
+ { 0.35018222772483443, -0.40000000000000002, 0.34906585039886590 },
+ { 0.52729015917508748, -0.40000000000000002, 0.52359877559829882 },
+ { 0.70662374407341255, -0.40000000000000002, 0.69813170079773179 },
+ { 0.88859210497602170, -0.40000000000000002, 0.87266462599716477 },
+ { 1.0733136290471379, -0.40000000000000002, 1.0471975511965976 },
+ { 1.2605612170157061, -0.40000000000000002, 1.2217304763960306 },
+ { 1.4497513956433437, -0.40000000000000002, 1.3962634015954636 },
+ { 1.6399998658645112, -0.40000000000000002, 1.5707963267948966 },
+};
+
+// Test function for k=-0.40000000000000002.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data006[i].k), Tp(data006[i].phi));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.30000000000000004.
+testcase_ellint_1<double> data007[] = {
+ { -0.0000000000000000, -0.30000000000000004, 0.0000000000000000 },
+ { 0.17461228653000102, -0.30000000000000004, 0.17453292519943295 },
+ { 0.34969146102798415, -0.30000000000000004, 0.34906585039886590 },
+ { 0.52565822873726320, -0.30000000000000004, 0.52359877559829882 },
+ { 0.70284226512408532, -0.30000000000000004, 0.69813170079773179 },
+ { 0.88144139195111182, -0.30000000000000004, 0.87266462599716477 },
+ { 1.0614897067260523, -0.30000000000000004, 1.0471975511965976 },
+ { 1.2428416824174218, -0.30000000000000004, 1.2217304763960306 },
+ { 1.4251795877015925, -0.30000000000000004, 1.3962634015954636 },
+ { 1.6080486199305126, -0.30000000000000004, 1.5707963267948966 },
+};
+
+// Test function for k=-0.30000000000000004.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data007[i].k), Tp(data007[i].phi));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.19999999999999996.
+testcase_ellint_1<double> data008[] = {
+ { -0.0000000000000000, -0.19999999999999996, 0.0000000000000000 },
+ { 0.17456817290292811, -0.19999999999999996, 0.17453292519943295 },
+ { 0.34934315932086801, -0.19999999999999996, 0.34906585039886590 },
+ { 0.52450880529443988, -0.19999999999999996, 0.52359877559829882 },
+ { 0.70020491009844910, -0.19999999999999996, 0.69813170079773179 },
+ { 0.87651006649967955, -0.19999999999999996, 0.87266462599716477 },
+ { 1.0534305870298994, -0.19999999999999996, 1.0471975511965976 },
+ { 1.2308975521670784, -0.19999999999999996, 1.2217304763960306 },
+ { 1.4087733584990738, -0.19999999999999996, 1.3962634015954636 },
+ { 1.5868678474541664, -0.19999999999999996, 1.5707963267948966 },
+};
+
+// Test function for k=-0.19999999999999996.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data008[i].k), Tp(data008[i].phi));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.099999999999999978.
+testcase_ellint_1<double> data009[] = {
+ { -0.0000000000000000, -0.099999999999999978, 0.0000000000000000 },
+ { 0.17454173353063665, -0.099999999999999978, 0.17453292519943295 },
+ { 0.34913506721468085, -0.099999999999999978, 0.34906585039886590 },
+ { 0.52382550016538953, -0.099999999999999978, 0.52359877559829882 },
+ { 0.69864700854177031, -0.099999999999999978, 0.69813170079773179 },
+ { 0.87361792586964870, -0.099999999999999978, 0.87266462599716477 },
+ { 1.0487386319621685, -0.099999999999999978, 1.0471975511965976 },
+ { 1.2239913752078757, -0.099999999999999978, 1.2217304763960306 },
+ { 1.3993423113684049, -0.099999999999999978, 1.3962634015954636 },
+ { 1.5747455615173562, -0.099999999999999978, 1.5707963267948966 },
+};
+
+// Test function for k=-0.099999999999999978.
+template <typename Tp>
+void test009()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data009)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data009[i].k), Tp(data009[i].phi));
+ const Tp f0 = data009[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.0000000000000000.
+testcase_ellint_1<double> data010[] = {
+ { -0.0000000000000000, 0.0000000000000000, 0.0000000000000000 },
+ { 0.17453292519943295, 0.0000000000000000, 0.17453292519943295 },
+ { 0.34906585039886584, 0.0000000000000000, 0.34906585039886590 },
+ { 0.52359877559829882, 0.0000000000000000, 0.52359877559829882 },
+ { 0.69813170079773179, 0.0000000000000000, 0.69813170079773179 },
+ { 0.87266462599716477, 0.0000000000000000, 0.87266462599716477 },
+ { 1.0471975511965976, 0.0000000000000000, 1.0471975511965976 },
+ { 1.2217304763960304, 0.0000000000000000, 1.2217304763960306 },
+ { 1.3962634015954631, 0.0000000000000000, 1.3962634015954636 },
+ { 1.5707963267948966, 0.0000000000000000, 1.5707963267948966 },
+};
+
+// Test function for k=0.0000000000000000.
+template <typename Tp>
+void test010()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data010)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data010[i].k), Tp(data010[i].phi));
+ const Tp f0 = data010[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.10000000000000009.
+testcase_ellint_1<double> data011[] = {
+ { -0.0000000000000000, 0.10000000000000009, 0.0000000000000000 },
+ { 0.17454173353063665, 0.10000000000000009, 0.17453292519943295 },
+ { 0.34913506721468085, 0.10000000000000009, 0.34906585039886590 },
+ { 0.52382550016538953, 0.10000000000000009, 0.52359877559829882 },
+ { 0.69864700854177031, 0.10000000000000009, 0.69813170079773179 },
+ { 0.87361792586964870, 0.10000000000000009, 0.87266462599716477 },
+ { 1.0487386319621685, 0.10000000000000009, 1.0471975511965976 },
+ { 1.2239913752078757, 0.10000000000000009, 1.2217304763960306 },
+ { 1.3993423113684049, 0.10000000000000009, 1.3962634015954636 },
+ { 1.5747455615173562, 0.10000000000000009, 1.5707963267948966 },
+};
+
+// Test function for k=0.10000000000000009.
+template <typename Tp>
+void test011()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data011)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data011[i].k), Tp(data011[i].phi));
+ const Tp f0 = data011[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.19999999999999996.
+testcase_ellint_1<double> data012[] = {
+ { -0.0000000000000000, 0.19999999999999996, 0.0000000000000000 },
+ { 0.17456817290292811, 0.19999999999999996, 0.17453292519943295 },
+ { 0.34934315932086801, 0.19999999999999996, 0.34906585039886590 },
+ { 0.52450880529443988, 0.19999999999999996, 0.52359877559829882 },
+ { 0.70020491009844910, 0.19999999999999996, 0.69813170079773179 },
+ { 0.87651006649967955, 0.19999999999999996, 0.87266462599716477 },
+ { 1.0534305870298994, 0.19999999999999996, 1.0471975511965976 },
+ { 1.2308975521670784, 0.19999999999999996, 1.2217304763960306 },
+ { 1.4087733584990738, 0.19999999999999996, 1.3962634015954636 },
+ { 1.5868678474541664, 0.19999999999999996, 1.5707963267948966 },
+};
+
+// Test function for k=0.19999999999999996.
+template <typename Tp>
+void test012()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data012)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data012[i].k), Tp(data012[i].phi));
+ const Tp f0 = data012[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.30000000000000004.
+testcase_ellint_1<double> data013[] = {
+ { -0.0000000000000000, 0.30000000000000004, 0.0000000000000000 },
+ { 0.17461228653000102, 0.30000000000000004, 0.17453292519943295 },
+ { 0.34969146102798415, 0.30000000000000004, 0.34906585039886590 },
+ { 0.52565822873726320, 0.30000000000000004, 0.52359877559829882 },
+ { 0.70284226512408532, 0.30000000000000004, 0.69813170079773179 },
+ { 0.88144139195111182, 0.30000000000000004, 0.87266462599716477 },
+ { 1.0614897067260523, 0.30000000000000004, 1.0471975511965976 },
+ { 1.2428416824174218, 0.30000000000000004, 1.2217304763960306 },
+ { 1.4251795877015925, 0.30000000000000004, 1.3962634015954636 },
+ { 1.6080486199305126, 0.30000000000000004, 1.5707963267948966 },
+};
+
+// Test function for k=0.30000000000000004.
+template <typename Tp>
+void test013()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data013)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data013[i].k), Tp(data013[i].phi));
+ const Tp f0 = data013[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.39999999999999991.
+testcase_ellint_1<double> data014[] = {
+ { -0.0000000000000000, 0.39999999999999991, 0.0000000000000000 },
+ { 0.17467414669441531, 0.39999999999999991, 0.17453292519943295 },
+ { 0.35018222772483443, 0.39999999999999991, 0.34906585039886590 },
+ { 0.52729015917508748, 0.39999999999999991, 0.52359877559829882 },
+ { 0.70662374407341255, 0.39999999999999991, 0.69813170079773179 },
+ { 0.88859210497602170, 0.39999999999999991, 0.87266462599716477 },
+ { 1.0733136290471379, 0.39999999999999991, 1.0471975511965976 },
+ { 1.2605612170157061, 0.39999999999999991, 1.2217304763960306 },
+ { 1.4497513956433437, 0.39999999999999991, 1.3962634015954636 },
+ { 1.6399998658645112, 0.39999999999999991, 1.5707963267948966 },
+};
+
+// Test function for k=0.39999999999999991.
+template <typename Tp>
+void test014()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data014)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data014[i].k), Tp(data014[i].phi));
+ const Tp f0 = data014[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.50000000000000000.
+testcase_ellint_1<double> data015[] = {
+ { -0.0000000000000000, 0.50000000000000000, 0.0000000000000000 },
+ { 0.17475385514035785, 0.50000000000000000, 0.17453292519943295 },
+ { 0.35081868470101585, 0.50000000000000000, 0.34906585039886590 },
+ { 0.52942862705190585, 0.50000000000000000, 0.52359877559829882 },
+ { 0.71164727562630326, 0.50000000000000000, 0.69813170079773179 },
+ { 0.89824523594227768, 0.50000000000000000, 0.87266462599716477 },
+ { 1.0895506700518851, 0.50000000000000000, 1.0471975511965976 },
+ { 1.2853005857432933, 0.50000000000000000, 1.2217304763960306 },
+ { 1.4845545520549484, 0.50000000000000000, 1.3962634015954636 },
+ { 1.6857503548125963, 0.50000000000000000, 1.5707963267948966 },
+};
+
+// Test function for k=0.50000000000000000.
+template <typename Tp>
+void test015()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data015)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data015[i].k), Tp(data015[i].phi));
+ const Tp f0 = data015[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.60000000000000009.
+testcase_ellint_1<double> data016[] = {
+ { -0.0000000000000000, 0.60000000000000009, 0.0000000000000000 },
+ { 0.17485154362988362, 0.60000000000000009, 0.17453292519943295 },
+ { 0.35160509865544326, 0.60000000000000009, 0.34906585039886590 },
+ { 0.53210652578446160, 0.60000000000000009, 0.52359877559829882 },
+ { 0.71805304664485670, 0.60000000000000009, 0.69813170079773179 },
+ { 0.91082759030195970, 0.60000000000000009, 0.87266462599716477 },
+ { 1.1112333229323366, 0.60000000000000009, 1.0471975511965976 },
+ { 1.3191461190365270, 0.60000000000000009, 1.2217304763960306 },
+ { 1.5332022105084775, 0.60000000000000009, 1.3962634015954636 },
+ { 1.7507538029157526, 0.60000000000000009, 1.5707963267948966 },
+};
+
+// Test function for k=0.60000000000000009.
+template <typename Tp>
+void test016()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data016)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data016[i].k), Tp(data016[i].phi));
+ const Tp f0 = data016[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.69999999999999996.
+testcase_ellint_1<double> data017[] = {
+ { -0.0000000000000000, 0.69999999999999996, 0.0000000000000000 },
+ { 0.17496737466916720, 0.69999999999999996, 0.17453292519943295 },
+ { 0.35254687535677925, 0.69999999999999996, 0.34906585039886590 },
+ { 0.53536740275997130, 0.69999999999999996, 0.52359877559829882 },
+ { 0.72603797651684465, 0.69999999999999996, 0.69813170079773179 },
+ { 0.92698296348313458, 0.69999999999999996, 0.87266462599716477 },
+ { 1.1400447527693316, 0.69999999999999996, 1.0471975511965976 },
+ { 1.3657668117194071, 0.69999999999999996, 1.2217304763960306 },
+ { 1.6024686895959159, 0.69999999999999996, 1.3962634015954636 },
+ { 1.8456939983747236, 0.69999999999999996, 1.5707963267948966 },
+};
+
+// Test function for k=0.69999999999999996.
+template <typename Tp>
+void test017()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data017)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data017[i].k), Tp(data017[i].phi));
+ const Tp f0 = data017[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.80000000000000004.
+testcase_ellint_1<double> data018[] = {
+ { -0.0000000000000000, 0.80000000000000004, 0.0000000000000000 },
+ { 0.17510154241338902, 0.80000000000000004, 0.17453292519943295 },
+ { 0.35365068839779390, 0.80000000000000004, 0.34906585039886590 },
+ { 0.53926804409084561, 0.80000000000000004, 0.52359877559829882 },
+ { 0.73587926028070383, 0.80000000000000004, 0.69813170079773179 },
+ { 0.94770942970071170, 0.80000000000000004, 0.87266462599716477 },
+ { 1.1789022995388239, 0.80000000000000004, 1.0471975511965976 },
+ { 1.4323027881876009, 0.80000000000000004, 1.2217304763960306 },
+ { 1.7069629739121674, 0.80000000000000004, 1.3962634015954636 },
+ { 1.9953027776647296, 0.80000000000000004, 1.5707963267948966 },
+};
+
+// Test function for k=0.80000000000000004.
+template <typename Tp>
+void test018()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data018)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data018[i].k), Tp(data018[i].phi));
+ const Tp f0 = data018[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.89999999999999991.
+testcase_ellint_1<double> data019[] = {
+ { -0.0000000000000000, 0.89999999999999991, 0.0000000000000000 },
+ { 0.17525427376115027, 0.89999999999999991, 0.17453292519943295 },
+ { 0.35492464591297446, 0.89999999999999991, 0.34906585039886590 },
+ { 0.54388221416157123, 0.89999999999999991, 0.52359877559829882 },
+ { 0.74797400423532501, 0.89999999999999991, 0.69813170079773179 },
+ { 0.97463898451966458, 0.89999999999999991, 0.87266462599716477 },
+ { 1.2334463254523438, 0.89999999999999991, 1.0471975511965976 },
+ { 1.5355247765594910, 0.89999999999999991, 1.2217304763960306 },
+ { 1.8882928567775117, 0.89999999999999991, 1.3962634015954636 },
+ { 2.2805491384227699, 0.89999999999999991, 1.5707963267948966 },
+};
+
+// Test function for k=0.89999999999999991.
+template <typename Tp>
+void test019()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data019)
+ / sizeof(testcase_ellint_1<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_1(Tp(data019[i].k), Tp(data019[i].phi));
+ const Tp f0 = data019[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ test009<double>();
+ test010<double>();
+ test011<double>();
+ test012<double>();
+ test013<double>();
+ test014<double>();
+ test015<double>();
+ test016<double>();
+ test017<double>();
+ test018<double>();
+ test019<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/compile.cc
new file mode 100644
index 00000000000..d925f82da6d
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/compile.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.12 ellint_1
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+ float kf = 0.5F, phif = std::atan2(1.0F, 1.0F);
+ double kd = 0.5, phid = std::atan2(1.0, 1.0);
+ long double kl = 0.5L, phil = std::atan2(1.0L, 1.0L);
+
+ std::tr1::ellint_1(kf, phif);
+ std::tr1::ellint_1f(kf, phif);
+ std::tr1::ellint_1(kd, phid);
+ std::tr1::ellint_1(kl, phil);
+ std::tr1::ellint_1l(kl, phil);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/compile_2.cc
new file mode 100644
index 00000000000..38119b6f866
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/12_ellint_1/compile_2.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.12 ellint_1
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+ float kf = 0.5F, phif = std::atan2(1.0F, 1.0F);
+ double kd = 0.5, phid = std::atan2(1.0, 1.0);
+ long double kl = 0.5L, phil = std::atan2(1.0L, 1.0L);
+
+ ellint_1(kf, phif);
+ ellint_1f(kf, phif);
+ ellint_1(kd, phid);
+ ellint_1(kl, phil);
+ ellint_1l(kl, phil);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/check_nan.cc
new file mode 100644
index 00000000000..9e1775e5749
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/check_nan.cc
@@ -0,0 +1,87 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.13 ellint_2
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+ float kf = std::numeric_limits<float>::quiet_NaN();
+ double kd = std::numeric_limits<double>::quiet_NaN();
+ long double kl = std::numeric_limits<long double>::quiet_NaN();
+
+ float phif = std::atan2(1.0F, 1.0F);
+ double phid = std::atan2(1.0, 1.0);
+ long double phil = std::atan2(1.0L, 1.0L);
+
+ float a = std::tr1::ellint_2(kf, phif);
+ float b = std::tr1::ellint_2f(kf, phif);
+ double c = std::tr1::ellint_2(kd, phid);
+ long double d = std::tr1::ellint_2(kl, phil);
+ long double e = std::tr1::ellint_2l(kl, phil);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+void
+test02()
+{
+ float kf = 0.5F;
+ double kd = 0.5;
+ long double kl = 0.5L;
+
+ float phif = std::numeric_limits<float>::quiet_NaN();
+ double phid = std::numeric_limits<double>::quiet_NaN();
+ long double phil = std::numeric_limits<long double>::quiet_NaN();
+
+ float a = std::tr1::ellint_2(kf, phif);
+ float b = std::tr1::ellint_2f(kf, phif);
+ double c = std::tr1::ellint_2(kd, phid);
+ long double d = std::tr1::ellint_2(kl, phil);
+ long double e = std::tr1::ellint_2l(kl, phil);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ test02();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/check_value.cc
new file mode 100644
index 00000000000..fa9e4d3a0a9
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/check_value.cc
@@ -0,0 +1,844 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// ellint_2
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for k=-0.90000000000000002.
+testcase_ellint_2<double> data001[] = {
+ { -0.0000000000000000, -0.90000000000000002, 0.0000000000000000 },
+ { 0.17381690606167963, -0.90000000000000002, 0.17453292519943295 },
+ { 0.34337919186972055, -0.90000000000000002, 0.34906585039886590 },
+ { 0.50464268659856337, -0.90000000000000002, 0.52359877559829882 },
+ { 0.65400003842368593, -0.90000000000000002, 0.69813170079773179 },
+ { 0.78854928419904657, -0.90000000000000002, 0.87266462599716477 },
+ { 0.90645698626315407, -0.90000000000000002, 1.0471975511965976 },
+ { 1.0075154899135925, -0.90000000000000002, 1.2217304763960306 },
+ { 1.0940135583194071, -0.90000000000000002, 1.3962634015954636 },
+ { 1.1716970527816140, -0.90000000000000002, 1.5707963267948966 },
+};
+
+// Test function for k=-0.90000000000000002.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data001[i].k), Tp(data001[i].phi));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000029e-12));
+}
+
+// Test data for k=-0.80000000000000004.
+testcase_ellint_2<double> data002[] = {
+ { -0.0000000000000000, -0.80000000000000004, 0.0000000000000000 },
+ { 0.17396762274534808, -0.80000000000000004, 0.17453292519943295 },
+ { 0.34458685226969316, -0.80000000000000004, 0.34906585039886590 },
+ { 0.50872923654502444, -0.80000000000000004, 0.52359877559829882 },
+ { 0.66372016539176237, -0.80000000000000004, 0.69813170079773179 },
+ { 0.80760344410167406, -0.80000000000000004, 0.87266462599716477 },
+ { 0.93945480372495072, -0.80000000000000004, 1.0471975511965976 },
+ { 1.0597473310395036, -0.80000000000000004, 1.2217304763960306 },
+ { 1.1706981862452361, -0.80000000000000004, 1.3962634015954636 },
+ { 1.2763499431699066, -0.80000000000000004, 1.5707963267948966 },
+};
+
+// Test function for k=-0.80000000000000004.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data002[i].k), Tp(data002[i].phi));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for k=-0.69999999999999996.
+testcase_ellint_2<double> data003[] = {
+ { -0.0000000000000000, -0.69999999999999996, 0.0000000000000000 },
+ { 0.17410041242702540, -0.69999999999999996, 0.17453292519943295 },
+ { 0.34564605085764760, -0.69999999999999996, 0.34906585039886590 },
+ { 0.51228495693314657, -0.69999999999999996, 0.52359877559829882 },
+ { 0.67207654098799530, -0.69999999999999996, 0.69813170079773179 },
+ { 0.82370932631556515, -0.69999999999999996, 0.87266462599716477 },
+ { 0.96672313309452795, -0.69999999999999996, 1.0471975511965976 },
+ { 1.1017090644949503, -0.69999999999999996, 1.2217304763960306 },
+ { 1.2304180097292916, -0.69999999999999996, 1.3962634015954636 },
+ { 1.3556611355719557, -0.69999999999999996, 1.5707963267948966 },
+};
+
+// Test function for k=-0.69999999999999996.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data003[i].k), Tp(data003[i].phi));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for k=-0.59999999999999998.
+testcase_ellint_2<double> data004[] = {
+ { -0.0000000000000000, -0.59999999999999998, 0.0000000000000000 },
+ { 0.17421534919599130, -0.59999999999999998, 0.17453292519943295 },
+ { 0.34655927787174101, -0.59999999999999998, 0.34906585039886590 },
+ { 0.51533034538432165, -0.59999999999999998, 0.52359877559829882 },
+ { 0.67916550597453029, -0.59999999999999998, 0.69813170079773179 },
+ { 0.83720218180349870, -0.59999999999999998, 0.87266462599716477 },
+ { 0.98922159354937755, -0.59999999999999998, 1.0471975511965976 },
+ { 1.1357478470419360, -0.59999999999999998, 1.2217304763960306 },
+ { 1.2780617372844056, -0.59999999999999998, 1.3962634015954636 },
+ { 1.4180833944487243, -0.59999999999999998, 1.5707963267948966 },
+};
+
+// Test function for k=-0.59999999999999998.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data004[i].k), Tp(data004[i].phi));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for k=-0.50000000000000000.
+testcase_ellint_2<double> data005[] = {
+ { -0.0000000000000000, -0.50000000000000000, 0.0000000000000000 },
+ { 0.17431249677315910, -0.50000000000000000, 0.17453292519943295 },
+ { 0.34732862537770803, -0.50000000000000000, 0.34906585039886590 },
+ { 0.51788193485993805, -0.50000000000000000, 0.52359877559829882 },
+ { 0.68506022954164536, -0.50000000000000000, 0.69813170079773179 },
+ { 0.84831662803347196, -0.50000000000000000, 0.87266462599716477 },
+ { 1.0075555551444717, -0.50000000000000000, 1.0471975511965976 },
+ { 1.1631768599287302, -0.50000000000000000, 1.2217304763960306 },
+ { 1.3160584048772543, -0.50000000000000000, 1.3962634015954636 },
+ { 1.4674622093394274, -0.50000000000000000, 1.5707963267948966 },
+};
+
+// Test function for k=-0.50000000000000000.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data005[i].k), Tp(data005[i].phi));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.40000000000000002.
+testcase_ellint_2<double> data006[] = {
+ { -0.0000000000000000, -0.40000000000000002, 0.0000000000000000 },
+ { 0.17439190872481269, -0.40000000000000002, 0.17453292519943295 },
+ { 0.34795581767099210, -0.40000000000000002, 0.34906585039886590 },
+ { 0.51995290683804474, -0.40000000000000002, 0.52359877559829882 },
+ { 0.68981638464431549, -0.40000000000000002, 0.69813170079773179 },
+ { 0.85722088859936041, -0.40000000000000002, 0.87266462599716477 },
+ { 1.0221301327876993, -0.40000000000000002, 1.0471975511965976 },
+ { 1.1848138019818371, -0.40000000000000002, 1.2217304763960306 },
+ { 1.3458259266501531, -0.40000000000000002, 1.3962634015954636 },
+ { 1.5059416123600402, -0.40000000000000002, 1.5707963267948966 },
+};
+
+// Test function for k=-0.40000000000000002.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data006[i].k), Tp(data006[i].phi));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.30000000000000004.
+testcase_ellint_2<double> data007[] = {
+ { -0.0000000000000000, -0.30000000000000004, 0.0000000000000000 },
+ { 0.17445362864048916, -0.30000000000000004, 0.17453292519943295 },
+ { 0.34844223535713464, -0.30000000000000004, 0.34906585039886590 },
+ { 0.52155353877411770, -0.30000000000000004, 0.52359877559829882 },
+ { 0.69347584418369879, -0.30000000000000004, 0.69813170079773179 },
+ { 0.86403609928237668, -0.30000000000000004, 0.87266462599716477 },
+ { 1.0332234514065410, -0.30000000000000004, 1.0471975511965976 },
+ { 1.2011943182068923, -0.30000000000000004, 1.2217304763960306 },
+ { 1.3682566113689620, -0.30000000000000004, 1.3962634015954636 },
+ { 1.5348334649232489, -0.30000000000000004, 1.5707963267948966 },
+};
+
+// Test function for k=-0.30000000000000004.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data007[i].k), Tp(data007[i].phi));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.19999999999999996.
+testcase_ellint_2<double> data008[] = {
+ { -0.0000000000000000, -0.19999999999999996, 0.0000000000000000 },
+ { 0.17449769027652814, -0.19999999999999996, 0.17453292519943295 },
+ { 0.34878893400762095, -0.19999999999999996, 0.34906585039886590 },
+ { 0.52269152856057410, -0.19999999999999996, 0.52359877559829882 },
+ { 0.69606913360157596, -0.19999999999999996, 0.69813170079773179 },
+ { 0.86884782374863356, -0.19999999999999996, 0.87266462599716477 },
+ { 1.0410255369689567, -0.19999999999999996, 1.0471975511965976 },
+ { 1.2126730391631360, -0.19999999999999996, 1.2217304763960306 },
+ { 1.3839259540325153, -0.19999999999999996, 1.3962634015954636 },
+ { 1.5549685462425296, -0.19999999999999996, 1.5707963267948966 },
+};
+
+// Test function for k=-0.19999999999999996.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data008[i].k), Tp(data008[i].phi));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.099999999999999978.
+testcase_ellint_2<double> data009[] = {
+ { -0.0000000000000000, -0.099999999999999978, 0.0000000000000000 },
+ { 0.17452411766649945, -0.099999999999999978, 0.17453292519943295 },
+ { 0.34899665805442398, -0.099999999999999978, 0.34906585039886590 },
+ { 0.52337222400508787, -0.099999999999999978, 0.52359877559829882 },
+ { 0.69761705217284875, -0.099999999999999978, 0.69813170079773179 },
+ { 0.87171309273007491, -0.099999999999999978, 0.87266462599716477 },
+ { 1.0456602197056328, -0.099999999999999978, 1.0471975511965976 },
+ { 1.2194762899272025, -0.099999999999999978, 1.2217304763960306 },
+ { 1.3931950229892744, -0.099999999999999978, 1.3962634015954636 },
+ { 1.5668619420216685, -0.099999999999999978, 1.5707963267948966 },
+};
+
+// Test function for k=-0.099999999999999978.
+template <typename Tp>
+void test009()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data009)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data009[i].k), Tp(data009[i].phi));
+ const Tp f0 = data009[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.0000000000000000.
+testcase_ellint_2<double> data010[] = {
+ { -0.0000000000000000, 0.0000000000000000, 0.0000000000000000 },
+ { 0.17453292519943295, 0.0000000000000000, 0.17453292519943295 },
+ { 0.34906585039886584, 0.0000000000000000, 0.34906585039886590 },
+ { 0.52359877559829882, 0.0000000000000000, 0.52359877559829882 },
+ { 0.69813170079773179, 0.0000000000000000, 0.69813170079773179 },
+ { 0.87266462599716477, 0.0000000000000000, 0.87266462599716477 },
+ { 1.0471975511965976, 0.0000000000000000, 1.0471975511965976 },
+ { 1.2217304763960304, 0.0000000000000000, 1.2217304763960306 },
+ { 1.3962634015954631, 0.0000000000000000, 1.3962634015954636 },
+ { 1.5707963267948966, 0.0000000000000000, 1.5707963267948966 },
+};
+
+// Test function for k=0.0000000000000000.
+template <typename Tp>
+void test010()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data010)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data010[i].k), Tp(data010[i].phi));
+ const Tp f0 = data010[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.10000000000000009.
+testcase_ellint_2<double> data011[] = {
+ { -0.0000000000000000, 0.10000000000000009, 0.0000000000000000 },
+ { 0.17452411766649945, 0.10000000000000009, 0.17453292519943295 },
+ { 0.34899665805442398, 0.10000000000000009, 0.34906585039886590 },
+ { 0.52337222400508787, 0.10000000000000009, 0.52359877559829882 },
+ { 0.69761705217284875, 0.10000000000000009, 0.69813170079773179 },
+ { 0.87171309273007491, 0.10000000000000009, 0.87266462599716477 },
+ { 1.0456602197056328, 0.10000000000000009, 1.0471975511965976 },
+ { 1.2194762899272025, 0.10000000000000009, 1.2217304763960306 },
+ { 1.3931950229892744, 0.10000000000000009, 1.3962634015954636 },
+ { 1.5668619420216685, 0.10000000000000009, 1.5707963267948966 },
+};
+
+// Test function for k=0.10000000000000009.
+template <typename Tp>
+void test011()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data011)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data011[i].k), Tp(data011[i].phi));
+ const Tp f0 = data011[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.19999999999999996.
+testcase_ellint_2<double> data012[] = {
+ { -0.0000000000000000, 0.19999999999999996, 0.0000000000000000 },
+ { 0.17449769027652814, 0.19999999999999996, 0.17453292519943295 },
+ { 0.34878893400762095, 0.19999999999999996, 0.34906585039886590 },
+ { 0.52269152856057410, 0.19999999999999996, 0.52359877559829882 },
+ { 0.69606913360157596, 0.19999999999999996, 0.69813170079773179 },
+ { 0.86884782374863356, 0.19999999999999996, 0.87266462599716477 },
+ { 1.0410255369689567, 0.19999999999999996, 1.0471975511965976 },
+ { 1.2126730391631360, 0.19999999999999996, 1.2217304763960306 },
+ { 1.3839259540325153, 0.19999999999999996, 1.3962634015954636 },
+ { 1.5549685462425296, 0.19999999999999996, 1.5707963267948966 },
+};
+
+// Test function for k=0.19999999999999996.
+template <typename Tp>
+void test012()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data012)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data012[i].k), Tp(data012[i].phi));
+ const Tp f0 = data012[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.30000000000000004.
+testcase_ellint_2<double> data013[] = {
+ { -0.0000000000000000, 0.30000000000000004, 0.0000000000000000 },
+ { 0.17445362864048916, 0.30000000000000004, 0.17453292519943295 },
+ { 0.34844223535713464, 0.30000000000000004, 0.34906585039886590 },
+ { 0.52155353877411770, 0.30000000000000004, 0.52359877559829882 },
+ { 0.69347584418369879, 0.30000000000000004, 0.69813170079773179 },
+ { 0.86403609928237668, 0.30000000000000004, 0.87266462599716477 },
+ { 1.0332234514065410, 0.30000000000000004, 1.0471975511965976 },
+ { 1.2011943182068923, 0.30000000000000004, 1.2217304763960306 },
+ { 1.3682566113689620, 0.30000000000000004, 1.3962634015954636 },
+ { 1.5348334649232489, 0.30000000000000004, 1.5707963267948966 },
+};
+
+// Test function for k=0.30000000000000004.
+template <typename Tp>
+void test013()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data013)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data013[i].k), Tp(data013[i].phi));
+ const Tp f0 = data013[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.39999999999999991.
+testcase_ellint_2<double> data014[] = {
+ { -0.0000000000000000, 0.39999999999999991, 0.0000000000000000 },
+ { 0.17439190872481269, 0.39999999999999991, 0.17453292519943295 },
+ { 0.34795581767099210, 0.39999999999999991, 0.34906585039886590 },
+ { 0.51995290683804474, 0.39999999999999991, 0.52359877559829882 },
+ { 0.68981638464431549, 0.39999999999999991, 0.69813170079773179 },
+ { 0.85722088859936041, 0.39999999999999991, 0.87266462599716477 },
+ { 1.0221301327876993, 0.39999999999999991, 1.0471975511965976 },
+ { 1.1848138019818373, 0.39999999999999991, 1.2217304763960306 },
+ { 1.3458259266501531, 0.39999999999999991, 1.3962634015954636 },
+ { 1.5059416123600404, 0.39999999999999991, 1.5707963267948966 },
+};
+
+// Test function for k=0.39999999999999991.
+template <typename Tp>
+void test014()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data014)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data014[i].k), Tp(data014[i].phi));
+ const Tp f0 = data014[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.50000000000000000.
+testcase_ellint_2<double> data015[] = {
+ { -0.0000000000000000, 0.50000000000000000, 0.0000000000000000 },
+ { 0.17431249677315910, 0.50000000000000000, 0.17453292519943295 },
+ { 0.34732862537770803, 0.50000000000000000, 0.34906585039886590 },
+ { 0.51788193485993805, 0.50000000000000000, 0.52359877559829882 },
+ { 0.68506022954164536, 0.50000000000000000, 0.69813170079773179 },
+ { 0.84831662803347196, 0.50000000000000000, 0.87266462599716477 },
+ { 1.0075555551444717, 0.50000000000000000, 1.0471975511965976 },
+ { 1.1631768599287302, 0.50000000000000000, 1.2217304763960306 },
+ { 1.3160584048772543, 0.50000000000000000, 1.3962634015954636 },
+ { 1.4674622093394274, 0.50000000000000000, 1.5707963267948966 },
+};
+
+// Test function for k=0.50000000000000000.
+template <typename Tp>
+void test015()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data015)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data015[i].k), Tp(data015[i].phi));
+ const Tp f0 = data015[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.60000000000000009.
+testcase_ellint_2<double> data016[] = {
+ { -0.0000000000000000, 0.60000000000000009, 0.0000000000000000 },
+ { 0.17421534919599130, 0.60000000000000009, 0.17453292519943295 },
+ { 0.34655927787174101, 0.60000000000000009, 0.34906585039886590 },
+ { 0.51533034538432165, 0.60000000000000009, 0.52359877559829882 },
+ { 0.67916550597453029, 0.60000000000000009, 0.69813170079773179 },
+ { 0.83720218180349870, 0.60000000000000009, 0.87266462599716477 },
+ { 0.98922159354937789, 0.60000000000000009, 1.0471975511965976 },
+ { 1.1357478470419360, 0.60000000000000009, 1.2217304763960306 },
+ { 1.2780617372844056, 0.60000000000000009, 1.3962634015954636 },
+ { 1.4180833944487241, 0.60000000000000009, 1.5707963267948966 },
+};
+
+// Test function for k=0.60000000000000009.
+template <typename Tp>
+void test016()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data016)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data016[i].k), Tp(data016[i].phi));
+ const Tp f0 = data016[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for k=0.69999999999999996.
+testcase_ellint_2<double> data017[] = {
+ { -0.0000000000000000, 0.69999999999999996, 0.0000000000000000 },
+ { 0.17410041242702540, 0.69999999999999996, 0.17453292519943295 },
+ { 0.34564605085764760, 0.69999999999999996, 0.34906585039886590 },
+ { 0.51228495693314657, 0.69999999999999996, 0.52359877559829882 },
+ { 0.67207654098799530, 0.69999999999999996, 0.69813170079773179 },
+ { 0.82370932631556515, 0.69999999999999996, 0.87266462599716477 },
+ { 0.96672313309452795, 0.69999999999999996, 1.0471975511965976 },
+ { 1.1017090644949503, 0.69999999999999996, 1.2217304763960306 },
+ { 1.2304180097292916, 0.69999999999999996, 1.3962634015954636 },
+ { 1.3556611355719557, 0.69999999999999996, 1.5707963267948966 },
+};
+
+// Test function for k=0.69999999999999996.
+template <typename Tp>
+void test017()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data017)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data017[i].k), Tp(data017[i].phi));
+ const Tp f0 = data017[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for k=0.80000000000000004.
+testcase_ellint_2<double> data018[] = {
+ { -0.0000000000000000, 0.80000000000000004, 0.0000000000000000 },
+ { 0.17396762274534808, 0.80000000000000004, 0.17453292519943295 },
+ { 0.34458685226969316, 0.80000000000000004, 0.34906585039886590 },
+ { 0.50872923654502444, 0.80000000000000004, 0.52359877559829882 },
+ { 0.66372016539176237, 0.80000000000000004, 0.69813170079773179 },
+ { 0.80760344410167406, 0.80000000000000004, 0.87266462599716477 },
+ { 0.93945480372495072, 0.80000000000000004, 1.0471975511965976 },
+ { 1.0597473310395036, 0.80000000000000004, 1.2217304763960306 },
+ { 1.1706981862452361, 0.80000000000000004, 1.3962634015954636 },
+ { 1.2763499431699066, 0.80000000000000004, 1.5707963267948966 },
+};
+
+// Test function for k=0.80000000000000004.
+template <typename Tp>
+void test018()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data018)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data018[i].k), Tp(data018[i].phi));
+ const Tp f0 = data018[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for k=0.89999999999999991.
+testcase_ellint_2<double> data019[] = {
+ { -0.0000000000000000, 0.89999999999999991, 0.0000000000000000 },
+ { 0.17381690606167963, 0.89999999999999991, 0.17453292519943295 },
+ { 0.34337919186972055, 0.89999999999999991, 0.34906585039886590 },
+ { 0.50464268659856337, 0.89999999999999991, 0.52359877559829882 },
+ { 0.65400003842368581, 0.89999999999999991, 0.69813170079773179 },
+ { 0.78854928419904657, 0.89999999999999991, 0.87266462599716477 },
+ { 0.90645698626315385, 0.89999999999999991, 1.0471975511965976 },
+ { 1.0075154899135930, 0.89999999999999991, 1.2217304763960306 },
+ { 1.0940135583194071, 0.89999999999999991, 1.3962634015954636 },
+ { 1.1716970527816142, 0.89999999999999991, 1.5707963267948966 },
+};
+
+// Test function for k=0.89999999999999991.
+template <typename Tp>
+void test019()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data019)
+ / sizeof(testcase_ellint_2<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_2(Tp(data019[i].k), Tp(data019[i].phi));
+ const Tp f0 = data019[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000029e-12));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ test009<double>();
+ test010<double>();
+ test011<double>();
+ test012<double>();
+ test013<double>();
+ test014<double>();
+ test015<double>();
+ test016<double>();
+ test017<double>();
+ test018<double>();
+ test019<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/compile.cc
new file mode 100644
index 00000000000..0f4cf9793cb
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/compile.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.13 ellint_2
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+ float kf = 0.5F, phif = std::atan2(1.0F, 1.0F);
+ double kd = 0.5, phid = std::atan2(1.0, 1.0);
+ long double kl = 0.5L, phil = std::atan2(1.0L, 1.0L);
+
+ std::tr1::ellint_2(kf, phif);
+ std::tr1::ellint_2f(kf, phif);
+ std::tr1::ellint_2(kd, phid);
+ std::tr1::ellint_2(kl, phil);
+ std::tr1::ellint_2l(kl, phil);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/compile_2.cc
new file mode 100644
index 00000000000..27dd739bc00
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/13_ellint_2/compile_2.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.13 ellint_2
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+ float kf = 0.5F, phif = std::atan2(1.0F, 1.0F);
+ double kd = 0.5, phid = std::atan2(1.0, 1.0);
+ long double kl = 0.5L, phil = std::atan2(1.0L, 1.0L);
+
+ ellint_2(kf, phif);
+ ellint_2f(kf, phif);
+ ellint_2(kd, phid);
+ ellint_2(kl, phil);
+ ellint_2l(kl, phil);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/check_nan.cc
new file mode 100644
index 00000000000..fcf2f680d94
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/check_nan.cc
@@ -0,0 +1,126 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.13 ellint_3
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+ float kf = std::numeric_limits<float>::quiet_NaN();
+ double kd = std::numeric_limits<double>::quiet_NaN();
+ long double kl = std::numeric_limits<long double>::quiet_NaN();
+
+ float nuf = 0.2F;
+ double nud = 0.2;
+ long double nul = 0.2L;
+
+ float phif = std::atan2(1.0F, 1.0F);
+ double phid = std::atan2(1.0, 1.0);
+ long double phil = std::atan2(1.0L, 1.0L);
+
+ float a = std::tr1::ellint_3(kf, nuf, phif);
+ float b = std::tr1::ellint_3f(kf, nuf, phif);
+ double c = std::tr1::ellint_3(kd, nud, phid);
+ long double d = std::tr1::ellint_3(kl, nul, phil);
+ long double e = std::tr1::ellint_3l(kl, nul, phil);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+void
+test02()
+{
+ float kf = 0.5F;
+ double kd = 0.5;
+ long double kl = 0.5L;
+
+ float nuf = std::numeric_limits<float>::quiet_NaN();
+ double nud = std::numeric_limits<double>::quiet_NaN();
+ long double nul = std::numeric_limits<long double>::quiet_NaN();
+
+ float phif = std::atan2(1.0F, 1.0F);
+ double phid = std::atan2(1.0, 1.0);
+ long double phil = std::atan2(1.0L, 1.0L);
+
+ float a = std::tr1::ellint_3(kf, nuf, phif);
+ float b = std::tr1::ellint_3f(kf, nuf, phif);
+ double c = std::tr1::ellint_3(kd, nud, phid);
+ long double d = std::tr1::ellint_3(kl, nul, phil);
+ long double e = std::tr1::ellint_3l(kl, nul, phil);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+void
+test03()
+{
+ float kf = 0.5F;
+ double kd = 0.5;
+ long double kl = 0.5L;
+
+ float nuf = 0.2F;
+ double nud = 0.2;
+ long double nul = 0.2L;
+
+ float phif = std::numeric_limits<float>::quiet_NaN();
+ double phid = std::numeric_limits<double>::quiet_NaN();
+ long double phil = std::numeric_limits<long double>::quiet_NaN();
+
+ float a = std::tr1::ellint_3(kf, nuf, phif);
+ float b = std::tr1::ellint_3f(kf, nuf, phif);
+ double c = std::tr1::ellint_3(kd, nud, phid);
+ long double d = std::tr1::ellint_3(kl, nul, phil);
+ long double e = std::tr1::ellint_3l(kl, nul, phil);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ test02();
+ test03();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/check_value.cc
new file mode 100644
index 00000000000..a86771b3173
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/check_value.cc
@@ -0,0 +1,10116 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// ellint_3
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for k=-0.90000000000000002, nu=0.0000000000000000.
+testcase_ellint_3<double> data001[] = {
+ { -0.0000000000000000, -0.90000000000000002, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17525427376115027, -0.90000000000000002, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.35492464591297446, -0.90000000000000002, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.54388221416157134, -0.90000000000000002, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.74797400423532523, -0.90000000000000002, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.97463898451966458, -0.90000000000000002, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.2334463254523440, -0.90000000000000002, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.5355247765594910, -0.90000000000000002, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.8882928567775124, -0.90000000000000002, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 2.2805491384227703, -0.90000000000000002, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.90000000000000002, nu=0.0000000000000000.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data001[i].k), Tp(data001[i].nu),
+ Tp(data001[i].phi));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.90000000000000002, nu=0.10000000000000001.
+testcase_ellint_3<double> data002[] = {
+ { -0.0000000000000000, -0.90000000000000002, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17507714233254659, -0.90000000000000002, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.35350932904326521, -0.90000000000000002, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.53911129989870998, -0.90000000000000002, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.73666644254508429, -0.90000000000000002, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.95250736612100184, -0.90000000000000002, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.1950199550905594, -0.90000000000000002, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.4741687286340848, -0.90000000000000002, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.7968678183506059, -0.90000000000000002, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 2.1537868513875287, -0.90000000000000002, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.90000000000000002, nu=0.10000000000000001.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data002[i].k), Tp(data002[i].nu),
+ Tp(data002[i].phi));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.90000000000000002, nu=0.20000000000000001.
+testcase_ellint_3<double> data003[] = {
+ { -0.0000000000000000, -0.90000000000000002, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17490065089140930, -0.90000000000000002, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.35211377590661436, -0.90000000000000002, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.53448220334204122, -0.90000000000000002, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.72591368943179613, -0.90000000000000002, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.93192539780038763, -0.90000000000000002, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 1.1600809679692683, -0.90000000000000002, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.4195407225882508, -0.90000000000000002, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.7168966476424528, -0.90000000000000002, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 2.0443194576468890, -0.90000000000000002, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.90000000000000002, nu=0.20000000000000001.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data003[i].k), Tp(data003[i].nu),
+ Tp(data003[i].phi));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.90000000000000002, nu=0.29999999999999999.
+testcase_ellint_3<double> data004[] = {
+ { -0.0000000000000000, -0.90000000000000002, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17472479532647534, -0.90000000000000002, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.35073750187374114, -0.90000000000000002, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.52998766129466979, -0.90000000000000002, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.71566993548699587, -0.90000000000000002, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.91271517762560195, -0.90000000000000002, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 1.1281241199843370, -0.90000000000000002, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.3704929576917448, -0.90000000000000002, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.6461981511487715, -0.90000000000000002, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.9486280260314426, -0.90000000000000002, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.90000000000000002, nu=0.29999999999999999.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data004[i].k), Tp(data004[i].nu),
+ Tp(data004[i].phi));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.90000000000000002, nu=0.40000000000000002.
+testcase_ellint_3<double> data005[] = {
+ { -0.0000000000000000, -0.90000000000000002, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17454957156468839, -0.90000000000000002, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34938003933330430, -0.90000000000000002, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.52562093533067455, -0.90000000000000002, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.70589461324915703, -0.90000000000000002, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.89472658511942849, -0.90000000000000002, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 1.0987419542323440, -0.90000000000000002, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.3261349565496301, -0.90000000000000002, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.5831293909853767, -0.90000000000000002, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.8641114227238349, -0.90000000000000002, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.90000000000000002, nu=0.40000000000000002.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data005[i].k), Tp(data005[i].nu),
+ Tp(data005[i].phi));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.90000000000000002, nu=0.50000000000000000.
+testcase_ellint_3<double> data006[] = {
+ { -0.0000000000000000, -0.90000000000000002, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17437497557073336, -0.90000000000000002, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34804093691586013, -0.90000000000000002, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.52137576320372914, -0.90000000000000002, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.69655163996912284, -0.90000000000000002, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.87783188683054236, -0.90000000000000002, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 1.0716015959755185, -0.90000000000000002, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.2857636916026747, -0.90000000000000002, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.5264263913252365, -0.90000000000000002, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.7888013241937861, -0.90000000000000002, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.90000000000000002, nu=0.50000000000000000.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data006[i].k), Tp(data006[i].nu),
+ Tp(data006[i].phi));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.90000000000000002, nu=0.59999999999999998.
+testcase_ellint_3<double> data007[] = {
+ { -0.0000000000000000, -0.90000000000000002, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17420100334657815, -0.90000000000000002, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34671975876122157, -0.90000000000000002, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.51724631570707968, -0.90000000000000002, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.68760879113743056, -0.90000000000000002, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.86192157779698364, -0.90000000000000002, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 1.0464279696166354, -0.90000000000000002, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.2488156247094004, -0.90000000000000002, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.4750988777188474, -0.90000000000000002, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.7211781128919523, -0.90000000000000002, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.90000000000000002, nu=0.59999999999999998.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data007[i].k), Tp(data007[i].nu),
+ Tp(data007[i].phi));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.90000000000000002, nu=0.69999999999999996.
+testcase_ellint_3<double> data008[] = {
+ { -0.0000000000000000, -0.90000000000000002, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17402765093102210, -0.90000000000000002, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.34541608382635131, -0.90000000000000002, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.51322715827061705, -0.90000000000000002, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.67903717872440306, -0.90000000000000002, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.84690113601682671, -0.90000000000000002, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 1.0229914311548418, -0.90000000000000002, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 1.2148329639709381, -0.90000000000000002, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.4283586501307806, -0.90000000000000002, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.6600480747670938, -0.90000000000000002, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.90000000000000002, nu=0.69999999999999996.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data008[i].k), Tp(data008[i].nu),
+ Tp(data008[i].phi));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.90000000000000002, nu=0.80000000000000004.
+testcase_ellint_3<double> data009[] = {
+ { -0.0000000000000000, -0.90000000000000002, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17385491439925149, -0.90000000000000002, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.34412950523113928, -0.90000000000000002, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.50931321668729612, -0.90000000000000002, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.67081081392296349, -0.90000000000000002, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.83268846097293259, -0.90000000000000002, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 1.0010985015814027, -0.90000000000000002, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 1.1834394045489678, -0.90000000000000002, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.3855695891683188, -0.90000000000000002, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.6044591960982204, -0.90000000000000002, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.90000000000000002, nu=0.80000000000000004.
+template <typename Tp>
+void test009()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data009)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data009[i].k), Tp(data009[i].nu),
+ Tp(data009[i].phi));
+ const Tp f0 = data009[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.90000000000000002, nu=0.90000000000000002.
+testcase_ellint_3<double> data010[] = {
+ { -0.0000000000000000, -0.90000000000000002, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17368278986240138, -0.90000000000000002, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.34285962963961397, -0.90000000000000002, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.50549974644993323, -0.90000000000000002, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.66290623857720898, -0.90000000000000002, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.81921183128847164, -0.90000000000000002, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.98058481956066390, -0.90000000000000002, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 1.1543223520473567, -0.90000000000000002, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.3462119782292938, -0.90000000000000002, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.5536420236310946, -0.90000000000000002, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.90000000000000002, nu=0.90000000000000002.
+template <typename Tp>
+void test010()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data010)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data010[i].k), Tp(data010[i].nu),
+ Tp(data010[i].phi));
+ const Tp f0 = data010[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.80000000000000004, nu=0.0000000000000000.
+testcase_ellint_3<double> data011[] = {
+ { -0.0000000000000000, -0.80000000000000004, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17510154241338902, -0.80000000000000004, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.35365068839779390, -0.80000000000000004, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.53926804409084561, -0.80000000000000004, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.73587926028070383, -0.80000000000000004, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.94770942970071170, -0.80000000000000004, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.1789022995388239, -0.80000000000000004, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.4323027881876009, -0.80000000000000004, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.7069629739121674, -0.80000000000000004, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 1.9953027776647296, -0.80000000000000004, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.80000000000000004, nu=0.0000000000000000.
+template <typename Tp>
+void test011()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data011)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data011[i].k), Tp(data011[i].nu),
+ Tp(data011[i].phi));
+ const Tp f0 = data011[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.80000000000000004, nu=0.10000000000000001.
+testcase_ellint_3<double> data012[] = {
+ { -0.0000000000000000, -0.80000000000000004, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17492468824017166, -0.80000000000000004, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.35224443521476911, -0.80000000000000004, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.53456851853226961, -0.80000000000000004, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.72488875602364944, -0.80000000000000004, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.92661354274638952, -0.80000000000000004, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.1432651144499077, -0.80000000000000004, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.3774479927211429, -0.80000000000000004, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.6287092337196041, -0.80000000000000004, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 1.8910755418379521, -0.80000000000000004, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.80000000000000004, nu=0.10000000000000001.
+template <typename Tp>
+void test012()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data012)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data012[i].k), Tp(data012[i].nu),
+ Tp(data012[i].phi));
+ const Tp f0 = data012[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.80000000000000004, nu=0.20000000000000001.
+testcase_ellint_3<double> data013[] = {
+ { -0.0000000000000000, -0.80000000000000004, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17474847286224943, -0.80000000000000004, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.35085779529084682, -0.80000000000000004, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.53000829263059157, -0.80000000000000004, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.71443466027453406, -0.80000000000000004, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.90698196872715420, -0.80000000000000004, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 1.1108198200558581, -0.80000000000000004, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.3284988909963957, -0.80000000000000004, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.5600369318140328, -0.80000000000000004, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 1.8007226661734588, -0.80000000000000004, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.80000000000000004, nu=0.20000000000000001.
+template <typename Tp>
+void test013()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data013)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data013[i].k), Tp(data013[i].nu),
+ Tp(data013[i].phi));
+ const Tp f0 = data013[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.80000000000000004, nu=0.29999999999999999.
+testcase_ellint_3<double> data014[] = {
+ { -0.0000000000000000, -0.80000000000000004, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17457289217669891, -0.80000000000000004, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.34949028801501258, -0.80000000000000004, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.52558024362769318, -0.80000000000000004, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.70447281740094914, -0.80000000000000004, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.88864745641528986, -0.80000000000000004, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 1.0811075819341465, -0.80000000000000004, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.2844589654082377, -0.80000000000000004, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.4991461361277849, -0.80000000000000004, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.7214611048717301, -0.80000000000000004, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.80000000000000004, nu=0.29999999999999999.
+template <typename Tp>
+void test014()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data014)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data014[i].k), Tp(data014[i].nu),
+ Tp(data014[i].phi));
+ const Tp f0 = data014[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.80000000000000004, nu=0.40000000000000002.
+testcase_ellint_3<double> data015[] = {
+ { -0.0000000000000000, -0.80000000000000004, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17439794211872178, -0.80000000000000004, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34814144964568972, -0.80000000000000004, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.52127776285273075, -0.80000000000000004, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.69496411438966599, -0.80000000000000004, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.87146878427509589, -0.80000000000000004, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 1.0537579024937762, -0.80000000000000004, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.2445534387922637, -0.80000000000000004, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.4446769766361993, -0.80000000000000004, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.6512267838651289, -0.80000000000000004, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.80000000000000004, nu=0.40000000000000002.
+template <typename Tp>
+void test015()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data015)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data015[i].k), Tp(data015[i].nu),
+ Tp(data015[i].phi));
+ const Tp f0 = data015[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.80000000000000004, nu=0.50000000000000000.
+testcase_ellint_3<double> data016[] = {
+ { -0.0000000000000000, -0.80000000000000004, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17422361866118047, -0.80000000000000004, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34681083254170475, -0.80000000000000004, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.51709470815494440, -0.80000000000000004, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.68587375344080259, -0.80000000000000004, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.85532571852810624, -0.80000000000000004, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 1.0284677391874906, -0.80000000000000004, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.2081693942686225, -0.80000000000000004, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.3955803006426311, -0.80000000000000004, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.5884528947755532, -0.80000000000000004, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.80000000000000004, nu=0.50000000000000000.
+template <typename Tp>
+void test016()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data016)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data016[i].k), Tp(data016[i].nu),
+ Tp(data016[i].phi));
+ const Tp f0 = data016[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.80000000000000004, nu=0.59999999999999998.
+testcase_ellint_3<double> data017[] = {
+ { -0.0000000000000000, -0.80000000000000004, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17404991781414092, -0.80000000000000004, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34549800443625167, -0.80000000000000004, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.51302536167001556, -0.80000000000000004, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.67717065003912258, -0.80000000000000004, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.84011512421134416, -0.80000000000000004, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 1.0049863847088742, -0.80000000000000004, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.1748145941898918, -0.80000000000000004, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.3510319699755071, -0.80000000000000004, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.5319262547427865, -0.80000000000000004, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.80000000000000004, nu=0.59999999999999998.
+template <typename Tp>
+void test017()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data017)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data017[i].k), Tp(data017[i].nu),
+ Tp(data017[i].phi));
+ const Tp f0 = data017[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.80000000000000004, nu=0.69999999999999996.
+testcase_ellint_3<double> data018[] = {
+ { -0.0000000000000000, -0.80000000000000004, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17387683562442202, -0.80000000000000004, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.34420254775101611, -0.80000000000000004, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.50906439222143685, -0.80000000000000004, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.66882693152688433, -0.80000000000000004, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.82574792844091316, -0.80000000000000004, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 0.98310431309490953, -0.80000000000000004, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 1.1440884535113258, -0.80000000000000004, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.3103743938952537, -0.80000000000000004, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.4806912324625332, -0.80000000000000004, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.80000000000000004, nu=0.69999999999999996.
+template <typename Tp>
+void test018()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data018)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data018[i].k), Tp(data018[i].nu),
+ Tp(data018[i].phi));
+ const Tp f0 = data018[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.80000000000000004, nu=0.80000000000000004.
+testcase_ellint_3<double> data019[] = {
+ { -0.0000000000000000, -0.80000000000000004, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17370436817515206, -0.80000000000000004, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.34292405894783395, -0.80000000000000004, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.50520682176250087, -0.80000000000000004, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.66081751679736189, -0.80000000000000004, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.81214672249355102, -0.80000000000000004, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 0.96264481387685574, -0.80000000000000004, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 1.1156611352656258, -0.80000000000000004, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.2730756225143889, -0.80000000000000004, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.4339837018309474, -0.80000000000000004, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.80000000000000004, nu=0.80000000000000004.
+template <typename Tp>
+void test019()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data019)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data019[i].k), Tp(data019[i].nu),
+ Tp(data019[i].phi));
+ const Tp f0 = data019[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.80000000000000004, nu=0.90000000000000002.
+testcase_ellint_3<double> data020[] = {
+ { -0.0000000000000000, -0.80000000000000004, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17353251158533153, -0.80000000000000004, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.34166214791545768, -0.80000000000000004, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.50144799535130580, -0.80000000000000004, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.65311976193814447, -0.80000000000000004, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.79924384892320866, -0.80000000000000004, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.94345762353365625, -0.80000000000000004, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 1.0892582069219159, -0.80000000000000004, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.2387000876610268, -0.80000000000000004, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.3911845406776222, -0.80000000000000004, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.80000000000000004, nu=0.90000000000000002.
+template <typename Tp>
+void test020()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data020)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data020[i].k), Tp(data020[i].nu),
+ Tp(data020[i].phi));
+ const Tp f0 = data020[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.69999999999999996, nu=0.0000000000000000.
+testcase_ellint_3<double> data021[] = {
+ { -0.0000000000000000, -0.69999999999999996, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17496737466916720, -0.69999999999999996, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.35254687535677925, -0.69999999999999996, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.53536740275997130, -0.69999999999999996, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.72603797651684465, -0.69999999999999996, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.92698296348313458, -0.69999999999999996, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.1400447527693316, -0.69999999999999996, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.3657668117194071, -0.69999999999999996, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.6024686895959159, -0.69999999999999996, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 1.8456939983747236, -0.69999999999999996, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.69999999999999996, nu=0.0000000000000000.
+template <typename Tp>
+void test021()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data021)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data021[i].k), Tp(data021[i].nu),
+ Tp(data021[i].phi));
+ const Tp f0 = data021[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.69999999999999996, nu=0.10000000000000001.
+testcase_ellint_3<double> data022[] = {
+ { -0.0000000000000000, -0.69999999999999996, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17479076384884681, -0.69999999999999996, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.35114844900396364, -0.69999999999999996, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.53072776947527012, -0.69999999999999996, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.71530198262386246, -0.69999999999999996, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.90666760677828306, -0.69999999999999996, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.1063366517438080, -0.69999999999999996, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.3149477243092147, -0.69999999999999996, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.5314886725038925, -0.69999999999999996, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 1.7528050171757608, -0.69999999999999996, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.69999999999999996, nu=0.10000000000000001.
+template <typename Tp>
+void test022()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data022)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data022[i].k), Tp(data022[i].nu),
+ Tp(data022[i].phi));
+ const Tp f0 = data022[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.69999999999999996, nu=0.20000000000000001.
+testcase_ellint_3<double> data023[] = {
+ { -0.0000000000000000, -0.69999999999999996, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17461479077791472, -0.69999999999999996, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.34976950621407538, -0.69999999999999996, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.52622533231350188, -0.69999999999999996, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.70508774017895226, -0.69999999999999996, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.88775302531730294, -0.69999999999999996, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 1.0756195476149006, -0.69999999999999996, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.2695349716654372, -0.69999999999999996, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.4690814617070540, -0.69999999999999996, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 1.6721098780092147, -0.69999999999999996, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.69999999999999996, nu=0.20000000000000001.
+template <typename Tp>
+void test023()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data023)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data023[i].k), Tp(data023[i].nu),
+ Tp(data023[i].phi));
+ const Tp f0 = data023[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.69999999999999996, nu=0.29999999999999999.
+testcase_ellint_3<double> data024[] = {
+ { -0.0000000000000000, -0.69999999999999996, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17443945136076172, -0.69999999999999996, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.34840956983535287, -0.69999999999999996, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.52185308551329179, -0.69999999999999996, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.69535240431168266, -0.69999999999999996, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.87007983473964923, -0.69999999999999996, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 1.0474657975577066, -0.69999999999999996, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.2286225419931889, -0.69999999999999996, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.4136490671013271, -0.69999999999999996, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.6011813647733213, -0.69999999999999996, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.69999999999999996, nu=0.29999999999999999.
+template <typename Tp>
+void test024()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data024)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data024[i].k), Tp(data024[i].nu),
+ Tp(data024[i].phi));
+ const Tp f0 = data024[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.69999999999999996, nu=0.40000000000000002.
+testcase_ellint_3<double> data025[] = {
+ { -0.0000000000000000, -0.69999999999999996, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17426474153983226, -0.69999999999999996, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34706817945773732, -0.69999999999999996, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.51760452851738159, -0.69999999999999996, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.68605801534722766, -0.69999999999999996, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.85351339387296532, -0.69999999999999996, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 1.0215297967969537, -0.69999999999999996, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.1915051074460528, -0.69999999999999996, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.3639821911744707, -0.69999999999999996, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.5382162002954762, -0.69999999999999996, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.69999999999999996, nu=0.40000000000000002.
+template <typename Tp>
+void test025()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data025)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data025[i].k), Tp(data025[i].nu),
+ Tp(data025[i].phi));
+ const Tp f0 = data025[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.69999999999999996, nu=0.50000000000000000.
+testcase_ellint_3<double> data026[] = {
+ { -0.0000000000000000, -0.69999999999999996, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17409065729516093, -0.69999999999999996, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34574489064986091, -0.69999999999999996, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.51347361925579793, -0.69999999999999996, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.67717079489579290, -0.69999999999999996, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.83793902055292280, -0.69999999999999996, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 0.99752863545289705, -0.69999999999999996, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.1576240080401499, -0.69999999999999996, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.3191464023923762, -0.69999999999999996, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.4818433192178544, -0.69999999999999996, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.69999999999999996, nu=0.50000000000000000.
+template <typename Tp>
+void test026()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data026)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data026[i].k), Tp(data026[i].nu),
+ Tp(data026[i].phi));
+ const Tp f0 = data026[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.69999999999999996, nu=0.59999999999999998.
+testcase_ellint_3<double> data027[] = {
+ { -0.0000000000000000, -0.69999999999999996, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17391719464391611, -0.69999999999999996, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34443927423869031, -0.69999999999999996, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.50945473266486074, -0.69999999999999996, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.66866056326513823, -0.69999999999999996, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.82325830002337352, -0.69999999999999996, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 0.97522808245669357, -0.69999999999999996, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.1265300613705282, -0.69999999999999996, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.2784066076152003, -0.69999999999999996, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.4309994736080540, -0.69999999999999996, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.69999999999999996, nu=0.59999999999999998.
+template <typename Tp>
+void test027()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data027)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data027[i].k), Tp(data027[i].nu),
+ Tp(data027[i].phi));
+ const Tp f0 = data027[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.69999999999999996, nu=0.69999999999999996.
+testcase_ellint_3<double> data028[] = {
+ { -0.0000000000000000, -0.69999999999999996, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17374434963995028, -0.69999999999999996, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.34315091562900674, -0.69999999999999996, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.50554262375653358, -0.69999999999999996, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.66050025406305812, -0.69999999999999996, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.80938620118847404, -0.69999999999999996, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 0.95443223855852144, -0.69999999999999996, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 1.0978573207128302, -0.69999999999999996, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.2411754575007123, -0.69999999999999996, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.3848459188329196, -0.69999999999999996, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.69999999999999996, nu=0.69999999999999996.
+template <typename Tp>
+void test028()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data028)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data028[i].k), Tp(data028[i].nu),
+ Tp(data028[i].phi));
+ const Tp f0 = data028[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.69999999999999996, nu=0.80000000000000004.
+testcase_ellint_3<double> data029[] = {
+ { -0.0000000000000000, -0.69999999999999996, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17357211837335737, -0.69999999999999996, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.34187941416012108, -0.69999999999999996, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.50173239465478270, -0.69999999999999996, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.65266550725988315, -0.69999999999999996, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.79624879865249298, -0.69999999999999996, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 0.93497577043296920, -0.69999999999999996, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 1.0713041566930748, -0.69999999999999996, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.2069772023255652, -0.69999999999999996, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.3427110650397533, -0.69999999999999996, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.69999999999999996, nu=0.80000000000000004.
+template <typename Tp>
+void test029()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data029)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data029[i].k), Tp(data029[i].nu),
+ Tp(data029[i].phi));
+ const Tp f0 = data029[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.69999999999999996, nu=0.90000000000000002.
+testcase_ellint_3<double> data030[] = {
+ { -0.0000000000000000, -0.69999999999999996, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17340049697003634, -0.69999999999999996, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.34062438249741556, -0.69999999999999996, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.49801946510076878, -0.69999999999999996, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.64513432604750487, -0.69999999999999996, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.78378145487573758, -0.69999999999999996, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.91671799500854634, -0.69999999999999996, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 1.0466193579463123, -0.69999999999999996, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.1754218079199146, -0.69999999999999996, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.3040500499695911, -0.69999999999999996, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.69999999999999996, nu=0.90000000000000002.
+template <typename Tp>
+void test030()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data030)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data030[i].k), Tp(data030[i].nu),
+ Tp(data030[i].phi));
+ const Tp f0 = data030[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.59999999999999998, nu=0.0000000000000000.
+testcase_ellint_3<double> data031[] = {
+ { -0.0000000000000000, -0.59999999999999998, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17485154362988362, -0.59999999999999998, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.35160509865544326, -0.59999999999999998, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.53210652578446160, -0.59999999999999998, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.71805304664485670, -0.59999999999999998, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.91082759030195970, -0.59999999999999998, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.1112333229323361, -0.59999999999999998, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.3191461190365270, -0.59999999999999998, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.5332022105084773, -0.59999999999999998, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 1.7507538029157526, -0.59999999999999998, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.59999999999999998, nu=0.0000000000000000.
+template <typename Tp>
+void test031()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data031)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data031[i].k), Tp(data031[i].nu),
+ Tp(data031[i].phi));
+ const Tp f0 = data031[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.59999999999999998, nu=0.10000000000000001.
+testcase_ellint_3<double> data032[] = {
+ { -0.0000000000000000, -0.59999999999999998, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17467514275022014, -0.59999999999999998, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.35021333086258255, -0.59999999999999998, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.52751664092962713, -0.59999999999999998, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.70752126971957885, -0.59999999999999998, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.89111058756112871, -0.59999999999999998, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.0789241202877768, -0.59999999999999998, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.2710800210399946, -0.59999999999999998, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.4669060574440276, -0.59999999999999998, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 1.6648615773343014, -0.59999999999999998, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.59999999999999998, nu=0.10000000000000001.
+template <typename Tp>
+void test032()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data032)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data032[i].k), Tp(data032[i].nu),
+ Tp(data032[i].phi));
+ const Tp f0 = data032[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.59999999999999998, nu=0.20000000000000001.
+testcase_ellint_3<double> data033[] = {
+ { -0.0000000000000000, -0.59999999999999998, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17449937871800653, -0.59999999999999998, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.34884093647346553, -0.59999999999999998, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.52306221119844110, -0.59999999999999998, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.69749955678982223, -0.59999999999999998, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.87274610682416853, -0.59999999999999998, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 1.0494620540750792, -0.59999999999999998, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.2280847305507339, -0.59999999999999998, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.4085436279696886, -0.59999999999999998, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 1.5901418016279374, -0.59999999999999998, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.59999999999999998, nu=0.20000000000000001.
+template <typename Tp>
+void test033()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data033)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data033[i].k), Tp(data033[i].nu),
+ Tp(data033[i].phi));
+ const Tp f0 = data033[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.59999999999999998, nu=0.29999999999999999.
+testcase_ellint_3<double> data034[] = {
+ { -0.0000000000000000, -0.59999999999999998, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17432424744393935, -0.59999999999999998, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.34748744127146447, -0.59999999999999998, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.51873632743924847, -0.59999999999999998, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.68794610396313127, -0.59999999999999998, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.85558070175468726, -0.59999999999999998, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 1.0224416343605653, -0.59999999999999998, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.1893144457936788, -0.59999999999999998, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.3566435377982575, -0.59999999999999998, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.5243814243493585, -0.59999999999999998, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.59999999999999998, nu=0.29999999999999999.
+template <typename Tp>
+void test034()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data034)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data034[i].k), Tp(data034[i].nu),
+ Tp(data034[i].phi));
+ const Tp f0 = data034[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.59999999999999998, nu=0.40000000000000002.
+testcase_ellint_3<double> data035[] = {
+ { -0.0000000000000000, -0.59999999999999998, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17414974487670720, -0.59999999999999998, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34615238767335027, -0.59999999999999998, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.51453257838108579, -0.59999999999999998, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.67882386787534410, -0.59999999999999998, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.83948470233173578, -0.59999999999999998, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 0.99753496200073977, -0.59999999999999998, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.1541101404388487, -0.59999999999999998, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.3100911323398814, -0.59999999999999998, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.4659345278069984, -0.59999999999999998, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.59999999999999998, nu=0.40000000000000002.
+template <typename Tp>
+void test035()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data035)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data035[i].k), Tp(data035[i].nu),
+ Tp(data035[i].phi));
+ const Tp f0 = data035[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.59999999999999998, nu=0.50000000000000000.
+testcase_ellint_3<double> data036[] = {
+ { -0.0000000000000000, -0.59999999999999998, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17397586700252810, -0.59999999999999998, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34483533397138516, -0.59999999999999998, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.51044500461706499, -0.59999999999999998, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.67009988034712675, -0.59999999999999998, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.82434762375735193, -0.59999999999999998, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 0.97447346702798998, -0.59999999999999998, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.1219494000522143, -0.59999999999999998, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.2680242605954486, -0.59999999999999998, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.4135484285693078, -0.59999999999999998, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.59999999999999998, nu=0.50000000000000000.
+template <typename Tp>
+void test036()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data036)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data036[i].k), Tp(data036[i].nu),
+ Tp(data036[i].phi));
+ const Tp f0 = data036[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.59999999999999998, nu=0.59999999999999998.
+testcase_ellint_3<double> data037[] = {
+ { -0.0000000000000000, -0.59999999999999998, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17380260984469356, -0.59999999999999998, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34353585361777839, -0.59999999999999998, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.50646805774321402, -0.59999999999999998, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.66174468108625517, -0.59999999999999998, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.81007462280278408, -0.59999999999999998, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 0.95303466945718729, -0.59999999999999998, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.0924118588677503, -0.59999999999999998, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.2297640574847937, -0.59999999999999998, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.3662507535812816, -0.59999999999999998, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.59999999999999998, nu=0.59999999999999998.
+template <typename Tp>
+void test037()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data037)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data037[i].k), Tp(data037[i].nu),
+ Tp(data037[i].phi));
+ const Tp f0 = data037[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.59999999999999998, nu=0.69999999999999996.
+testcase_ellint_3<double> data038[] = {
+ { -0.0000000000000000, -0.59999999999999998, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17362996946312009, -0.59999999999999998, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.34225353454870588, -0.59999999999999998, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.50259656397799546, -0.59999999999999998, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.65373184496628944, -0.59999999999999998, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.79658372884056439, -0.59999999999999998, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 0.93303240100245421, -0.59999999999999998, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 1.0651547944716557, -0.59999999999999998, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.1947676204853441, -0.59999999999999998, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.3232737468822811, -0.59999999999999998, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.59999999999999998, nu=0.69999999999999996.
+template <typename Tp>
+void test038()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data038)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data038[i].k), Tp(data038[i].nu),
+ Tp(data038[i].phi));
+ const Tp f0 = data038[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.59999999999999998, nu=0.80000000000000004.
+testcase_ellint_3<double> data039[] = {
+ { -0.0000000000000000, -0.59999999999999998, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17345794195390687, -0.59999999999999998, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.34098797854531027, -0.59999999999999998, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.49882569168826230, -0.59999999999999998, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.64603758566475511, -0.59999999999999998, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.78380365594769730, -0.59999999999999998, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 0.91430946255611190, -0.59999999999999998, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 1.0398955217270607, -0.59999999999999998, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.1625948314277676, -0.59999999999999998, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.2840021261752192, -0.59999999999999998, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.59999999999999998, nu=0.80000000000000004.
+template <typename Tp>
+void test039()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data039)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data039[i].k), Tp(data039[i].nu),
+ Tp(data039[i].phi));
+ const Tp f0 = data039[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.59999999999999998, nu=0.90000000000000002.
+testcase_ellint_3<double> data040[] = {
+ { -0.0000000000000000, -0.59999999999999998, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17328652344890033, -0.59999999999999998, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.33973880062929018, -0.59999999999999998, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.49515092233122765, -0.59999999999999998, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.63864042139737043, -0.59999999999999998, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.77167205646538850, -0.59999999999999998, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.89673202848034383, -0.59999999999999998, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 1.0163984492661304, -0.59999999999999998, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.1328845785162431, -0.59999999999999998, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.2479362973851875, -0.59999999999999998, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.59999999999999998, nu=0.90000000000000002.
+template <typename Tp>
+void test040()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data040)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data040[i].k), Tp(data040[i].nu),
+ Tp(data040[i].phi));
+ const Tp f0 = data040[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.50000000000000000, nu=0.0000000000000000.
+testcase_ellint_3<double> data041[] = {
+ { -0.0000000000000000, -0.50000000000000000, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17475385514035785, -0.50000000000000000, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.35081868470101585, -0.50000000000000000, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.52942862705190585, -0.50000000000000000, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.71164727562630326, -0.50000000000000000, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.89824523594227768, -0.50000000000000000, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.0895506700518851, -0.50000000000000000, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.2853005857432933, -0.50000000000000000, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.4845545520549484, -0.50000000000000000, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 1.6857503548125963, -0.50000000000000000, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.50000000000000000, nu=0.0000000000000000.
+template <typename Tp>
+void test041()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data041)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data041[i].k), Tp(data041[i].nu),
+ Tp(data041[i].phi));
+ const Tp f0 = data041[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.50000000000000000, nu=0.10000000000000001.
+testcase_ellint_3<double> data042[] = {
+ { -0.0000000000000000, -0.50000000000000000, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17457763120814676, -0.50000000000000000, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.34943246340849154, -0.50000000000000000, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.52487937869610801, -0.50000000000000000, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.70127785096388395, -0.50000000000000000, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.87898815988624479, -0.50000000000000000, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.0582764576094172, -0.50000000000000000, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.2391936844060207, -0.50000000000000000, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.4214793542995841, -0.50000000000000000, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 1.6045524936084892, -0.50000000000000000, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.50000000000000000, nu=0.10000000000000001.
+template <typename Tp>
+void test042()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data042)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data042[i].k), Tp(data042[i].nu),
+ Tp(data042[i].phi));
+ const Tp f0 = data042[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.50000000000000000, nu=0.20000000000000001.
+testcase_ellint_3<double> data043[] = {
+ { -0.0000000000000000, -0.50000000000000000, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17440204336345433, -0.50000000000000000, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.34806552388338824, -0.50000000000000000, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.52046416757129821, -0.50000000000000000, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.69140924550993876, -0.50000000000000000, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.86104678636125520, -0.50000000000000000, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 1.0297439459053981, -0.50000000000000000, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.1979214112912036, -0.50000000000000000, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.3659033858648930, -0.50000000000000000, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 1.5338490483665983, -0.50000000000000000, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.50000000000000000, nu=0.20000000000000001.
+template <typename Tp>
+void test043()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data043)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data043[i].k), Tp(data043[i].nu),
+ Tp(data043[i].phi));
+ const Tp f0 = data043[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.50000000000000000, nu=0.29999999999999999.
+testcase_ellint_3<double> data044[] = {
+ { -0.0000000000000000, -0.50000000000000000, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17422708752228896, -0.50000000000000000, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.34671739434855858, -0.50000000000000000, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.51617616305641889, -0.50000000000000000, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.68200047612545178, -0.50000000000000000, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.84427217869498372, -0.50000000000000000, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 1.0035637821389782, -0.50000000000000000, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.1606800483933113, -0.50000000000000000, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.3164407134643459, -0.50000000000000000, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.4715681939859637, -0.50000000000000000, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.50000000000000000, nu=0.29999999999999999.
+template <typename Tp>
+void test044()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data044)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data044[i].k), Tp(data044[i].nu),
+ Tp(data044[i].phi));
+ const Tp f0 = data044[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.50000000000000000, nu=0.40000000000000002.
+testcase_ellint_3<double> data045[] = {
+ { -0.0000000000000000, -0.50000000000000000, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17405275963859917, -0.50000000000000000, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34538761957029329, -0.50000000000000000, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.51200902646603919, -0.50000000000000000, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.67301522212868792, -0.50000000000000000, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.82853844466313320, -0.50000000000000000, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 0.97942097862681488, -0.50000000000000000, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.1268429801220616, -0.50000000000000000, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.2720406704533922, -0.50000000000000000, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.4161679518465340, -0.50000000000000000, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.50000000000000000, nu=0.40000000000000002.
+template <typename Tp>
+void test045()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data045)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data045[i].k), Tp(data045[i].nu),
+ Tp(data045[i].phi));
+ const Tp f0 = data045[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.50000000000000000, nu=0.50000000000000000.
+testcase_ellint_3<double> data046[] = {
+ { -0.0000000000000000, -0.50000000000000000, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17387905570381157, -0.50000000000000000, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34407576010465207, -0.50000000000000000, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.50795686560160835, -0.50000000000000000, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.66442115453330175, -0.50000000000000000, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.81373829119355345, -0.50000000000000000, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 0.95705743313235825, -0.50000000000000000, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.0959131991362556, -0.50000000000000000, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.2318900529754597, -0.50000000000000000, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.3664739530045971, -0.50000000000000000, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.50000000000000000, nu=0.50000000000000000.
+template <typename Tp>
+void test046()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data046)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data046[i].k), Tp(data046[i].nu),
+ Tp(data046[i].phi));
+ const Tp f0 = data046[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.50000000000000000, nu=0.59999999999999998.
+testcase_ellint_3<double> data047[] = {
+ { -0.0000000000000000, -0.50000000000000000, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17370597174637581, -0.50000000000000000, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34278139158591414, -0.50000000000000000, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.50401419439302719, -0.50000000000000000, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.65618938076167221, -0.50000000000000000, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.79977959248855424, -0.50000000000000000, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 0.93625925190753545, -0.50000000000000000, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.0674905658379710, -0.50000000000000000, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.1953481298023048, -0.50000000000000000, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.3215740290190876, -0.50000000000000000, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.50000000000000000, nu=0.59999999999999998.
+template <typename Tp>
+void test047()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data047)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data047[i].k), Tp(data047[i].nu),
+ Tp(data047[i].phi));
+ const Tp f0 = data047[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.50000000000000000, nu=0.69999999999999996.
+testcase_ellint_3<double> data048[] = {
+ { -0.0000000000000000, -0.50000000000000000, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17353350383131641, -0.50000000000000000, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.34150410405436771, -0.50000000000000000, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.50017589696443487, -0.50000000000000000, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.64829398188419962, -0.50000000000000000, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.78658270782402073, -0.50000000000000000, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 0.91684738336675053, -0.50000000000000000, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 1.0412486789555937, -0.50000000000000000, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.1619021847612001, -0.50000000000000000, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.2807475181182502, -0.50000000000000000, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.50000000000000000, nu=0.69999999999999996.
+template <typename Tp>
+void test048()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data048)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data048[i].k), Tp(data048[i].nu),
+ Tp(data048[i].phi));
+ const Tp f0 = data048[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.50000000000000000, nu=0.80000000000000004.
+testcase_ellint_3<double> data049[] = {
+ { -0.0000000000000000, -0.50000000000000000, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17336164805979126, -0.50000000000000000, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.34024350132086773, -0.50000000000000000, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.49643719555734084, -0.50000000000000000, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.64071162456976150, -0.50000000000000000, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.77407836177211908, -0.50000000000000000, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 0.89867058251905652, -0.50000000000000000, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 1.0169181822134912, -0.50000000000000000, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.1311363312779448, -0.50000000000000000, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.2434165408189539, -0.50000000000000000, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.50000000000000000, nu=0.80000000000000004.
+template <typename Tp>
+void test049()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data049)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data049[i].k), Tp(data049[i].nu),
+ Tp(data049[i].phi));
+ const Tp f0 = data049[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.50000000000000000, nu=0.90000000000000002.
+testcase_ellint_3<double> data050[] = {
+ { -0.0000000000000000, -0.50000000000000000, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17319040056865681, -0.50000000000000000, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.33899920036578557, -0.50000000000000000, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.49279362182695186, -0.50000000000000000, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.63342123379746151, -0.50000000000000000, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.76220595179550321, -0.50000000000000000, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.88160004743532294, -0.50000000000000000, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 0.99427448642310134, -0.50000000000000000, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.1027091512470093, -0.50000000000000000, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.2091116095504744, -0.50000000000000000, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.50000000000000000, nu=0.90000000000000002.
+template <typename Tp>
+void test050()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data050)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data050[i].k), Tp(data050[i].nu),
+ Tp(data050[i].phi));
+ const Tp f0 = data050[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.40000000000000002, nu=0.0000000000000000.
+testcase_ellint_3<double> data051[] = {
+ { -0.0000000000000000, -0.40000000000000002, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17467414669441531, -0.40000000000000002, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.35018222772483443, -0.40000000000000002, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.52729015917508748, -0.40000000000000002, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.70662374407341255, -0.40000000000000002, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.88859210497602170, -0.40000000000000002, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.0733136290471379, -0.40000000000000002, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.2605612170157061, -0.40000000000000002, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.4497513956433437, -0.40000000000000002, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 1.6399998658645112, -0.40000000000000002, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.40000000000000002, nu=0.0000000000000000.
+template <typename Tp>
+void test051()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data051)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data051[i].k), Tp(data051[i].nu),
+ Tp(data051[i].phi));
+ const Tp f0 = data051[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.40000000000000002, nu=0.10000000000000001.
+testcase_ellint_3<double> data052[] = {
+ { -0.0000000000000000, -0.40000000000000002, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17449806706684673, -0.40000000000000002, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.34880048623856075, -0.40000000000000002, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.52277322065757403, -0.40000000000000002, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.69638072056918376, -0.40000000000000002, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.86968426619831540, -0.40000000000000002, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.0428044206578095, -0.40000000000000002, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.2158651158274378, -0.40000000000000002, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.3889447129893322, -0.40000000000000002, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 1.5620566886683604, -0.40000000000000002, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.40000000000000002, nu=0.10000000000000001.
+template <typename Tp>
+void test052()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data052)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data052[i].k), Tp(data052[i].nu),
+ Tp(data052[i].phi));
+ const Tp f0 = data052[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.40000000000000002, nu=0.20000000000000001.
+testcase_ellint_3<double> data053[] = {
+ { -0.0000000000000000, -0.40000000000000002, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17432262290723399, -0.40000000000000002, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.34743795258968596, -0.40000000000000002, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.51838919472805123, -0.40000000000000002, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.68663134739057918, -0.40000000000000002, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.85206432981833979, -0.40000000000000002, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 1.0149595349004430, -0.40000000000000002, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.1758349405464676, -0.40000000000000002, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.3353337673882635, -0.40000000000000002, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 1.4941414344266770, -0.40000000000000002, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.40000000000000002, nu=0.20000000000000001.
+template <typename Tp>
+void test053()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data053)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data053[i].k), Tp(data053[i].nu),
+ Tp(data053[i].phi));
+ const Tp f0 = data053[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.40000000000000002, nu=0.29999999999999999.
+testcase_ellint_3<double> data054[] = {
+ { -0.0000000000000000, -0.40000000000000002, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17414781013591543, -0.40000000000000002, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.34609415696777285, -0.40000000000000002, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.51413131295862546, -0.40000000000000002, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.67733527622935630, -0.40000000000000002, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.83558675182733266, -0.40000000000000002, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 0.98940140808865906, -0.40000000000000002, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.1396968797728058, -0.40000000000000002, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.2875920037865087, -0.40000000000000002, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.4342789859950078, -0.40000000000000002, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.40000000000000002, nu=0.29999999999999999.
+template <typename Tp>
+void test054()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data054)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data054[i].k), Tp(data054[i].nu),
+ Tp(data054[i].phi));
+ const Tp f0 = data054[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.40000000000000002, nu=0.40000000000000002.
+testcase_ellint_3<double> data055[] = {
+ { -0.0000000000000000, -0.40000000000000002, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17397362471112710, -0.40000000000000002, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34476864603333196, -0.40000000000000002, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.50999329415379357, -0.40000000000000002, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.66845674551396017, -0.40000000000000002, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.82012848346231748, -0.40000000000000002, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 0.96582449258349057, -0.40000000000000002, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.1068473749476286, -0.40000000000000002, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.2447132729159986, -0.40000000000000002, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.3809986210732901, -0.40000000000000002, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.40000000000000002, nu=0.40000000000000002.
+template <typename Tp>
+void test055()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data055)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data055[i].k), Tp(data055[i].nu),
+ Tp(data055[i].phi));
+ const Tp f0 = data055[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.40000000000000002, nu=0.50000000000000000.
+testcase_ellint_3<double> data056[] = {
+ { -0.0000000000000000, -0.40000000000000002, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17380006262854139, -0.40000000000000002, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34346098216756610, -0.40000000000000002, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.50596929935059420, -0.40000000000000002, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.65996392089131262, -0.40000000000000002, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.80558463511364786, -0.40000000000000002, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 0.94397834522857704, -0.40000000000000002, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.0768075114108115, -0.40000000000000002, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.2059184624251329, -0.40000000000000002, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.3331797176377398, -0.40000000000000002, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.40000000000000002, nu=0.50000000000000000.
+template <typename Tp>
+void test056()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data056)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data056[i].k), Tp(data056[i].nu),
+ Tp(data056[i].phi));
+ const Tp f0 = data056[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.40000000000000002, nu=0.59999999999999998.
+testcase_ellint_3<double> data057[] = {
+ { -0.0000000000000000, -0.40000000000000002, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17362711992081248, -0.40000000000000002, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34217074276403953, -0.40000000000000002, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.50205389185761617, -0.40000000000000002, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.65182834920372745, -0.40000000000000002, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.79186512820565136, -0.40000000000000002, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 0.92365535916287134, -0.40000000000000002, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.0491915663957907, -0.40000000000000002, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.1705934291745104, -0.40000000000000002, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.2899514672527024, -0.40000000000000002, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.40000000000000002, nu=0.59999999999999998.
+template <typename Tp>
+void test057()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data057)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data057[i].k), Tp(data057[i].nu),
+ Tp(data057[i].phi));
+ const Tp f0 = data057[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.40000000000000002, nu=0.69999999999999996.
+testcase_ellint_3<double> data058[] = {
+ { -0.0000000000000000, -0.40000000000000002, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17345479265712871, -0.40000000000000002, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.34089751955950354, -0.40000000000000002, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.49824200167361343, -0.40000000000000002, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.64402450341199413, -0.40000000000000002, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.77889207804122873, -0.40000000000000002, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 0.90468169720957992, -0.40000000000000002, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 1.0236847823692916, -0.40000000000000002, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.1382465247425164, -0.40000000000000002, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.2506255923253344, -0.40000000000000002, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.40000000000000002, nu=0.69999999999999996.
+template <typename Tp>
+void test058()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data058)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data058[i].k), Tp(data058[i].nu),
+ Tp(data058[i].phi));
+ const Tp f0 = data058[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.40000000000000002, nu=0.80000000000000004.
+testcase_ellint_3<double> data059[] = {
+ { -0.0000000000000000, -0.40000000000000002, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17328307694277156, -0.40000000000000002, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.33964091800132007, -0.40000000000000002, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.49452889372467451, -0.40000000000000002, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.63652940095937327, -0.40000000000000002, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.76659772511159097, -0.40000000000000002, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 0.88691047977338111, -0.40000000000000002, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 1.0000273200611638, -0.40000000000000002, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.1084787902188007, -0.40000000000000002, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.2146499565727209, -0.40000000000000002, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.40000000000000002, nu=0.80000000000000004.
+template <typename Tp>
+void test059()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data059)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data059[i].k), Tp(data059[i].nu),
+ Tp(data059[i].phi));
+ const Tp f0 = data059[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.40000000000000002, nu=0.90000000000000002.
+testcase_ellint_3<double> data060[] = {
+ { -0.0000000000000000, -0.40000000000000002, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17311196891868130, -0.40000000000000002, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.33840055664911906, -0.40000000000000002, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.49091013944075340, -0.40000000000000002, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.62932228186809591, -0.40000000000000002, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.75492278323019801, -0.40000000000000002, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.87021659043854294, -0.40000000000000002, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 0.97800245228239246, -0.40000000000000002, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.0809625773173694, -0.40000000000000002, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.1815758115929846, -0.40000000000000002, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.40000000000000002, nu=0.90000000000000002.
+template <typename Tp>
+void test060()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data060)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data060[i].k), Tp(data060[i].nu),
+ Tp(data060[i].phi));
+ const Tp f0 = data060[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.30000000000000004, nu=0.0000000000000000.
+testcase_ellint_3<double> data061[] = {
+ { -0.0000000000000000, -0.30000000000000004, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17461228653000102, -0.30000000000000004, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.34969146102798415, -0.30000000000000004, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.52565822873726320, -0.30000000000000004, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.70284226512408532, -0.30000000000000004, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.88144139195111182, -0.30000000000000004, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.0614897067260523, -0.30000000000000004, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.2428416824174218, -0.30000000000000004, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.4251795877015925, -0.30000000000000004, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 1.6080486199305126, -0.30000000000000004, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.30000000000000004, nu=0.0000000000000000.
+template <typename Tp>
+void test061()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data061)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data061[i].k), Tp(data061[i].nu),
+ Tp(data061[i].phi));
+ const Tp f0 = data061[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.30000000000000004, nu=0.10000000000000001.
+testcase_ellint_3<double> data062[] = {
+ { -0.0000000000000000, -0.30000000000000004, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17443631884814378, -0.30000000000000004, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.34831316835124926, -0.30000000000000004, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.52116586276523857, -0.30000000000000004, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.69269385837910036, -0.30000000000000004, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.86279023163070856, -0.30000000000000004, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.0315321461438265, -0.30000000000000004, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.1991449111869024, -0.30000000000000004, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.3659561780923211, -0.30000000000000004, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 1.5323534693557526, -0.30000000000000004, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.30000000000000004, nu=0.10000000000000001.
+template <typename Tp>
+void test062()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data062)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data062[i].k), Tp(data062[i].nu),
+ Tp(data062[i].phi));
+ const Tp f0 = data062[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.30000000000000004, nu=0.20000000000000001.
+testcase_ellint_3<double> data063[] = {
+ { -0.0000000000000000, -0.30000000000000004, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17426098615372090, -0.30000000000000004, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.34695402664689923, -0.30000000000000004, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.51680555567038933, -0.30000000000000004, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.68303375225260210, -0.30000000000000004, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.84540662891295026, -0.30000000000000004, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 1.0041834051646927, -0.30000000000000004, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.1599952702345711, -0.30000000000000004, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.3137179520499163, -0.30000000000000004, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 1.4663658145259875, -0.30000000000000004, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.30000000000000004, nu=0.20000000000000001.
+template <typename Tp>
+void test063()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data063)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data063[i].k), Tp(data063[i].nu),
+ Tp(data063[i].phi));
+ const Tp f0 = data063[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.30000000000000004, nu=0.29999999999999999.
+testcase_ellint_3<double> data064[] = {
+ { -0.0000000000000000, -0.30000000000000004, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17408628437042845, -0.30000000000000004, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.34561356761638401, -0.30000000000000004, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.51257058617875850, -0.30000000000000004, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.67382207124602866, -0.30000000000000004, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.82914751587825131, -0.30000000000000004, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 0.97907434814374950, -0.30000000000000004, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.1246399297351584, -0.30000000000000004, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.2671793970398146, -0.30000000000000004, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.4081767433479089, -0.30000000000000004, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.30000000000000004, nu=0.29999999999999999.
+template <typename Tp>
+void test064()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data064)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data064[i].k), Tp(data064[i].nu),
+ Tp(data064[i].phi));
+ const Tp f0 = data064[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.30000000000000004, nu=0.40000000000000002.
+testcase_ellint_3<double> data065[] = {
+ { -0.0000000000000000, -0.30000000000000004, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17391220945982730, -0.30000000000000004, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34429133937639689, -0.30000000000000004, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.50845471668581632, -0.30000000000000004, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.66502347027873854, -0.30000000000000004, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.81389191978012254, -0.30000000000000004, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 0.95590618002140593, -0.30000000000000004, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.0924915195213121, -0.30000000000000004, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.2253651604038058, -0.30000000000000004, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.3563643538969761, -0.30000000000000004, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.30000000000000004, nu=0.40000000000000002.
+template <typename Tp>
+void test065()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data065)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data065[i].k), Tp(data065[i].nu),
+ Tp(data065[i].phi));
+ const Tp f0 = data065[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.30000000000000004, nu=0.50000000000000000.
+testcase_ellint_3<double> data066[] = {
+ { -0.0000000000000000, -0.30000000000000004, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17373875742088235, -0.30000000000000004, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34298690571124157, -0.30000000000000004, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.50445214859646936, -0.30000000000000004, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.65660648352418516, -0.30000000000000004, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.79953670639287289, -0.30000000000000004, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 0.93443393926588558, -0.30000000000000004, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.0630838369016911, -0.30000000000000004, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.1875197325653026, -0.30000000000000004, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.3098448759814960, -0.30000000000000004, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.30000000000000004, nu=0.50000000000000000.
+template <typename Tp>
+void test066()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data066)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data066[i].k), Tp(data066[i].nu),
+ Tp(data066[i].phi));
+ const Tp f0 = data066[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.30000000000000004, nu=0.59999999999999998.
+testcase_ellint_3<double> data067[] = {
+ { -0.0000000000000000, -0.30000000000000004, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17356592428950826, -0.30000000000000004, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34169984536697379, -0.30000000000000004, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.50055748266498457, -0.30000000000000004, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.64854298527106768, -0.30000000000000004, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.78599329284207431, -0.30000000000000004, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 0.91445452089128221, -0.30000000000000004, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.0360412952290587, -0.30000000000000004, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.1530473919778639, -0.30000000000000004, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.2677758800420666, -0.30000000000000004, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.30000000000000004, nu=0.59999999999999998.
+template <typename Tp>
+void test067()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data067)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data067[i].k), Tp(data067[i].nu),
+ Tp(data067[i].phi));
+ const Tp f0 = data067[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.30000000000000004, nu=0.69999999999999996.
+testcase_ellint_3<double> data068[] = {
+ { -0.0000000000000000, -0.30000000000000004, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17339370613812227, -0.30000000000000004, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.34042975138455933, -0.30000000000000004, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.49676568368075985, -0.30000000000000004, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.64080774055753720, -0.30000000000000004, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.77318507779667278, -0.30000000000000004, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 0.89579782346548631, -0.30000000000000004, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 1.0110573286052202, -0.30000000000000004, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.1214710972949633, -0.30000000000000004, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.2294913236274980, -0.30000000000000004, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.30000000000000004, nu=0.69999999999999996.
+template <typename Tp>
+void test068()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data068)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data068[i].k), Tp(data068[i].nu),
+ Tp(data068[i].phi));
+ const Tp f0 = data068[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.30000000000000004, nu=0.80000000000000004.
+testcase_ellint_3<double> data069[] = {
+ { -0.0000000000000000, -0.30000000000000004, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17322209907520361, -0.30000000000000004, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.33917623046949996, -0.30000000000000004, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.49307204894329176, -0.30000000000000004, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.63337802830291723, -0.30000000000000004, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.76104540997689407, -0.30000000000000004, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 0.87832009635450736, -0.30000000000000004, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 0.98787879723171790, -0.30000000000000004, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.0924036340069336, -0.30000000000000004, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.1944567571590046, -0.30000000000000004, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.30000000000000004, nu=0.80000000000000004.
+template <typename Tp>
+void test069()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data069)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data069[i].k), Tp(data069[i].nu),
+ Tp(data069[i].phi));
+ const Tp f0 = data069[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.30000000000000004, nu=0.90000000000000002.
+testcase_ellint_3<double> data070[] = {
+ { -0.0000000000000000, -0.30000000000000004, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17305109924485948, -0.30000000000000004, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.33793890239556984, -0.30000000000000004, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.48947218005089738, -0.30000000000000004, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.62623332340775151, -0.30000000000000004, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.74951596581511148, -0.30000000000000004, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.86189886597756005, -0.30000000000000004, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 0.96629451153092005, -0.30000000000000004, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.0655269133492680, -0.30000000000000004, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.1622376896064912, -0.30000000000000004, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.30000000000000004, nu=0.90000000000000002.
+template <typename Tp>
+void test070()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data070)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data070[i].k), Tp(data070[i].nu),
+ Tp(data070[i].phi));
+ const Tp f0 = data070[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.19999999999999996, nu=0.0000000000000000.
+testcase_ellint_3<double> data071[] = {
+ { -0.0000000000000000, -0.19999999999999996, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17456817290292811, -0.19999999999999996, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.34934315932086801, -0.19999999999999996, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.52450880529443988, -0.19999999999999996, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.70020491009844910, -0.19999999999999996, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.87651006649967955, -0.19999999999999996, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.0534305870298994, -0.19999999999999996, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.2308975521670784, -0.19999999999999996, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.4087733584990738, -0.19999999999999996, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 1.5868678474541664, -0.19999999999999996, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.19999999999999996, nu=0.0000000000000000.
+template <typename Tp>
+void test071()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data071)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data071[i].k), Tp(data071[i].nu),
+ Tp(data071[i].phi));
+ const Tp f0 = data071[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.19999999999999996, nu=0.10000000000000001.
+testcase_ellint_3<double> data072[] = {
+ { -0.0000000000000000, -0.19999999999999996, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17439228502691750, -0.19999999999999996, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.34796731137565740, -0.19999999999999996, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.52003370294544848, -0.19999999999999996, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.69012222258631495, -0.19999999999999996, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.85803491465566772, -0.19999999999999996, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.0238463961099364, -0.19999999999999996, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.1878691059202153, -0.19999999999999996, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.3505985031831940, -0.19999999999999996, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 1.5126513474261092, -0.19999999999999996, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.19999999999999996, nu=0.10000000000000001.
+template <typename Tp>
+void test072()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data072)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data072[i].k), Tp(data072[i].nu),
+ Tp(data072[i].phi));
+ const Tp f0 = data072[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.19999999999999996, nu=0.20000000000000001.
+testcase_ellint_3<double> data073[] = {
+ { -0.0000000000000000, -0.19999999999999996, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17421703179583750, -0.19999999999999996, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.34661057411998791, -0.19999999999999996, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.51569006052647393, -0.19999999999999996, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.68052412821107278, -0.19999999999999996, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.84081341263313825, -0.19999999999999996, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 0.99683359988842890, -0.19999999999999996, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.1493086715118852, -0.19999999999999996, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.2992699693957541, -0.19999999999999996, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 1.4479323932249568, -0.19999999999999996, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.19999999999999996, nu=0.20000000000000001.
+template <typename Tp>
+void test073()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data073)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data073[i].k), Tp(data073[i].nu),
+ Tp(data073[i].phi));
+ const Tp f0 = data073[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.19999999999999996, nu=0.29999999999999999.
+testcase_ellint_3<double> data074[] = {
+ { -0.0000000000000000, -0.19999999999999996, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17404240913577707, -0.19999999999999996, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.34527248032587193, -0.19999999999999996, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.51147118981668416, -0.19999999999999996, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.67137107867777635, -0.19999999999999996, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.82470418188668893, -0.19999999999999996, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 0.97202873223594299, -0.19999999999999996, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.1144773569375266, -0.19999999999999996, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.2535292433701000, -0.19999999999999996, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.3908453514752481, -0.19999999999999996, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.19999999999999996, nu=0.29999999999999999.
+template <typename Tp>
+void test074()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data074)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data074[i].k), Tp(data074[i].nu),
+ Tp(data074[i].phi));
+ const Tp f0 = data074[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.19999999999999996, nu=0.40000000000000002.
+testcase_ellint_3<double> data075[] = {
+ { -0.0000000000000000, -0.19999999999999996, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17386841301066677, -0.19999999999999996, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34395257914113253, -0.19999999999999996, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.50737088376869466, -0.19999999999999996, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.66262801717277664, -0.19999999999999996, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.80958766645079094, -0.19999999999999996, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 0.94913754236162040, -0.19999999999999996, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.0827985514223000, -0.19999999999999996, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.2124212429050478, -0.19999999999999996, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.3400002519661010, -0.19999999999999996, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.19999999999999996, nu=0.40000000000000002.
+template <typename Tp>
+void test075()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data075)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data075[i].k), Tp(data075[i].nu),
+ Tp(data075[i].phi));
+ const Tp f0 = data075[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.19999999999999996, nu=0.50000000000000000.
+testcase_ellint_3<double> data076[] = {
+ { -0.0000000000000000, -0.19999999999999996, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17369503942181802, -0.19999999999999996, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34265043534362660, -0.19999999999999996, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.50338337208655415, -0.19999999999999996, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.65426373297163642, -0.19999999999999996, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.79536193036145808, -0.19999999999999996, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 0.92791875910061605, -0.19999999999999996, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.0538145052725829, -0.19999999999999996, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.1752060022875899, -0.19999999999999996, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.2943374404397376, -0.19999999999999996, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.19999999999999996, nu=0.50000000000000000.
+template <typename Tp>
+void test076()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data076)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data076[i].k), Tp(data076[i].nu),
+ Tp(data076[i].phi));
+ const Tp f0 = data076[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.19999999999999996, nu=0.59999999999999998.
+testcase_ellint_3<double> data077[] = {
+ { -0.0000000000000000, -0.19999999999999996, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17352228440746928, -0.19999999999999996, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34136562863713626, -0.19999999999999996, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.49950328177638481, -0.19999999999999996, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.64625032705690832, -0.19999999999999996, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.78193941198403094, -0.19999999999999996, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 0.90817230934317128, -0.19999999999999996, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.0271563751276462, -0.19999999999999996, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.1412999379040518, -0.19999999999999996, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.2530330675914561, -0.19999999999999996, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.19999999999999996, nu=0.59999999999999998.
+template <typename Tp>
+void test077()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data077)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data077[i].k), Tp(data077[i].nu),
+ Tp(data077[i].phi));
+ const Tp f0 = data077[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.19999999999999996, nu=0.69999999999999996.
+testcase_ellint_3<double> data078[] = {
+ { -0.0000000000000000, -0.19999999999999996, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17335014404233898, -0.19999999999999996, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.34009775298617811, -0.19999999999999996, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.49572560201923810, -0.19999999999999996, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.63856276669886525, -0.19999999999999996, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.76924438644867565, -0.19999999999999996, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 0.88973060843856466, -0.19999999999999996, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 1.0025230471636377, -0.19999999999999996, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.1102356376093103, -0.19999999999999996, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.2154356555075867, -0.19999999999999996, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.19999999999999996, nu=0.69999999999999996.
+template <typename Tp>
+void test078()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data078)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data078[i].k), Tp(data078[i].nu),
+ Tp(data078[i].phi));
+ const Tp f0 = data078[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.19999999999999996, nu=0.80000000000000004.
+testcase_ellint_3<double> data079[] = {
+ { -0.0000000000000000, -0.19999999999999996, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17317861443718541, -0.19999999999999996, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.33884641598718701, -0.19999999999999996, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.49204565281259494, -0.19999999999999996, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.63117851188220353, -0.19999999999999996, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.75721095949544170, -0.19999999999999996, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 0.87245201443919118, -0.19999999999999996, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 0.97966584238831089, -0.19999999999999996, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.0816336325174360, -0.19999999999999996, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.1810223448909913, -0.19999999999999996, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.19999999999999996, nu=0.80000000000000004.
+template <typename Tp>
+void test079()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data079)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data079[i].k), Tp(data079[i].nu),
+ Tp(data079[i].phi));
+ const Tp f0 = data079[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.19999999999999996, nu=0.90000000000000002.
+testcase_ellint_3<double> data080[] = {
+ { -0.0000000000000000, -0.19999999999999996, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17300769173837280, -0.19999999999999996, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.33761123827372508, -0.19999999999999996, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.48845905690769426, -0.19999999999999996, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.62407720017324986, -0.19999999999999996, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.74578146525124289, -0.19999999999999996, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.85621583540073076, -0.19999999999999996, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 0.95837725988001199, -0.19999999999999996, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.0551821412633928, -0.19999999999999996, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.1493679916141863, -0.19999999999999996, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.19999999999999996, nu=0.90000000000000002.
+template <typename Tp>
+void test080()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data080)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data080[i].k), Tp(data080[i].nu),
+ Tp(data080[i].phi));
+ const Tp f0 = data080[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.099999999999999978, nu=0.0000000000000000.
+testcase_ellint_3<double> data081[] = {
+ { -0.0000000000000000, -0.099999999999999978, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17454173353063665, -0.099999999999999978, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.34913506721468085, -0.099999999999999978, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.52382550016538953, -0.099999999999999978, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.69864700854177031, -0.099999999999999978, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.87361792586964870, -0.099999999999999978, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.0487386319621685, -0.099999999999999978, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.2239913752078757, -0.099999999999999978, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.3993423113684049, -0.099999999999999978, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 1.5747455615173562, -0.099999999999999978, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.099999999999999978, nu=0.0000000000000000.
+template <typename Tp>
+void test081()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data081)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data081[i].k), Tp(data081[i].nu),
+ Tp(data081[i].phi));
+ const Tp f0 = data081[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.099999999999999978, nu=0.10000000000000001.
+testcase_ellint_3<double> data082[] = {
+ { -0.0000000000000000, -0.099999999999999978, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17436589347616618, -0.099999999999999978, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.34776067871237354, -0.099999999999999978, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.51936064354727807, -0.099999999999999978, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.68860303749364360, -0.099999999999999978, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.85524561882332051, -0.099999999999999978, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.0193708301908337, -0.099999999999999978, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.1813474067123044, -0.099999999999999978, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.3417670770424983, -0.099999999999999978, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 1.5013711111199950, -0.099999999999999978, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.099999999999999978, nu=0.10000000000000001.
+template <typename Tp>
+void test082()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data082)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data082[i].k), Tp(data082[i].nu),
+ Tp(data082[i].phi));
+ const Tp f0 = data082[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.099999999999999978, nu=0.20000000000000001.
+testcase_ellint_3<double> data083[] = {
+ { -0.0000000000000000, -0.099999999999999978, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17419068786141345, -0.099999999999999978, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.34640537686230127, -0.099999999999999978, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.51502689171753957, -0.099999999999999978, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.67904147863672726, -0.099999999999999978, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.83811885126105179, -0.099999999999999978, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 0.99255278555742810, -0.099999999999999978, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.1431260546194930, -0.099999999999999978, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.2909589656532101, -0.099999999999999978, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 1.4373749386463430, -0.099999999999999978, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.099999999999999978, nu=0.20000000000000001.
+template <typename Tp>
+void test083()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data083)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data083[i].k), Tp(data083[i].nu),
+ Tp(data083[i].phi));
+ const Tp f0 = data083[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.099999999999999978, nu=0.29999999999999999.
+testcase_ellint_3<double> data084[] = {
+ { -0.0000000000000000, -0.099999999999999978, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17401611261390110, -0.099999999999999978, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.34506869507511767, -0.099999999999999978, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.51081757604259870, -0.099999999999999978, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.66992297597712303, -0.099999999999999978, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.82209722856174228, -0.099999999999999978, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 0.96792430487669612, -0.099999999999999978, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.1085964108954092, -0.099999999999999978, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.2456748370836999, -0.099999999999999978, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.3809159606704959, -0.099999999999999978, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.099999999999999978, nu=0.29999999999999999.
+template <typename Tp>
+void test084()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data084)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data084[i].k), Tp(data084[i].nu),
+ Tp(data084[i].phi));
+ const Tp f0 = data084[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.099999999999999978, nu=0.40000000000000002.
+testcase_ellint_3<double> data085[] = {
+ { -0.0000000000000000, -0.099999999999999978, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17384216369897937, -0.099999999999999978, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34375018311376782, -0.099999999999999978, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.50672650758380455, -0.099999999999999978, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.66121264213337616, -0.099999999999999978, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.80706202005774441, -0.099999999999999978, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 0.94519376138245892, -0.099999999999999978, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.0771880300759584, -0.099999999999999978, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.2049711557188272, -0.099999999999999978, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.3306223265207477, -0.099999999999999978, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.099999999999999978, nu=0.40000000000000002.
+template <typename Tp>
+void test085()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data085)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data085[i].k), Tp(data085[i].nu),
+ Tp(data085[i].phi));
+ const Tp f0 = data085[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.099999999999999978, nu=0.50000000000000000.
+testcase_ellint_3<double> data086[] = {
+ { -0.0000000000000000, -0.099999999999999978, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17366883711936554, -0.099999999999999978, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34244940634881876, -0.099999999999999978, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.50274793281634378, -0.099999999999999978, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.65287941633275093, -0.099999999999999978, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.79291198790315398, -0.099999999999999978, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 0.92412201537880345, -0.099999999999999978, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.0484480076799370, -0.099999999999999978, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.1681168130475206, -0.099999999999999978, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.2854480708580160, -0.099999999999999978, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.099999999999999978, nu=0.50000000000000000.
+template <typename Tp>
+void test086()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data086)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data086[i].k), Tp(data086[i].nu),
+ Tp(data086[i].phi));
+ const Tp f0 = data086[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.099999999999999978, nu=0.59999999999999998.
+testcase_ellint_3<double> data087[] = {
+ { -0.0000000000000000, -0.099999999999999978, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17349612891469018, -0.099999999999999978, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34116594505539438, -0.099999999999999978, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.49887649430466685, -0.099999999999999978, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.64489553282165157, -0.099999999999999978, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.77956016553782437, -0.099999999999999978, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 0.90451074530096309, -0.099999999999999978, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.0220113666961632, -0.099999999999999978, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.1345351441065563, -0.099999999999999978, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.2445798942989255, -0.099999999999999978, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.099999999999999978, nu=0.59999999999999998.
+template <typename Tp>
+void test087()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data087)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data087[i].k), Tp(data087[i].nu),
+ Tp(data087[i].phi));
+ const Tp f0 = data087[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.099999999999999978, nu=0.69999999999999996.
+testcase_ellint_3<double> data088[] = {
+ { -0.0000000000000000, -0.099999999999999978, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17332403516105052, -0.099999999999999978, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.33989939374896877, -0.099999999999999978, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.49510719568614081, -0.099999999999999978, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.63723607776354974, -0.099999999999999978, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.76693133887935327, -0.099999999999999978, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 0.88619382078823827, -0.099999999999999978, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 0.99758012018676490, -0.099999999999999978, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.1037642270814410, -0.099999999999999978, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.2073745911083187, -0.099999999999999978, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.099999999999999978, nu=0.69999999999999996.
+template <typename Tp>
+void test088()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data088)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data088[i].k), Tp(data088[i].nu),
+ Tp(data088[i].phi));
+ const Tp f0 = data088[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.099999999999999978, nu=0.80000000000000004.
+testcase_ellint_3<double> data089[] = {
+ { -0.0000000000000000, -0.099999999999999978, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17315255197057020, -0.099999999999999978, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.33864936055747985, -0.099999999999999978, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.49143537041117619, -0.099999999999999978, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.62987861760047492, -0.099999999999999978, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.75496005490917517, -0.099999999999999978, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 0.86903081862701903, -0.099999999999999978, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 0.97490814820725591, -0.099999999999999978, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.0754290107171083, -0.099999999999999978, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.1733158866987732, -0.099999999999999978, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.099999999999999978, nu=0.80000000000000004.
+template <typename Tp>
+void test089()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data089)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data089[i].k), Tp(data089[i].nu),
+ Tp(data089[i].phi));
+ const Tp f0 = data089[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=-0.099999999999999978, nu=0.90000000000000002.
+testcase_ellint_3<double> data090[] = {
+ { -0.0000000000000000, -0.099999999999999978, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17298167549096569, -0.099999999999999978, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.33741546662741584, -0.099999999999999978, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.48785665376856879, -0.099999999999999978, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.62280288554518959, -0.099999999999999978, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.74358903115455199, -0.099999999999999978, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.85290207679298358, -0.099999999999999978, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 0.95379006645397379, -0.099999999999999978, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.0492213119872327, -0.099999999999999978, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.1419839485283374, -0.099999999999999978, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=-0.099999999999999978, nu=0.90000000000000002.
+template <typename Tp>
+void test090()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data090)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data090[i].k), Tp(data090[i].nu),
+ Tp(data090[i].phi));
+ const Tp f0 = data090[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.0000000000000000, nu=0.0000000000000000.
+testcase_ellint_3<double> data091[] = {
+ { -0.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17453292519943295, 0.0000000000000000, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.34906585039886584, 0.0000000000000000, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.52359877559829882, 0.0000000000000000, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.69813170079773179, 0.0000000000000000, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.87266462599716477, 0.0000000000000000, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.0471975511965976, 0.0000000000000000, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.2217304763960304, 0.0000000000000000, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.3962634015954631, 0.0000000000000000, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 1.5707963267948966, 0.0000000000000000, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.0000000000000000, nu=0.0000000000000000.
+template <typename Tp>
+void test091()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data091)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data091[i].k), Tp(data091[i].nu),
+ Tp(data091[i].phi));
+ const Tp f0 = data091[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.0000000000000000, nu=0.10000000000000001.
+testcase_ellint_3<double> data092[] = {
+ { -0.0000000000000000, 0.0000000000000000, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17435710107516608, 0.0000000000000000, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.34769194715329604, 0.0000000000000000, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.51913731575866118, 0.0000000000000000, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.68810051897078461, 0.0000000000000000, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.85432615661706823, 0.0000000000000000, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.0179006647340796, 0.0000000000000000, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.1792120640746322, 0.0000000000000000, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.3388834245070498, 0.0000000000000000, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 1.4976955329233277, 0.0000000000000000, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.0000000000000000, nu=0.10000000000000001.
+template <typename Tp>
+void test092()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data092)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data092[i].k), Tp(data092[i].nu),
+ Tp(data092[i].phi));
+ const Tp f0 = data092[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.0000000000000000, nu=0.20000000000000001.
+testcase_ellint_3<double> data093[] = {
+ { -0.0000000000000000, 0.0000000000000000, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17418191132226077, 0.0000000000000000, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.34633712256943405, 0.0000000000000000, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.51480684302043711, 0.0000000000000000, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.67855102942481949, 0.0000000000000000, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.83723056090326253, 0.0000000000000000, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 0.99114645269578183, 0.0000000000000000, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.1411014627915537, 0.0000000000000000, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.2882448138013969, 0.0000000000000000, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 1.4339343023863691, 0.0000000000000000, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.0000000000000000, nu=0.20000000000000001.
+template <typename Tp>
+void test093()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data093)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data093[i].k), Tp(data093[i].nu),
+ Tp(data093[i].phi));
+ const Tp f0 = data093[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.0000000000000000, nu=0.29999999999999999.
+testcase_ellint_3<double> data094[] = {
+ { -0.0000000000000000, 0.0000000000000000, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17400735186871727, 0.0000000000000000, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.34500091027020219, 0.0000000000000000, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.51060069523901541, 0.0000000000000000, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.66944393961375459, 0.0000000000000000, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.82123776744538157, 0.0000000000000000, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 0.96657579245516523, 0.0000000000000000, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.1066703663542414, 0.0000000000000000, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.2431094251944901, 0.0000000000000000, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.3776795151134889, 0.0000000000000000, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.0000000000000000, nu=0.29999999999999999.
+template <typename Tp>
+void test094()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data094)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data094[i].k), Tp(data094[i].nu),
+ Tp(data094[i].phi));
+ const Tp f0 = data094[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.0000000000000000, nu=0.40000000000000002.
+testcase_ellint_3<double> data095[] = {
+ { -0.0000000000000000, 0.0000000000000000, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17383341868035865, 0.0000000000000000, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34368286022299821, 0.0000000000000000, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.50651268947499406, 0.0000000000000000, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.66074441806097550, 0.0000000000000000, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.80622931670113485, 0.0000000000000000, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 0.94389791565435233, 0.0000000000000000, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.0753503387899728, 0.0000000000000000, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.2025374759127518, 0.0000000000000000, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.3275651989026322, 0.0000000000000000, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.0000000000000000, nu=0.40000000000000002.
+template <typename Tp>
+void test095()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data095)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data095[i].k), Tp(data095[i].nu),
+ Tp(data095[i].phi));
+ const Tp f0 = data095[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.0000000000000000, nu=0.50000000000000000.
+testcase_ellint_3<double> data096[] = {
+ { -0.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17366010776037047, 0.0000000000000000, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34238253799539309, 0.0000000000000000, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.50253707775976408, 0.0000000000000000, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.65242145347295766, 0.0000000000000000, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.79210420018698058, 0.0000000000000000, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 0.92287437995632193, 0.0000000000000000, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.0466900550798661, 0.0000000000000000, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.1658007366618623, 0.0000000000000000, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.2825498301618641, 0.0000000000000000, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.0000000000000000, nu=0.50000000000000000.
+template <typename Tp>
+void test096()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data096)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data096[i].k), Tp(data096[i].nu),
+ Tp(data096[i].phi));
+ const Tp f0 = data096[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.0000000000000000, nu=0.59999999999999998.
+testcase_ellint_3<double> data097[] = {
+ { -0.0000000000000000, 0.0000000000000000, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17348741514884702, 0.0000000000000000, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34109952405241289, 0.0000000000000000, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.49866850781226296, 0.0000000000000000, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.64444732407062510, 0.0000000000000000, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.77877564686544720, 0.0000000000000000, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 0.90330743691883497, 0.0000000000000000, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.0203257987604104, 0.0000000000000000, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.1323247918768631, 0.0000000000000000, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.2418235332245127, 0.0000000000000000, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.0000000000000000, nu=0.59999999999999998.
+template <typename Tp>
+void test097()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data097)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data097[i].k), Tp(data097[i].nu),
+ Tp(data097[i].phi));
+ const Tp f0 = data097[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.0000000000000000, nu=0.69999999999999996.
+testcase_ellint_3<double> data098[] = {
+ { -0.0000000000000000, 0.0000000000000000, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17331533692234477, 0.0000000000000000, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.33983341309265941, 0.0000000000000000, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.49490198805931990, 0.0000000000000000, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.63679715525145308, 0.0000000000000000, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.76616861049481944, 0.0000000000000000, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 0.88503143209004220, 0.0000000000000000, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 0.99596060249112173, 0.0000000000000000, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.1016495050260424, 0.0000000000000000, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.2047457872617382, 0.0000000000000000, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.0000000000000000, nu=0.69999999999999996.
+template <typename Tp>
+void test098()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data098)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data098[i].k), Tp(data098[i].nu),
+ Tp(data098[i].phi));
+ const Tp f0 = data098[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.0000000000000000, nu=0.80000000000000004.
+testcase_ellint_3<double> data099[] = {
+ { -0.0000000000000000, 0.0000000000000000, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17314386919344213, 0.0000000000000000, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.33858381342073240, 0.0000000000000000, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.49123285640844738, 0.0000000000000000, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.62944854858904520, 0.0000000000000000, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.75421778305499343, 0.0000000000000000, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 0.86790634112156639, 0.0000000000000000, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 0.97334918087427558, 0.0000000000000000, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.0734012615283985, 0.0000000000000000, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.1708024551734544, 0.0000000000000000, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.0000000000000000, nu=0.80000000000000004.
+template <typename Tp>
+void test099()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data099)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data099[i].k), Tp(data099[i].nu),
+ Tp(data099[i].phi));
+ const Tp f0 = data099[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.0000000000000000, nu=0.90000000000000002.
+testcase_ellint_3<double> data100[] = {
+ { -0.0000000000000000, 0.0000000000000000, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17297300811030600, 0.0000000000000000, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.33735034635360817, 0.0000000000000000, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.48765675230233141, 0.0000000000000000, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.62238126886123568, 0.0000000000000000, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.74286600807269243, 0.0000000000000000, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.85181283909264971, 0.0000000000000000, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 0.95228683995371122, 0.0000000000000000, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.0472730487412552, 0.0000000000000000, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.1395754288497419, 0.0000000000000000, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.0000000000000000, nu=0.90000000000000002.
+template <typename Tp>
+void test100()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data100)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data100[i].k), Tp(data100[i].nu),
+ Tp(data100[i].phi));
+ const Tp f0 = data100[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.10000000000000009, nu=0.0000000000000000.
+testcase_ellint_3<double> data101[] = {
+ { -0.0000000000000000, 0.10000000000000009, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17454173353063665, 0.10000000000000009, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.34913506721468085, 0.10000000000000009, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.52382550016538953, 0.10000000000000009, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.69864700854177031, 0.10000000000000009, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.87361792586964870, 0.10000000000000009, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.0487386319621685, 0.10000000000000009, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.2239913752078757, 0.10000000000000009, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.3993423113684049, 0.10000000000000009, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 1.5747455615173562, 0.10000000000000009, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.10000000000000009, nu=0.0000000000000000.
+template <typename Tp>
+void test101()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data101)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data101[i].k), Tp(data101[i].nu),
+ Tp(data101[i].phi));
+ const Tp f0 = data101[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.10000000000000009, nu=0.10000000000000001.
+testcase_ellint_3<double> data102[] = {
+ { -0.0000000000000000, 0.10000000000000009, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17436589347616618, 0.10000000000000009, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.34776067871237354, 0.10000000000000009, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.51936064354727807, 0.10000000000000009, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.68860303749364360, 0.10000000000000009, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.85524561882332051, 0.10000000000000009, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.0193708301908337, 0.10000000000000009, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.1813474067123044, 0.10000000000000009, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.3417670770424983, 0.10000000000000009, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 1.5013711111199950, 0.10000000000000009, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.10000000000000009, nu=0.10000000000000001.
+template <typename Tp>
+void test102()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data102)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data102[i].k), Tp(data102[i].nu),
+ Tp(data102[i].phi));
+ const Tp f0 = data102[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.10000000000000009, nu=0.20000000000000001.
+testcase_ellint_3<double> data103[] = {
+ { -0.0000000000000000, 0.10000000000000009, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17419068786141345, 0.10000000000000009, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.34640537686230127, 0.10000000000000009, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.51502689171753957, 0.10000000000000009, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.67904147863672726, 0.10000000000000009, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.83811885126105179, 0.10000000000000009, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 0.99255278555742810, 0.10000000000000009, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.1431260546194930, 0.10000000000000009, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.2909589656532101, 0.10000000000000009, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 1.4373749386463430, 0.10000000000000009, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.10000000000000009, nu=0.20000000000000001.
+template <typename Tp>
+void test103()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data103)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data103[i].k), Tp(data103[i].nu),
+ Tp(data103[i].phi));
+ const Tp f0 = data103[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.10000000000000009, nu=0.29999999999999999.
+testcase_ellint_3<double> data104[] = {
+ { -0.0000000000000000, 0.10000000000000009, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17401611261390110, 0.10000000000000009, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.34506869507511767, 0.10000000000000009, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.51081757604259870, 0.10000000000000009, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.66992297597712303, 0.10000000000000009, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.82209722856174228, 0.10000000000000009, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 0.96792430487669612, 0.10000000000000009, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.1085964108954092, 0.10000000000000009, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.2456748370836999, 0.10000000000000009, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.3809159606704959, 0.10000000000000009, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.10000000000000009, nu=0.29999999999999999.
+template <typename Tp>
+void test104()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data104)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data104[i].k), Tp(data104[i].nu),
+ Tp(data104[i].phi));
+ const Tp f0 = data104[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.10000000000000009, nu=0.40000000000000002.
+testcase_ellint_3<double> data105[] = {
+ { -0.0000000000000000, 0.10000000000000009, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17384216369897937, 0.10000000000000009, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34375018311376782, 0.10000000000000009, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.50672650758380455, 0.10000000000000009, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.66121264213337616, 0.10000000000000009, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.80706202005774441, 0.10000000000000009, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 0.94519376138245892, 0.10000000000000009, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.0771880300759584, 0.10000000000000009, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.2049711557188272, 0.10000000000000009, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.3306223265207477, 0.10000000000000009, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.10000000000000009, nu=0.40000000000000002.
+template <typename Tp>
+void test105()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data105)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data105[i].k), Tp(data105[i].nu),
+ Tp(data105[i].phi));
+ const Tp f0 = data105[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.10000000000000009, nu=0.50000000000000000.
+testcase_ellint_3<double> data106[] = {
+ { -0.0000000000000000, 0.10000000000000009, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17366883711936554, 0.10000000000000009, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34244940634881876, 0.10000000000000009, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.50274793281634378, 0.10000000000000009, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.65287941633275093, 0.10000000000000009, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.79291198790315398, 0.10000000000000009, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 0.92412201537880345, 0.10000000000000009, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.0484480076799370, 0.10000000000000009, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.1681168130475206, 0.10000000000000009, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.2854480708580160, 0.10000000000000009, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.10000000000000009, nu=0.50000000000000000.
+template <typename Tp>
+void test106()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data106)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data106[i].k), Tp(data106[i].nu),
+ Tp(data106[i].phi));
+ const Tp f0 = data106[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.10000000000000009, nu=0.59999999999999998.
+testcase_ellint_3<double> data107[] = {
+ { -0.0000000000000000, 0.10000000000000009, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17349612891469018, 0.10000000000000009, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34116594505539438, 0.10000000000000009, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.49887649430466685, 0.10000000000000009, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.64489553282165157, 0.10000000000000009, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.77956016553782437, 0.10000000000000009, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 0.90451074530096309, 0.10000000000000009, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.0220113666961632, 0.10000000000000009, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.1345351441065563, 0.10000000000000009, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.2445798942989255, 0.10000000000000009, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.10000000000000009, nu=0.59999999999999998.
+template <typename Tp>
+void test107()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data107)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data107[i].k), Tp(data107[i].nu),
+ Tp(data107[i].phi));
+ const Tp f0 = data107[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.10000000000000009, nu=0.69999999999999996.
+testcase_ellint_3<double> data108[] = {
+ { -0.0000000000000000, 0.10000000000000009, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17332403516105052, 0.10000000000000009, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.33989939374896877, 0.10000000000000009, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.49510719568614081, 0.10000000000000009, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.63723607776354974, 0.10000000000000009, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.76693133887935327, 0.10000000000000009, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 0.88619382078823827, 0.10000000000000009, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 0.99758012018676490, 0.10000000000000009, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.1037642270814410, 0.10000000000000009, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.2073745911083187, 0.10000000000000009, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.10000000000000009, nu=0.69999999999999996.
+template <typename Tp>
+void test108()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data108)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data108[i].k), Tp(data108[i].nu),
+ Tp(data108[i].phi));
+ const Tp f0 = data108[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.10000000000000009, nu=0.80000000000000004.
+testcase_ellint_3<double> data109[] = {
+ { -0.0000000000000000, 0.10000000000000009, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17315255197057020, 0.10000000000000009, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.33864936055747985, 0.10000000000000009, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.49143537041117619, 0.10000000000000009, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.62987861760047492, 0.10000000000000009, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.75496005490917517, 0.10000000000000009, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 0.86903081862701903, 0.10000000000000009, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 0.97490814820725591, 0.10000000000000009, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.0754290107171083, 0.10000000000000009, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.1733158866987732, 0.10000000000000009, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.10000000000000009, nu=0.80000000000000004.
+template <typename Tp>
+void test109()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data109)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data109[i].k), Tp(data109[i].nu),
+ Tp(data109[i].phi));
+ const Tp f0 = data109[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.10000000000000009, nu=0.90000000000000002.
+testcase_ellint_3<double> data110[] = {
+ { -0.0000000000000000, 0.10000000000000009, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17298167549096569, 0.10000000000000009, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.33741546662741584, 0.10000000000000009, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.48785665376856879, 0.10000000000000009, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.62280288554518959, 0.10000000000000009, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.74358903115455199, 0.10000000000000009, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.85290207679298358, 0.10000000000000009, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 0.95379006645397379, 0.10000000000000009, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.0492213119872327, 0.10000000000000009, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.1419839485283374, 0.10000000000000009, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.10000000000000009, nu=0.90000000000000002.
+template <typename Tp>
+void test110()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data110)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data110[i].k), Tp(data110[i].nu),
+ Tp(data110[i].phi));
+ const Tp f0 = data110[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.19999999999999996, nu=0.0000000000000000.
+testcase_ellint_3<double> data111[] = {
+ { -0.0000000000000000, 0.19999999999999996, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17456817290292811, 0.19999999999999996, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.34934315932086801, 0.19999999999999996, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.52450880529443988, 0.19999999999999996, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.70020491009844910, 0.19999999999999996, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.87651006649967955, 0.19999999999999996, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.0534305870298994, 0.19999999999999996, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.2308975521670784, 0.19999999999999996, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.4087733584990738, 0.19999999999999996, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 1.5868678474541664, 0.19999999999999996, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.19999999999999996, nu=0.0000000000000000.
+template <typename Tp>
+void test111()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data111)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data111[i].k), Tp(data111[i].nu),
+ Tp(data111[i].phi));
+ const Tp f0 = data111[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.19999999999999996, nu=0.10000000000000001.
+testcase_ellint_3<double> data112[] = {
+ { -0.0000000000000000, 0.19999999999999996, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17439228502691750, 0.19999999999999996, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.34796731137565740, 0.19999999999999996, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.52003370294544848, 0.19999999999999996, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.69012222258631495, 0.19999999999999996, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.85803491465566772, 0.19999999999999996, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.0238463961099364, 0.19999999999999996, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.1878691059202153, 0.19999999999999996, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.3505985031831940, 0.19999999999999996, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 1.5126513474261092, 0.19999999999999996, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.19999999999999996, nu=0.10000000000000001.
+template <typename Tp>
+void test112()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data112)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data112[i].k), Tp(data112[i].nu),
+ Tp(data112[i].phi));
+ const Tp f0 = data112[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.19999999999999996, nu=0.20000000000000001.
+testcase_ellint_3<double> data113[] = {
+ { -0.0000000000000000, 0.19999999999999996, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17421703179583750, 0.19999999999999996, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.34661057411998791, 0.19999999999999996, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.51569006052647393, 0.19999999999999996, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.68052412821107278, 0.19999999999999996, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.84081341263313825, 0.19999999999999996, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 0.99683359988842890, 0.19999999999999996, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.1493086715118852, 0.19999999999999996, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.2992699693957541, 0.19999999999999996, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 1.4479323932249568, 0.19999999999999996, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.19999999999999996, nu=0.20000000000000001.
+template <typename Tp>
+void test113()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data113)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data113[i].k), Tp(data113[i].nu),
+ Tp(data113[i].phi));
+ const Tp f0 = data113[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.19999999999999996, nu=0.29999999999999999.
+testcase_ellint_3<double> data114[] = {
+ { -0.0000000000000000, 0.19999999999999996, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17404240913577707, 0.19999999999999996, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.34527248032587193, 0.19999999999999996, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.51147118981668416, 0.19999999999999996, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.67137107867777635, 0.19999999999999996, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.82470418188668893, 0.19999999999999996, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 0.97202873223594299, 0.19999999999999996, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.1144773569375266, 0.19999999999999996, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.2535292433701000, 0.19999999999999996, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.3908453514752481, 0.19999999999999996, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.19999999999999996, nu=0.29999999999999999.
+template <typename Tp>
+void test114()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data114)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data114[i].k), Tp(data114[i].nu),
+ Tp(data114[i].phi));
+ const Tp f0 = data114[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.19999999999999996, nu=0.40000000000000002.
+testcase_ellint_3<double> data115[] = {
+ { -0.0000000000000000, 0.19999999999999996, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17386841301066677, 0.19999999999999996, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34395257914113253, 0.19999999999999996, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.50737088376869466, 0.19999999999999996, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.66262801717277664, 0.19999999999999996, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.80958766645079094, 0.19999999999999996, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 0.94913754236162040, 0.19999999999999996, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.0827985514223000, 0.19999999999999996, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.2124212429050478, 0.19999999999999996, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.3400002519661010, 0.19999999999999996, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.19999999999999996, nu=0.40000000000000002.
+template <typename Tp>
+void test115()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data115)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data115[i].k), Tp(data115[i].nu),
+ Tp(data115[i].phi));
+ const Tp f0 = data115[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.19999999999999996, nu=0.50000000000000000.
+testcase_ellint_3<double> data116[] = {
+ { -0.0000000000000000, 0.19999999999999996, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17369503942181802, 0.19999999999999996, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34265043534362660, 0.19999999999999996, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.50338337208655415, 0.19999999999999996, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.65426373297163642, 0.19999999999999996, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.79536193036145808, 0.19999999999999996, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 0.92791875910061605, 0.19999999999999996, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.0538145052725829, 0.19999999999999996, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.1752060022875899, 0.19999999999999996, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.2943374404397376, 0.19999999999999996, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.19999999999999996, nu=0.50000000000000000.
+template <typename Tp>
+void test116()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data116)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data116[i].k), Tp(data116[i].nu),
+ Tp(data116[i].phi));
+ const Tp f0 = data116[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.19999999999999996, nu=0.59999999999999998.
+testcase_ellint_3<double> data117[] = {
+ { -0.0000000000000000, 0.19999999999999996, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17352228440746928, 0.19999999999999996, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34136562863713626, 0.19999999999999996, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.49950328177638481, 0.19999999999999996, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.64625032705690832, 0.19999999999999996, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.78193941198403094, 0.19999999999999996, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 0.90817230934317128, 0.19999999999999996, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.0271563751276462, 0.19999999999999996, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.1412999379040518, 0.19999999999999996, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.2530330675914561, 0.19999999999999996, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.19999999999999996, nu=0.59999999999999998.
+template <typename Tp>
+void test117()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data117)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data117[i].k), Tp(data117[i].nu),
+ Tp(data117[i].phi));
+ const Tp f0 = data117[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.19999999999999996, nu=0.69999999999999996.
+testcase_ellint_3<double> data118[] = {
+ { -0.0000000000000000, 0.19999999999999996, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17335014404233898, 0.19999999999999996, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.34009775298617811, 0.19999999999999996, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.49572560201923810, 0.19999999999999996, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.63856276669886525, 0.19999999999999996, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.76924438644867565, 0.19999999999999996, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 0.88973060843856466, 0.19999999999999996, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 1.0025230471636377, 0.19999999999999996, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.1102356376093103, 0.19999999999999996, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.2154356555075867, 0.19999999999999996, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.19999999999999996, nu=0.69999999999999996.
+template <typename Tp>
+void test118()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data118)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data118[i].k), Tp(data118[i].nu),
+ Tp(data118[i].phi));
+ const Tp f0 = data118[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.19999999999999996, nu=0.80000000000000004.
+testcase_ellint_3<double> data119[] = {
+ { -0.0000000000000000, 0.19999999999999996, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17317861443718541, 0.19999999999999996, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.33884641598718701, 0.19999999999999996, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.49204565281259494, 0.19999999999999996, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.63117851188220353, 0.19999999999999996, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.75721095949544170, 0.19999999999999996, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 0.87245201443919118, 0.19999999999999996, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 0.97966584238831089, 0.19999999999999996, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.0816336325174360, 0.19999999999999996, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.1810223448909913, 0.19999999999999996, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.19999999999999996, nu=0.80000000000000004.
+template <typename Tp>
+void test119()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data119)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data119[i].k), Tp(data119[i].nu),
+ Tp(data119[i].phi));
+ const Tp f0 = data119[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.19999999999999996, nu=0.90000000000000002.
+testcase_ellint_3<double> data120[] = {
+ { -0.0000000000000000, 0.19999999999999996, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17300769173837280, 0.19999999999999996, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.33761123827372508, 0.19999999999999996, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.48845905690769426, 0.19999999999999996, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.62407720017324986, 0.19999999999999996, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.74578146525124289, 0.19999999999999996, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.85621583540073076, 0.19999999999999996, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 0.95837725988001199, 0.19999999999999996, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.0551821412633928, 0.19999999999999996, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.1493679916141863, 0.19999999999999996, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.19999999999999996, nu=0.90000000000000002.
+template <typename Tp>
+void test120()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data120)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data120[i].k), Tp(data120[i].nu),
+ Tp(data120[i].phi));
+ const Tp f0 = data120[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.30000000000000004, nu=0.0000000000000000.
+testcase_ellint_3<double> data121[] = {
+ { -0.0000000000000000, 0.30000000000000004, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17461228653000102, 0.30000000000000004, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.34969146102798415, 0.30000000000000004, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.52565822873726320, 0.30000000000000004, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.70284226512408532, 0.30000000000000004, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.88144139195111182, 0.30000000000000004, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.0614897067260523, 0.30000000000000004, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.2428416824174218, 0.30000000000000004, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.4251795877015925, 0.30000000000000004, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 1.6080486199305126, 0.30000000000000004, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.30000000000000004, nu=0.0000000000000000.
+template <typename Tp>
+void test121()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data121)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data121[i].k), Tp(data121[i].nu),
+ Tp(data121[i].phi));
+ const Tp f0 = data121[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.30000000000000004, nu=0.10000000000000001.
+testcase_ellint_3<double> data122[] = {
+ { -0.0000000000000000, 0.30000000000000004, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17443631884814378, 0.30000000000000004, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.34831316835124926, 0.30000000000000004, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.52116586276523857, 0.30000000000000004, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.69269385837910036, 0.30000000000000004, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.86279023163070856, 0.30000000000000004, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.0315321461438265, 0.30000000000000004, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.1991449111869024, 0.30000000000000004, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.3659561780923211, 0.30000000000000004, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 1.5323534693557526, 0.30000000000000004, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.30000000000000004, nu=0.10000000000000001.
+template <typename Tp>
+void test122()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data122)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data122[i].k), Tp(data122[i].nu),
+ Tp(data122[i].phi));
+ const Tp f0 = data122[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.30000000000000004, nu=0.20000000000000001.
+testcase_ellint_3<double> data123[] = {
+ { -0.0000000000000000, 0.30000000000000004, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17426098615372090, 0.30000000000000004, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.34695402664689923, 0.30000000000000004, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.51680555567038933, 0.30000000000000004, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.68303375225260210, 0.30000000000000004, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.84540662891295026, 0.30000000000000004, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 1.0041834051646927, 0.30000000000000004, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.1599952702345711, 0.30000000000000004, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.3137179520499163, 0.30000000000000004, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 1.4663658145259875, 0.30000000000000004, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.30000000000000004, nu=0.20000000000000001.
+template <typename Tp>
+void test123()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data123)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data123[i].k), Tp(data123[i].nu),
+ Tp(data123[i].phi));
+ const Tp f0 = data123[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.30000000000000004, nu=0.29999999999999999.
+testcase_ellint_3<double> data124[] = {
+ { -0.0000000000000000, 0.30000000000000004, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17408628437042845, 0.30000000000000004, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.34561356761638401, 0.30000000000000004, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.51257058617875850, 0.30000000000000004, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.67382207124602866, 0.30000000000000004, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.82914751587825131, 0.30000000000000004, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 0.97907434814374950, 0.30000000000000004, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.1246399297351584, 0.30000000000000004, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.2671793970398146, 0.30000000000000004, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.4081767433479089, 0.30000000000000004, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.30000000000000004, nu=0.29999999999999999.
+template <typename Tp>
+void test124()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data124)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data124[i].k), Tp(data124[i].nu),
+ Tp(data124[i].phi));
+ const Tp f0 = data124[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.30000000000000004, nu=0.40000000000000002.
+testcase_ellint_3<double> data125[] = {
+ { -0.0000000000000000, 0.30000000000000004, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17391220945982730, 0.30000000000000004, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34429133937639689, 0.30000000000000004, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.50845471668581632, 0.30000000000000004, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.66502347027873854, 0.30000000000000004, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.81389191978012254, 0.30000000000000004, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 0.95590618002140593, 0.30000000000000004, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.0924915195213121, 0.30000000000000004, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.2253651604038058, 0.30000000000000004, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.3563643538969761, 0.30000000000000004, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.30000000000000004, nu=0.40000000000000002.
+template <typename Tp>
+void test125()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data125)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data125[i].k), Tp(data125[i].nu),
+ Tp(data125[i].phi));
+ const Tp f0 = data125[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.30000000000000004, nu=0.50000000000000000.
+testcase_ellint_3<double> data126[] = {
+ { -0.0000000000000000, 0.30000000000000004, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17373875742088235, 0.30000000000000004, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34298690571124157, 0.30000000000000004, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.50445214859646936, 0.30000000000000004, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.65660648352418516, 0.30000000000000004, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.79953670639287289, 0.30000000000000004, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 0.93443393926588558, 0.30000000000000004, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.0630838369016911, 0.30000000000000004, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.1875197325653026, 0.30000000000000004, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.3098448759814960, 0.30000000000000004, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.30000000000000004, nu=0.50000000000000000.
+template <typename Tp>
+void test126()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data126)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data126[i].k), Tp(data126[i].nu),
+ Tp(data126[i].phi));
+ const Tp f0 = data126[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.30000000000000004, nu=0.59999999999999998.
+testcase_ellint_3<double> data127[] = {
+ { -0.0000000000000000, 0.30000000000000004, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17356592428950826, 0.30000000000000004, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34169984536697379, 0.30000000000000004, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.50055748266498457, 0.30000000000000004, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.64854298527106768, 0.30000000000000004, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.78599329284207431, 0.30000000000000004, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 0.91445452089128221, 0.30000000000000004, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.0360412952290587, 0.30000000000000004, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.1530473919778639, 0.30000000000000004, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.2677758800420666, 0.30000000000000004, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.30000000000000004, nu=0.59999999999999998.
+template <typename Tp>
+void test127()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data127)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data127[i].k), Tp(data127[i].nu),
+ Tp(data127[i].phi));
+ const Tp f0 = data127[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.30000000000000004, nu=0.69999999999999996.
+testcase_ellint_3<double> data128[] = {
+ { -0.0000000000000000, 0.30000000000000004, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17339370613812227, 0.30000000000000004, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.34042975138455933, 0.30000000000000004, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.49676568368075985, 0.30000000000000004, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.64080774055753720, 0.30000000000000004, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.77318507779667278, 0.30000000000000004, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 0.89579782346548631, 0.30000000000000004, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 1.0110573286052202, 0.30000000000000004, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.1214710972949633, 0.30000000000000004, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.2294913236274980, 0.30000000000000004, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.30000000000000004, nu=0.69999999999999996.
+template <typename Tp>
+void test128()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data128)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data128[i].k), Tp(data128[i].nu),
+ Tp(data128[i].phi));
+ const Tp f0 = data128[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.30000000000000004, nu=0.80000000000000004.
+testcase_ellint_3<double> data129[] = {
+ { -0.0000000000000000, 0.30000000000000004, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17322209907520361, 0.30000000000000004, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.33917623046949996, 0.30000000000000004, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.49307204894329176, 0.30000000000000004, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.63337802830291723, 0.30000000000000004, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.76104540997689407, 0.30000000000000004, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 0.87832009635450736, 0.30000000000000004, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 0.98787879723171790, 0.30000000000000004, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.0924036340069336, 0.30000000000000004, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.1944567571590046, 0.30000000000000004, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.30000000000000004, nu=0.80000000000000004.
+template <typename Tp>
+void test129()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data129)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data129[i].k), Tp(data129[i].nu),
+ Tp(data129[i].phi));
+ const Tp f0 = data129[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.30000000000000004, nu=0.90000000000000002.
+testcase_ellint_3<double> data130[] = {
+ { -0.0000000000000000, 0.30000000000000004, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17305109924485948, 0.30000000000000004, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.33793890239556984, 0.30000000000000004, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.48947218005089738, 0.30000000000000004, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.62623332340775151, 0.30000000000000004, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.74951596581511148, 0.30000000000000004, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.86189886597756005, 0.30000000000000004, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 0.96629451153092005, 0.30000000000000004, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.0655269133492680, 0.30000000000000004, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.1622376896064912, 0.30000000000000004, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.30000000000000004, nu=0.90000000000000002.
+template <typename Tp>
+void test130()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data130)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data130[i].k), Tp(data130[i].nu),
+ Tp(data130[i].phi));
+ const Tp f0 = data130[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.39999999999999991, nu=0.0000000000000000.
+testcase_ellint_3<double> data131[] = {
+ { -0.0000000000000000, 0.39999999999999991, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17467414669441531, 0.39999999999999991, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.35018222772483443, 0.39999999999999991, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.52729015917508748, 0.39999999999999991, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.70662374407341255, 0.39999999999999991, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.88859210497602170, 0.39999999999999991, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.0733136290471379, 0.39999999999999991, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.2605612170157061, 0.39999999999999991, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.4497513956433437, 0.39999999999999991, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 1.6399998658645112, 0.39999999999999991, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.39999999999999991, nu=0.0000000000000000.
+template <typename Tp>
+void test131()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data131)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data131[i].k), Tp(data131[i].nu),
+ Tp(data131[i].phi));
+ const Tp f0 = data131[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.39999999999999991, nu=0.10000000000000001.
+testcase_ellint_3<double> data132[] = {
+ { -0.0000000000000000, 0.39999999999999991, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17449806706684673, 0.39999999999999991, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.34880048623856075, 0.39999999999999991, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.52277322065757403, 0.39999999999999991, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.69638072056918376, 0.39999999999999991, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.86968426619831540, 0.39999999999999991, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.0428044206578095, 0.39999999999999991, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.2158651158274378, 0.39999999999999991, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.3889447129893322, 0.39999999999999991, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 1.5620566886683604, 0.39999999999999991, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.39999999999999991, nu=0.10000000000000001.
+template <typename Tp>
+void test132()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data132)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data132[i].k), Tp(data132[i].nu),
+ Tp(data132[i].phi));
+ const Tp f0 = data132[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.39999999999999991, nu=0.20000000000000001.
+testcase_ellint_3<double> data133[] = {
+ { -0.0000000000000000, 0.39999999999999991, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17432262290723399, 0.39999999999999991, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.34743795258968596, 0.39999999999999991, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.51838919472805123, 0.39999999999999991, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.68663134739057918, 0.39999999999999991, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.85206432981833979, 0.39999999999999991, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 1.0149595349004430, 0.39999999999999991, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.1758349405464676, 0.39999999999999991, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.3353337673882635, 0.39999999999999991, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 1.4941414344266770, 0.39999999999999991, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.39999999999999991, nu=0.20000000000000001.
+template <typename Tp>
+void test133()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data133)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data133[i].k), Tp(data133[i].nu),
+ Tp(data133[i].phi));
+ const Tp f0 = data133[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.39999999999999991, nu=0.29999999999999999.
+testcase_ellint_3<double> data134[] = {
+ { -0.0000000000000000, 0.39999999999999991, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17414781013591543, 0.39999999999999991, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.34609415696777285, 0.39999999999999991, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.51413131295862546, 0.39999999999999991, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.67733527622935630, 0.39999999999999991, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.83558675182733266, 0.39999999999999991, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 0.98940140808865906, 0.39999999999999991, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.1396968797728058, 0.39999999999999991, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.2875920037865087, 0.39999999999999991, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.4342789859950078, 0.39999999999999991, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.39999999999999991, nu=0.29999999999999999.
+template <typename Tp>
+void test134()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data134)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data134[i].k), Tp(data134[i].nu),
+ Tp(data134[i].phi));
+ const Tp f0 = data134[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.39999999999999991, nu=0.40000000000000002.
+testcase_ellint_3<double> data135[] = {
+ { -0.0000000000000000, 0.39999999999999991, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17397362471112710, 0.39999999999999991, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34476864603333196, 0.39999999999999991, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.50999329415379357, 0.39999999999999991, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.66845674551396017, 0.39999999999999991, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.82012848346231748, 0.39999999999999991, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 0.96582449258349057, 0.39999999999999991, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.1068473749476286, 0.39999999999999991, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.2447132729159986, 0.39999999999999991, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.3809986210732901, 0.39999999999999991, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.39999999999999991, nu=0.40000000000000002.
+template <typename Tp>
+void test135()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data135)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data135[i].k), Tp(data135[i].nu),
+ Tp(data135[i].phi));
+ const Tp f0 = data135[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.39999999999999991, nu=0.50000000000000000.
+testcase_ellint_3<double> data136[] = {
+ { -0.0000000000000000, 0.39999999999999991, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17380006262854139, 0.39999999999999991, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34346098216756610, 0.39999999999999991, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.50596929935059420, 0.39999999999999991, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.65996392089131262, 0.39999999999999991, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.80558463511364786, 0.39999999999999991, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 0.94397834522857704, 0.39999999999999991, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.0768075114108115, 0.39999999999999991, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.2059184624251329, 0.39999999999999991, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.3331797176377398, 0.39999999999999991, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.39999999999999991, nu=0.50000000000000000.
+template <typename Tp>
+void test136()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data136)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data136[i].k), Tp(data136[i].nu),
+ Tp(data136[i].phi));
+ const Tp f0 = data136[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.39999999999999991, nu=0.59999999999999998.
+testcase_ellint_3<double> data137[] = {
+ { -0.0000000000000000, 0.39999999999999991, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17362711992081248, 0.39999999999999991, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34217074276403953, 0.39999999999999991, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.50205389185761617, 0.39999999999999991, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.65182834920372745, 0.39999999999999991, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.79186512820565136, 0.39999999999999991, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 0.92365535916287134, 0.39999999999999991, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.0491915663957907, 0.39999999999999991, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.1705934291745104, 0.39999999999999991, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.2899514672527024, 0.39999999999999991, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.39999999999999991, nu=0.59999999999999998.
+template <typename Tp>
+void test137()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data137)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data137[i].k), Tp(data137[i].nu),
+ Tp(data137[i].phi));
+ const Tp f0 = data137[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.39999999999999991, nu=0.69999999999999996.
+testcase_ellint_3<double> data138[] = {
+ { -0.0000000000000000, 0.39999999999999991, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17345479265712871, 0.39999999999999991, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.34089751955950354, 0.39999999999999991, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.49824200167361343, 0.39999999999999991, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.64402450341199413, 0.39999999999999991, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.77889207804122873, 0.39999999999999991, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 0.90468169720957992, 0.39999999999999991, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 1.0236847823692916, 0.39999999999999991, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.1382465247425164, 0.39999999999999991, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.2506255923253344, 0.39999999999999991, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.39999999999999991, nu=0.69999999999999996.
+template <typename Tp>
+void test138()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data138)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data138[i].k), Tp(data138[i].nu),
+ Tp(data138[i].phi));
+ const Tp f0 = data138[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.39999999999999991, nu=0.80000000000000004.
+testcase_ellint_3<double> data139[] = {
+ { -0.0000000000000000, 0.39999999999999991, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17328307694277156, 0.39999999999999991, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.33964091800132007, 0.39999999999999991, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.49452889372467451, 0.39999999999999991, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.63652940095937327, 0.39999999999999991, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.76659772511159097, 0.39999999999999991, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 0.88691047977338111, 0.39999999999999991, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 1.0000273200611640, 0.39999999999999991, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.1084787902188007, 0.39999999999999991, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.2146499565727209, 0.39999999999999991, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.39999999999999991, nu=0.80000000000000004.
+template <typename Tp>
+void test139()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data139)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data139[i].k), Tp(data139[i].nu),
+ Tp(data139[i].phi));
+ const Tp f0 = data139[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.39999999999999991, nu=0.90000000000000002.
+testcase_ellint_3<double> data140[] = {
+ { -0.0000000000000000, 0.39999999999999991, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17311196891868130, 0.39999999999999991, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.33840055664911906, 0.39999999999999991, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.49091013944075340, 0.39999999999999991, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.62932228186809591, 0.39999999999999991, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.75492278323019801, 0.39999999999999991, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.87021659043854294, 0.39999999999999991, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 0.97800245228239246, 0.39999999999999991, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.0809625773173694, 0.39999999999999991, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.1815758115929846, 0.39999999999999991, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.39999999999999991, nu=0.90000000000000002.
+template <typename Tp>
+void test140()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data140)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data140[i].k), Tp(data140[i].nu),
+ Tp(data140[i].phi));
+ const Tp f0 = data140[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.50000000000000000, nu=0.0000000000000000.
+testcase_ellint_3<double> data141[] = {
+ { -0.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17475385514035785, 0.50000000000000000, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.35081868470101585, 0.50000000000000000, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.52942862705190585, 0.50000000000000000, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.71164727562630326, 0.50000000000000000, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.89824523594227768, 0.50000000000000000, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.0895506700518851, 0.50000000000000000, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.2853005857432933, 0.50000000000000000, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.4845545520549484, 0.50000000000000000, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 1.6857503548125963, 0.50000000000000000, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.50000000000000000, nu=0.0000000000000000.
+template <typename Tp>
+void test141()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data141)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data141[i].k), Tp(data141[i].nu),
+ Tp(data141[i].phi));
+ const Tp f0 = data141[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.50000000000000000, nu=0.10000000000000001.
+testcase_ellint_3<double> data142[] = {
+ { -0.0000000000000000, 0.50000000000000000, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17457763120814676, 0.50000000000000000, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.34943246340849154, 0.50000000000000000, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.52487937869610801, 0.50000000000000000, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.70127785096388395, 0.50000000000000000, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.87898815988624479, 0.50000000000000000, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.0582764576094172, 0.50000000000000000, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.2391936844060207, 0.50000000000000000, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.4214793542995841, 0.50000000000000000, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 1.6045524936084892, 0.50000000000000000, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.50000000000000000, nu=0.10000000000000001.
+template <typename Tp>
+void test142()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data142)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data142[i].k), Tp(data142[i].nu),
+ Tp(data142[i].phi));
+ const Tp f0 = data142[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.50000000000000000, nu=0.20000000000000001.
+testcase_ellint_3<double> data143[] = {
+ { -0.0000000000000000, 0.50000000000000000, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17440204336345433, 0.50000000000000000, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.34806552388338824, 0.50000000000000000, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.52046416757129821, 0.50000000000000000, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.69140924550993876, 0.50000000000000000, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.86104678636125520, 0.50000000000000000, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 1.0297439459053981, 0.50000000000000000, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.1979214112912036, 0.50000000000000000, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.3659033858648930, 0.50000000000000000, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 1.5338490483665983, 0.50000000000000000, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.50000000000000000, nu=0.20000000000000001.
+template <typename Tp>
+void test143()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data143)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data143[i].k), Tp(data143[i].nu),
+ Tp(data143[i].phi));
+ const Tp f0 = data143[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.50000000000000000, nu=0.29999999999999999.
+testcase_ellint_3<double> data144[] = {
+ { -0.0000000000000000, 0.50000000000000000, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17422708752228896, 0.50000000000000000, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.34671739434855858, 0.50000000000000000, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.51617616305641889, 0.50000000000000000, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.68200047612545178, 0.50000000000000000, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.84427217869498372, 0.50000000000000000, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 1.0035637821389782, 0.50000000000000000, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.1606800483933113, 0.50000000000000000, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.3164407134643459, 0.50000000000000000, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.4715681939859637, 0.50000000000000000, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.50000000000000000, nu=0.29999999999999999.
+template <typename Tp>
+void test144()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data144)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data144[i].k), Tp(data144[i].nu),
+ Tp(data144[i].phi));
+ const Tp f0 = data144[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.50000000000000000, nu=0.40000000000000002.
+testcase_ellint_3<double> data145[] = {
+ { -0.0000000000000000, 0.50000000000000000, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17405275963859917, 0.50000000000000000, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34538761957029329, 0.50000000000000000, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.51200902646603919, 0.50000000000000000, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.67301522212868792, 0.50000000000000000, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.82853844466313320, 0.50000000000000000, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 0.97942097862681488, 0.50000000000000000, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.1268429801220616, 0.50000000000000000, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.2720406704533922, 0.50000000000000000, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.4161679518465340, 0.50000000000000000, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.50000000000000000, nu=0.40000000000000002.
+template <typename Tp>
+void test145()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data145)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data145[i].k), Tp(data145[i].nu),
+ Tp(data145[i].phi));
+ const Tp f0 = data145[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.50000000000000000, nu=0.50000000000000000.
+testcase_ellint_3<double> data146[] = {
+ { -0.0000000000000000, 0.50000000000000000, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17387905570381157, 0.50000000000000000, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34407576010465207, 0.50000000000000000, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.50795686560160835, 0.50000000000000000, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.66442115453330175, 0.50000000000000000, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.81373829119355345, 0.50000000000000000, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 0.95705743313235825, 0.50000000000000000, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.0959131991362556, 0.50000000000000000, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.2318900529754597, 0.50000000000000000, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.3664739530045971, 0.50000000000000000, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.50000000000000000, nu=0.50000000000000000.
+template <typename Tp>
+void test146()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data146)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data146[i].k), Tp(data146[i].nu),
+ Tp(data146[i].phi));
+ const Tp f0 = data146[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.50000000000000000, nu=0.59999999999999998.
+testcase_ellint_3<double> data147[] = {
+ { -0.0000000000000000, 0.50000000000000000, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17370597174637581, 0.50000000000000000, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34278139158591414, 0.50000000000000000, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.50401419439302719, 0.50000000000000000, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.65618938076167221, 0.50000000000000000, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.79977959248855424, 0.50000000000000000, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 0.93625925190753545, 0.50000000000000000, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.0674905658379710, 0.50000000000000000, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.1953481298023048, 0.50000000000000000, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.3215740290190876, 0.50000000000000000, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.50000000000000000, nu=0.59999999999999998.
+template <typename Tp>
+void test147()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data147)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data147[i].k), Tp(data147[i].nu),
+ Tp(data147[i].phi));
+ const Tp f0 = data147[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.50000000000000000, nu=0.69999999999999996.
+testcase_ellint_3<double> data148[] = {
+ { -0.0000000000000000, 0.50000000000000000, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17353350383131641, 0.50000000000000000, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.34150410405436771, 0.50000000000000000, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.50017589696443487, 0.50000000000000000, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.64829398188419962, 0.50000000000000000, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.78658270782402073, 0.50000000000000000, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 0.91684738336675053, 0.50000000000000000, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 1.0412486789555937, 0.50000000000000000, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.1619021847612001, 0.50000000000000000, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.2807475181182502, 0.50000000000000000, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.50000000000000000, nu=0.69999999999999996.
+template <typename Tp>
+void test148()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data148)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data148[i].k), Tp(data148[i].nu),
+ Tp(data148[i].phi));
+ const Tp f0 = data148[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.50000000000000000, nu=0.80000000000000004.
+testcase_ellint_3<double> data149[] = {
+ { -0.0000000000000000, 0.50000000000000000, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17336164805979126, 0.50000000000000000, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.34024350132086773, 0.50000000000000000, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.49643719555734084, 0.50000000000000000, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.64071162456976150, 0.50000000000000000, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.77407836177211908, 0.50000000000000000, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 0.89867058251905652, 0.50000000000000000, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 1.0169181822134912, 0.50000000000000000, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.1311363312779448, 0.50000000000000000, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.2434165408189539, 0.50000000000000000, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.50000000000000000, nu=0.80000000000000004.
+template <typename Tp>
+void test149()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data149)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data149[i].k), Tp(data149[i].nu),
+ Tp(data149[i].phi));
+ const Tp f0 = data149[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.50000000000000000, nu=0.90000000000000002.
+testcase_ellint_3<double> data150[] = {
+ { -0.0000000000000000, 0.50000000000000000, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17319040056865681, 0.50000000000000000, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.33899920036578557, 0.50000000000000000, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.49279362182695186, 0.50000000000000000, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.63342123379746151, 0.50000000000000000, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.76220595179550321, 0.50000000000000000, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.88160004743532294, 0.50000000000000000, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 0.99427448642310134, 0.50000000000000000, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.1027091512470093, 0.50000000000000000, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.2091116095504744, 0.50000000000000000, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.50000000000000000, nu=0.90000000000000002.
+template <typename Tp>
+void test150()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data150)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data150[i].k), Tp(data150[i].nu),
+ Tp(data150[i].phi));
+ const Tp f0 = data150[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.60000000000000009, nu=0.0000000000000000.
+testcase_ellint_3<double> data151[] = {
+ { -0.0000000000000000, 0.60000000000000009, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17485154362988362, 0.60000000000000009, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.35160509865544326, 0.60000000000000009, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.53210652578446160, 0.60000000000000009, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.71805304664485670, 0.60000000000000009, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.91082759030195970, 0.60000000000000009, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.1112333229323366, 0.60000000000000009, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.3191461190365270, 0.60000000000000009, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.5332022105084775, 0.60000000000000009, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 1.7507538029157526, 0.60000000000000009, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.60000000000000009, nu=0.0000000000000000.
+template <typename Tp>
+void test151()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data151)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data151[i].k), Tp(data151[i].nu),
+ Tp(data151[i].phi));
+ const Tp f0 = data151[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.60000000000000009, nu=0.10000000000000001.
+testcase_ellint_3<double> data152[] = {
+ { -0.0000000000000000, 0.60000000000000009, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17467514275022014, 0.60000000000000009, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.35021333086258255, 0.60000000000000009, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.52751664092962713, 0.60000000000000009, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.70752126971957885, 0.60000000000000009, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.89111058756112871, 0.60000000000000009, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.0789241202877773, 0.60000000000000009, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.2710800210399946, 0.60000000000000009, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.4669060574440278, 0.60000000000000009, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 1.6648615773343014, 0.60000000000000009, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.60000000000000009, nu=0.10000000000000001.
+template <typename Tp>
+void test152()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data152)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data152[i].k), Tp(data152[i].nu),
+ Tp(data152[i].phi));
+ const Tp f0 = data152[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.60000000000000009, nu=0.20000000000000001.
+testcase_ellint_3<double> data153[] = {
+ { -0.0000000000000000, 0.60000000000000009, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17449937871800653, 0.60000000000000009, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.34884093647346553, 0.60000000000000009, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.52306221119844110, 0.60000000000000009, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.69749955678982223, 0.60000000000000009, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.87274610682416853, 0.60000000000000009, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 1.0494620540750796, 0.60000000000000009, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.2280847305507339, 0.60000000000000009, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.4085436279696888, 0.60000000000000009, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 1.5901418016279374, 0.60000000000000009, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.60000000000000009, nu=0.20000000000000001.
+template <typename Tp>
+void test153()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data153)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data153[i].k), Tp(data153[i].nu),
+ Tp(data153[i].phi));
+ const Tp f0 = data153[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.60000000000000009, nu=0.29999999999999999.
+testcase_ellint_3<double> data154[] = {
+ { -0.0000000000000000, 0.60000000000000009, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17432424744393935, 0.60000000000000009, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.34748744127146447, 0.60000000000000009, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.51873632743924847, 0.60000000000000009, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.68794610396313127, 0.60000000000000009, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.85558070175468726, 0.60000000000000009, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 1.0224416343605658, 0.60000000000000009, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.1893144457936788, 0.60000000000000009, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.3566435377982575, 0.60000000000000009, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.5243814243493585, 0.60000000000000009, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.60000000000000009, nu=0.29999999999999999.
+template <typename Tp>
+void test154()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data154)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data154[i].k), Tp(data154[i].nu),
+ Tp(data154[i].phi));
+ const Tp f0 = data154[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.60000000000000009, nu=0.40000000000000002.
+testcase_ellint_3<double> data155[] = {
+ { -0.0000000000000000, 0.60000000000000009, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17414974487670720, 0.60000000000000009, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34615238767335027, 0.60000000000000009, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.51453257838108579, 0.60000000000000009, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.67882386787534410, 0.60000000000000009, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.83948470233173578, 0.60000000000000009, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 0.99753496200074021, 0.60000000000000009, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.1541101404388487, 0.60000000000000009, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.3100911323398816, 0.60000000000000009, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.4659345278069984, 0.60000000000000009, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.60000000000000009, nu=0.40000000000000002.
+template <typename Tp>
+void test155()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data155)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data155[i].k), Tp(data155[i].nu),
+ Tp(data155[i].phi));
+ const Tp f0 = data155[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.60000000000000009, nu=0.50000000000000000.
+testcase_ellint_3<double> data156[] = {
+ { -0.0000000000000000, 0.60000000000000009, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17397586700252810, 0.60000000000000009, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34483533397138516, 0.60000000000000009, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.51044500461706499, 0.60000000000000009, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.67009988034712675, 0.60000000000000009, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.82434762375735193, 0.60000000000000009, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 0.97447346702799043, 0.60000000000000009, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.1219494000522143, 0.60000000000000009, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.2680242605954488, 0.60000000000000009, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.4135484285693078, 0.60000000000000009, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.60000000000000009, nu=0.50000000000000000.
+template <typename Tp>
+void test156()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data156)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data156[i].k), Tp(data156[i].nu),
+ Tp(data156[i].phi));
+ const Tp f0 = data156[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.60000000000000009, nu=0.59999999999999998.
+testcase_ellint_3<double> data157[] = {
+ { -0.0000000000000000, 0.60000000000000009, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17380260984469356, 0.60000000000000009, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34353585361777839, 0.60000000000000009, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.50646805774321402, 0.60000000000000009, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.66174468108625517, 0.60000000000000009, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.81007462280278408, 0.60000000000000009, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 0.95303466945718773, 0.60000000000000009, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.0924118588677503, 0.60000000000000009, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.2297640574847937, 0.60000000000000009, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.3662507535812816, 0.60000000000000009, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.60000000000000009, nu=0.59999999999999998.
+template <typename Tp>
+void test157()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data157)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data157[i].k), Tp(data157[i].nu),
+ Tp(data157[i].phi));
+ const Tp f0 = data157[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.60000000000000009, nu=0.69999999999999996.
+testcase_ellint_3<double> data158[] = {
+ { -0.0000000000000000, 0.60000000000000009, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17362996946312009, 0.60000000000000009, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.34225353454870588, 0.60000000000000009, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.50259656397799546, 0.60000000000000009, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.65373184496628944, 0.60000000000000009, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.79658372884056439, 0.60000000000000009, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 0.93303240100245466, 0.60000000000000009, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 1.0651547944716557, 0.60000000000000009, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.1947676204853441, 0.60000000000000009, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.3232737468822811, 0.60000000000000009, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.60000000000000009, nu=0.69999999999999996.
+template <typename Tp>
+void test158()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data158)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data158[i].k), Tp(data158[i].nu),
+ Tp(data158[i].phi));
+ const Tp f0 = data158[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.60000000000000009, nu=0.80000000000000004.
+testcase_ellint_3<double> data159[] = {
+ { -0.0000000000000000, 0.60000000000000009, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17345794195390687, 0.60000000000000009, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.34098797854531027, 0.60000000000000009, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.49882569168826230, 0.60000000000000009, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.64603758566475511, 0.60000000000000009, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.78380365594769730, 0.60000000000000009, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 0.91430946255611223, 0.60000000000000009, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 1.0398955217270607, 0.60000000000000009, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.1625948314277679, 0.60000000000000009, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.2840021261752192, 0.60000000000000009, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.60000000000000009, nu=0.80000000000000004.
+template <typename Tp>
+void test159()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data159)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data159[i].k), Tp(data159[i].nu),
+ Tp(data159[i].phi));
+ const Tp f0 = data159[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.60000000000000009, nu=0.90000000000000002.
+testcase_ellint_3<double> data160[] = {
+ { -0.0000000000000000, 0.60000000000000009, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17328652344890033, 0.60000000000000009, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.33973880062929018, 0.60000000000000009, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.49515092233122765, 0.60000000000000009, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.63864042139737043, 0.60000000000000009, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.77167205646538850, 0.60000000000000009, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.89673202848034428, 0.60000000000000009, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 1.0163984492661304, 0.60000000000000009, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.1328845785162431, 0.60000000000000009, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.2479362973851875, 0.60000000000000009, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.60000000000000009, nu=0.90000000000000002.
+template <typename Tp>
+void test160()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data160)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data160[i].k), Tp(data160[i].nu),
+ Tp(data160[i].phi));
+ const Tp f0 = data160[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.69999999999999996, nu=0.0000000000000000.
+testcase_ellint_3<double> data161[] = {
+ { -0.0000000000000000, 0.69999999999999996, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17496737466916720, 0.69999999999999996, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.35254687535677925, 0.69999999999999996, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.53536740275997130, 0.69999999999999996, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.72603797651684465, 0.69999999999999996, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.92698296348313458, 0.69999999999999996, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.1400447527693316, 0.69999999999999996, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.3657668117194071, 0.69999999999999996, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.6024686895959159, 0.69999999999999996, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 1.8456939983747236, 0.69999999999999996, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.69999999999999996, nu=0.0000000000000000.
+template <typename Tp>
+void test161()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data161)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data161[i].k), Tp(data161[i].nu),
+ Tp(data161[i].phi));
+ const Tp f0 = data161[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.69999999999999996, nu=0.10000000000000001.
+testcase_ellint_3<double> data162[] = {
+ { -0.0000000000000000, 0.69999999999999996, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17479076384884681, 0.69999999999999996, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.35114844900396364, 0.69999999999999996, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.53072776947527012, 0.69999999999999996, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.71530198262386246, 0.69999999999999996, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.90666760677828306, 0.69999999999999996, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.1063366517438080, 0.69999999999999996, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.3149477243092147, 0.69999999999999996, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.5314886725038925, 0.69999999999999996, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 1.7528050171757608, 0.69999999999999996, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.69999999999999996, nu=0.10000000000000001.
+template <typename Tp>
+void test162()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data162)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data162[i].k), Tp(data162[i].nu),
+ Tp(data162[i].phi));
+ const Tp f0 = data162[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.69999999999999996, nu=0.20000000000000001.
+testcase_ellint_3<double> data163[] = {
+ { -0.0000000000000000, 0.69999999999999996, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17461479077791472, 0.69999999999999996, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.34976950621407538, 0.69999999999999996, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.52622533231350188, 0.69999999999999996, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.70508774017895226, 0.69999999999999996, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.88775302531730294, 0.69999999999999996, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 1.0756195476149006, 0.69999999999999996, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.2695349716654372, 0.69999999999999996, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.4690814617070540, 0.69999999999999996, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 1.6721098780092147, 0.69999999999999996, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.69999999999999996, nu=0.20000000000000001.
+template <typename Tp>
+void test163()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data163)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data163[i].k), Tp(data163[i].nu),
+ Tp(data163[i].phi));
+ const Tp f0 = data163[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.69999999999999996, nu=0.29999999999999999.
+testcase_ellint_3<double> data164[] = {
+ { -0.0000000000000000, 0.69999999999999996, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17443945136076172, 0.69999999999999996, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.34840956983535287, 0.69999999999999996, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.52185308551329179, 0.69999999999999996, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.69535240431168266, 0.69999999999999996, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.87007983473964923, 0.69999999999999996, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 1.0474657975577066, 0.69999999999999996, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.2286225419931889, 0.69999999999999996, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.4136490671013271, 0.69999999999999996, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.6011813647733213, 0.69999999999999996, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.69999999999999996, nu=0.29999999999999999.
+template <typename Tp>
+void test164()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data164)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data164[i].k), Tp(data164[i].nu),
+ Tp(data164[i].phi));
+ const Tp f0 = data164[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.69999999999999996, nu=0.40000000000000002.
+testcase_ellint_3<double> data165[] = {
+ { -0.0000000000000000, 0.69999999999999996, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17426474153983226, 0.69999999999999996, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34706817945773732, 0.69999999999999996, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.51760452851738159, 0.69999999999999996, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.68605801534722766, 0.69999999999999996, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.85351339387296532, 0.69999999999999996, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 1.0215297967969537, 0.69999999999999996, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.1915051074460528, 0.69999999999999996, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.3639821911744707, 0.69999999999999996, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.5382162002954762, 0.69999999999999996, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.69999999999999996, nu=0.40000000000000002.
+template <typename Tp>
+void test165()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data165)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data165[i].k), Tp(data165[i].nu),
+ Tp(data165[i].phi));
+ const Tp f0 = data165[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.69999999999999996, nu=0.50000000000000000.
+testcase_ellint_3<double> data166[] = {
+ { -0.0000000000000000, 0.69999999999999996, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17409065729516093, 0.69999999999999996, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34574489064986091, 0.69999999999999996, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.51347361925579793, 0.69999999999999996, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.67717079489579290, 0.69999999999999996, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.83793902055292280, 0.69999999999999996, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 0.99752863545289705, 0.69999999999999996, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.1576240080401499, 0.69999999999999996, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.3191464023923762, 0.69999999999999996, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.4818433192178544, 0.69999999999999996, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.69999999999999996, nu=0.50000000000000000.
+template <typename Tp>
+void test166()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data166)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data166[i].k), Tp(data166[i].nu),
+ Tp(data166[i].phi));
+ const Tp f0 = data166[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.69999999999999996, nu=0.59999999999999998.
+testcase_ellint_3<double> data167[] = {
+ { -0.0000000000000000, 0.69999999999999996, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17391719464391611, 0.69999999999999996, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34443927423869031, 0.69999999999999996, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.50945473266486074, 0.69999999999999996, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.66866056326513823, 0.69999999999999996, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.82325830002337352, 0.69999999999999996, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 0.97522808245669357, 0.69999999999999996, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.1265300613705282, 0.69999999999999996, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.2784066076152003, 0.69999999999999996, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.4309994736080540, 0.69999999999999996, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.69999999999999996, nu=0.59999999999999998.
+template <typename Tp>
+void test167()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data167)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data167[i].k), Tp(data167[i].nu),
+ Tp(data167[i].phi));
+ const Tp f0 = data167[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.69999999999999996, nu=0.69999999999999996.
+testcase_ellint_3<double> data168[] = {
+ { -0.0000000000000000, 0.69999999999999996, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17374434963995028, 0.69999999999999996, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.34315091562900674, 0.69999999999999996, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.50554262375653358, 0.69999999999999996, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.66050025406305812, 0.69999999999999996, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.80938620118847404, 0.69999999999999996, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 0.95443223855852144, 0.69999999999999996, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 1.0978573207128302, 0.69999999999999996, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.2411754575007123, 0.69999999999999996, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.3848459188329196, 0.69999999999999996, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.69999999999999996, nu=0.69999999999999996.
+template <typename Tp>
+void test168()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data168)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data168[i].k), Tp(data168[i].nu),
+ Tp(data168[i].phi));
+ const Tp f0 = data168[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.69999999999999996, nu=0.80000000000000004.
+testcase_ellint_3<double> data169[] = {
+ { -0.0000000000000000, 0.69999999999999996, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17357211837335737, 0.69999999999999996, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.34187941416012108, 0.69999999999999996, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.50173239465478270, 0.69999999999999996, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.65266550725988315, 0.69999999999999996, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.79624879865249298, 0.69999999999999996, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 0.93497577043296920, 0.69999999999999996, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 1.0713041566930748, 0.69999999999999996, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.2069772023255652, 0.69999999999999996, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.3427110650397533, 0.69999999999999996, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.69999999999999996, nu=0.80000000000000004.
+template <typename Tp>
+void test169()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data169)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data169[i].k), Tp(data169[i].nu),
+ Tp(data169[i].phi));
+ const Tp f0 = data169[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.69999999999999996, nu=0.90000000000000002.
+testcase_ellint_3<double> data170[] = {
+ { -0.0000000000000000, 0.69999999999999996, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17340049697003634, 0.69999999999999996, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.34062438249741556, 0.69999999999999996, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.49801946510076878, 0.69999999999999996, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.64513432604750487, 0.69999999999999996, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.78378145487573758, 0.69999999999999996, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.91671799500854634, 0.69999999999999996, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 1.0466193579463123, 0.69999999999999996, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.1754218079199146, 0.69999999999999996, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.3040500499695911, 0.69999999999999996, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.69999999999999996, nu=0.90000000000000002.
+template <typename Tp>
+void test170()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data170)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data170[i].k), Tp(data170[i].nu),
+ Tp(data170[i].phi));
+ const Tp f0 = data170[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.80000000000000004, nu=0.0000000000000000.
+testcase_ellint_3<double> data171[] = {
+ { -0.0000000000000000, 0.80000000000000004, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17510154241338902, 0.80000000000000004, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.35365068839779390, 0.80000000000000004, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.53926804409084561, 0.80000000000000004, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.73587926028070383, 0.80000000000000004, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.94770942970071170, 0.80000000000000004, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.1789022995388239, 0.80000000000000004, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.4323027881876009, 0.80000000000000004, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.7069629739121674, 0.80000000000000004, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 1.9953027776647296, 0.80000000000000004, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.80000000000000004, nu=0.0000000000000000.
+template <typename Tp>
+void test171()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data171)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data171[i].k), Tp(data171[i].nu),
+ Tp(data171[i].phi));
+ const Tp f0 = data171[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.80000000000000004, nu=0.10000000000000001.
+testcase_ellint_3<double> data172[] = {
+ { -0.0000000000000000, 0.80000000000000004, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17492468824017166, 0.80000000000000004, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.35224443521476911, 0.80000000000000004, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.53456851853226961, 0.80000000000000004, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.72488875602364944, 0.80000000000000004, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.92661354274638952, 0.80000000000000004, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.1432651144499077, 0.80000000000000004, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.3774479927211429, 0.80000000000000004, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.6287092337196041, 0.80000000000000004, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 1.8910755418379521, 0.80000000000000004, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.80000000000000004, nu=0.10000000000000001.
+template <typename Tp>
+void test172()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data172)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data172[i].k), Tp(data172[i].nu),
+ Tp(data172[i].phi));
+ const Tp f0 = data172[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.80000000000000004, nu=0.20000000000000001.
+testcase_ellint_3<double> data173[] = {
+ { -0.0000000000000000, 0.80000000000000004, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17474847286224943, 0.80000000000000004, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.35085779529084682, 0.80000000000000004, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.53000829263059157, 0.80000000000000004, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.71443466027453406, 0.80000000000000004, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.90698196872715420, 0.80000000000000004, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 1.1108198200558581, 0.80000000000000004, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.3284988909963957, 0.80000000000000004, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.5600369318140328, 0.80000000000000004, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 1.8007226661734588, 0.80000000000000004, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.80000000000000004, nu=0.20000000000000001.
+template <typename Tp>
+void test173()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data173)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data173[i].k), Tp(data173[i].nu),
+ Tp(data173[i].phi));
+ const Tp f0 = data173[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.80000000000000004, nu=0.29999999999999999.
+testcase_ellint_3<double> data174[] = {
+ { -0.0000000000000000, 0.80000000000000004, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17457289217669891, 0.80000000000000004, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.34949028801501258, 0.80000000000000004, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.52558024362769318, 0.80000000000000004, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.70447281740094914, 0.80000000000000004, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.88864745641528986, 0.80000000000000004, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 1.0811075819341465, 0.80000000000000004, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.2844589654082377, 0.80000000000000004, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.4991461361277849, 0.80000000000000004, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.7214611048717301, 0.80000000000000004, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.80000000000000004, nu=0.29999999999999999.
+template <typename Tp>
+void test174()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data174)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data174[i].k), Tp(data174[i].nu),
+ Tp(data174[i].phi));
+ const Tp f0 = data174[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.80000000000000004, nu=0.40000000000000002.
+testcase_ellint_3<double> data175[] = {
+ { -0.0000000000000000, 0.80000000000000004, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17439794211872178, 0.80000000000000004, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34814144964568972, 0.80000000000000004, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.52127776285273075, 0.80000000000000004, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.69496411438966599, 0.80000000000000004, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.87146878427509589, 0.80000000000000004, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 1.0537579024937762, 0.80000000000000004, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.2445534387922637, 0.80000000000000004, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.4446769766361993, 0.80000000000000004, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.6512267838651289, 0.80000000000000004, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.80000000000000004, nu=0.40000000000000002.
+template <typename Tp>
+void test175()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data175)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data175[i].k), Tp(data175[i].nu),
+ Tp(data175[i].phi));
+ const Tp f0 = data175[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.80000000000000004, nu=0.50000000000000000.
+testcase_ellint_3<double> data176[] = {
+ { -0.0000000000000000, 0.80000000000000004, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17422361866118047, 0.80000000000000004, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34681083254170475, 0.80000000000000004, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.51709470815494440, 0.80000000000000004, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.68587375344080259, 0.80000000000000004, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.85532571852810624, 0.80000000000000004, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 1.0284677391874906, 0.80000000000000004, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.2081693942686225, 0.80000000000000004, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.3955803006426311, 0.80000000000000004, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.5884528947755532, 0.80000000000000004, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.80000000000000004, nu=0.50000000000000000.
+template <typename Tp>
+void test176()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data176)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data176[i].k), Tp(data176[i].nu),
+ Tp(data176[i].phi));
+ const Tp f0 = data176[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.80000000000000004, nu=0.59999999999999998.
+testcase_ellint_3<double> data177[] = {
+ { -0.0000000000000000, 0.80000000000000004, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17404991781414092, 0.80000000000000004, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34549800443625167, 0.80000000000000004, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.51302536167001556, 0.80000000000000004, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.67717065003912258, 0.80000000000000004, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.84011512421134416, 0.80000000000000004, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 1.0049863847088742, 0.80000000000000004, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.1748145941898918, 0.80000000000000004, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.3510319699755071, 0.80000000000000004, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.5319262547427865, 0.80000000000000004, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.80000000000000004, nu=0.59999999999999998.
+template <typename Tp>
+void test177()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data177)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data177[i].k), Tp(data177[i].nu),
+ Tp(data177[i].phi));
+ const Tp f0 = data177[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.80000000000000004, nu=0.69999999999999996.
+testcase_ellint_3<double> data178[] = {
+ { -0.0000000000000000, 0.80000000000000004, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17387683562442202, 0.80000000000000004, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.34420254775101611, 0.80000000000000004, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.50906439222143685, 0.80000000000000004, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.66882693152688433, 0.80000000000000004, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.82574792844091316, 0.80000000000000004, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 0.98310431309490953, 0.80000000000000004, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 1.1440884535113258, 0.80000000000000004, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.3103743938952537, 0.80000000000000004, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.4806912324625332, 0.80000000000000004, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.80000000000000004, nu=0.69999999999999996.
+template <typename Tp>
+void test178()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data178)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data178[i].k), Tp(data178[i].nu),
+ Tp(data178[i].phi));
+ const Tp f0 = data178[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.80000000000000004, nu=0.80000000000000004.
+testcase_ellint_3<double> data179[] = {
+ { -0.0000000000000000, 0.80000000000000004, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17370436817515206, 0.80000000000000004, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.34292405894783395, 0.80000000000000004, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.50520682176250087, 0.80000000000000004, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.66081751679736189, 0.80000000000000004, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.81214672249355102, 0.80000000000000004, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 0.96264481387685574, 0.80000000000000004, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 1.1156611352656258, 0.80000000000000004, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.2730756225143889, 0.80000000000000004, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.4339837018309474, 0.80000000000000004, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.80000000000000004, nu=0.80000000000000004.
+template <typename Tp>
+void test179()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data179)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data179[i].k), Tp(data179[i].nu),
+ Tp(data179[i].phi));
+ const Tp f0 = data179[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.80000000000000004, nu=0.90000000000000002.
+testcase_ellint_3<double> data180[] = {
+ { -0.0000000000000000, 0.80000000000000004, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17353251158533153, 0.80000000000000004, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.34166214791545768, 0.80000000000000004, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.50144799535130580, 0.80000000000000004, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.65311976193814447, 0.80000000000000004, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.79924384892320866, 0.80000000000000004, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.94345762353365625, 0.80000000000000004, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 1.0892582069219159, 0.80000000000000004, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.2387000876610268, 0.80000000000000004, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.3911845406776222, 0.80000000000000004, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.80000000000000004, nu=0.90000000000000002.
+template <typename Tp>
+void test180()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data180)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data180[i].k), Tp(data180[i].nu),
+ Tp(data180[i].phi));
+ const Tp f0 = data180[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.89999999999999991, nu=0.0000000000000000.
+testcase_ellint_3<double> data181[] = {
+ { -0.0000000000000000, 0.89999999999999991, 0.0000000000000000,
+ 0.0000000000000000 },
+ { 0.17525427376115027, 0.89999999999999991, 0.0000000000000000,
+ 0.17453292519943295 },
+ { 0.35492464591297446, 0.89999999999999991, 0.0000000000000000,
+ 0.34906585039886590 },
+ { 0.54388221416157123, 0.89999999999999991, 0.0000000000000000,
+ 0.52359877559829882 },
+ { 0.74797400423532501, 0.89999999999999991, 0.0000000000000000,
+ 0.69813170079773179 },
+ { 0.97463898451966458, 0.89999999999999991, 0.0000000000000000,
+ 0.87266462599716477 },
+ { 1.2334463254523438, 0.89999999999999991, 0.0000000000000000,
+ 1.0471975511965976 },
+ { 1.5355247765594910, 0.89999999999999991, 0.0000000000000000,
+ 1.2217304763960306 },
+ { 1.8882928567775117, 0.89999999999999991, 0.0000000000000000,
+ 1.3962634015954636 },
+ { 2.2805491384227699, 0.89999999999999991, 0.0000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.89999999999999991, nu=0.0000000000000000.
+template <typename Tp>
+void test181()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data181)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data181[i].k), Tp(data181[i].nu),
+ Tp(data181[i].phi));
+ const Tp f0 = data181[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.89999999999999991, nu=0.10000000000000001.
+testcase_ellint_3<double> data182[] = {
+ { -0.0000000000000000, 0.89999999999999991, 0.10000000000000001,
+ 0.0000000000000000 },
+ { 0.17507714233254659, 0.89999999999999991, 0.10000000000000001,
+ 0.17453292519943295 },
+ { 0.35350932904326521, 0.89999999999999991, 0.10000000000000001,
+ 0.34906585039886590 },
+ { 0.53911129989870987, 0.89999999999999991, 0.10000000000000001,
+ 0.52359877559829882 },
+ { 0.73666644254508407, 0.89999999999999991, 0.10000000000000001,
+ 0.69813170079773179 },
+ { 0.95250736612100184, 0.89999999999999991, 0.10000000000000001,
+ 0.87266462599716477 },
+ { 1.1950199550905591, 0.89999999999999991, 0.10000000000000001,
+ 1.0471975511965976 },
+ { 1.4741687286340848, 0.89999999999999991, 0.10000000000000001,
+ 1.2217304763960306 },
+ { 1.7968678183506053, 0.89999999999999991, 0.10000000000000001,
+ 1.3962634015954636 },
+ { 2.1537868513875282, 0.89999999999999991, 0.10000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.89999999999999991, nu=0.10000000000000001.
+template <typename Tp>
+void test182()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data182)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data182[i].k), Tp(data182[i].nu),
+ Tp(data182[i].phi));
+ const Tp f0 = data182[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.89999999999999991, nu=0.20000000000000001.
+testcase_ellint_3<double> data183[] = {
+ { -0.0000000000000000, 0.89999999999999991, 0.20000000000000001,
+ 0.0000000000000000 },
+ { 0.17490065089140930, 0.89999999999999991, 0.20000000000000001,
+ 0.17453292519943295 },
+ { 0.35211377590661436, 0.89999999999999991, 0.20000000000000001,
+ 0.34906585039886590 },
+ { 0.53448220334204111, 0.89999999999999991, 0.20000000000000001,
+ 0.52359877559829882 },
+ { 0.72591368943179591, 0.89999999999999991, 0.20000000000000001,
+ 0.69813170079773179 },
+ { 0.93192539780038763, 0.89999999999999991, 0.20000000000000001,
+ 0.87266462599716477 },
+ { 1.1600809679692681, 0.89999999999999991, 0.20000000000000001,
+ 1.0471975511965976 },
+ { 1.4195407225882508, 0.89999999999999991, 0.20000000000000001,
+ 1.2217304763960306 },
+ { 1.7168966476424521, 0.89999999999999991, 0.20000000000000001,
+ 1.3962634015954636 },
+ { 2.0443194576468890, 0.89999999999999991, 0.20000000000000001,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.89999999999999991, nu=0.20000000000000001.
+template <typename Tp>
+void test183()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data183)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data183[i].k), Tp(data183[i].nu),
+ Tp(data183[i].phi));
+ const Tp f0 = data183[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.89999999999999991, nu=0.29999999999999999.
+testcase_ellint_3<double> data184[] = {
+ { -0.0000000000000000, 0.89999999999999991, 0.29999999999999999,
+ 0.0000000000000000 },
+ { 0.17472479532647534, 0.89999999999999991, 0.29999999999999999,
+ 0.17453292519943295 },
+ { 0.35073750187374114, 0.89999999999999991, 0.29999999999999999,
+ 0.34906585039886590 },
+ { 0.52998766129466968, 0.89999999999999991, 0.29999999999999999,
+ 0.52359877559829882 },
+ { 0.71566993548699565, 0.89999999999999991, 0.29999999999999999,
+ 0.69813170079773179 },
+ { 0.91271517762560195, 0.89999999999999991, 0.29999999999999999,
+ 0.87266462599716477 },
+ { 1.1281241199843368, 0.89999999999999991, 0.29999999999999999,
+ 1.0471975511965976 },
+ { 1.3704929576917448, 0.89999999999999991, 0.29999999999999999,
+ 1.2217304763960306 },
+ { 1.6461981511487711, 0.89999999999999991, 0.29999999999999999,
+ 1.3962634015954636 },
+ { 1.9486280260314424, 0.89999999999999991, 0.29999999999999999,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.89999999999999991, nu=0.29999999999999999.
+template <typename Tp>
+void test184()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data184)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data184[i].k), Tp(data184[i].nu),
+ Tp(data184[i].phi));
+ const Tp f0 = data184[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.89999999999999991, nu=0.40000000000000002.
+testcase_ellint_3<double> data185[] = {
+ { -0.0000000000000000, 0.89999999999999991, 0.40000000000000002,
+ 0.0000000000000000 },
+ { 0.17454957156468839, 0.89999999999999991, 0.40000000000000002,
+ 0.17453292519943295 },
+ { 0.34938003933330430, 0.89999999999999991, 0.40000000000000002,
+ 0.34906585039886590 },
+ { 0.52562093533067444, 0.89999999999999991, 0.40000000000000002,
+ 0.52359877559829882 },
+ { 0.70589461324915681, 0.89999999999999991, 0.40000000000000002,
+ 0.69813170079773179 },
+ { 0.89472658511942849, 0.89999999999999991, 0.40000000000000002,
+ 0.87266462599716477 },
+ { 1.0987419542323438, 0.89999999999999991, 0.40000000000000002,
+ 1.0471975511965976 },
+ { 1.3261349565496301, 0.89999999999999991, 0.40000000000000002,
+ 1.2217304763960306 },
+ { 1.5831293909853761, 0.89999999999999991, 0.40000000000000002,
+ 1.3962634015954636 },
+ { 1.8641114227238347, 0.89999999999999991, 0.40000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.89999999999999991, nu=0.40000000000000002.
+template <typename Tp>
+void test185()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data185)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data185[i].k), Tp(data185[i].nu),
+ Tp(data185[i].phi));
+ const Tp f0 = data185[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.89999999999999991, nu=0.50000000000000000.
+testcase_ellint_3<double> data186[] = {
+ { -0.0000000000000000, 0.89999999999999991, 0.50000000000000000,
+ 0.0000000000000000 },
+ { 0.17437497557073336, 0.89999999999999991, 0.50000000000000000,
+ 0.17453292519943295 },
+ { 0.34804093691586013, 0.89999999999999991, 0.50000000000000000,
+ 0.34906585039886590 },
+ { 0.52137576320372903, 0.89999999999999991, 0.50000000000000000,
+ 0.52359877559829882 },
+ { 0.69655163996912262, 0.89999999999999991, 0.50000000000000000,
+ 0.69813170079773179 },
+ { 0.87783188683054236, 0.89999999999999991, 0.50000000000000000,
+ 0.87266462599716477 },
+ { 1.0716015959755183, 0.89999999999999991, 0.50000000000000000,
+ 1.0471975511965976 },
+ { 1.2857636916026749, 0.89999999999999991, 0.50000000000000000,
+ 1.2217304763960306 },
+ { 1.5264263913252358, 0.89999999999999991, 0.50000000000000000,
+ 1.3962634015954636 },
+ { 1.7888013241937859, 0.89999999999999991, 0.50000000000000000,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.89999999999999991, nu=0.50000000000000000.
+template <typename Tp>
+void test186()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data186)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data186[i].k), Tp(data186[i].nu),
+ Tp(data186[i].phi));
+ const Tp f0 = data186[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.89999999999999991, nu=0.59999999999999998.
+testcase_ellint_3<double> data187[] = {
+ { -0.0000000000000000, 0.89999999999999991, 0.59999999999999998,
+ 0.0000000000000000 },
+ { 0.17420100334657815, 0.89999999999999991, 0.59999999999999998,
+ 0.17453292519943295 },
+ { 0.34671975876122157, 0.89999999999999991, 0.59999999999999998,
+ 0.34906585039886590 },
+ { 0.51724631570707957, 0.89999999999999991, 0.59999999999999998,
+ 0.52359877559829882 },
+ { 0.68760879113743034, 0.89999999999999991, 0.59999999999999998,
+ 0.69813170079773179 },
+ { 0.86192157779698364, 0.89999999999999991, 0.59999999999999998,
+ 0.87266462599716477 },
+ { 1.0464279696166352, 0.89999999999999991, 0.59999999999999998,
+ 1.0471975511965976 },
+ { 1.2488156247094004, 0.89999999999999991, 0.59999999999999998,
+ 1.2217304763960306 },
+ { 1.4750988777188470, 0.89999999999999991, 0.59999999999999998,
+ 1.3962634015954636 },
+ { 1.7211781128919521, 0.89999999999999991, 0.59999999999999998,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.89999999999999991, nu=0.59999999999999998.
+template <typename Tp>
+void test187()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data187)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data187[i].k), Tp(data187[i].nu),
+ Tp(data187[i].phi));
+ const Tp f0 = data187[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.89999999999999991, nu=0.69999999999999996.
+testcase_ellint_3<double> data188[] = {
+ { -0.0000000000000000, 0.89999999999999991, 0.69999999999999996,
+ 0.0000000000000000 },
+ { 0.17402765093102210, 0.89999999999999991, 0.69999999999999996,
+ 0.17453292519943295 },
+ { 0.34541608382635131, 0.89999999999999991, 0.69999999999999996,
+ 0.34906585039886590 },
+ { 0.51322715827061693, 0.89999999999999991, 0.69999999999999996,
+ 0.52359877559829882 },
+ { 0.67903717872440283, 0.89999999999999991, 0.69999999999999996,
+ 0.69813170079773179 },
+ { 0.84690113601682671, 0.89999999999999991, 0.69999999999999996,
+ 0.87266462599716477 },
+ { 1.0229914311548416, 0.89999999999999991, 0.69999999999999996,
+ 1.0471975511965976 },
+ { 1.2148329639709381, 0.89999999999999991, 0.69999999999999996,
+ 1.2217304763960306 },
+ { 1.4283586501307799, 0.89999999999999991, 0.69999999999999996,
+ 1.3962634015954636 },
+ { 1.6600480747670936, 0.89999999999999991, 0.69999999999999996,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.89999999999999991, nu=0.69999999999999996.
+template <typename Tp>
+void test188()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data188)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data188[i].k), Tp(data188[i].nu),
+ Tp(data188[i].phi));
+ const Tp f0 = data188[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.89999999999999991, nu=0.80000000000000004.
+testcase_ellint_3<double> data189[] = {
+ { -0.0000000000000000, 0.89999999999999991, 0.80000000000000004,
+ 0.0000000000000000 },
+ { 0.17385491439925149, 0.89999999999999991, 0.80000000000000004,
+ 0.17453292519943295 },
+ { 0.34412950523113928, 0.89999999999999991, 0.80000000000000004,
+ 0.34906585039886590 },
+ { 0.50931321668729601, 0.89999999999999991, 0.80000000000000004,
+ 0.52359877559829882 },
+ { 0.67081081392296327, 0.89999999999999991, 0.80000000000000004,
+ 0.69813170079773179 },
+ { 0.83268846097293259, 0.89999999999999991, 0.80000000000000004,
+ 0.87266462599716477 },
+ { 1.0010985015814025, 0.89999999999999991, 0.80000000000000004,
+ 1.0471975511965976 },
+ { 1.1834394045489678, 0.89999999999999991, 0.80000000000000004,
+ 1.2217304763960306 },
+ { 1.3855695891683182, 0.89999999999999991, 0.80000000000000004,
+ 1.3962634015954636 },
+ { 1.6044591960982200, 0.89999999999999991, 0.80000000000000004,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.89999999999999991, nu=0.80000000000000004.
+template <typename Tp>
+void test189()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data189)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data189[i].k), Tp(data189[i].nu),
+ Tp(data189[i].phi));
+ const Tp f0 = data189[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for k=0.89999999999999991, nu=0.90000000000000002.
+testcase_ellint_3<double> data190[] = {
+ { -0.0000000000000000, 0.89999999999999991, 0.90000000000000002,
+ 0.0000000000000000 },
+ { 0.17368278986240138, 0.89999999999999991, 0.90000000000000002,
+ 0.17453292519943295 },
+ { 0.34285962963961397, 0.89999999999999991, 0.90000000000000002,
+ 0.34906585039886590 },
+ { 0.50549974644993312, 0.89999999999999991, 0.90000000000000002,
+ 0.52359877559829882 },
+ { 0.66290623857720876, 0.89999999999999991, 0.90000000000000002,
+ 0.69813170079773179 },
+ { 0.81921183128847164, 0.89999999999999991, 0.90000000000000002,
+ 0.87266462599716477 },
+ { 0.98058481956066368, 0.89999999999999991, 0.90000000000000002,
+ 1.0471975511965976 },
+ { 1.1543223520473569, 0.89999999999999991, 0.90000000000000002,
+ 1.2217304763960306 },
+ { 1.3462119782292934, 0.89999999999999991, 0.90000000000000002,
+ 1.3962634015954636 },
+ { 1.5536420236310944, 0.89999999999999991, 0.90000000000000002,
+ 1.5707963267948966 },
+};
+
+// Test function for k=0.89999999999999991, nu=0.90000000000000002.
+template <typename Tp>
+void test190()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data190)
+ / sizeof(testcase_ellint_3<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::ellint_3(Tp(data190[i].k), Tp(data190[i].nu),
+ Tp(data190[i].phi));
+ const Tp f0 = data190[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ test009<double>();
+ test010<double>();
+ test011<double>();
+ test012<double>();
+ test013<double>();
+ test014<double>();
+ test015<double>();
+ test016<double>();
+ test017<double>();
+ test018<double>();
+ test019<double>();
+ test020<double>();
+ test021<double>();
+ test022<double>();
+ test023<double>();
+ test024<double>();
+ test025<double>();
+ test026<double>();
+ test027<double>();
+ test028<double>();
+ test029<double>();
+ test030<double>();
+ test031<double>();
+ test032<double>();
+ test033<double>();
+ test034<double>();
+ test035<double>();
+ test036<double>();
+ test037<double>();
+ test038<double>();
+ test039<double>();
+ test040<double>();
+ test041<double>();
+ test042<double>();
+ test043<double>();
+ test044<double>();
+ test045<double>();
+ test046<double>();
+ test047<double>();
+ test048<double>();
+ test049<double>();
+ test050<double>();
+ test051<double>();
+ test052<double>();
+ test053<double>();
+ test054<double>();
+ test055<double>();
+ test056<double>();
+ test057<double>();
+ test058<double>();
+ test059<double>();
+ test060<double>();
+ test061<double>();
+ test062<double>();
+ test063<double>();
+ test064<double>();
+ test065<double>();
+ test066<double>();
+ test067<double>();
+ test068<double>();
+ test069<double>();
+ test070<double>();
+ test071<double>();
+ test072<double>();
+ test073<double>();
+ test074<double>();
+ test075<double>();
+ test076<double>();
+ test077<double>();
+ test078<double>();
+ test079<double>();
+ test080<double>();
+ test081<double>();
+ test082<double>();
+ test083<double>();
+ test084<double>();
+ test085<double>();
+ test086<double>();
+ test087<double>();
+ test088<double>();
+ test089<double>();
+ test090<double>();
+ test091<double>();
+ test092<double>();
+ test093<double>();
+ test094<double>();
+ test095<double>();
+ test096<double>();
+ test097<double>();
+ test098<double>();
+ test099<double>();
+ test100<double>();
+ test101<double>();
+ test102<double>();
+ test103<double>();
+ test104<double>();
+ test105<double>();
+ test106<double>();
+ test107<double>();
+ test108<double>();
+ test109<double>();
+ test110<double>();
+ test111<double>();
+ test112<double>();
+ test113<double>();
+ test114<double>();
+ test115<double>();
+ test116<double>();
+ test117<double>();
+ test118<double>();
+ test119<double>();
+ test120<double>();
+ test121<double>();
+ test122<double>();
+ test123<double>();
+ test124<double>();
+ test125<double>();
+ test126<double>();
+ test127<double>();
+ test128<double>();
+ test129<double>();
+ test130<double>();
+ test131<double>();
+ test132<double>();
+ test133<double>();
+ test134<double>();
+ test135<double>();
+ test136<double>();
+ test137<double>();
+ test138<double>();
+ test139<double>();
+ test140<double>();
+ test141<double>();
+ test142<double>();
+ test143<double>();
+ test144<double>();
+ test145<double>();
+ test146<double>();
+ test147<double>();
+ test148<double>();
+ test149<double>();
+ test150<double>();
+ test151<double>();
+ test152<double>();
+ test153<double>();
+ test154<double>();
+ test155<double>();
+ test156<double>();
+ test157<double>();
+ test158<double>();
+ test159<double>();
+ test160<double>();
+ test161<double>();
+ test162<double>();
+ test163<double>();
+ test164<double>();
+ test165<double>();
+ test166<double>();
+ test167<double>();
+ test168<double>();
+ test169<double>();
+ test170<double>();
+ test171<double>();
+ test172<double>();
+ test173<double>();
+ test174<double>();
+ test175<double>();
+ test176<double>();
+ test177<double>();
+ test178<double>();
+ test179<double>();
+ test180<double>();
+ test181<double>();
+ test182<double>();
+ test183<double>();
+ test184<double>();
+ test185<double>();
+ test186<double>();
+ test187<double>();
+ test188<double>();
+ test189<double>();
+ test190<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/compile.cc
new file mode 100644
index 00000000000..f988eaa081c
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/compile.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.14 ellint_3
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+ float kf = 0.5F, nuf = 0.2F, phif = std::atan2(1.0F, 1.0F);
+ double kd = 0.5, nud = 0.2, phid = std::atan2(1.0, 1.0);
+ long double kl = 0.5L, nul = 0.2L, phil = std::atan2(1.0L, 1.0L);
+
+ std::tr1::ellint_3(kf, nuf, phif);
+ std::tr1::ellint_3f(kf, nuf, phif);
+ std::tr1::ellint_3(kd, nud, phid);
+ std::tr1::ellint_3(kl, nul, phil);
+ std::tr1::ellint_3l(kl, nul, phil);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/compile_2.cc
new file mode 100644
index 00000000000..49f0a70339c
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/14_ellint_3/compile_2.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.14 ellint_3
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+ float kf = 0.5F, nuf = 0.2F, phif = std::atan2(1.0F, 1.0F);
+ double kd = 0.5, nud = 0.2, phid = std::atan2(1.0, 1.0);
+ long double kl = 0.5L, nul = 0.2L, phil = std::atan2(1.0L, 1.0L);
+
+ ellint_3(kf, nuf, phif);
+ ellint_3f(kf, nuf, phif);
+ ellint_3(kd, nud, phid);
+ ellint_3(kl, nul, phil);
+ ellint_3l(kl, nul, phil);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/check_nan.cc
new file mode 100644
index 00000000000..f01caa05144
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/check_nan.cc
@@ -0,0 +1,57 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.15 expint
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+
+ float xf = std::numeric_limits<float>::quiet_NaN();
+ double xd = std::numeric_limits<double>::quiet_NaN();
+ long double xl = std::numeric_limits<long double>::quiet_NaN();
+
+ float a = std::tr1::expint(xf);
+ float b = std::tr1::expintf(xf);
+ double c = std::tr1::expint(xd);
+ long double d = std::tr1::expint(xl);
+ long double e = std::tr1::expintl(xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/check_value_neg.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/check_value_neg.cc
new file mode 100644
index 00000000000..3aa239e15af
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/check_value_neg.cc
@@ -0,0 +1,128 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// expint
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data.
+testcase_expint<double> data001[] = {
+ { -3.7832640295504591e-24, -50.000000000000000 },
+ { -1.0489811642368024e-23, -49.000000000000000 },
+ { -2.9096641904058423e-23, -48.000000000000000 },
+ { -8.0741978427258127e-23, -47.000000000000000 },
+ { -2.2415317597442998e-22, -46.000000000000000 },
+ { -6.2256908094623838e-22, -45.000000000000000 },
+ { -1.7299598742816476e-21, -44.000000000000000 },
+ { -4.8094965569500181e-21, -43.000000000000000 },
+ { -1.3377908810011775e-20, -42.000000000000000 },
+ { -3.7231667764599780e-20, -41.000000000000000 },
+ { -1.0367732614516570e-19, -40.000000000000000 },
+ { -2.8887793015227007e-19, -39.000000000000000 },
+ { -8.0541069142907499e-19, -38.000000000000000 },
+ { -2.2470206975885714e-18, -37.000000000000000 },
+ { -6.2733390097622421e-18, -36.000000000000000 },
+ { -1.7527059389947371e-17, -35.000000000000000 },
+ { -4.9006761183927874e-17, -34.000000000000000 },
+ { -1.3713843484487468e-16, -33.000000000000000 },
+ { -3.8409618012250666e-16, -32.000000000000000 },
+ { -1.0767670386162383e-15, -31.000000000000000 },
+ { -3.0215520106888128e-15, -30.000000000000000 },
+ { -8.4877597783535618e-15, -29.000000000000000 },
+ { -2.3869415119337330e-14, -28.000000000000000 },
+ { -6.7206374352620390e-14, -27.000000000000000 },
+ { -1.8946858856749785e-13, -26.000000000000000 },
+ { -5.3488997553402167e-13, -25.000000000000000 },
+ { -1.5123058939997059e-12, -24.000000000000000 },
+ { -4.2826847956656722e-12, -23.000000000000000 },
+ { -1.2149378956204371e-11, -22.000000000000000 },
+ { -3.4532012671467559e-11, -21.000000000000000 },
+ { -9.8355252906498815e-11, -20.000000000000000 },
+ { -2.8078290970607954e-10, -19.000000000000000 },
+ { -8.0360903448286769e-10, -18.000000000000000 },
+ { -2.3064319898216547e-09, -17.000000000000000 },
+ { -6.6404872494410427e-09, -16.000000000000000 },
+ { -1.9186278921478670e-08, -15.000000000000000 },
+ { -5.5656311111451816e-08, -14.000000000000000 },
+ { -1.6218662188014328e-07, -13.000000000000000 },
+ { -4.7510818246724931e-07, -12.000000000000000 },
+ { -1.4003003042474418e-06, -11.000000000000000 },
+ { -4.1569689296853246e-06, -10.000000000000000 },
+ { -1.2447354178006272e-05, -9.0000000000000000 },
+ { -3.7665622843924906e-05, -8.0000000000000000 },
+ { -0.00011548173161033820, -7.0000000000000000 },
+ { -0.00036008245216265867, -6.0000000000000000 },
+ { -0.0011482955912753257, -5.0000000000000000 },
+ { -0.0037793524098489058, -4.0000000000000000 },
+ { -0.013048381094197037, -3.0000000000000000 },
+ { -0.048900510708061125, -2.0000000000000000 },
+ { -0.21938393439552029, -1.0000000000000000 },
+};
+
+// Test function.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_expint<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::expint(Tp(data001[i].x));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/check_value_pos.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/check_value_pos.cc
new file mode 100644
index 00000000000..1b9e7fba2d0
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/check_value_pos.cc
@@ -0,0 +1,128 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// expint
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data.
+testcase_expint<double> data001[] = {
+ { 1.8951178163559366, 1.0000000000000000 },
+ { 4.9542343560018907, 2.0000000000000000 },
+ { 9.9338325706254160, 3.0000000000000000 },
+ { 19.630874470056217, 4.0000000000000000 },
+ { 40.185275355803178, 5.0000000000000000 },
+ { 85.989762142439204, 6.0000000000000000 },
+ { 191.50474333550139, 7.0000000000000000 },
+ { 440.37989953483827, 8.0000000000000000 },
+ { 1037.8782907170896, 9.0000000000000000 },
+ { 2492.2289762418782, 10.000000000000000 },
+ { 6071.4063740986112, 11.000000000000000 },
+ { 14959.532666397527, 12.000000000000000 },
+ { 37197.688490689041, 13.000000000000000 },
+ { 93192.513633965369, 14.000000000000000 },
+ { 234955.85249076830, 15.000000000000000 },
+ { 595560.99867083703, 16.000000000000000 },
+ { 1516637.8940425171, 17.000000000000000 },
+ { 3877904.3305974435, 18.000000000000000 },
+ { 9950907.2510468438, 19.000000000000000 },
+ { 25615652.664056588, 20.000000000000000 },
+ { 66127186.355484918, 21.000000000000000 },
+ { 171144671.30036369, 22.000000000000000 },
+ { 443966369.83027118, 23.000000000000000 },
+ { 1154115391.8491828, 24.000000000000000 },
+ { 3005950906.5255489, 25.000000000000000 },
+ { 7842940991.8981876, 26.000000000000000 },
+ { 20496497119.880810, 27.000000000000000 },
+ { 53645118592.314682, 28.000000000000000 },
+ { 140599195758.40689, 29.000000000000000 },
+ { 368973209407.27423, 30.000000000000000 },
+ { 969455575968.39392, 31.000000000000000 },
+ { 2550043566357.7866, 32.000000000000000 },
+ { 6714640184076.4980, 33.000000000000000 },
+ { 17698037244116.266, 34.000000000000000 },
+ { 46690550144661.594, 35.000000000000000 },
+ { 123285207991209.75, 36.000000000000000 },
+ { 325798899867226.44, 37.000000000000000 },
+ { 861638819996578.62, 38.000000000000000 },
+ { 2280446200301902.5, 39.000000000000000 },
+ { 6039718263611242.0, 40.000000000000000 },
+ { 16006649143245042., 41.000000000000000 },
+ { 42447960921368504., 42.000000000000000 },
+ { 1.1263482901669667e+17, 43.000000000000000 },
+ { 2.9904447186323366e+17, 44.000000000000000 },
+ { 7.9439160357044531e+17, 45.000000000000000 },
+ { 2.1113423886478239e+18, 46.000000000000000 },
+ { 5.6143296808103434e+18, 47.000000000000000 },
+ { 1.4936302131129930e+19, 48.000000000000000 },
+ { 3.9754427479037444e+19, 49.000000000000000 },
+ { 1.0585636897131690e+20, 50.000000000000000 },
+};
+
+// Test function.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_expint<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::expint(Tp(data001[i].x));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/compile.cc
new file mode 100644
index 00000000000..17f5a76649b
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/compile.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.15 expint
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+
+ std::tr1::expint(xf);
+ std::tr1::expintf(xf);
+ std::tr1::expint(xd);
+ std::tr1::expint(xl);
+ std::tr1::expintl(xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/compile_2.cc
new file mode 100644
index 00000000000..901aa9fbc76
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/15_expint/compile_2.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.15 expint
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+
+ expint(xf);
+ expintf(xf);
+ expint(xd);
+ expint(xl);
+ expintl(xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/check_nan.cc
new file mode 100644
index 00000000000..8d06a964d79
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/check_nan.cc
@@ -0,0 +1,59 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.4 hermite
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+
+ float xf = std::numeric_limits<float>::quiet_NaN();
+ double xd = std::numeric_limits<double>::quiet_NaN();
+ long double xl = std::numeric_limits<long double>::quiet_NaN();
+
+ unsigned int n = 5;
+
+ float a = std::tr1::hermite(n, xf);
+ float b = std::tr1::hermitef(n, xf);
+ double c = std::tr1::hermite(n, xd);
+ long double d = std::tr1::hermite(n, xl);
+ long double e = std::tr1::hermitel(n, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/compile.cc
new file mode 100644
index 00000000000..ac6484ba8d1
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/compile.cc
@@ -0,0 +1,44 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.16 hermite
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+ float xf = 2.5F;
+ double xd = 2.5;
+ long double xl = 2.5L;
+
+ unsigned int n = 5;
+
+ std::tr1::hermite(n, xf);
+ std::tr1::hermitef(n, xf);
+ std::tr1::hermite(n, xd);
+ std::tr1::hermite(n, xl);
+ std::tr1::hermitel(n, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/compile_2.cc
new file mode 100644
index 00000000000..301b5df8d93
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/16_hermite/compile_2.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.16 hermite
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+ float xf = 2.5F;
+ double xd = 2.5;
+ long double xl = 2.5L;
+ unsigned int n = 5;
+
+ hermite(n, xf);
+ hermitef(n, xf);
+ hermite(n, xd);
+ hermite(n, xl);
+ hermitel(n, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/check_nan.cc
new file mode 100644
index 00000000000..e120e520355
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/check_nan.cc
@@ -0,0 +1,173 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.17 hyperg
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+ float af = std::numeric_limits<float>::quiet_NaN();
+ double ad = std::numeric_limits<double>::quiet_NaN();
+ long double al = std::numeric_limits<long double>::quiet_NaN();
+
+ float bf = 10.0F;
+ double bd = 10.0;
+ long double bl = 10.0L;
+
+ float cf = 3.0F;
+ double cd = 3.0;
+ long double cl = 3.0L;
+
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+
+ float a = std::tr1::hyperg(af, bf, cf, xf);
+ float b = std::tr1::hypergf(af, bf, cf, xf);
+ double c = std::tr1::hyperg(ad, bd, cd, xd);
+ long double d = std::tr1::hyperg(al, bl, cl, xl);
+ long double e = std::tr1::hypergl(al, bl, cl, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+void
+test02()
+{
+ float af = 2.0F;
+ double ad = 2.0;
+ long double al = 2.0L;
+
+ float bf = std::numeric_limits<float>::quiet_NaN();
+ double bd = std::numeric_limits<double>::quiet_NaN();
+ long double bl = std::numeric_limits<long double>::quiet_NaN();
+
+ float cf = 3.0F;
+ double cd = 3.0;
+ long double cl = 3.0L;
+
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+
+ float a = std::tr1::hyperg(af, bf, cf, xf);
+ float b = std::tr1::hypergf(af, bf, cf, xf);
+ double c = std::tr1::hyperg(ad, bd, cd, xd);
+ long double d = std::tr1::hyperg(al, bl, cl, xl);
+ long double e = std::tr1::hypergl(al, bl, cl, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+void
+test03()
+{
+ float af = 2.0F;
+ double ad = 2.0;
+ long double al = 2.0L;
+
+ float bf = 10.0F;
+ double bd = 10.0;
+ long double bl = 10.0L;
+
+ float cf = std::numeric_limits<float>::quiet_NaN();
+ double cd = std::numeric_limits<double>::quiet_NaN();
+ long double cl = std::numeric_limits<long double>::quiet_NaN();
+
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+
+ float a = std::tr1::hyperg(af, bf, cf, xf);
+ float b = std::tr1::hypergf(af, bf, cf, xf);
+ double c = std::tr1::hyperg(ad, bd, cd, xd);
+ long double d = std::tr1::hyperg(al, bl, cl, xl);
+ long double e = std::tr1::hypergl(al, bl, cl, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+void
+test04()
+{
+ float af = 2.0F;
+ double ad = 2.0;
+ long double al = 2.0L;
+
+ float bf = 10.0F;
+ double bd = 10.0;
+ long double bl = 10.0L;
+
+ float cf = 3.0F;
+ double cd = 3.0;
+ long double cl = 3.0L;
+
+ float xf = std::numeric_limits<float>::quiet_NaN();
+ double xd = std::numeric_limits<double>::quiet_NaN();
+ long double xl = std::numeric_limits<long double>::quiet_NaN();
+
+ float a = std::tr1::hyperg(af, bf, cf, xf);
+ float b = std::tr1::hypergf(af, bf, cf, xf);
+ double c = std::tr1::hyperg(ad, bd, cd, xd);
+ long double d = std::tr1::hyperg(al, bl, cl, xl);
+ long double e = std::tr1::hypergl(al, bl, cl, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ test02();
+ test03();
+ test04();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/check_value.cc
new file mode 100644
index 00000000000..d453b19b8e0
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/check_value.cc
@@ -0,0 +1,17196 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// hyperg
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for a=0.0000000000000000, b=0.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data001[] = {
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=0.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data001[i].a), Tp(data001[i].b),
+ Tp(data001[i].c), Tp(data001[i].x));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=0.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data002[] = {
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=0.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data002[i].a), Tp(data002[i].b),
+ Tp(data002[i].c), Tp(data002[i].x));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=0.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data003[] = {
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=0.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data003[i].a), Tp(data003[i].b),
+ Tp(data003[i].c), Tp(data003[i].x));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=0.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data004[] = {
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=0.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data004[i].a), Tp(data004[i].b),
+ Tp(data004[i].c), Tp(data004[i].x));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=0.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data005[] = {
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=0.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data005[i].a), Tp(data005[i].b),
+ Tp(data005[i].c), Tp(data005[i].x));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=0.50000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data006[] = {
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=0.50000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data006[i].a), Tp(data006[i].b),
+ Tp(data006[i].c), Tp(data006[i].x));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=0.50000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data007[] = {
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=0.50000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data007[i].a), Tp(data007[i].b),
+ Tp(data007[i].c), Tp(data007[i].x));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=0.50000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data008[] = {
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=0.50000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data008[i].a), Tp(data008[i].b),
+ Tp(data008[i].c), Tp(data008[i].x));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=0.50000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data009[] = {
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=0.50000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test009()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data009)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data009[i].a), Tp(data009[i].b),
+ Tp(data009[i].c), Tp(data009[i].x));
+ const Tp f0 = data009[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=0.50000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data010[] = {
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=0.50000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test010()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data010)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data010[i].a), Tp(data010[i].b),
+ Tp(data010[i].c), Tp(data010[i].x));
+ const Tp f0 = data010[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=1.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data011[] = {
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=1.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test011()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data011)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data011[i].a), Tp(data011[i].b),
+ Tp(data011[i].c), Tp(data011[i].x));
+ const Tp f0 = data011[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=1.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data012[] = {
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=1.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test012()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data012)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data012[i].a), Tp(data012[i].b),
+ Tp(data012[i].c), Tp(data012[i].x));
+ const Tp f0 = data012[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=1.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data013[] = {
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=1.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test013()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data013)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data013[i].a), Tp(data013[i].b),
+ Tp(data013[i].c), Tp(data013[i].x));
+ const Tp f0 = data013[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=1.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data014[] = {
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=1.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test014()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data014)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data014[i].a), Tp(data014[i].b),
+ Tp(data014[i].c), Tp(data014[i].x));
+ const Tp f0 = data014[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=1.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data015[] = {
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=1.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test015()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data015)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data015[i].a), Tp(data015[i].b),
+ Tp(data015[i].c), Tp(data015[i].x));
+ const Tp f0 = data015[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=2.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data016[] = {
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=2.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test016()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data016)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data016[i].a), Tp(data016[i].b),
+ Tp(data016[i].c), Tp(data016[i].x));
+ const Tp f0 = data016[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=2.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data017[] = {
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=2.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test017()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data017)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data017[i].a), Tp(data017[i].b),
+ Tp(data017[i].c), Tp(data017[i].x));
+ const Tp f0 = data017[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=2.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data018[] = {
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=2.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test018()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data018)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data018[i].a), Tp(data018[i].b),
+ Tp(data018[i].c), Tp(data018[i].x));
+ const Tp f0 = data018[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=2.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data019[] = {
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=2.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test019()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data019)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data019[i].a), Tp(data019[i].b),
+ Tp(data019[i].c), Tp(data019[i].x));
+ const Tp f0 = data019[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=2.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data020[] = {
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=2.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test020()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data020)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data020[i].a), Tp(data020[i].b),
+ Tp(data020[i].c), Tp(data020[i].x));
+ const Tp f0 = data020[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=5.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data021[] = {
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=5.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test021()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data021)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data021[i].a), Tp(data021[i].b),
+ Tp(data021[i].c), Tp(data021[i].x));
+ const Tp f0 = data021[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=5.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data022[] = {
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=5.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test022()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data022)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data022[i].a), Tp(data022[i].b),
+ Tp(data022[i].c), Tp(data022[i].x));
+ const Tp f0 = data022[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=5.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data023[] = {
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=5.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test023()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data023)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data023[i].a), Tp(data023[i].b),
+ Tp(data023[i].c), Tp(data023[i].x));
+ const Tp f0 = data023[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=5.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data024[] = {
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=5.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test024()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data024)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data024[i].a), Tp(data024[i].b),
+ Tp(data024[i].c), Tp(data024[i].x));
+ const Tp f0 = data024[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=5.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data025[] = {
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=5.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test025()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data025)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data025[i].a), Tp(data025[i].b),
+ Tp(data025[i].c), Tp(data025[i].x));
+ const Tp f0 = data025[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=10.000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data026[] = {
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=10.000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test026()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data026)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data026[i].a), Tp(data026[i].b),
+ Tp(data026[i].c), Tp(data026[i].x));
+ const Tp f0 = data026[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=10.000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data027[] = {
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=10.000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test027()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data027)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data027[i].a), Tp(data027[i].b),
+ Tp(data027[i].c), Tp(data027[i].x));
+ const Tp f0 = data027[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=10.000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data028[] = {
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=10.000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test028()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data028)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data028[i].a), Tp(data028[i].b),
+ Tp(data028[i].c), Tp(data028[i].x));
+ const Tp f0 = data028[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=10.000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data029[] = {
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=10.000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test029()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data029)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data029[i].a), Tp(data029[i].b),
+ Tp(data029[i].c), Tp(data029[i].x));
+ const Tp f0 = data029[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=10.000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data030[] = {
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=10.000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test030()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data030)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data030[i].a), Tp(data030[i].b),
+ Tp(data030[i].c), Tp(data030[i].x));
+ const Tp f0 = data030[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=20.000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data031[] = {
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=20.000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test031()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data031)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data031[i].a), Tp(data031[i].b),
+ Tp(data031[i].c), Tp(data031[i].x));
+ const Tp f0 = data031[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=20.000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data032[] = {
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=20.000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test032()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data032)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data032[i].a), Tp(data032[i].b),
+ Tp(data032[i].c), Tp(data032[i].x));
+ const Tp f0 = data032[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=20.000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data033[] = {
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=20.000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test033()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data033)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data033[i].a), Tp(data033[i].b),
+ Tp(data033[i].c), Tp(data033[i].x));
+ const Tp f0 = data033[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=20.000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data034[] = {
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=20.000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test034()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data034)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data034[i].a), Tp(data034[i].b),
+ Tp(data034[i].c), Tp(data034[i].x));
+ const Tp f0 = data034[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.0000000000000000, b=20.000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data035[] = {
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.0000000000000000, b=20.000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test035()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data035)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data035[i].a), Tp(data035[i].b),
+ Tp(data035[i].c), Tp(data035[i].x));
+ const Tp f0 = data035[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=0.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data036[] = {
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=0.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test036()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data036)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data036[i].a), Tp(data036[i].b),
+ Tp(data036[i].c), Tp(data036[i].x));
+ const Tp f0 = data036[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=0.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data037[] = {
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=0.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test037()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data037)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data037[i].a), Tp(data037[i].b),
+ Tp(data037[i].c), Tp(data037[i].x));
+ const Tp f0 = data037[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=0.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data038[] = {
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=0.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test038()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data038)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data038[i].a), Tp(data038[i].b),
+ Tp(data038[i].c), Tp(data038[i].x));
+ const Tp f0 = data038[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=0.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data039[] = {
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=0.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test039()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data039)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data039[i].a), Tp(data039[i].b),
+ Tp(data039[i].c), Tp(data039[i].x));
+ const Tp f0 = data039[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=0.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data040[] = {
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 0.50000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=0.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test040()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data040)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data040[i].a), Tp(data040[i].b),
+ Tp(data040[i].c), Tp(data040[i].x));
+ const Tp f0 = data040[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=0.50000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data041[] = {
+ { 0.91383715388743758, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.92151232618202283, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.92955086110354823, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.93798900119104844, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.94686887307107304, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.95623987262143295, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.96616049387450154, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.97670078782187519, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.98794573712298384, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0129947682256604, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.0270980168168973, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.0425304520063581, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.0595915916161471, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.0787052023767585, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.1005053642285867, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.1260196351148746, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1.1571341977338991, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.1982111053717450, 0.50000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=0.50000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test041()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data041)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data041[i].a), Tp(data041[i].b),
+ Tp(data041[i].c), Tp(data041[i].x));
+ const Tp f0 = data041[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=0.50000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data042[] = {
+ { 0.95255425675562733, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.95712841850078245, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.96184734120034532, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.96672141255196242, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.97176228710138646, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.97698311668286286, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.98239883902556069, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.98802654401961032, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.99388594556732701, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0063957328951061, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0131053706824598, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0201679332118803, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.0276315524377497, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.0355569942816882, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.0440233080381554, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.0531375808028993, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.0630536689840200, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.0740149570414563, 0.50000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=0.50000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test042()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data042)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data042[i].a), Tp(data042[i].b),
+ Tp(data042[i].c), Tp(data042[i].x));
+ const Tp f0 = data042[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=0.50000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data043[] = {
+ { 0.96694084713323891, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.97024454918852587, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.97362815600391461, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.97709622064205115, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.98065374770570624, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.98430626119885489, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.98805988669621037, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.99192145185739655, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.99589861079880937, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0042354366729904, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0086161755545404, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0131552481403503, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0178679218284707, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.0227723400312978, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.0278904483717863, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.0332494012993472, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.0388838453357794, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.0448400142331342, 0.50000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=0.50000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test043()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data043)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data043[i].a), Tp(data043[i].b),
+ Tp(data043[i].c), Tp(data043[i].x));
+ const Tp f0 = data043[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=0.50000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data044[] = {
+ { 0.97456073259047449, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.97715689327833344, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.97980416868943099, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.98250498942832509, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.98526199049760832, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.98807803762902813, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.99095625840920332, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.99390007937387959, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.99691327061866730, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0031648997547440, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0064131494767281, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0097505810668461, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0131838138968663, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0167204326938339, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0203692279382193, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.0241405318057402, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.0280467087844301, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.0321029179180026, 0.50000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=0.50000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test044()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data044)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data044[i].a), Tp(data044[i].b),
+ Tp(data044[i].c), Tp(data044[i].x));
+ const Tp f0 = data044[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=0.50000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data045[] = {
+ { 0.97930223035212161, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.98144406855076416, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.98362155940297302, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.98583616201745805, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.98808944235385077, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.99038308530635433, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.99271890872975732, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.99509887982916734, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.99752513445413604, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0025260228440118, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0051060015613384, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0077430276253163, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0104405359789990, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0132023689128868, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0160328583559475, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0189369344885053, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0219202735809589, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.0249895076611382, 0.50000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=0.50000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test045()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data045)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data045[i].a), Tp(data045[i].b),
+ Tp(data045[i].c), Tp(data045[i].x));
+ const Tp f0 = data045[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=1.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data046[] = {
+ { 0.84089972268671609, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.85410196624968437, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.86811566011579933, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.88303688022450544, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.89897948556635565, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.91607978309961580, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.93450283399425305, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.95445115010332193, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.97617696340303095, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0263340389897240, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.0557280900008410, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.0889331564394962, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.1270166537925830, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.1715728752538095, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.2251482265544145, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.2922212642709541, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1.3819660112501042, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.5194938532959119, 0.50000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=1.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test046()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data046)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data046[i].a), Tp(data046[i].b),
+ Tp(data046[i].c), Tp(data046[i].x));
+ const Tp f0 = data046[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=1.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data047[] = {
+ { 0.90992197313391499, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.91822592662244507, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.92687104566419531, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.93588628166548815, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.94530459215552909, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.95516374875247467, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.96550736800511827, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.97638624595136270, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.98786011482678993, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0128914530682316, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0266391040215350, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0413732738729464, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.0572599536532992, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.0745166004060953, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.0934387388831386, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.1144486980714641, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.1381966011250106, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.1658171625342397, 0.50000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=1.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test047()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data047)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data047[i].a), Tp(data047[i].b),
+ Tp(data047[i].c), Tp(data047[i].x));
+ const Tp f0 = data047[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=1.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data048[] = {
+ { 0.93641908369732885, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.94256349654111315, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.94890138508461319, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.95544578858430007, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.96221121193620718, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.96921386948293542, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.97647198488394704, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.98400616412578656, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.99183986544963032, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0085177124149158, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0174294150407122, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0267781897388850, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0366157405967285, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.0470052068648839, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.0580253905513313, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.0697774741209765, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.0823965556448414, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.0960739512057103, 0.50000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=1.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test048()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data048)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data048[i].a), Tp(data048[i].b),
+ Tp(data048[i].c), Tp(data048[i].x));
+ const Tp f0 = data048[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=1.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data049[] = {
+ { 0.95069883346936235, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.95559618047704165, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.96061938755931653, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.96577553912851344, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.97107239473807716, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.97651848528588503, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.98212322830227139, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.98789706736195781, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.99385164237825074, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0063568569383123, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0129389344715818, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0197653907773940, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0268583912277143, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0342438793937092, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0419526514766855, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.0500219124976327, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.0584976491907043, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.0674385240268101, 0.50000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=1.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test049()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data049)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data049[i].a), Tp(data049[i].b),
+ Tp(data049[i].c), Tp(data049[i].x));
+ const Tp f0 = data049[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=1.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data050[] = {
+ { 0.95968319138913893, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.96376169072755768, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.96792900082729316, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.97218942798115737, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.97654763592586857, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.98100869054353856, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.98557811238699278, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.99026193885795544, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.99506679842072221, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0050696417919618, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0102847452747090, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0156554225057022, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0211930882963096, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0269107343740711, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0328232917216298, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0389481230247195, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0453057164134614, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.0519207114461246, 0.50000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=1.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test050()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data050)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data050[i].a), Tp(data050[i].b),
+ Tp(data050[i].c), Tp(data050[i].x));
+ const Tp f0 = data050[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=2.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data051[] = {
+ { 0.72547625011001171, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.74535599249992990, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.76696498884737041, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.79056941504209477, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.81649658092772603, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.84515425472851657, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.87705801930702920, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.91287092917527690, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.95346258924559224, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0540925533894598, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.1180339887498949, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.1952286093343938, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.2909944487358056, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.4142135623730949, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.5811388300841900, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.8257418583505536, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 2.2360679774997898, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 3.1622776601683782, 0.50000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=2.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test051()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data051)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data051[i].a), Tp(data051[i].b),
+ Tp(data051[i].c), Tp(data051[i].x));
+ const Tp f0 = data051[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=2.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data052[] = {
+ { 0.83664260086443798, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.85046584300227146, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.86509574979651593, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.88062082573041867, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.89714464248521586, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.91478946588967558, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.93370105322348573, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.95405511057700887, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.97606616007978142, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0261916902334731, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0550723519434702, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0872106588188091, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.1233801699379020, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.1646752981725688, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.2127272514219511, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.2701518651068637, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.3416407864998725, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.4374795179111102, 0.50000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=2.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test052()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data052)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data052[i].a), Tp(data052[i].b),
+ Tp(data052[i].c), Tp(data052[i].x));
+ const Tp f0 = data052[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=2.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data053[] = {
+ { 0.88195381730235833, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.89265078469555093, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.90382937908303707, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.91553161389880577, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.92780530349281576, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.94070521140346042, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.95429450630523349, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.96864663325785849, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.98384775588541795, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0172258496884334, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0356742479163459, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0555293036908924, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0770231491562379, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.1004557416484888, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.1262270515731978, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.1548932919125086, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.1872757758134724, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.2247091713458949, 0.50000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=2.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test053()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data053)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data053[i].a), Tp(data053[i].b),
+ Tp(data053[i].c), Tp(data053[i].x));
+ const Tp f0 = data053[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=2.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data054[] = {
+ { 0.90716919697107301, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.91592299407142519, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.92500027075874236, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.93442464185467167, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.94422248683737009, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.95442341810133347, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.96506085725516400, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.97617275213704069, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.98780247986309799, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0128233505813447, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0263406246541855, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0406326381700366, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0557966239802845, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0719515075786321, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0892457392422055, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.1078695188000958, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.1280752258974340, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.1502152002706476, 0.50000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=2.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test054()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data054)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data054[i].a), Tp(data054[i].b),
+ Tp(data054[i].c), Tp(data054[i].x));
+ const Tp f0 = data054[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=2.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data055[] = {
+ { 0.92336416053263093, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.93078397248364519, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.93843714333600226, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.94633837784068076, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.95450388104967909, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.96295158125742764, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.97170139827854296, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.98077556918512687, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.99019904777750845, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0102104261941198, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0208669540935695, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0320118665407505, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0436944599504387, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0559728828278145, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0689166967761712, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0826105758119842, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0971599106346146, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.1126998828023964, 0.50000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=2.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test055()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data055)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data055[i].a), Tp(data055[i].b),
+ Tp(data055[i].c), Tp(data055[i].x));
+ const Tp f0 = data055[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=5.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data056[] = {
+ { 0.52275983209457511, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.54700336898142965, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.57468955512601971, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.60665490543315015, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.64403057859056123, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.68838183648623719, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.74193265039311085, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.80794095908995300, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.89135275749639320, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.1469266219310688, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.3552340708357489, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.6690840478838305, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 2.1815415453174483, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 3.1156892546032235, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 5.1109077417760416, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 10.560352936466296, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 33.541019662496815, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 300.66343065819501, 0.50000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=5.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test056()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data056)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data056[i].a), Tp(data056[i].b),
+ Tp(data056[i].c), Tp(data056[i].x));
+ const Tp f0 = data056[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=5.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data057[] = {
+ { 0.68252041951139264, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.70394732624993395, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.72748884971552041, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.75351147371199689, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.78247589005573748, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.81497017420249818, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.85175826875009564, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.89385278481745867, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.94262778709507411, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0687327277420910, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.1529725508983291, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.2592587134058799, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.3985773194637892, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.5909902576697317, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.8776023607249752, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 2.3582499003694646, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 3.3541019662496838, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 6.7198400278577859, 0.50000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=5.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test057()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data057)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data057[i].a), Tp(data057[i].b),
+ Tp(data057[i].c), Tp(data057[i].x));
+ const Tp f0 = data057[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=5.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data058[] = {
+ { 0.75755211927082589, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.77603550233010998, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.79596241913438492, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.81753360792105201, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.84099165409805521, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.86663303852180873, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.89482475828629970, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.92602774279590350, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.96083064727087386, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0445570841313008, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0959004638926031, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.1560106261370562, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.2278121770678145, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.3158640214709998, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.4278095344155000, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.5778700502946612, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.7972173289196469, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 2.1789970569269732, 0.50000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=5.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test058()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data058)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data058[i].a), Tp(data058[i].b),
+ Tp(data058[i].c), Tp(data058[i].x));
+ const Tp f0 = data058[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=5.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data059[] = {
+ { 0.80270093579329471, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.81884974572462788, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.83605266330015271, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.85443340762795972, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.87413762182790655, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.89533826626907331, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.91824276674115268, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.94310265050720576, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.97022678857609712, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0329098673199812, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0695865684573389, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.1108642103944570, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.1578795055970506, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.2122394794169442, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.2763274721556934, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.3539179650251021, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.4515986118197148, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.5829284571614219, 0.50000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=5.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test059()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data059)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data059[i].a), Tp(data059[i].b),
+ Tp(data059[i].c), Tp(data059[i].x));
+ const Tp f0 = data059[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=5.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data060[] = {
+ { 0.83322694172301959, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.84753931604765664, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.86265784532195022, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.87866479300707079, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.89565516540263501, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.91373946207610557, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.93304721345881891, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.95373159512905148, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.97597554238828121, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0260752851887982, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0545371197996178, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0858099017045830, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.1204416568688709, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.1591587835964847, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.2029564720303347, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.2532588722007874, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.3122319926925459, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.3834948587364100, 0.50000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=5.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test060()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data060)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data060[i].a), Tp(data060[i].b),
+ Tp(data060[i].c), Tp(data060[i].x));
+ const Tp f0 = data060[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=10.000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data061[] = {
+ { 0.37727530159464628, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.39816010922169010, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.42283703041362453, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.45255640448730505, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.48919507154431141, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.53569358917731880, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.59689778897029566, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.68128587569875731, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.80478739308790359, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.3408664196153621, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 2.0175364359923860, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 3.6011214553736646, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 8.1799429939495312, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 25.644834637536000, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 123.13738891597615, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1088.7122410321333, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 27358.291704709951, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 8174369.0266731177, 0.50000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=10.000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test061()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data061)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data061[i].a), Tp(data061[i].b),
+ Tp(data061[i].c), Tp(data061[i].x));
+ const Tp f0 = data061[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=10.000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data062[] = {
+ { 0.53905528308450834, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.56235533974376162, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.58887657983263575, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.61941227047262915, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.65504896640793853, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.69731666644529999, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.74844073299399128, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.81178446800105752, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.89266981277598023, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.1497248473106778, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.3729717112654571, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.7374982340374392, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 2.4134479340960580, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 3.9191255240471192, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 8.3316373077761270, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 28.323020339843335, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 225.84286572747891, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 12757.127591286655, 0.50000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=10.000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test062()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data062)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data062[i].a), Tp(data062[i].b),
+ Tp(data062[i].c), Tp(data062[i].x));
+ const Tp f0 = data062[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=10.000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data063[] = {
+ { 0.62672622092226071, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.64931010269769829, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.67448067519076316, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.70276306239803676, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.73484179773087555, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.77162761412743897, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.81436116844816531, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.86477994787944557, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.92539820516603888, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0945599448210315, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.2190897395597264, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.3916844336856475, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.6484497630432013, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 2.0717772717131155, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 2.8893613630810924, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 4.9459404075413529, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 13.487394149998716, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 136.57616044013972, 0.50000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=10.000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test063()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data063)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data063[i].a), Tp(data063[i].b),
+ Tp(data063[i].c), Tp(data063[i].x));
+ const Tp f0 = data063[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=10.000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data064[] = {
+ { 0.68421604440344341, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.70548098055548891, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.72884342311710348, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.75466953437856243, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.78342090924662600, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.81568884278645049, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.85224480241465206, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.89411692571131696, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.94270986892954756, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0688682849120232, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.1537004376097553, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.2615455028370031, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.4045541456153436, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.6057216489444517, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.9146603020550739, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 2.4617931307620298, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 3.7267799624996498, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 9.3880118036248401, 0.50000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=10.000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test064()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data064)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data064[i].a), Tp(data064[i].b),
+ Tp(data064[i].c), Tp(data064[i].x));
+ const Tp f0 = data064[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=10.000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data065[] = {
+ { 0.72547625011001171, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.74535599249992990, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.76696498884737041, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.79056941504209477, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.81649658092772603, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.84515425472851657, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.87705801930702920, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.91287092917527690, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.95346258924559224, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0540925533894598, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.1180339887498949, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.1952286093343938, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.2909944487358056, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.4142135623730949, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.5811388300841900, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.8257418583505536, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 2.2360679774997898, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 3.1622776601683782, 0.50000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=10.000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test065()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data065)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data065[i].a), Tp(data065[i].b),
+ Tp(data065[i].c), Tp(data065[i].x));
+ const Tp f0 = data065[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=20.000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data066[] = {
+ { 0.26690449940521566, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.28252302866181805, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.30123616141153819, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.32421384687602628, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.35334630811776752, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.39191793127467034, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.44620488618129206, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.52980896919265685, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.67754711477562357, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.9567557771780317, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 6.1816042148333086, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 35.653088618561227, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 377.51482843179906, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 7645.8816551195359, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 354791.74537980522, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 57009889.966638684, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 83771357024.863937, 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 25866972896376408., 0.50000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=20.000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test066()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data066)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data066[i].a), Tp(data066[i].b),
+ Tp(data066[i].c), Tp(data066[i].x));
+ const Tp f0 = data066[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=20.000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data067[] = {
+ { 0.40342659436153405, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.42420571192034318, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.44852768286073008, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.47751245808592863, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.51283632632707754, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.55713468814894307, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.61481320817757312, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.69383483410097202, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.81012002526006033, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.3622225506603911, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 2.2349513086109001, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 5.1864917536761723, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 21.020560423779411, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 175.19649997100612, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 3467.1587803688708, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 225003.88683445856, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 110837674.65652709, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 6688966964170.6807, 0.50000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=20.000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test067()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data067)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data067[i].a), Tp(data067[i].b),
+ Tp(data067[i].c), Tp(data067[i].x));
+ const Tp f0 = data067[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=20.000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data068[] = {
+ { 0.48716309885816761, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.50965859152542281, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.53554809210658971, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.56576689207507136, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.60164849637133688, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.64516711595404375, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.69938278735493542, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.76931621518401860, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.86381808725530695, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.2152051956815531, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.6052546785425543, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 2.4765586046012635, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 5.1564492216997486, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 18.446158392136365, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 150.44577670123971, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 3862.6317400115768, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 632428.34833625401, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 7426927663.3808765, 0.50000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=20.000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test068()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data068)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data068[i].a), Tp(data068[i].b),
+ Tp(data068[i].c), Tp(data068[i].x));
+ const Tp f0 = data068[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=20.000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data069[] = {
+ { 0.54703266209548362, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.56997321774144971, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.59603026159654970, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.62596978851120511, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.66084565876898926, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.70215256667232839, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.75208916592008568, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.81403631111658648, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.89348608489854608, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.1517793185139173, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.3878110313656598, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.8061071794572381, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 2.7148594517859586, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 5.4529435709049361, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 19.487310275377109, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 191.69079165937470, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 10218.543981792311, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 23160836.646583911, 0.50000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=20.000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test069()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data069)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data069[i].a), Tp(data069[i].b),
+ Tp(data069[i].c), Tp(data069[i].x));
+ const Tp f0 = data069[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=0.50000000000000000, b=20.000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data070[] = {
+ { 0.59292067298616002, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.61572496720679915, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.64135339122875623, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.67043457419280483, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.70380956268170980, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.74263251901495231, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.78853555445528278, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.84391122775673766, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.91242401018807406, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.1169059681274873, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.2825928301302667, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.5385937789924939, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.9895771187893898, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 2.9707335806970168, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 6.0299506157180467, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 24.259090336955577, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 406.27267173257223, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 174330.03997220192, 0.50000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=0.50000000000000000, b=20.000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test070()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data070)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data070[i].a), Tp(data070[i].b),
+ Tp(data070[i].c), Tp(data070[i].x));
+ const Tp f0 = data070[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=0.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data071[] = {
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=0.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test071()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data071)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data071[i].a), Tp(data071[i].b),
+ Tp(data071[i].c), Tp(data071[i].x));
+ const Tp f0 = data071[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=0.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data072[] = {
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=0.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test072()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data072)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data072[i].a), Tp(data072[i].b),
+ Tp(data072[i].c), Tp(data072[i].x));
+ const Tp f0 = data072[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=0.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data073[] = {
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=0.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test073()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data073)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data073[i].a), Tp(data073[i].b),
+ Tp(data073[i].c), Tp(data073[i].x));
+ const Tp f0 = data073[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=0.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data074[] = {
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=0.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test074()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data074)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data074[i].a), Tp(data074[i].b),
+ Tp(data074[i].c), Tp(data074[i].x));
+ const Tp f0 = data074[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=0.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data075[] = {
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 1.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=0.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test075()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data075)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data075[i].a), Tp(data075[i].b),
+ Tp(data075[i].c), Tp(data075[i].x));
+ const Tp f0 = data075[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=0.50000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data076[] = {
+ { 0.84089972268671609, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.85410196624968437, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.86811566011579933, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.88303688022450544, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.89897948556635565, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.91607978309961580, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.93450283399425305, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.95445115010332193, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.97617696340303095, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0263340389897240, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.0557280900008410, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.0889331564394962, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.1270166537925830, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.1715728752538095, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.2251482265544145, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.2922212642709541, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1.3819660112501042, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.5194938532959119, 1.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=0.50000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test076()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data076)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data076[i].a), Tp(data076[i].b),
+ Tp(data076[i].c), Tp(data076[i].x));
+ const Tp f0 = data076[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=0.50000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data077[] = {
+ { 0.90992197313391499, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.91822592662244507, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.92687104566419531, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.93588628166548815, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.94530459215552909, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.95516374875247467, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.96550736800511827, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.97638624595136270, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.98786011482678993, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0128914530682316, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0266391040215350, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0413732738729464, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.0572599536532992, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.0745166004060953, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.0934387388831386, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.1144486980714641, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.1381966011250106, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.1658171625342397, 1.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=0.50000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test077()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data077)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data077[i].a), Tp(data077[i].b),
+ Tp(data077[i].c), Tp(data077[i].x));
+ const Tp f0 = data077[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=0.50000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data078[] = {
+ { 0.93641908369732885, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.94256349654111315, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.94890138508461319, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.95544578858430007, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.96221121193620718, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.96921386948293542, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.97647198488394704, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.98400616412578656, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.99183986544963032, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0085177124149158, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0174294150407122, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0267781897388850, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0366157405967285, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.0470052068648839, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.0580253905513313, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.0697774741209765, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.0823965556448414, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.0960739512057103, 1.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=0.50000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test078()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data078)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data078[i].a), Tp(data078[i].b),
+ Tp(data078[i].c), Tp(data078[i].x));
+ const Tp f0 = data078[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=0.50000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data079[] = {
+ { 0.95069883346936235, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.95559618047704165, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.96061938755931653, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.96577553912851344, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.97107239473807716, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.97651848528588503, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.98212322830227139, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.98789706736195781, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.99385164237825074, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0063568569383123, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0129389344715818, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0197653907773940, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0268583912277143, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0342438793937092, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0419526514766855, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.0500219124976327, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.0584976491907043, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.0674385240268101, 1.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=0.50000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test079()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data079)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data079[i].a), Tp(data079[i].b),
+ Tp(data079[i].c), Tp(data079[i].x));
+ const Tp f0 = data079[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=0.50000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data080[] = {
+ { 0.95968319138913893, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.96376169072755768, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.96792900082729316, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.97218942798115737, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.97654763592586857, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.98100869054353856, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.98557811238699278, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.99026193885795544, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.99506679842072221, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0050696417919618, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0102847452747090, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0156554225057022, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0211930882963096, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0269107343740711, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0328232917216298, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0389481230247195, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0453057164134614, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.0519207114461246, 1.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=0.50000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test080()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data080)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data080[i].a), Tp(data080[i].b),
+ Tp(data080[i].c), Tp(data080[i].x));
+ const Tp f0 = data080[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=1.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data081[] = {
+ { 0.71317098463599404, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.73473333112764871, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.75804035866024377, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.78333938207622600, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.81093021621632877, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.84118059155303226, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.87454754822497005, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.91160778396977304, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.95310179804324857, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0536051565782629, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.1157177565710485, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.1889164797957747, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.2770640594149765, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.3862943611198899, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.5271512197902593, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.7199611490370503, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 2.0117973905426232, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 2.5584278811044912, 1.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=1.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test081()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data081)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data081[i].a), Tp(data081[i].b),
+ Tp(data081[i].c), Tp(data081[i].x));
+ const Tp f0 = data081[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=1.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data082[] = {
+ { 0.83165649828125576, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.84626246650116577, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.86165287670267410, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.87790681762615241, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.89511583784087689, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.91338673957393823, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.93284521667331954, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.95364066873549813, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.97595268969924187, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0260530485179122, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0544523154103413, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0856358366643180, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.1201824010510930, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.1588830833596719, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.2028682930536780, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.2538561433469468, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.3147120107267418, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.3910528844853491, 1.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=1.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test082()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data082)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data082[i].a), Tp(data082[i].b),
+ Tp(data082[i].c), Tp(data082[i].x));
+ const Tp f0 = data082[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=1.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data083[] = {
+ { 0.87917686994924527, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.89033956110358414, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.90196195126098366, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.91408080149514692, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.92673756761314952, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.93997926630123407, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.95385955885019291, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.96844012412988900, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.98379242268046208, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0171615499181177, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0353950776091037, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0548437030651112, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0756840039415978, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.0981384722661196, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.1224950318916129, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.1491396357184527, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.1786158344507012, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.2117500593515478, 1.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=1.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test083()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data083)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data083[i].a), Tp(data083[i].b),
+ Tp(data083[i].c), Tp(data083[i].x));
+ const Tp f0 = data083[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=1.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data084[] = {
+ { 0.90538259348578409, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.91444830598832050, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.92381915945974002, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.93351553488501815, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.94356001859234884, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.95397775039949584, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.96479684710618019, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.97604892281308531, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.98776973540356938, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0127864273812119, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0261830717772533, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0402531144740719, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0550712790827002, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0707271945059007, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0873302420658923, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.1050168587085545, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.1239622188477687, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.1444006183097781, 1.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=1.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test084()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data084)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data084[i].a), Tp(data084[i].b),
+ Tp(data084[i].c), Tp(data084[i].x));
+ const Tp f0 = data084[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=1.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data085[] = {
+ { 0.92211295632330403, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.92975727737040659, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.93761992348333467, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.94571346180587801, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.95405164371146867, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.96264956879205954, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.97152388013493096, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.98069299877709348, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.99017740778385854, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0101865087004833, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0207660479892111, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0317718013185031, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0432419144892398, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0552206786504446, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0677601383233675, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0809223485579968, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0947826783002668, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.1094349304493603, 1.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=1.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test085()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data085)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data085[i].a), Tp(data085[i].b),
+ Tp(data085[i].c), Tp(data085[i].x));
+ const Tp f0 = data085[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=2.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data086[] = {
+ { 0.52631578947368429, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.55555555555555558, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.58823529411764708, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.62500000000000000, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.66666666666666663, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.71428571428571430, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.76923076923076927, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.83333333333333337, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.90909090909090906, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.1111111111111112, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.2500000000000000, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.4285714285714286, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.6666666666666663, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 2.0000000000000000, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 2.5000000000000004, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 3.3333333333333330, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 5.0000000000000009, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 9.9999999999999929, 1.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=2.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test086()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data086)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data086[i].a), Tp(data086[i].b),
+ Tp(data086[i].c), Tp(data086[i].x));
+ const Tp f0 = data086[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=2.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data087[] = {
+ { 0.70351947549341520, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.72637503722092711, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.75099661564391251, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.77761647796730871, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.80651221621216451, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.83801894346580275, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.87254582050258467, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.91059888544083678, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.95281329145592386, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0532154477379738, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.1138692114741471, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.1838976095305187, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.2660586631630237, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.3644676665613118, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.4856585347316102, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.6409590443536872, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.8528798927325769, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 2.1789423102929644, 1.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=2.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test087()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data087)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data087[i].a), Tp(data087[i].b),
+ Tp(data087[i].c), Tp(data087[i].x));
+ const Tp f0 = data087[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=2.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data088[] = {
+ { 0.78068027379106253, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.79924541976981278, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.81891305585650942, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.83979799626213270, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.86203315303160166, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.88577352485361693, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.91120135738402208, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.93853291956703588, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.96802755388922956, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0348375559194773, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0730246119544820, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.1151788396279341, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.1621066403893472, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.2148922218710421, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.2750496810838674, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.3448048570872917, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.4276833109859521, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.5299976259379788, 1.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=2.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test088()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data088)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data088[i].a), Tp(data088[i].b),
+ Tp(data088[i].c), Tp(data088[i].x));
+ const Tp f0 = data088[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=2.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data089[] = {
+ { 0.82510759951857582, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.84072786892782092, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.85710884896562356, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.87431674418118333, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.89242659229727017, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.91152392685930339, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.93170685950993570, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.95308871926790661, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.97580144325325802, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0258682619030324, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0536269616706000, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0835447330793833, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.1159538758396654, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.1512736659291880, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.1900463690116090, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.2329961591622411, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.2811334345669059, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.3359629014132051, 1.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=2.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test089()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data089)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data089[i].a), Tp(data089[i].b),
+ Tp(data089[i].c), Tp(data089[i].x));
+ const Tp f0 = data089[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=2.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data090[] = {
+ { 0.85426123653345876, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.86774543390930370, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.88178859537254239, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.89643269097060951, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.91172456687216763, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.92771674975966134, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.94446842993888647, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.96204667481937678, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.98052794339012128, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0205643671068179, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0423395201078882, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0654651277885334, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0901078068101382, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.1164691415928940, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.1447972335326551, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.1754040384534161, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.2086928679893112, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.2452055640510711, 1.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=2.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test090()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data090)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data090[i].a), Tp(data090[i].b),
+ Tp(data090[i].c), Tp(data090[i].x));
+ const Tp f0 = data090[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=5.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data091[] = {
+ { 0.25646288779245091, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.28273129096174382, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.31438201170962976, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.35308837890625017, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.40123456790123463, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.46230737192836319, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.54156016946185359, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.64718364197530875, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.79246636158732342, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.3103947568968148, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.8017578125000004, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 2.6374427321949185, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 4.1975308641975282, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 7.4999999999999964, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 15.859375000000012, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 43.734567901234513, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 194.99999999999994, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 2777.4999999999832, 1.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=5.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test091()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data091)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data091[i].a), Tp(data091[i].b),
+ Tp(data091[i].c), Tp(data091[i].x));
+ const Tp f0 = data091[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=5.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data092[] = {
+ { 0.46398891966759004, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.49382716049382713, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.52768166089965396, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.56640624999999978, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.61111111111111116, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.66326530612244894, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.72485207100591698, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.79861111111111094, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.88842975206611552, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.1419753086419753, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.3281249999999998, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.5816326530612239, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.9444444444444444, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 2.5000000000000000, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 3.4374999999999996, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 5.2777777777777715, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 9.9999999999999947, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 32.499999999999837, 1.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=5.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test092()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data092)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data092[i].a), Tp(data092[i].b),
+ Tp(data092[i].c), Tp(data092[i].x));
+ const Tp f0 = data092[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=5.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data093[] = {
+ { 0.57476744883397501, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.60302731682513933, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.63425708719096396, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.66895764182970419, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.70775063063963428, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.75141762103495924, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.80095569442603298, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.85765823887436754, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.92323549576335540, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0911622464839472, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.2013226178607666, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.3373332072682687, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.5099074378209716, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.7368822229245819, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 2.0505871832661429, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 2.5172389775867967, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 3.3015631983556144, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 5.0005935155044519, 1.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=5.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test093()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data093)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data093[i].a), Tp(data093[i].b),
+ Tp(data093[i].c), Tp(data093[i].x));
+ const Tp f0 = data093[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=5.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data094[] = {
+ { 0.64582752605387961, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.67184161997264169, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.70012779922368040, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.73100784656910256, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.76486919089091077, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.80218301124334579, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.84352883533234446, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.88962858902212572, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.94139473468584123, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0669812691939897, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.1443996012177726, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.2350966976721314, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.3431264370409088, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.4745266814162399, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.6388137104840066, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.8522074849776518, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 2.1458016978417458, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 2.5927464669826339, 1.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=5.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test094()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data094)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data094[i].a), Tp(data094[i].b),
+ Tp(data094[i].c), Tp(data094[i].x));
+ const Tp f0 = data094[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=5.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data095[] = {
+ { 0.69583236336670629, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.71968920666899694, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.74533885416044232, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.77300145361503014, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.80293630810919514, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.83545132638592035, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.87091544744412508, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.90977522877919847, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.95257738192069130, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0528968282789379, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.1123617169062123, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.1798254572896132, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.2572069000522696, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.3471600884974377, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.4535032279573519, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.5820245752814948, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.7421756366906538, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.9513145531098233, 1.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=5.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test095()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data095)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data095[i].a), Tp(data095[i].b),
+ Tp(data095[i].c), Tp(data095[i].x));
+ const Tp f0 = data095[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=10.000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data096[] = {
+ { 0.12307420104127871, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.13818870041457423, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.15739165631811691, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.18249038606882068, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.21644171225027786, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.26433326159804160, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.33544459430654533, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.44788516696232517, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.63989153514168362, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.7568608796813312, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 3.5836558871799027, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 8.8077526749963226, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 27.285841702089190, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 113.55555555555557, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 706.24023437500091, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 8064.1687976651992, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 271267.22222222196, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 123456789.99999890, 1.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=10.000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test096()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data096)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data096[i].a), Tp(data096[i].b),
+ Tp(data096[i].c), Tp(data096[i].x));
+ const Tp f0 = data096[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=10.000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data097[] = {
+ { 0.28363728383055758, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.30933003169808387, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.33998437757128797, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.37713553224291119, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.42299736538419658, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.48086597727600106, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.55583495759293045, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.65612850114039667, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.79573668772968120, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.3184712058058303, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.8576958065941214, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 2.8759509651764228, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 5.1046225531822182, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 11.095238095238095, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 32.797154017857174, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 158.01935680536477, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1815.9523809523814, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 163302.14285714156, 1.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=10.000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test097()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data097)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data097[i].a), Tp(data097[i].b),
+ Tp(data097[i].c), Tp(data097[i].x));
+ const Tp f0 = data097[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=10.000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data098[] = {
+ { 0.39006633302741794, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.41898885698103294, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.45245557983812590, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.49160548618861633, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.53798419230517980, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.59373881442067344, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.66193391357076115, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.74708402736952129, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.85609281019430605, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.1974451135148187, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.4820886036706347, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.9201183180477521, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 2.6569338297733336, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 4.0634920634920650, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 7.3102678571428568, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 17.512574302697733, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 74.206349206349131, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1342.8571428571363, 1.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=10.000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test098()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data098)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data098[i].a), Tp(data098[i].b),
+ Tp(data098[i].c), Tp(data098[i].x));
+ const Tp f0 = data098[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=10.000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data099[] = {
+ { 0.46726928123633193, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.49687547629934464, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.53045208856322235, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.56884765624999978, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.61316872427983526, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.66488500161969544, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.72598998634501577, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.79925411522633782, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.88863845062192193, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.1423563481176653, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.3302951388888888, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.5889212827988335, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.9650205761316870, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 2.5555555555555549, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 3.5937500000000013, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 5.7818930041152203, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 12.222222222222220, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 54.999999999999780, 1.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=10.000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test099()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data099)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data099[i].a), Tp(data099[i].b),
+ Tp(data099[i].c), Tp(data099[i].x));
+ const Tp f0 = data099[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=10.000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data100[] = {
+ { 0.52631578947368429, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.55555555555555558, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.58823529411764708, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.62500000000000000, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.66666666666666663, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.71428571428571430, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.76923076923076927, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.83333333333333337, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.90909090909090906, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.1111111111111112, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.2500000000000000, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.4285714285714286, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.6666666666666663, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 2.0000000000000000, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 2.5000000000000004, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 3.3333333333333330, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 5.0000000000000009, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 9.9999999999999929, 1.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=10.000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test100()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data100)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data100[i].a), Tp(data100[i].b),
+ Tp(data100[i].c), Tp(data100[i].x));
+ const Tp f0 = data100[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=20.000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data101[] = {
+ { 0.058479236576646373, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.065788544763137669, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.075184824937824662, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.087707688693157260, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.10521567442213345, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.13135877960541525, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.17423854066297104, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.25492082527223525, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.44025895219654843, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 3.3698615820910360, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 17.997089220808483, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 153.73298291118951, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 2159.1667587825627, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 55188.105263157879, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 3191209.3921857267, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 646910975.29152656, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1254834626850.2659, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 5.8479532163741414e+17, 1.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=20.000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test101()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data101)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data101[i].a), Tp(data101[i].b),
+ Tp(data101[i].c), Tp(data101[i].x));
+ const Tp f0 = data101[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=20.000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data102[] = {
+ { 0.15519511120894947, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.17197165701692899, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.19276847315207363, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.21920107206179093, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.25386158960390581, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.30115970686600657, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.36916408142057117, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.47406175901569558, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.65237908266239919, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.8227213362622299, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 4.3716358339791332, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 15.670841312959222, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 94.742651122760179, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1081.7275541795671, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 27809.787731465960, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 2329811.1715181042, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1537787532.6780224, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 141562653506999.88, 1.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=20.000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test102()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data102)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data102[i].a), Tp(data102[i].b),
+ Tp(data102[i].c), Tp(data102[i].x));
+ const Tp f0 = data102[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=20.000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data103[] = {
+ { 0.23253645591196570, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.25484220947068353, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.28181987881113829, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.31508211677735765, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.35706285886959599, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.41160053409238195, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.48508083111181949, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.58885194371375260, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.74482241684585748, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.4700356864367146, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 2.4955144453055143, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 5.3506594845833471, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 16.618413752184221, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 89.310629514963878, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1029.3439900542960, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 35659.847863372350, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 8009309.6233230168, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 145640590027.39731, 1.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=20.000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test103()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data103)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data103[i].a), Tp(data103[i].b),
+ Tp(data103[i].c), Tp(data103[i].x));
+ const Tp f0 = data103[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=20.000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data104[] = {
+ { 0.29614148314592498, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.32176277356430810, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.35217870475550522, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.38885270445515091, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.43389978380608424, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.49048612522269436, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.56355539635634611, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.66123153239117682, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.79773363961895427, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.3245132157016595, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.9065148749742076, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 3.1328798652457452, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 6.4172532944033476, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 19.071683734222436, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 104.41989641582512, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1510.5743992324240, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 115518.14360562043, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 414930455.29173034, 1.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=20.000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test104()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data104)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data104[i].a), Tp(data104[i].b),
+ Tp(data104[i].c), Tp(data104[i].x));
+ const Tp f0 = data104[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=1.0000000000000000, b=20.000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data105[] = {
+ { 0.34954259539177696, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.37714038609235123, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.40942091659748725, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.44767109606846428, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.49368984777532254, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.55006638216982318, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.62065830207408912, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.71145554513583786, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.83223839666914623, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.2466748028187731, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.6386752725021749, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 2.3340068725479681, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 3.7848108613132054, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 7.6754638550304133, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 23.344217312927277, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 149.83491198246921, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 3936.9253501916060, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 2794143.5036480185, 1.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=1.0000000000000000, b=20.000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test105()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data105)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data105[i].a), Tp(data105[i].b),
+ Tp(data105[i].c), Tp(data105[i].x));
+ const Tp f0 = data105[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=0.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data106[] = {
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=0.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test106()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data106)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data106[i].a), Tp(data106[i].b),
+ Tp(data106[i].c), Tp(data106[i].x));
+ const Tp f0 = data106[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=0.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data107[] = {
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=0.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test107()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data107)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data107[i].a), Tp(data107[i].b),
+ Tp(data107[i].c), Tp(data107[i].x));
+ const Tp f0 = data107[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=0.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data108[] = {
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=0.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test108()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data108)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data108[i].a), Tp(data108[i].b),
+ Tp(data108[i].c), Tp(data108[i].x));
+ const Tp f0 = data108[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=0.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data109[] = {
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=0.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test109()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data109)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data109[i].a), Tp(data109[i].b),
+ Tp(data109[i].c), Tp(data109[i].x));
+ const Tp f0 = data109[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=0.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data110[] = {
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 2.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=0.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test110()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data110)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data110[i].a), Tp(data110[i].b),
+ Tp(data110[i].c), Tp(data110[i].x));
+ const Tp f0 = data110[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=0.50000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data111[] = {
+ { 0.72547625011001171, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.74535599249992990, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.76696498884737041, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.79056941504209477, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.81649658092772603, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.84515425472851657, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.87705801930702920, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.91287092917527690, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.95346258924559224, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0540925533894598, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.1180339887498949, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.1952286093343938, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.2909944487358056, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.4142135623730949, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.5811388300841900, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.8257418583505536, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 2.2360679774997898, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 3.1622776601683782, 2.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=0.50000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test111()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data111)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data111[i].a), Tp(data111[i].b),
+ Tp(data111[i].c), Tp(data111[i].x));
+ const Tp f0 = data111[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=0.50000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data112[] = {
+ { 0.83664260086443798, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.85046584300227146, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.86509574979651593, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.88062082573041867, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.89714464248521586, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.91478946588967558, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.93370105322348573, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.95405511057700887, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.97606616007978142, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0261916902334731, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0550723519434702, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0872106588188091, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.1233801699379020, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.1646752981725688, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.2127272514219511, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.2701518651068637, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.3416407864998725, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.4374795179111102, 2.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=0.50000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test112()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data112)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data112[i].a), Tp(data112[i].b),
+ Tp(data112[i].c), Tp(data112[i].x));
+ const Tp f0 = data112[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=0.50000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data113[] = {
+ { 0.88195381730235833, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.89265078469555093, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.90382937908303707, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.91553161389880577, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.92780530349281576, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.94070521140346042, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.95429450630523349, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.96864663325785849, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.98384775588541795, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0172258496884334, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0356742479163459, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0555293036908924, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0770231491562379, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.1004557416484888, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.1262270515731978, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.1548932919125086, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.1872757758134724, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.2247091713458949, 2.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=0.50000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test113()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data113)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data113[i].a), Tp(data113[i].b),
+ Tp(data113[i].c), Tp(data113[i].x));
+ const Tp f0 = data113[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=0.50000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data114[] = {
+ { 0.90716919697107301, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.91592299407142519, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.92500027075874236, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.93442464185467167, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.94422248683737009, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.95442341810133347, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.96506085725516400, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.97617275213704069, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.98780247986309799, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0128233505813447, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0263406246541855, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0406326381700366, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0557966239802845, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0719515075786321, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0892457392422055, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.1078695188000958, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.1280752258974340, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.1502152002706476, 2.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=0.50000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test114()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data114)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data114[i].a), Tp(data114[i].b),
+ Tp(data114[i].c), Tp(data114[i].x));
+ const Tp f0 = data114[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=0.50000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data115[] = {
+ { 0.92336416053263093, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.93078397248364519, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.93843714333600226, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.94633837784068076, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.95450388104967909, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.96295158125742764, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.97170139827854296, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.98077556918512687, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.99019904777750845, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0102104261941198, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0208669540935695, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0320118665407505, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0436944599504387, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0559728828278145, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0689166967761712, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0826105758119842, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0971599106346146, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.1126998828023964, 2.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=0.50000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test115()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data115)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data115[i].a), Tp(data115[i].b),
+ Tp(data115[i].c), Tp(data115[i].x));
+ const Tp f0 = data115[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=1.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data116[] = {
+ { 0.52631578947368429, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.55555555555555558, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.58823529411764708, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.62500000000000000, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.66666666666666663, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.71428571428571430, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.76923076923076927, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.83333333333333337, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.90909090909090906, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.1111111111111112, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.2500000000000000, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.4285714285714286, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.6666666666666663, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 2.0000000000000000, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 2.5000000000000004, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 3.3333333333333330, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 5.0000000000000009, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 9.9999999999999929, 2.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=1.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test116()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data116)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data116[i].a), Tp(data116[i].b),
+ Tp(data116[i].c), Tp(data116[i].x));
+ const Tp f0 = data116[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=1.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data117[] = {
+ { 0.70351947549341520, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.72637503722092711, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.75099661564391251, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.77761647796730871, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.80651221621216451, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.83801894346580275, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.87254582050258467, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.91059888544083678, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.95281329145592386, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0532154477379738, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.1138692114741471, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.1838976095305187, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.2660586631630237, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.3644676665613118, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.4856585347316102, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.6409590443536872, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.8528798927325769, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 2.1789423102929644, 2.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=1.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test117()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data117)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data117[i].a), Tp(data117[i].b),
+ Tp(data117[i].c), Tp(data117[i].x));
+ const Tp f0 = data117[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=1.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data118[] = {
+ { 0.78068027379106253, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.79924541976981278, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.81891305585650942, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.83979799626213270, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.86203315303160166, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.88577352485361693, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.91120135738402208, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.93853291956703588, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.96802755388922956, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0348375559194773, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0730246119544820, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.1151788396279341, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.1621066403893472, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.2148922218710421, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.2750496810838674, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.3448048570872917, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.4276833109859521, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.5299976259379788, 2.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=1.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test118()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data118)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data118[i].a), Tp(data118[i].b),
+ Tp(data118[i].c), Tp(data118[i].x));
+ const Tp f0 = data118[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=1.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data119[] = {
+ { 0.82510759951857582, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.84072786892782092, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.85710884896562356, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.87431674418118333, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.89242659229727017, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.91152392685930339, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.93170685950993570, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.95308871926790661, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.97580144325325802, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0258682619030324, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0536269616706000, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0835447330793833, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.1159538758396654, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.1512736659291880, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.1900463690116090, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.2329961591622411, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.2811334345669059, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.3359629014132051, 2.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=1.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test119()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data119)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data119[i].a), Tp(data119[i].b),
+ Tp(data119[i].c), Tp(data119[i].x));
+ const Tp f0 = data119[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=1.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data120[] = {
+ { 0.85426123653345876, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.86774543390930370, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.88178859537254239, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.89643269097060951, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.91172456687216763, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.92771674975966134, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.94446842993888647, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.96204667481937678, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.98052794339012128, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0205643671068179, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0423395201078882, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0654651277885334, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0901078068101382, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.1164691415928940, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.1447972335326551, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.1754040384534161, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.2086928679893112, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.2452055640510711, 2.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=1.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test120()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data120)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data120[i].a), Tp(data120[i].b),
+ Tp(data120[i].c), Tp(data120[i].x));
+ const Tp f0 = data120[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=2.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data121[] = {
+ { 0.27700831024930750, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.30864197530864196, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.34602076124567477, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.39062499999999994, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.44444444444444442, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.51020408163265307, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.59171597633136097, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.69444444444444453, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.82644628099173545, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.2345679012345681, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.5624999999999998, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 2.0408163265306127, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 2.7777777777777768, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 4.0000000000000000, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 6.2500000000000036, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 11.111111111111109, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 25.000000000000007, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 99.999999999999872, 2.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=2.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test121()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data121)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data121[i].a), Tp(data121[i].b),
+ Tp(data121[i].c), Tp(data121[i].x));
+ const Tp f0 = data121[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=2.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data122[] = {
+ { 0.50515448477320868, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.53674994210078020, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.57194655162437447, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.61137322330312327, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.65581297297972574, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.70625323977290932, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.76395739449542643, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.83056871002513311, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.90826553449323655, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.1098784992198341, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.2437942741831700, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.4105343768544543, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.6238435648986016, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.9065970003160624, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 2.3001951284393627, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 2.8891774744673464, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 3.8827206436045336, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 6.0316345867773542, 2.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=2.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test122()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data122)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data122[i].a), Tp(data122[i].b),
+ Tp(data122[i].c), Tp(data122[i].x));
+ const Tp f0 = data122[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=2.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data123[] = {
+ { 0.61824560969673303, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.64645665839161048, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.67712272792612083, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.71058076074636822, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.74723387423852861, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.78756892188863126, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.83218012557592713, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.88180144818204143, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.93735184459468934, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0712594799044883, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.1531330932162096, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.2483404191094898, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.3606934909972501, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.4957544469027071, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.6620777107871287, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.8738132387064506, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 2.1570670242247409, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 2.5700735959225494, 2.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=2.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test123()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data123)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data123[i].a), Tp(data123[i].b),
+ Tp(data123[i].c), Tp(data123[i].x));
+ const Tp f0 = data123[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=2.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data124[] = {
+ { 0.68776713859043437, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.71280582849489826, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.73962983054724929, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.76844343025262085, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.79948476671182911, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.83303347721461229, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.86942060391338782, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.90904161711581655, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.95237381468647742, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0526413941912305, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.1112045278881502, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.1768500306393046, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.2510971588297888, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.3359896747789315, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.4343740183432725, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.5504011881337365, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.6905307012604318, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.8658920279264424, 2.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=2.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test124()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data124)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data124[i].a), Tp(data124[i].b),
+ Tp(data124[i].c), Tp(data124[i].x));
+ const Tp f0 = data124[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=2.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data125[] = {
+ { 0.73530262886958830, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.75768898977673638, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.78143483544640069, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.80667428603297209, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.83356078772438325, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.86227093001346145, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.89300925500556994, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.92601438873425990, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.96156696230910810, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0417127776179342, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0871896789480930, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.1370264514689949, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.1919677804049154, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.2529628761065934, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.3212511796458866, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.3985017309668506, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.4870567523847895, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.5904049523738040, 2.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=2.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test125()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data125)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data125[i].a), Tp(data125[i].b),
+ Tp(data125[i].c), Tp(data125[i].x));
+ const Tp f0 = data125[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=5.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data126[] = {
+ { 0.040386107340619266, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.052922149401344633, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.070429627772374270, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.095367431640624972, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.13168724279835387, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.18593443208187066, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.26932907434290437, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.40187757201646096, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.62092132305915493, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.6935087808430296, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 3.0517578124999991, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 5.9499018266198629, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 12.860082304526737, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 32.000000000000000, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 97.656250000000114, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 411.52263374485580, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 3124.9999999999991, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 99999.999999999665, 2.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=5.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test126()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data126)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data126[i].a), Tp(data126[i].b),
+ Tp(data126[i].c), Tp(data126[i].x));
+ const Tp f0 = data126[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=5.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data127[] = {
+ { 0.21140107887447140, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.24005486968449935, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.27478119275391821, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.31738281249999994, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.37037037037037035, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.43731778425655982, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.52344105598543444, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.63657407407407429, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.78888054094665638, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.3031550068587108, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.7578125000000002, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 2.4781341107871717, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 3.7037037037037037, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 5.9999999999999982, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 10.937500000000005, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 24.074074074074076, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 74.999999999999957, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 549.99999999999670, 2.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=5.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test127()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data127)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data127[i].a), Tp(data127[i].b),
+ Tp(data127[i].c), Tp(data127[i].x));
+ const Tp f0 = data127[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=5.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data128[] = {
+ { 0.33250915203252107, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.36566851047721960, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.40414812182437942, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.44916943268118470, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.50233081077479569, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.56575808728873322, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.64233106844971422, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.73603371116919514, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.85251256240112439, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.1909065696197674, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.4447095285569311, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.7935243137840653, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 2.2937035820494454, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 3.0524711083016687, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 4.2976512669354259, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 6.5977107563194677, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 11.793747206577530, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 29.997625937982058, 2.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=5.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test128()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data128)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data128[i].a), Tp(data128[i].b),
+ Tp(data128[i].c), Tp(data128[i].x));
+ const Tp f0 = data128[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=5.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data129[] = {
+ { 0.42108197362250305, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.45503172013983051, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.49345609813624303, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.53720880551221295, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.58736431524847466, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.64529222467897962, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.71276337354393904, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.79210466220795306, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.88643063455510596, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.1387832139040652, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.3114025920844752, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.5307655016768162, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.8170727950333345, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 2.2037865486700836, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 2.7506766056439380, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 3.5764534935716972, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 4.9587762302155403, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 7.7740847924166800, 2.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=5.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test129()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data129)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data129[i].a), Tp(data129[i].b),
+ Tp(data129[i].c), Tp(data129[i].x));
+ const Tp f0 = data129[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=5.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data130[] = {
+ { 0.48860241312958425, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.52193382517068487, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.55902375003954219, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.60049055150230346, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.64709127927203480, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.69976233335368998, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.75967529501081055, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.82831498895254407, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.90759090169653933, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.1088712278667465, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.2387445478440853, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.3959812720437546, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.5897930661091164, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.8340789380307454, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 2.1509548085970764, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 2.5782406951207504, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 3.1877847194242737, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 4.1421596631676900, 2.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=5.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test130()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data130)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data130[i].a), Tp(data130[i].b),
+ Tp(data130[i].c), Tp(data130[i].x));
+ const Tp f0 = data130[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=10.000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data131[] = {
+ { 0.0016310376661280216, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.0028007538972582421, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.0049603324681551939, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.0090949470177292789, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.017341529915832606, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.034571613033607777, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.072538150286405714, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.16150558288984579, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.38554328942953148, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 2.8679719907924444, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 9.3132257461547816, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 35.401331746414378, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 165.38171687920172, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1024.0000000000000, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 9536.7431640625200, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 169350.87808430271, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 9765624.9999999944, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 9999999999.9999332, 2.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=10.000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test131()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data131)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data131[i].a), Tp(data131[i].b),
+ Tp(data131[i].c), Tp(data131[i].x));
+ const Tp f0 = data131[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=10.000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data132[] = {
+ { 0.071191280690193509, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.085646504654238079, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.10478215656371073, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.13074816337653575, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.16701141666848116, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.21939323375313971, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.29813515331786627, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.42225974638874386, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.62942145962174867, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.7218685262373197, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 3.2855760483514689, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 7.1616652508907093, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 18.612326808485907, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 61.476190476190474, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 286.27580915178623, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 2274.9441142102296, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 47229.761904761865, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 9961460.7142856438, 2.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=10.000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test132()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data132)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data132[i].a), Tp(data132[i].b),
+ Tp(data132[i].c), Tp(data132[i].x));
+ const Tp f0 = data132[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=10.000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data133[] = {
+ { 0.14747230019381052, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.17073600100690603, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.19982795745135354, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.23681776864188067, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.28475624360398022, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.34827500743063144, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.43464829159684681, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.55576053438064787, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.73195020913445485, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.4310223867822929, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 2.1742563399057540, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 3.5769231236256043, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 6.5620441134844363, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 14.063492063492063, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 38.085937500000036, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 150.92973632068282, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1212.3015873015852, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 55107.142857142389, 2.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=10.000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test133()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data133)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data133[i].a), Tp(data133[i].b),
+ Tp(data133[i].c), Tp(data133[i].x));
+ const Tp f0 = data133[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=10.000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data134[] = {
+ { 0.21658059714090588, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.24513539602702844, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.27967018274845046, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.32196044921874994, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.37448559670781900, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.44078856032208796, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.52606701446027815, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.63818158436214001, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.78944971882612769, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.3044251384443430, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.7659505208333335, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 2.5093710953769270, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 3.8065843621399158, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 6.3333333333333313, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 12.109375000000004, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 29.115226337448540, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 108.33333333333330, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1224.9999999999923, 2.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=10.000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test134()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data134)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data134[i].a), Tp(data134[i].b),
+ Tp(data134[i].c), Tp(data134[i].x));
+ const Tp f0 = data134[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=10.000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data135[] = {
+ { 0.27700831024930750, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.30864197530864196, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.34602076124567477, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.39062499999999994, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.44444444444444442, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.51020408163265307, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.59171597633136097, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.69444444444444453, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.82644628099173545, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.2345679012345681, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.5624999999999998, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 2.0408163265306127, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 2.7777777777777768, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 4.0000000000000000, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 6.2500000000000036, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 11.111111111111109, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 25.000000000000007, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 99.999999999999872, 2.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=10.000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test135()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data135)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data135[i].a), Tp(data135[i].b),
+ Tp(data135[i].c), Tp(data135[i].x));
+ const Tp f0 = data135[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=20.000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data136[] = {
+ { 2.6602838683283435e-06, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 7.8442223930072316e-06, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 2.4604898194634598e-05, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 8.2718061255302686e-05, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.00030072865982171723, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.0011951964277455193, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.0052617832469731814, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.026084053304588847, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.14864362802414346, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 8.2252633399699757, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 86.736173798840269, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1253.2542894196865, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 27351.112277912434, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1048576.0000000000, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 90949470.177293226, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 28679719907.924358, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 95367431640624.906, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 9.9999999999998657e+19, 2.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=20.000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test136()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data136)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data136[i].a), Tp(data136[i].b),
+ Tp(data136[i].c), Tp(data136[i].x));
+ const Tp f0 = data136[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for a=2.0000000000000000, b=20.000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data137[] = {
+ { 0.018828092583720951, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.023381944060455316, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.029789623984280793, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.039191021482500497, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.053727813036721514, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.077762010061669024, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.12110505620123302, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.20870149809080590, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.41429234328785769, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 3.1308087404153113, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 13.586180626453050, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 87.117304082784415, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 889.26474381242826, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 16231.913312693494, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 653537.51168945129, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 87756230.793848589, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 101493977171.74945, 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 21375960679556916., 2.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=20.000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test137()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data137)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data137[i].a), Tp(data137[i].b),
+ Tp(data137[i].c), Tp(data137[i].x));
+ const Tp f0 = data137[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for a=2.0000000000000000, b=20.000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data138[] = {
+ { 0.049200410661854252, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.059460876757152226, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.073244762686653350, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.092334626017932922, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.11976760350696837, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.16102414609169383, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.22670456785796222, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.33912903252727361, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.55049794600858060, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 2.1254722872032232, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 5.6261213886736172, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 20.137315891130996, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 108.04381584643853, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 992.41692466460245, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 19055.363816004465, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1105471.9504312086, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 448521363.90608919, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 19078917293639.004, 2.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=20.000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test138()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data138)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data138[i].a), Tp(data138[i].b),
+ Tp(data138[i].c), Tp(data138[i].x));
+ const Tp f0 = data138[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for a=2.0000000000000000, b=20.000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data139[] = {
+ { 0.083753547015334745, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.099238444687035701, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.11938294012867758, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.14622683905023326, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.18303556733713025, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.23527764069382409, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.31261681740827085, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.43327581880538862, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.63445840637296658, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.7438842395813297, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 3.5070840938209269, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 8.6573372006089713, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 28.779342118408906, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 147.50178613955714, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1427.1686016136398, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 36780.643714655642, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 5313869.6058585485, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 46057280607.381966, 2.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=20.000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test139()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data139)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data139[i].a), Tp(data139[i].b),
+ Tp(data139[i].c), Tp(data139[i].x));
+ const Tp f0 = data139[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=2.0000000000000000, b=20.000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data140[] = {
+ { 0.11920045035073683, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.13907946814302774, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.16431439792559688, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.19698796016987008, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.24028510928790570, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.29926031296483119, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.38229327814229169, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.50402047283093110, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.69167261179586503, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.5503152253394308, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 2.6469548193635797, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 5.1882631330566813, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 12.476792759124516, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 41.026391565091259, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 220.92584715988204, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 2677.0834450236207, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 141774.31260689779, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 254267148.83196995, 2.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=2.0000000000000000, b=20.000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test140()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data140)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data140[i].a), Tp(data140[i].b),
+ Tp(data140[i].c), Tp(data140[i].x));
+ const Tp f0 = data140[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=0.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data141[] = {
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=0.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test141()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data141)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data141[i].a), Tp(data141[i].b),
+ Tp(data141[i].c), Tp(data141[i].x));
+ const Tp f0 = data141[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=0.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data142[] = {
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=0.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test142()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data142)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data142[i].a), Tp(data142[i].b),
+ Tp(data142[i].c), Tp(data142[i].x));
+ const Tp f0 = data142[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=0.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data143[] = {
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=0.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test143()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data143)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data143[i].a), Tp(data143[i].b),
+ Tp(data143[i].c), Tp(data143[i].x));
+ const Tp f0 = data143[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=0.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data144[] = {
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=0.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test144()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data144)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data144[i].a), Tp(data144[i].b),
+ Tp(data144[i].c), Tp(data144[i].x));
+ const Tp f0 = data144[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=0.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data145[] = {
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 5.0000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=0.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test145()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data145)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data145[i].a), Tp(data145[i].b),
+ Tp(data145[i].c), Tp(data145[i].x));
+ const Tp f0 = data145[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=0.50000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data146[] = {
+ { 0.52275983209457511, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.54700336898142965, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.57468955512601971, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.60665490543315015, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.64403057859056123, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.68838183648623719, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.74193265039311085, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.80794095908995300, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.89135275749639320, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.1469266219310688, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.3552340708357489, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.6690840478838305, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 2.1815415453174483, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 3.1156892546032235, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 5.1109077417760416, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 10.560352936466296, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 33.541019662496815, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 300.66343065819501, 5.0000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=0.50000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test146()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data146)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data146[i].a), Tp(data146[i].b),
+ Tp(data146[i].c), Tp(data146[i].x));
+ const Tp f0 = data146[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=0.50000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data147[] = {
+ { 0.68252041951139264, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.70394732624993395, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.72748884971552041, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.75351147371199689, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.78247589005573748, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.81497017420249818, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.85175826875009564, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.89385278481745867, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.94262778709507411, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0687327277420910, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.1529725508983291, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.2592587134058799, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.3985773194637892, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.5909902576697317, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.8776023607249752, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 2.3582499003694646, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 3.3541019662496838, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 6.7198400278577859, 5.0000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=0.50000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test147()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data147)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data147[i].a), Tp(data147[i].b),
+ Tp(data147[i].c), Tp(data147[i].x));
+ const Tp f0 = data147[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=0.50000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data148[] = {
+ { 0.75755211927082589, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.77603550233010998, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.79596241913438492, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.81753360792105201, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.84099165409805521, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.86663303852180873, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.89482475828629970, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.92602774279590350, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.96083064727087386, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0445570841313008, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0959004638926031, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.1560106261370562, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.2278121770678145, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.3158640214709998, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.4278095344155000, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.5778700502946612, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.7972173289196469, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 2.1789970569269732, 5.0000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=0.50000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test148()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data148)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data148[i].a), Tp(data148[i].b),
+ Tp(data148[i].c), Tp(data148[i].x));
+ const Tp f0 = data148[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=0.50000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data149[] = {
+ { 0.80270093579329471, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.81884974572462788, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.83605266330015271, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.85443340762795972, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.87413762182790655, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.89533826626907331, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.91824276674115268, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.94310265050720576, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.97022678857609712, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0329098673199812, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0695865684573389, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.1108642103944570, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.1578795055970506, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.2122394794169442, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.2763274721556934, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.3539179650251021, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.4515986118197148, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.5829284571614219, 5.0000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=0.50000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test149()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data149)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data149[i].a), Tp(data149[i].b),
+ Tp(data149[i].c), Tp(data149[i].x));
+ const Tp f0 = data149[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=0.50000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data150[] = {
+ { 0.83322694172301959, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.84753931604765664, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.86265784532195022, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.87866479300707079, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.89565516540263501, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.91373946207610557, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.93304721345881891, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.95373159512905148, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.97597554238828121, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0260752851887982, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0545371197996178, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0858099017045830, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.1204416568688709, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.1591587835964847, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.2029564720303347, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.2532588722007874, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.3122319926925459, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.3834948587364100, 5.0000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=0.50000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test150()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data150)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data150[i].a), Tp(data150[i].b),
+ Tp(data150[i].c), Tp(data150[i].x));
+ const Tp f0 = data150[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=1.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data151[] = {
+ { 0.25646288779245091, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.28273129096174382, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.31438201170962976, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.35308837890625017, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.40123456790123463, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.46230737192836319, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.54156016946185359, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.64718364197530875, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.79246636158732342, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.3103947568968148, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.8017578125000004, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 2.6374427321949185, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 4.1975308641975282, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 7.4999999999999964, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 15.859375000000012, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 43.734567901234513, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 194.99999999999994, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 2777.4999999999832, 5.0000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=1.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test151()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data151)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data151[i].a), Tp(data151[i].b),
+ Tp(data151[i].c), Tp(data151[i].x));
+ const Tp f0 = data151[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=1.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data152[] = {
+ { 0.46398891966759004, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.49382716049382713, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.52768166089965396, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.56640624999999978, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.61111111111111116, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.66326530612244894, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.72485207100591698, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.79861111111111094, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.88842975206611552, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.1419753086419753, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.3281249999999998, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.5816326530612239, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.9444444444444444, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 2.5000000000000000, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 3.4374999999999996, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 5.2777777777777715, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 9.9999999999999947, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 32.499999999999837, 5.0000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=1.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test152()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data152)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data152[i].a), Tp(data152[i].b),
+ Tp(data152[i].c), Tp(data152[i].x));
+ const Tp f0 = data152[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=1.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data153[] = {
+ { 0.57476744883397501, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.60302731682513933, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.63425708719096396, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.66895764182970419, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.70775063063963428, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.75141762103495924, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.80095569442603298, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.85765823887436754, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.92323549576335540, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0911622464839472, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.2013226178607666, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.3373332072682687, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.5099074378209716, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.7368822229245819, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 2.0505871832661429, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 2.5172389775867967, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 3.3015631983556144, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 5.0005935155044519, 5.0000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=1.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test153()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data153)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data153[i].a), Tp(data153[i].b),
+ Tp(data153[i].c), Tp(data153[i].x));
+ const Tp f0 = data153[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=1.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data154[] = {
+ { 0.64582752605387961, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.67184161997264169, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.70012779922368040, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.73100784656910256, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.76486919089091077, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.80218301124334579, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.84352883533234446, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.88962858902212572, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.94139473468584123, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0669812691939897, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.1443996012177726, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.2350966976721314, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.3431264370409088, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.4745266814162399, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.6388137104840066, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.8522074849776518, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 2.1458016978417458, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 2.5927464669826339, 5.0000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=1.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test154()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data154)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data154[i].a), Tp(data154[i].b),
+ Tp(data154[i].c), Tp(data154[i].x));
+ const Tp f0 = data154[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=1.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data155[] = {
+ { 0.69583236336670629, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.71968920666899694, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.74533885416044232, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.77300145361503014, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.80293630810919514, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.83545132638592035, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.87091544744412508, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.90977522877919847, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.95257738192069130, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0528968282789379, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.1123617169062123, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.1798254572896132, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.2572069000522696, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.3471600884974377, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.4535032279573519, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.5820245752814948, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.7421756366906538, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.9513145531098233, 5.0000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=1.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test155()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data155)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data155[i].a), Tp(data155[i].b),
+ Tp(data155[i].c), Tp(data155[i].x));
+ const Tp f0 = data155[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=2.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data156[] = {
+ { 0.040386107340619266, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.052922149401344633, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.070429627772374270, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.095367431640624972, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.13168724279835387, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.18593443208187066, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.26932907434290437, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.40187757201646096, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.62092132305915493, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.6935087808430296, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 3.0517578124999991, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 5.9499018266198629, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 12.860082304526737, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 32.000000000000000, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 97.656250000000114, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 411.52263374485580, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 3124.9999999999991, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 99999.999999999665, 5.0000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=2.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test156()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data156)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data156[i].a), Tp(data156[i].b),
+ Tp(data156[i].c), Tp(data156[i].x));
+ const Tp f0 = data156[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=2.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data157[] = {
+ { 0.21140107887447140, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.24005486968449935, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.27478119275391821, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.31738281249999994, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.37037037037037035, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.43731778425655982, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.52344105598543444, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.63657407407407429, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.78888054094665638, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.3031550068587108, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.7578125000000002, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 2.4781341107871717, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 3.7037037037037037, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 5.9999999999999982, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 10.937500000000005, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 24.074074074074076, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 74.999999999999957, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 549.99999999999670, 5.0000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=2.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test157()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data157)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data157[i].a), Tp(data157[i].b),
+ Tp(data157[i].c), Tp(data157[i].x));
+ const Tp f0 = data157[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=2.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data158[] = {
+ { 0.33250915203252107, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.36566851047721960, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.40414812182437942, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.44916943268118470, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.50233081077479569, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.56575808728873322, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.64233106844971422, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.73603371116919514, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.85251256240112439, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.1909065696197674, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.4447095285569311, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.7935243137840653, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 2.2937035820494454, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 3.0524711083016687, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 4.2976512669354259, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 6.5977107563194677, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 11.793747206577530, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 29.997625937982058, 5.0000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=2.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test158()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data158)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data158[i].a), Tp(data158[i].b),
+ Tp(data158[i].c), Tp(data158[i].x));
+ const Tp f0 = data158[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=2.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data159[] = {
+ { 0.42108197362250305, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.45503172013983051, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.49345609813624303, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.53720880551221295, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.58736431524847466, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.64529222467897962, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.71276337354393904, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.79210466220795306, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.88643063455510596, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.1387832139040652, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.3114025920844752, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.5307655016768162, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.8170727950333345, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 2.2037865486700836, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 2.7506766056439380, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 3.5764534935716972, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 4.9587762302155403, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 7.7740847924166800, 5.0000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=2.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test159()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data159)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data159[i].a), Tp(data159[i].b),
+ Tp(data159[i].c), Tp(data159[i].x));
+ const Tp f0 = data159[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=2.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data160[] = {
+ { 0.48860241312958425, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.52193382517068487, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.55902375003954219, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.60049055150230346, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.64709127927203480, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.69976233335368998, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.75967529501081055, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.82831498895254407, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.90759090169653933, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.1088712278667465, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.2387445478440853, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.3959812720437546, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.5897930661091164, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.8340789380307454, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 2.1509548085970764, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 2.5782406951207504, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 3.1877847194242737, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 4.1421596631676900, 5.0000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=2.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test160()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data160)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data160[i].a), Tp(data160[i].b),
+ Tp(data160[i].c), Tp(data160[i].x));
+ const Tp f0 = data160[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=5.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data161[] = {
+ { -0.0047236848832209691, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { -0.0073321496427103212, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { -0.010977302557845672, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { -0.015692785382270907, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { -0.020728547477518677, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { -0.022767481479412769, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { -0.010634636868114139, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.050699832580781923, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.27045765367659280, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 3.4387055868901171, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 12.052059173583981, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 45.565319600798020, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 196.23532998018572, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1032.0000000000002, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 7376.0986328125073, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 86964.639536655843, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 2596875.0000000009, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 766224999.99999273, 5.0000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=5.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test161()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data161)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data161[i].a), Tp(data161[i].b),
+ Tp(data161[i].c), Tp(data161[i].x));
+ const Tp f0 = data161[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000015e-12));
+}
+
+// Test data for a=5.0000000000000000, b=5.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data162[] = {
+ { 0.016473280625778897, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.023520955289486407, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.034179084066004943, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.050663948059082052, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.076817558299039843, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.11952927776691676, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.19163799520552813, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.31815307784636504, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.55036208180243285, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.9287183337378946, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 4.0054321289062473, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 9.1373492337376394, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 23.576817558299005, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 71.999999999999972, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 280.76171875000023, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1611.7969821673514, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 18749.999999999996, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1224999.9999999879, 5.0000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=5.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test162()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data162)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data162[i].a), Tp(data162[i].b),
+ Tp(data162[i].c), Tp(data162[i].x));
+ const Tp f0 = data162[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for a=5.0000000000000000, b=5.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data163[] = {
+ { 0.067462409738203513, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.084813629887172517, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.10799223563666410, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.13947766136095369, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.18305927261494304, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.24468431546783445, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.33397274564972956, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.46703323887436765, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.67194346197695642, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.5503148146900136, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 2.5278200136940998, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 4.3933515329658954, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 8.3000308946110888, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 17.570215556257921, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 43.847462183266167, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 141.86909082943853, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 736.63489653168926, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 12117.500593515439, 5.0000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=5.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test163()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data163)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data163[i].a), Tp(data163[i].b),
+ Tp(data163[i].c), Tp(data163[i].x));
+ const Tp f0 = data163[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=5.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data164[] = {
+ { 0.12409443806004232, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.14886910375100412, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.18023328876836334, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.22044046981094714, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.27271160690708801, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.34174821195025840, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.43457788826160237, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.56199385898404552, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.74109892753745221, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.3869229400096228, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.9890168748121255, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 2.9741205609307424, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 4.6924751038237300, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 7.9555939380658254, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 14.933102063314404, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 32.780461638447491, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 94.848124287773530, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 523.16034401517425, 5.0000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=5.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test164()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data164)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data164[i].a), Tp(data164[i].b),
+ Tp(data164[i].c), Tp(data164[i].x));
+ const Tp f0 = data164[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=5.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data165[] = {
+ { 0.17885405888526873, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.20861302518993380, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.24504033307244924, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.29007236051133478, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.34635542859732726, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.41756858504598376, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.50892615622124382, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.62798173270509761, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.78595487360378424, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.2972517637384813, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.7224028197396388, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 2.3527690438263305, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 3.3305218060101116, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 4.9383884076775466, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 7.8007604680775229, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 13.518663719271885, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 27.285345906502567, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 75.572415101501988, 5.0000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=5.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test165()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data165)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data165[i].a), Tp(data165[i].b),
+ Tp(data165[i].c), Tp(data165[i].x));
+ const Tp f0 = data165[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=10.000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data166[] = {
+ { 0.00063586451658060152, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.0010334743461762443, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.0015326246054669515, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.0019007018181583387, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.0012845577715431577, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { -0.0027213806178058826, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { -0.015121744574954068, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { -0.036637840562974443, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.019117849062621491, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 9.8116901852350615, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 84.255589172244044, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 773.87517619421294, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 8556.9725363053585, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 129023.99999999996, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 3174543.3807373112, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 175133896.95814410, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 43564453125.000061, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 446859999999993.50, 5.0000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=10.000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test166()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data166)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data166[i].a), Tp(data166[i].b),
+ Tp(data166[i].c), Tp(data166[i].x));
+ const Tp f0 = data166[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-11));
+}
+
+// Test data for a=5.0000000000000000, b=10.000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data167[] = {
+ { -0.00030045430691819899, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { -0.00031119487747328581, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { -0.00014589213141649274, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.00056843418860809121, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.0028902549859721725, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.0098776037238877470, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.030689217428863914, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.094211590019076599, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.29791981455918376, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 3.6646308771236793, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 15.133991837501521, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 73.331330046144089, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 441.01791167787133, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 3583.9999999999991, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 45299.530029296984, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1157231.0002427341, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 107421875.00000016, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 234999999999.99734, 5.0000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=10.000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test167()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data167)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data167[i].a), Tp(data167[i].b),
+ Tp(data167[i].c), Tp(data167[i].x));
+ const Tp f0 = data167[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000014e-11));
+}
+
+// Test data for a=5.0000000000000000, b=10.000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data168[] = {
+ { 0.0058530497315411210, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.0088526869356855692, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.013770987983443108, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.022108932690960800, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.036786236450921578, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.063750669040426422, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.11577228680714464, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.22197573416125735, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.45361312968415268, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 2.4162889363082747, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 6.5381564791240399, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 20.415771011498428, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 76.870682056629221, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 373.58730158730162, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 2626.2555803571477, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 33060.960671081048, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1203521.8253968258, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 584564285.71427989, 5.0000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=10.000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test168()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data168)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data168[i].a), Tp(data168[i].b),
+ Tp(data168[i].c), Tp(data168[i].x));
+ const Tp f0 = data168[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000015e-12));
+}
+
+// Test data for a=5.0000000000000000, b=10.000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data169[] = {
+ { 0.020248990107069400, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.027876687750502421, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.039154648888447781, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.056251883506774923, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.082914189910074432, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.12585357817786477, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.19761423206224929, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.32280443863359243, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.55250024062839465, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.9374297986599267, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 4.0849049886067696, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 9.5926988633258983, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 25.958314281359531, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 85.333333333333300, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 372.31445312500028, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 2545.3436976070675, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 39583.333333333343, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 4599999.9999999627, 5.0000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=10.000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test169()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data169)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data169[i].a), Tp(data169[i].b),
+ Tp(data169[i].c), Tp(data169[i].x));
+ const Tp f0 = data169[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for a=5.0000000000000000, b=10.000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data170[] = {
+ { 0.040386107340619266, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.052922149401344633, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.070429627772374270, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.095367431640624972, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.13168724279835387, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.18593443208187066, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.26932907434290437, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.40187757201646096, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.62092132305915493, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.6935087808430296, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 3.0517578124999991, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 5.9499018266198629, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 12.860082304526737, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 32.000000000000000, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 97.656250000000114, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 411.52263374485580, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 3124.9999999999991, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 99999.999999999665, 5.0000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=10.000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test170()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data170)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data170[i].a), Tp(data170[i].b),
+ Tp(data170[i].c), Tp(data170[i].x));
+ const Tp f0 = data170[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=5.0000000000000000, b=20.000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data171[] = {
+ { -1.8650300348791041e-05, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { -3.6488008415183135e-05, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { -6.4614776410999025e-05, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { -8.4495207102575916e-05, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 2.2276197023819217e-05, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.00070736115111467578, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.0027829732057272809, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.0013283545664373570, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { -0.041767631015048733, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 61.311496556100003, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 2397.4420539085681, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 103687.60998586559, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 6247196.6451068865, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 656408576.00000000, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 165334768098.54715, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 175097125520816.81, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 2.6818275451660257e+18, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 2.9794599999999321e+25, 5.0000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=20.000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test171()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data171)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data171[i].a), Tp(data171[i].b),
+ Tp(data171[i].c), Tp(data171[i].x));
+ const Tp f0 = data171[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000034e-10));
+}
+
+// Test data for a=5.0000000000000000, b=20.000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data172[] = {
+ { -3.6403884515183385e-06, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { -9.5873829247725586e-06, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { -2.6052245147354694e-05, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { -7.2378303598294010e-05, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { -0.00020048577321454082, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { -0.00051222704046236022, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { -0.00080950511491911315, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.0043473422174314449, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.081078342558623825, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 12.794854084397739, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 195.15639104739046, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 3938.7991953190131, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 118521.48653762060, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 6291455.9999999972, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 773070496.50699198, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 363276452167.04102, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 2002716064453133.0, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 4.5999999999999109e+21, 5.0000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=20.000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test172()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data172)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data172[i].a), Tp(data172[i].b),
+ Tp(data172[i].c), Tp(data172[i].x));
+ const Tp f0 = data172[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000013e-09));
+}
+
+// Test data for a=5.0000000000000000, b=20.000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data173[] = {
+ { 0.00014313323624069244, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.00025426183473140697, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.00048255612836426809, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.00099096904674788092, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.0022347805521915607, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.0056271390060292376, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.016109059519227226, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.053453465775608999, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.20995202901839258, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 5.9534372167648799, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 46.157632071205875, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 494.32074431164915, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 7989.5277611775946, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 224179.55830753347, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 13848144.485282511, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 2948587692.8891716, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 5940513286161.6602, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 2.8531757655945201e+18, 5.0000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=20.000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test173()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data173)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data173[i].a), Tp(data173[i].b),
+ Tp(data173[i].c), Tp(data173[i].x));
+ const Tp f0 = data173[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-10));
+}
+
+// Test data for a=5.0000000000000000, b=20.000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data174[] = {
+ { 0.0012492049968742865, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.0019931241968014451, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.0033203386861411057, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.0058191894509855282, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.010830090368313866, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.021653062305193163, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.047180821280919084, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.11405637279736180, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.31275468794720990, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 3.8598904658643969, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 18.806301417906667, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 122.77054465017432, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1168.4762146808946, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 18437.511788521082, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 597441.79669264762, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 59390411.369227782, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 44681668993.361603, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 4559673269683164.0, 5.0000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=20.000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test174()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data174)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data174[i].a), Tp(data174[i].b),
+ Tp(data174[i].c), Tp(data174[i].x));
+ const Tp f0 = data174[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-11));
+}
+
+// Test data for a=5.0000000000000000, b=20.000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data175[] = {
+ { 0.0038867957051371450, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.0058484892597364443, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.0090987656053757009, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.014714392537270733, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.024900404542056769, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.044460184663785055, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.084638849196356836, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.17409058241290998, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.39357055823580755, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 2.9410794636226596, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 10.417226071414344, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 46.930585873140835, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 290.76717121814852, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 2788.1641083374830, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 50228.117718560752, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 2433042.3476752634, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 705345246.77141762, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 15652478868616.762, 5.0000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=5.0000000000000000, b=20.000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test175()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data175)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data175[i].a), Tp(data175[i].b),
+ Tp(data175[i].c), Tp(data175[i].x));
+ const Tp f0 = data175[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for a=10.000000000000000, b=0.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data176[] = {
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=0.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test176()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data176)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data176[i].a), Tp(data176[i].b),
+ Tp(data176[i].c), Tp(data176[i].x));
+ const Tp f0 = data176[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=0.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data177[] = {
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=0.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test177()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data177)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data177[i].a), Tp(data177[i].b),
+ Tp(data177[i].c), Tp(data177[i].x));
+ const Tp f0 = data177[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=0.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data178[] = {
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=0.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test178()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data178)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data178[i].a), Tp(data178[i].b),
+ Tp(data178[i].c), Tp(data178[i].x));
+ const Tp f0 = data178[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=0.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data179[] = {
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=0.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test179()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data179)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data179[i].a), Tp(data179[i].b),
+ Tp(data179[i].c), Tp(data179[i].x));
+ const Tp f0 = data179[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=0.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data180[] = {
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 10.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=0.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test180()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data180)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data180[i].a), Tp(data180[i].b),
+ Tp(data180[i].c), Tp(data180[i].x));
+ const Tp f0 = data180[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=0.50000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data181[] = {
+ { 0.37727530159464628, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.39816010922169010, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.42283703041362453, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.45255640448730505, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.48919507154431141, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.53569358917731880, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.59689778897029566, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.68128587569875731, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.80478739308790359, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.3408664196153621, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 2.0175364359923860, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 3.6011214553736646, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 8.1799429939495312, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 25.644834637536000, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 123.13738891597615, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1088.7122410321333, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 27358.291704709951, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 8174369.0266731177, 10.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=0.50000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test181()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data181)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data181[i].a), Tp(data181[i].b),
+ Tp(data181[i].c), Tp(data181[i].x));
+ const Tp f0 = data181[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=0.50000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data182[] = {
+ { 0.53905528308450834, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.56235533974376162, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.58887657983263575, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.61941227047262915, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.65504896640793853, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.69731666644529999, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.74844073299399128, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.81178446800105752, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.89266981277598023, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.1497248473106778, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.3729717112654571, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.7374982340374392, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 2.4134479340960580, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 3.9191255240471192, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 8.3316373077761270, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 28.323020339843335, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 225.84286572747891, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 12757.127591286655, 10.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=0.50000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test182()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data182)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data182[i].a), Tp(data182[i].b),
+ Tp(data182[i].c), Tp(data182[i].x));
+ const Tp f0 = data182[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=0.50000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data183[] = {
+ { 0.62672622092226071, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.64931010269769829, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.67448067519076316, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.70276306239803676, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.73484179773087555, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.77162761412743897, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.81436116844816531, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.86477994787944557, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.92539820516603888, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0945599448210315, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.2190897395597264, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.3916844336856475, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.6484497630432013, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 2.0717772717131155, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 2.8893613630810924, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 4.9459404075413529, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 13.487394149998716, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 136.57616044013972, 10.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=0.50000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test183()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data183)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data183[i].a), Tp(data183[i].b),
+ Tp(data183[i].c), Tp(data183[i].x));
+ const Tp f0 = data183[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=0.50000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data184[] = {
+ { 0.68421604440344341, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.70548098055548891, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.72884342311710348, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.75466953437856243, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.78342090924662600, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.81568884278645049, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.85224480241465206, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.89411692571131696, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.94270986892954756, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0688682849120232, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.1537004376097553, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.2615455028370031, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.4045541456153436, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.6057216489444517, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.9146603020550739, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 2.4617931307620298, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 3.7267799624996498, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 9.3880118036248401, 10.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=0.50000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test184()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data184)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data184[i].a), Tp(data184[i].b),
+ Tp(data184[i].c), Tp(data184[i].x));
+ const Tp f0 = data184[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=0.50000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data185[] = {
+ { 0.72547625011001171, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.74535599249992990, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.76696498884737041, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.79056941504209477, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.81649658092772603, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.84515425472851657, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.87705801930702920, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.91287092917527690, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.95346258924559224, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0540925533894598, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.1180339887498949, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.1952286093343938, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.2909944487358056, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.4142135623730949, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.5811388300841900, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.8257418583505536, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 2.2360679774997898, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 3.1622776601683782, 10.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=0.50000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test185()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data185)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data185[i].a), Tp(data185[i].b),
+ Tp(data185[i].c), Tp(data185[i].x));
+ const Tp f0 = data185[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=1.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data186[] = {
+ { 0.12307420104127871, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.13818870041457423, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.15739165631811691, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.18249038606882068, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.21644171225027786, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.26433326159804160, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.33544459430654533, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.44788516696232517, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.63989153514168362, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.7568608796813312, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 3.5836558871799027, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 8.8077526749963226, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 27.285841702089190, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 113.55555555555557, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 706.24023437500091, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 8064.1687976651992, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 271267.22222222196, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 123456789.99999890, 10.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=1.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test186()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data186)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data186[i].a), Tp(data186[i].b),
+ Tp(data186[i].c), Tp(data186[i].x));
+ const Tp f0 = data186[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=1.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data187[] = {
+ { 0.28363728383055758, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.30933003169808387, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.33998437757128797, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.37713553224291119, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.42299736538419658, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.48086597727600106, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.55583495759293045, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.65612850114039667, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.79573668772968120, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.3184712058058303, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.8576958065941214, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 2.8759509651764228, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 5.1046225531822182, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 11.095238095238095, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 32.797154017857174, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 158.01935680536477, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1815.9523809523814, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 163302.14285714156, 10.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=1.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test187()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data187)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data187[i].a), Tp(data187[i].b),
+ Tp(data187[i].c), Tp(data187[i].x));
+ const Tp f0 = data187[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=1.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data188[] = {
+ { 0.39006633302741794, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.41898885698103294, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.45245557983812590, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.49160548618861633, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.53798419230517980, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.59373881442067344, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.66193391357076115, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.74708402736952129, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.85609281019430605, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.1974451135148187, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.4820886036706347, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.9201183180477521, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 2.6569338297733336, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 4.0634920634920650, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 7.3102678571428568, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 17.512574302697733, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 74.206349206349131, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1342.8571428571363, 10.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=1.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test188()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data188)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data188[i].a), Tp(data188[i].b),
+ Tp(data188[i].c), Tp(data188[i].x));
+ const Tp f0 = data188[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=1.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data189[] = {
+ { 0.46726928123633193, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.49687547629934464, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.53045208856322235, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.56884765624999978, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.61316872427983526, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.66488500161969544, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.72598998634501577, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.79925411522633782, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.88863845062192193, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.1423563481176653, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.3302951388888888, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.5889212827988335, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.9650205761316870, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 2.5555555555555549, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 3.5937500000000013, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 5.7818930041152203, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 12.222222222222220, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 54.999999999999780, 10.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=1.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test189()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data189)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data189[i].a), Tp(data189[i].b),
+ Tp(data189[i].c), Tp(data189[i].x));
+ const Tp f0 = data189[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=1.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data190[] = {
+ { 0.52631578947368429, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.55555555555555558, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.58823529411764708, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.62500000000000000, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.66666666666666663, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.71428571428571430, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.76923076923076927, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.83333333333333337, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.90909090909090906, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.1111111111111112, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.2500000000000000, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.4285714285714286, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.6666666666666663, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 2.0000000000000000, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 2.5000000000000004, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 3.3333333333333330, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 5.0000000000000009, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 9.9999999999999929, 10.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=1.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test190()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data190)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data190[i].a), Tp(data190[i].b),
+ Tp(data190[i].c), Tp(data190[i].x));
+ const Tp f0 = data190[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=2.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data191[] = {
+ { 0.0016310376661280216, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.0028007538972582421, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.0049603324681551939, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.0090949470177292789, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.017341529915832606, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.034571613033607777, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.072538150286405714, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.16150558288984579, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.38554328942953148, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 2.8679719907924444, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 9.3132257461547816, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 35.401331746414378, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 165.38171687920172, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1024.0000000000000, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 9536.7431640625200, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 169350.87808430271, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 9765624.9999999944, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 9999999999.9999332, 10.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=2.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test191()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data191)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data191[i].a), Tp(data191[i].b),
+ Tp(data191[i].c), Tp(data191[i].x));
+ const Tp f0 = data191[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=2.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data192[] = {
+ { 0.071191280690193509, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.085646504654238079, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.10478215656371073, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.13074816337653575, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.16701141666848116, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.21939323375313971, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.29813515331786627, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.42225974638874386, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.62942145962174867, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.7218685262373197, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 3.2855760483514689, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 7.1616652508907093, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 18.612326808485907, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 61.476190476190474, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 286.27580915178623, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 2274.9441142102296, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 47229.761904761865, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 9961460.7142856438, 10.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=2.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test192()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data192)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data192[i].a), Tp(data192[i].b),
+ Tp(data192[i].c), Tp(data192[i].x));
+ const Tp f0 = data192[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=2.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data193[] = {
+ { 0.14747230019381052, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.17073600100690603, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.19982795745135354, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.23681776864188067, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.28475624360398022, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.34827500743063144, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.43464829159684681, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.55576053438064787, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.73195020913445485, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.4310223867822929, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 2.1742563399057540, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 3.5769231236256043, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 6.5620441134844363, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 14.063492063492063, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 38.085937500000036, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 150.92973632068282, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1212.3015873015852, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 55107.142857142389, 10.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=2.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test193()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data193)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data193[i].a), Tp(data193[i].b),
+ Tp(data193[i].c), Tp(data193[i].x));
+ const Tp f0 = data193[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=2.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data194[] = {
+ { 0.21658059714090588, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.24513539602702844, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.27967018274845046, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.32196044921874994, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.37448559670781900, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.44078856032208796, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.52606701446027815, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.63818158436214001, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.78944971882612769, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.3044251384443430, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.7659505208333335, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 2.5093710953769270, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 3.8065843621399158, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 6.3333333333333313, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 12.109375000000004, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 29.115226337448540, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 108.33333333333330, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1224.9999999999923, 10.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=2.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test194()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data194)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data194[i].a), Tp(data194[i].b),
+ Tp(data194[i].c), Tp(data194[i].x));
+ const Tp f0 = data194[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=2.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data195[] = {
+ { 0.27700831024930750, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.30864197530864196, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.34602076124567477, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.39062499999999994, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.44444444444444442, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.51020408163265307, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.59171597633136097, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.69444444444444453, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.82644628099173545, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.2345679012345681, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.5624999999999998, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 2.0408163265306127, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 2.7777777777777768, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 4.0000000000000000, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 6.2500000000000036, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 11.111111111111109, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 25.000000000000007, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 99.999999999999872, 10.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=2.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test195()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data195)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data195[i].a), Tp(data195[i].b),
+ Tp(data195[i].c), Tp(data195[i].x));
+ const Tp f0 = data195[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=5.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data196[] = {
+ { 0.00063586451658060152, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.0010334743461762443, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.0015326246054669515, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.0019007018181583387, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.0012845577715431577, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { -0.0027213806178058826, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { -0.015121744574954068, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { -0.036637840562974443, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.019117849062621491, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 9.8116901852350615, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 84.255589172244044, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 773.87517619421294, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 8556.9725363053585, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 129023.99999999996, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 3174543.3807373112, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 175133896.95814410, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 43564453125.000061, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 446859999999993.50, 10.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=5.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test196()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data196)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data196[i].a), Tp(data196[i].b),
+ Tp(data196[i].c), Tp(data196[i].x));
+ const Tp f0 = data196[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-11));
+}
+
+// Test data for a=10.000000000000000, b=5.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data197[] = {
+ { -0.00030045430691819899, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { -0.00031119487747328581, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { -0.00014589213141649274, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.00056843418860809121, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.0028902549859721725, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.0098776037238877470, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.030689217428863914, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.094211590019076599, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.29791981455918376, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 3.6646308771236793, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 15.133991837501521, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 73.331330046144089, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 441.01791167787133, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 3583.9999999999991, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 45299.530029296984, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1157231.0002427341, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 107421875.00000016, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 234999999999.99734, 10.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=5.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test197()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data197)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data197[i].a), Tp(data197[i].b),
+ Tp(data197[i].c), Tp(data197[i].x));
+ const Tp f0 = data197[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000014e-11));
+}
+
+// Test data for a=10.000000000000000, b=5.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data198[] = {
+ { 0.0058530497315411210, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.0088526869356855692, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.013770987983443108, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.022108932690960800, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.036786236450921578, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.063750669040426422, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.11577228680714464, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.22197573416125735, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.45361312968415268, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 2.4162889363082747, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 6.5381564791240399, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 20.415771011498428, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 76.870682056629221, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 373.58730158730162, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 2626.2555803571477, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 33060.960671081048, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1203521.8253968258, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 584564285.71427989, 10.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=5.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test198()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data198)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data198[i].a), Tp(data198[i].b),
+ Tp(data198[i].c), Tp(data198[i].x));
+ const Tp f0 = data198[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000015e-12));
+}
+
+// Test data for a=10.000000000000000, b=5.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data199[] = {
+ { 0.020248990107069400, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.027876687750502421, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.039154648888447781, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.056251883506774923, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.082914189910074432, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.12585357817786477, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.19761423206224929, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.32280443863359243, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.55250024062839465, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.9374297986599267, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 4.0849049886067696, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 9.5926988633258983, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 25.958314281359531, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 85.333333333333300, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 372.31445312500028, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 2545.3436976070675, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 39583.333333333343, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 4599999.9999999627, 10.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=5.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test199()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data199)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data199[i].a), Tp(data199[i].b),
+ Tp(data199[i].c), Tp(data199[i].x));
+ const Tp f0 = data199[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for a=10.000000000000000, b=5.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data200[] = {
+ { 0.040386107340619266, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.052922149401344633, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.070429627772374270, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.095367431640624972, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.13168724279835387, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.18593443208187066, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.26932907434290437, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.40187757201646096, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.62092132305915493, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.6935087808430296, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 3.0517578124999991, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 5.9499018266198629, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 12.860082304526737, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 32.000000000000000, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 97.656250000000114, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 411.52263374485580, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 3124.9999999999991, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 99999.999999999665, 10.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=5.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test200()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data200)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data200[i].a), Tp(data200[i].b),
+ Tp(data200[i].c), Tp(data200[i].x));
+ const Tp f0 = data200[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=10.000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data201[] = {
+ { 2.3388730079478623e-05, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { -2.3204970759807341e-05, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { -0.00016219730505520291, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { -0.00044366962360925706, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { -0.00071863577205454770, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 4.4378596544453810e-05, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.0044446568070623570, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.0071045155183571103, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { -0.049961558159890146, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 51.305449964107403, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1435.9545414461309, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 39657.913058984115, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1346016.4468570501, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 68086556.444444403, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 6646235808.7301531, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1954852335479.9702, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 4573796225043418.0, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.8280190368899683e+21, 10.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=10.000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test201()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data201)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data201[i].a), Tp(data201[i].b),
+ Tp(data201[i].c), Tp(data201[i].x));
+ const Tp f0 = data201[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-10));
+}
+
+// Test data for a=10.000000000000000, b=10.000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data202[] = {
+ { 1.3504013648882651e-05, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 3.1753432098404372e-05, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 6.2032098207659688e-05, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 8.8747213942768282e-05, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 1.0478094697243911e-05, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { -0.00055998751006011325, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { -0.0024718654966577563, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { -0.0027000264053619817, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.066515394406810674, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 11.579200866389527, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 137.50750548795256, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1901.3196072993419, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 34210.659507137796, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 920588.19047619053, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 45876220.933028772, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 6234608574.0963297, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 5445391090029.7783, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 4.6508713107142163e+17, 10.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=10.000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test202()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data202)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data202[i].a), Tp(data202[i].b),
+ Tp(data202[i].c), Tp(data202[i].x));
+ const Tp f0 = data202[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000013e-09));
+}
+
+// Test data for a=10.000000000000000, b=10.000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data203[] = {
+ { -2.6846726901567720e-05, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { -4.7817237144207266e-05, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { -7.2908121941975601e-05, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { -6.0427853197480476e-05, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.00020559720946645182, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.0017056910683365828, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.0088037230970526795, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.041510819735141674, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.19754880805677258, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 5.6130947302779246, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 36.475357196722442, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 289.29483001400672, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 3010.8676549536503, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 45844.317460317419, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1221852.6431492427, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 79585968.928968787, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 26733475942.460335, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 500206428571421.19, 10.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=10.000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test203()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data203)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data203[i].a), Tp(data203[i].b),
+ Tp(data203[i].c), Tp(data203[i].x));
+ const Tp f0 = data203[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000017e-10));
+}
+
+// Test data for a=10.000000000000000, b=10.000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data204[] = {
+ { 0.00025866179054245944, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.00053402577739214288, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.0011390075227240345, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.0025224267119483192, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.0058340332124251467, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.014189256143045285, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.036590990011337567, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.10106560781146992, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.30278778538531409, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 3.7187249990350599, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 16.023275545901704, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 83.265377219882822, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 553.31413918843987, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 5148.4444444444416, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 78082.084655761908, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 2565874.8781353114, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 346137152.77777809, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1472499999999.9834, 10.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=10.000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test204()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data204)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data204[i].a), Tp(data204[i].b),
+ Tp(data204[i].c), Tp(data204[i].x));
+ const Tp f0 = data204[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-10));
+}
+
+// Test data for a=10.000000000000000, b=10.000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data205[] = {
+ { 0.0016310376661280216, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.0028007538972582421, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.0049603324681551939, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.0090949470177292789, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.017341529915832606, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.034571613033607777, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.072538150286405714, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.16150558288984579, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.38554328942953148, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 2.8679719907924444, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 9.3132257461547816, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 35.401331746414378, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 165.38171687920172, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1024.0000000000000, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 9536.7431640625200, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 169350.87808430271, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 9765624.9999999944, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 9999999999.9999332, 10.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=10.000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test205()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data205)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data205[i].a), Tp(data205[i].b),
+ Tp(data205[i].c), Tp(data205[i].x));
+ const Tp f0 = data205[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=10.000000000000000, b=20.000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data206[] = {
+ { -2.1776535308707967e-07, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { -2.9128833151427998e-06, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { -9.4755553429035093e-06, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { -1.2844297353813116e-05, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 3.6576965483568809e-05, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.00020847453890692649, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { -0.00022868510398174632, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { -0.0021855513841942732, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.014662111759334634, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 746.44776348798098, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 136080.48445225612, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 23094279.597826406, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 5315913395.5545301, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 2261935718399.9990, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 2669150854828235.0, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.7499363099365994e+19, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 2.8881518494606140e+24, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.4165513933661626e+33, 10.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=20.000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test206()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data206)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data206[i].a), Tp(data206[i].b),
+ Tp(data206[i].c), Tp(data206[i].x));
+ const Tp f0 = data206[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000005e-08));
+}
+
+// Test data for a=10.000000000000000, b=20.000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data207[] = {
+ { 1.7149006973860441e-07, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 3.2399324904088936e-07, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 1.6015317712089860e-07, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { -2.0500917204199595e-06, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { -1.0175546788599472e-05, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { -1.1720101988202453e-05, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.00014199637113974185, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.00021263363640642297, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { -0.0072649256698441751, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 90.430293772869618, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 6248.1455940292308, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 501143.39852548984, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 58852027.356439680, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 12942923093.333330, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 7618073993853.6592, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 22630251562549288., 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.3708372433980356e+21, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.4154113619999653e+29, 10.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=20.000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test207()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data207)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data207[i].a), Tp(data207[i].b),
+ Tp(data207[i].c), Tp(data207[i].x));
+ const Tp f0 = data207[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000024e-08));
+}
+
+// Test data for a=10.000000000000000, b=20.000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data208[] = {
+ { -1.6667473370780257e-08, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 8.6214844067774863e-08, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 5.7778331238835108e-07, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 2.1911400500362969e-06, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 4.7440049217100417e-06, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { -1.0564233314924258e-05, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { -0.00017990026051856349, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { -0.00027618146288744351, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.030606019577723392, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 27.832854169493341, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 874.00624088575228, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 36049.199340831554, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 2270967.7298624986, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 266979100.44444439, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 80311224337.493027, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 110111693103799.72, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 2.4838871426052618e+18, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 5.4626349999998603e+25, 10.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=20.000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test208()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data208)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data208[i].a), Tp(data208[i].b),
+ Tp(data208[i].c), Tp(data208[i].x));
+ const Tp f0 = data208[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000019e-07));
+}
+
+// Test data for a=10.000000000000000, b=20.000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data209[] = {
+ { -1.5843795893321480e-07, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { -5.4877275994033766e-07, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { -1.7169507967745992e-06, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { -4.5236439748752000e-06, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { -5.5690492560325806e-06, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 5.6914115606934911e-05, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.00082507252097519922, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.0085739249288229857, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.088244357683754757, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 13.387208440156897, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 226.77895441155110, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 5281.5716482686785, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 189431.77762850464, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 12408149.333333332, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1966782292.5839682, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1274123112205.7495, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 10903676350911508., 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 5.1849999999998819e+22, 10.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=20.000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test209()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data209)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data209[i].a), Tp(data209[i].b),
+ Tp(data209[i].c), Tp(data209[i].x));
+ const Tp f0 = data209[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000012e-08));
+}
+
+// Test data for a=10.000000000000000, b=20.000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data210[] = {
+ { 2.6602838683283435e-06, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 7.8442223930072316e-06, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 2.4604898194634598e-05, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 8.2718061255302686e-05, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.00030072865982171723, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.0011951964277455193, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.0052617832469731814, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.026084053304588847, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.14864362802414346, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 8.2252633399699757, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 86.736173798840269, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1253.2542894196865, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 27351.112277912434, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1048576.0000000000, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 90949470.177293226, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 28679719907.924358, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 95367431640624.906, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 9.9999999999998657e+19, 10.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=10.000000000000000, b=20.000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test210()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data210)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data210[i].a), Tp(data210[i].b),
+ Tp(data210[i].c), Tp(data210[i].x));
+ const Tp f0 = data210[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for a=20.000000000000000, b=0.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data211[] = {
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=0.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test211()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data211)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data211[i].a), Tp(data211[i].b),
+ Tp(data211[i].c), Tp(data211[i].x));
+ const Tp f0 = data211[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, b=0.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data212[] = {
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=0.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test212()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data212)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data212[i].a), Tp(data212[i].b),
+ Tp(data212[i].c), Tp(data212[i].x));
+ const Tp f0 = data212[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, b=0.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data213[] = {
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=0.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test213()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data213)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data213[i].a), Tp(data213[i].b),
+ Tp(data213[i].c), Tp(data213[i].x));
+ const Tp f0 = data213[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, b=0.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data214[] = {
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=0.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test214()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data214)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data214[i].a), Tp(data214[i].b),
+ Tp(data214[i].c), Tp(data214[i].x));
+ const Tp f0 = data214[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, b=0.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data215[] = {
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.0000000000000000, 20.000000000000000, 0.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=0.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test215()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data215)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data215[i].a), Tp(data215[i].b),
+ Tp(data215[i].c), Tp(data215[i].x));
+ const Tp f0 = data215[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, b=0.50000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data216[] = {
+ { 0.26690449940521566, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.28252302866181805, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.30123616141153819, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.32421384687602628, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.35334630811776752, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.39191793127467034, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.44620488618129206, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.52980896919265685, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.67754711477562357, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 1.9567557771780317, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 6.1816042148333086, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 35.653088618561227, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 377.51482843179906, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 7645.8816551195359, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 354791.74537980522, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 57009889.966638684, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 83771357024.863937, 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 25866972896376408., 20.000000000000000, 0.50000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=0.50000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test216()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data216)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data216[i].a), Tp(data216[i].b),
+ Tp(data216[i].c), Tp(data216[i].x));
+ const Tp f0 = data216[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, b=0.50000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data217[] = {
+ { 0.40342659436153405, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.42420571192034318, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.44852768286073008, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.47751245808592863, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.51283632632707754, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.55713468814894307, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.61481320817757312, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.69383483410097202, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.81012002526006033, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.3622225506603911, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 2.2349513086109001, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 5.1864917536761723, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 21.020560423779411, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 175.19649997100612, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 3467.1587803688708, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 225003.88683445856, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 110837674.65652709, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 6688966964170.6807, 20.000000000000000, 0.50000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=0.50000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test217()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data217)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data217[i].a), Tp(data217[i].b),
+ Tp(data217[i].c), Tp(data217[i].x));
+ const Tp f0 = data217[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, b=0.50000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data218[] = {
+ { 0.48716309885816761, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.50965859152542281, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.53554809210658971, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.56576689207507136, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.60164849637133688, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.64516711595404375, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.69938278735493542, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.76931621518401860, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.86381808725530695, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.2152051956815531, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 1.6052546785425543, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 2.4765586046012635, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 5.1564492216997486, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 18.446158392136365, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 150.44577670123971, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 3862.6317400115768, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 632428.34833625401, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 7426927663.3808765, 20.000000000000000, 0.50000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=0.50000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test218()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data218)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data218[i].a), Tp(data218[i].b),
+ Tp(data218[i].c), Tp(data218[i].x));
+ const Tp f0 = data218[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, b=0.50000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data219[] = {
+ { 0.54703266209548362, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.56997321774144971, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.59603026159654970, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.62596978851120511, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.66084565876898926, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.70215256667232839, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.75208916592008568, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.81403631111658648, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.89348608489854608, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.1517793185139173, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.3878110313656598, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 1.8061071794572381, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 2.7148594517859586, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 5.4529435709049361, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 19.487310275377109, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 191.69079165937470, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 10218.543981792311, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 23160836.646583911, 20.000000000000000, 0.50000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=0.50000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test219()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data219)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data219[i].a), Tp(data219[i].b),
+ Tp(data219[i].c), Tp(data219[i].x));
+ const Tp f0 = data219[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, b=0.50000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data220[] = {
+ { 0.59292067298616002, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.61572496720679915, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.64135339122875623, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.67043457419280483, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.70380956268170980, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.74263251901495231, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.78853555445528278, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.84391122775673766, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.91242401018807406, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.1169059681274873, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.2825928301302667, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1.5385937789924939, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 1.9895771187893898, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 2.9707335806970168, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 6.0299506157180467, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 24.259090336955577, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 406.27267173257223, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 174330.03997220192, 20.000000000000000, 0.50000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=0.50000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test220()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data220)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data220[i].a), Tp(data220[i].b),
+ Tp(data220[i].c), Tp(data220[i].x));
+ const Tp f0 = data220[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, b=1.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data221[] = {
+ { 0.058479236576646373, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 0.065788544763137669, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 0.075184824937824662, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 0.087707688693157260, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.10521567442213345, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.13135877960541525, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.17423854066297104, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.25492082527223525, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.44025895219654843, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 3.3698615820910360, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 17.997089220808483, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 153.73298291118951, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 2159.1667587825627, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 55188.105263157879, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 3191209.3921857267, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 646910975.29152656, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 1254834626850.2659, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 5.8479532163741414e+17, 20.000000000000000, 1.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=1.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test221()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data221)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data221[i].a), Tp(data221[i].b),
+ Tp(data221[i].c), Tp(data221[i].x));
+ const Tp f0 = data221[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, b=1.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data222[] = {
+ { 0.15519511120894947, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.17197165701692899, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.19276847315207363, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.21920107206179093, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.25386158960390581, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.30115970686600657, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.36916408142057117, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.47406175901569558, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.65237908266239919, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 1.8227213362622299, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 4.3716358339791332, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 15.670841312959222, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 94.742651122760179, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 1081.7275541795671, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 27809.787731465960, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 2329811.1715181042, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1537787532.6780224, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 141562653506999.88, 20.000000000000000, 1.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=1.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test222()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data222)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data222[i].a), Tp(data222[i].b),
+ Tp(data222[i].c), Tp(data222[i].x));
+ const Tp f0 = data222[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, b=1.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data223[] = {
+ { 0.23253645591196570, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.25484220947068353, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.28181987881113829, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.31508211677735765, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.35706285886959599, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.41160053409238195, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.48508083111181949, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.58885194371375260, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.74482241684585748, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 1.4700356864367146, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 2.4955144453055143, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 5.3506594845833471, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 16.618413752184221, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 89.310629514963878, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1029.3439900542960, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 35659.847863372350, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 8009309.6233230168, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 145640590027.39731, 20.000000000000000, 1.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=1.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test223()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data223)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data223[i].a), Tp(data223[i].b),
+ Tp(data223[i].c), Tp(data223[i].x));
+ const Tp f0 = data223[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, b=1.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data224[] = {
+ { 0.29614148314592498, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.32176277356430810, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.35217870475550522, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.38885270445515091, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.43389978380608424, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.49048612522269436, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.56355539635634611, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.66123153239117682, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.79773363961895427, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.3245132157016595, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 1.9065148749742076, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 3.1328798652457452, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 6.4172532944033476, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 19.071683734222436, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 104.41989641582512, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1510.5743992324240, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 115518.14360562043, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 414930455.29173034, 20.000000000000000, 1.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=1.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test224()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data224)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data224[i].a), Tp(data224[i].b),
+ Tp(data224[i].c), Tp(data224[i].x));
+ const Tp f0 = data224[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, b=1.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data225[] = {
+ { 0.34954259539177696, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.37714038609235123, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.40942091659748725, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.44767109606846428, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.49368984777532254, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.55006638216982318, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.62065830207408912, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.71145554513583786, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.83223839666914623, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.2466748028187731, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 1.6386752725021749, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 2.3340068725479681, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 3.7848108613132054, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 7.6754638550304133, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 23.344217312927277, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 149.83491198246921, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 3936.9253501916060, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 2794143.5036480185, 20.000000000000000, 1.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=1.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test225()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data225)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data225[i].a), Tp(data225[i].b),
+ Tp(data225[i].c), Tp(data225[i].x));
+ const Tp f0 = data225[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, b=2.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data226[] = {
+ { 2.6602838683283435e-06, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 7.8442223930072316e-06, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 2.4604898194634598e-05, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { 8.2718061255302686e-05, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 0.00030072865982171723, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.0011951964277455193, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.0052617832469731814, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.026084053304588847, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.14864362802414346, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 8.2252633399699757, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 86.736173798840269, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 1253.2542894196865, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 27351.112277912434, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1048576.0000000000, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 90949470.177293226, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 28679719907.924358, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 95367431640624.906, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 9.9999999999998657e+19, 20.000000000000000, 2.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=2.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test226()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data226)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data226[i].a), Tp(data226[i].b),
+ Tp(data226[i].c), Tp(data226[i].x));
+ const Tp f0 = data226[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for a=20.000000000000000, b=2.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data227[] = {
+ { 0.018828092583720951, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 0.023381944060455316, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 0.029789623984280793, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 0.039191021482500497, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { 0.053727813036721514, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { 0.077762010061669024, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.12110505620123302, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.20870149809080590, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.41429234328785769, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 3.1308087404153113, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 13.586180626453050, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 87.117304082784415, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 889.26474381242826, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 16231.913312693494, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 653537.51168945129, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 87756230.793848589, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 101493977171.74945, 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 21375960679556916., 20.000000000000000, 2.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=2.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test227()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data227)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data227[i].a), Tp(data227[i].b),
+ Tp(data227[i].c), Tp(data227[i].x));
+ const Tp f0 = data227[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for a=20.000000000000000, b=2.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data228[] = {
+ { 0.049200410661854252, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.059460876757152226, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.073244762686653350, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.092334626017932922, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.11976760350696837, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.16102414609169383, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.22670456785796222, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.33912903252727361, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.55049794600858060, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 2.1254722872032232, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 5.6261213886736172, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 20.137315891130996, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 108.04381584643853, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 992.41692466460245, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 19055.363816004465, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 1105471.9504312086, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 448521363.90608919, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 19078917293639.004, 20.000000000000000, 2.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=2.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test228()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data228)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data228[i].a), Tp(data228[i].b),
+ Tp(data228[i].c), Tp(data228[i].x));
+ const Tp f0 = data228[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for a=20.000000000000000, b=2.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data229[] = {
+ { 0.083753547015334745, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.099238444687035701, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.11938294012867758, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.14622683905023326, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.18303556733713025, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.23527764069382409, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.31261681740827085, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.43327581880538862, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.63445840637296658, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 1.7438842395813297, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 3.5070840938209269, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 8.6573372006089713, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 28.779342118408906, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 147.50178613955714, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1427.1686016136398, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 36780.643714655642, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 5313869.6058585485, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 46057280607.381966, 20.000000000000000, 2.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=2.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test229()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data229)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data229[i].a), Tp(data229[i].b),
+ Tp(data229[i].c), Tp(data229[i].x));
+ const Tp f0 = data229[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, b=2.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data230[] = {
+ { 0.11920045035073683, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.13907946814302774, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.16431439792559688, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.19698796016987008, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.24028510928790570, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.29926031296483119, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.38229327814229169, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.50402047283093110, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.69167261179586503, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 1.5503152253394308, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 2.6469548193635797, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 5.1882631330566813, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 12.476792759124516, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 41.026391565091259, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 220.92584715988204, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 2677.0834450236207, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 141774.31260689779, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 254267148.83196995, 20.000000000000000, 2.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=2.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test230()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data230)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data230[i].a), Tp(data230[i].b),
+ Tp(data230[i].c), Tp(data230[i].x));
+ const Tp f0 = data230[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for a=20.000000000000000, b=5.0000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data231[] = {
+ { -1.8650300348791041e-05, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { -3.6488008415183135e-05, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { -6.4614776410999025e-05, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { -8.4495207102575916e-05, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 2.2276197023819217e-05, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.00070736115111467578, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { 0.0027829732057272809, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.0013283545664373570, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { -0.041767631015048733, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 61.311496556100003, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 2397.4420539085681, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 103687.60998586559, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 6247196.6451068865, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 656408576.00000000, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 165334768098.54715, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 175097125520816.81, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 2.6818275451660257e+18, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 2.9794599999999321e+25, 20.000000000000000, 5.0000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=5.0000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test231()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data231)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data231[i].a), Tp(data231[i].b),
+ Tp(data231[i].c), Tp(data231[i].x));
+ const Tp f0 = data231[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000034e-10));
+}
+
+// Test data for a=20.000000000000000, b=5.0000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data232[] = {
+ { -3.6403884515183385e-06, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { -9.5873829247725586e-06, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { -2.6052245147354694e-05, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { -7.2378303598294010e-05, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { -0.00020048577321454082, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { -0.00051222704046236022, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { -0.00080950511491911315, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.0043473422174314449, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.081078342558623825, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 12.794854084397739, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 195.15639104739046, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 3938.7991953190131, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 118521.48653762060, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 6291455.9999999972, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 773070496.50699198, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 363276452167.04102, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 2002716064453133.0, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 4.5999999999999109e+21, 20.000000000000000, 5.0000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=5.0000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test232()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data232)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data232[i].a), Tp(data232[i].b),
+ Tp(data232[i].c), Tp(data232[i].x));
+ const Tp f0 = data232[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000013e-09));
+}
+
+// Test data for a=20.000000000000000, b=5.0000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data233[] = {
+ { 0.00014313323624069244, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 0.00025426183473140697, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 0.00048255612836426809, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 0.00099096904674788092, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 0.0022347805521915607, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 0.0056271390060292376, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { 0.016109059519227226, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 0.053453465775608999, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.20995202901839258, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 5.9534372167648799, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 46.157632071205875, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 494.32074431164915, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 7989.5277611775946, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 224179.55830753347, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 13848144.485282511, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 2948587692.8891716, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 5940513286161.6602, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 2.8531757655945201e+18, 20.000000000000000, 5.0000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=5.0000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test233()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data233)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data233[i].a), Tp(data233[i].b),
+ Tp(data233[i].c), Tp(data233[i].x));
+ const Tp f0 = data233[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-10));
+}
+
+// Test data for a=20.000000000000000, b=5.0000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data234[] = {
+ { 0.0012492049968742865, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 0.0019931241968014451, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 0.0033203386861411057, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { 0.0058191894509855282, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { 0.010830090368313866, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 0.021653062305193163, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.047180821280919084, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.11405637279736180, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.31275468794720990, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 3.8598904658643969, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 18.806301417906667, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 122.77054465017432, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1168.4762146808946, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 18437.511788521082, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 597441.79669264762, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 59390411.369227782, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 44681668993.361603, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 4559673269683164.0, 20.000000000000000, 5.0000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=5.0000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test234()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data234)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data234[i].a), Tp(data234[i].b),
+ Tp(data234[i].c), Tp(data234[i].x));
+ const Tp f0 = data234[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000006e-11));
+}
+
+// Test data for a=20.000000000000000, b=5.0000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data235[] = {
+ { 0.0038867957051371450, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 0.0058484892597364443, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 0.0090987656053757009, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 0.014714392537270733, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.024900404542056769, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.044460184663785055, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.084638849196356836, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.17409058241290998, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.39357055823580755, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 2.9410794636226596, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 10.417226071414344, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 46.930585873140835, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 290.76717121814852, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 2788.1641083374830, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 50228.117718560752, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 2433042.3476752634, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 705345246.77141762, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 15652478868616.762, 20.000000000000000, 5.0000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=5.0000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test235()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data235)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data235[i].a), Tp(data235[i].b),
+ Tp(data235[i].c), Tp(data235[i].x));
+ const Tp f0 = data235[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for a=20.000000000000000, b=10.000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data236[] = {
+ { -2.1776535308707967e-07, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { -2.9128833151427998e-06, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { -9.4755553429035093e-06, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { -1.2844297353813116e-05, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { 3.6576965483568809e-05, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 0.00020847453890692649, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { -0.00022868510398174632, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { -0.0021855513841942732, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { 0.014662111759334634, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 746.44776348798098, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 136080.48445225612, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 23094279.597826406, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 5315913395.5545301, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 2261935718399.9990, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 2669150854828235.0, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 1.7499363099365994e+19, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 2.8881518494606140e+24, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 1.4165513933661626e+33, 20.000000000000000, 10.000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=10.000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test236()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data236)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data236[i].a), Tp(data236[i].b),
+ Tp(data236[i].c), Tp(data236[i].x));
+ const Tp f0 = data236[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000005e-08));
+}
+
+// Test data for a=20.000000000000000, b=10.000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data237[] = {
+ { 1.7149006973860441e-07, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { 3.2399324904088936e-07, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 1.6015317712089860e-07, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { -2.0500917204199595e-06, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { -1.0175546788599472e-05, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { -1.1720101988202453e-05, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 0.00014199637113974185, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { 0.00021263363640642297, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { -0.0072649256698441751, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 90.430293772869618, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 6248.1455940292308, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 501143.39852548984, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 58852027.356439680, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 12942923093.333330, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 7618073993853.6592, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 22630251562549288., 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.3708372433980356e+21, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.4154113619999653e+29, 20.000000000000000, 10.000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=10.000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test237()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data237)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data237[i].a), Tp(data237[i].b),
+ Tp(data237[i].c), Tp(data237[i].x));
+ const Tp f0 = data237[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000024e-08));
+}
+
+// Test data for a=20.000000000000000, b=10.000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data238[] = {
+ { -1.6667473370780257e-08, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { 8.6214844067774863e-08, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { 5.7778331238835108e-07, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { 2.1911400500362969e-06, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 4.7440049217100417e-06, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { -1.0564233314924258e-05, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { -0.00017990026051856349, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { -0.00027618146288744351, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { 0.030606019577723392, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 27.832854169493341, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 874.00624088575228, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 36049.199340831554, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 2270967.7298624986, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 266979100.44444439, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 80311224337.493027, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 110111693103799.72, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 2.4838871426052618e+18, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 5.4626349999998603e+25, 20.000000000000000, 10.000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=10.000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test238()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data238)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data238[i].a), Tp(data238[i].b),
+ Tp(data238[i].c), Tp(data238[i].x));
+ const Tp f0 = data238[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000019e-07));
+}
+
+// Test data for a=20.000000000000000, b=10.000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data239[] = {
+ { -1.5843795893321480e-07, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { -5.4877275994033766e-07, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { -1.7169507967745992e-06, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { -4.5236439748752000e-06, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { -5.5690492560325806e-06, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 5.6914115606934911e-05, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 0.00082507252097519922, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { 0.0085739249288229857, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.088244357683754757, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 13.387208440156897, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 226.77895441155110, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 5281.5716482686785, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 189431.77762850464, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 12408149.333333332, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1966782292.5839682, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 1274123112205.7495, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 10903676350911508., 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 5.1849999999998819e+22, 20.000000000000000, 10.000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=10.000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test239()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data239)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data239[i].a), Tp(data239[i].b),
+ Tp(data239[i].c), Tp(data239[i].x));
+ const Tp f0 = data239[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000012e-08));
+}
+
+// Test data for a=20.000000000000000, b=10.000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data240[] = {
+ { 2.6602838683283435e-06, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { 7.8442223930072316e-06, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 2.4604898194634598e-05, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 8.2718061255302686e-05, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 0.00030072865982171723, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { 0.0011951964277455193, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { 0.0052617832469731814, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.026084053304588847, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.14864362802414346, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 8.2252633399699757, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 86.736173798840269, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 1253.2542894196865, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 27351.112277912434, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 1048576.0000000000, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 90949470.177293226, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 28679719907.924358, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 95367431640624.906, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 9.9999999999998657e+19, 20.000000000000000, 10.000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=10.000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test240()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data240)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data240[i].a), Tp(data240[i].b),
+ Tp(data240[i].c), Tp(data240[i].x));
+ const Tp f0 = data240[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for a=20.000000000000000, b=20.000000000000000, c=2.0000000000000000.
+testcase_hyperg<double> data241[] = {
+ { 7.4612991101768883e-09, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.90000000000000002 },
+ { 1.1006588946889981e-07, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.80000000000000004 },
+ { 2.0126933743389316e-07, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.69999999999999996 },
+ { -1.0013775379801016e-06, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.59999999999999998 },
+ { -3.0371956856472516e-06, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.50000000000000000 },
+ { 2.2012669924527286e-05, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.40000000000000002 },
+ { -6.2415598025417670e-05, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.30000000000000004 },
+ { 0.00033551320394378602, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.19999999999999996 },
+ { -0.0062342152641436353, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.0000000000000000 },
+ { 34830.688900741610, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.10000000000000009 },
+ { 67626221.263030857, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.19999999999999996 },
+ { 102764604848.69762, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.30000000000000004 },
+ { 220278355222373.38, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.39999999999999991 },
+ { 1.0422324699794536e+18, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.50000000000000000 },
+ { 1.9128731788368004e+22, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.60000000000000009 },
+ { 3.5234592919485287e+27, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.69999999999999996 },
+ { 5.0867023209025249e+34, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.80000000000000004 },
+ { 3.7461088506658564e+46, 20.000000000000000, 20.000000000000000,
+ 2.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=20.000000000000000, c=2.0000000000000000.
+template <typename Tp>
+void test241()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data241)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data241[i].a), Tp(data241[i].b),
+ Tp(data241[i].c), Tp(data241[i].x));
+ const Tp f0 = data241[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000005e-07));
+}
+
+// Test data for a=20.000000000000000, b=20.000000000000000, c=4.0000000000000000.
+testcase_hyperg<double> data242[] = {
+ { -1.5895900796973045e-09, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.90000000000000002 },
+ { -2.4403576837293198e-09, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.80000000000000004 },
+ { 1.1622915290732117e-08, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.69999999999999996 },
+ { 6.3899796307731726e-08, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.59999999999999998 },
+ { -1.3503608352807462e-07, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.50000000000000000 },
+ { -1.2198533623899163e-06, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.40000000000000002 },
+ { 9.9086618119129001e-06, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.30000000000000004 },
+ { -7.6797020080162010e-05, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.19999999999999996 },
+ { 0.0013196405087170875, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.0000000000000000 },
+ { 2274.2044768143564, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.10000000000000009 },
+ { 1611640.1560475440, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.19999999999999996 },
+ { 1147063984.7359734, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.30000000000000004 },
+ { 1253162497163.8311, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.39999999999999991 },
+ { 3071321673390476.0, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.50000000000000000 },
+ { 2.8221123559124324e+19, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.60000000000000009 },
+ { 2.3658463807419519e+24, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.69999999999999996 },
+ { 1.2596553731345468e+31, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.80000000000000004 },
+ { 1.9627175792062075e+42, 20.000000000000000, 20.000000000000000,
+ 4.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=20.000000000000000, c=4.0000000000000000.
+template <typename Tp>
+void test242()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data242)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data242[i].a), Tp(data242[i].b),
+ Tp(data242[i].c), Tp(data242[i].x));
+ const Tp f0 = data242[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000006e-06));
+}
+
+// Test data for a=20.000000000000000, b=20.000000000000000, c=6.0000000000000000.
+testcase_hyperg<double> data243[] = {
+ { 8.0159808156941562e-11, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.90000000000000002 },
+ { -6.4422687845093557e-10, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.80000000000000004 },
+ { -3.7526134186308981e-09, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.69999999999999996 },
+ { -1.7692034167897114e-09, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.59999999999999998 },
+ { 7.9304558772837909e-08, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.50000000000000000 },
+ { 5.9348070318594204e-08, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.40000000000000002 },
+ { -3.5827694517425210e-06, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.30000000000000004 },
+ { 4.4951490418284159e-05, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.19999999999999996 },
+ { -0.0013716249406310486, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.0000000000000000 },
+ { 415.32493304415505, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.10000000000000009 },
+ { 121300.42991518594, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.19999999999999996 },
+ { 42725673.833462097, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.30000000000000004 },
+ { 24588915328.261719, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.39999999999999991 },
+ { 31929082412503.652, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.50000000000000000 },
+ { 1.4934954443280477e+17, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.60000000000000009 },
+ { 5.7726220597696125e+21, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.69999999999999996 },
+ { 1.1454387824049374e+28, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.80000000000000004 },
+ { 3.8088637321581534e+38, 20.000000000000000, 20.000000000000000,
+ 6.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=20.000000000000000, c=6.0000000000000000.
+template <typename Tp>
+void test243()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data243)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data243[i].a), Tp(data243[i].b),
+ Tp(data243[i].c), Tp(data243[i].x));
+ const Tp f0 = data243[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000005e-05));
+}
+
+// Test data for a=20.000000000000000, b=20.000000000000000, c=8.0000000000000000.
+testcase_hyperg<double> data244[] = {
+ { 1.0699072529874453e-10, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.90000000000000002 },
+ { 5.4297753417228627e-10, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.80000000000000004 },
+ { 9.7625471266824426e-10, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.69999999999999996 },
+ { -6.7257762867770348e-09, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.59999999999999998 },
+ { -5.4634571496175302e-08, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.50000000000000000 },
+ { 1.4595644213893387e-07, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.40000000000000002 },
+ { 3.3515966497049909e-06, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.30000000000000004 },
+ { -6.5848086985914887e-05, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.19999999999999996 },
+ { 0.0034800171306214813, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.0000000000000000 },
+ { 130.93865856750304, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.10000000000000009 },
+ { 17850.203502975532, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.19999999999999996 },
+ { 3307058.5655149994, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.30000000000000004 },
+ { 1041065396.2302787, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.39999999999999991 },
+ { 735221357488.41736, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.50000000000000000 },
+ { 1785176805049585.2, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.60000000000000009 },
+ { 3.2302829930269192e+19, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.69999999999999996 },
+ { 2.4184909805178299e+25, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.80000000000000004 },
+ { 1.7340021007794567e+35, 20.000000000000000, 20.000000000000000,
+ 8.0000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=20.000000000000000, c=8.0000000000000000.
+template <typename Tp>
+void test244()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data244)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data244[i].a), Tp(data244[i].b),
+ Tp(data244[i].c), Tp(data244[i].x));
+ const Tp f0 = data244[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000005e-05));
+}
+
+// Test data for a=20.000000000000000, b=20.000000000000000, c=10.000000000000000.
+testcase_hyperg<double> data245[] = {
+ { -1.7945363894141429e-10, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.90000000000000002 },
+ { -4.4440666675421800e-10, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.80000000000000004 },
+ { 6.6171630913717945e-10, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.69999999999999996 },
+ { 1.5453889642199650e-08, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.59999999999999998 },
+ { 7.5754083860094422e-08, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.50000000000000000 },
+ { -4.1113628639873710e-07, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.40000000000000002 },
+ { -9.5300704265214247e-06, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.30000000000000004 },
+ { 0.00016081533175785109, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.19999999999999996 },
+ { 0.017684650940379486, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, -0.099999999999999978 },
+ { 1.0000000000000000, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.0000000000000000 },
+ { 57.562247312454403, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.10000000000000009 },
+ { 4124.4159820362511, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.19999999999999996 },
+ { 428774.21436196787, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.30000000000000004 },
+ { 76996819.900892526, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.39999999999999991 },
+ { 30473174828.943691, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.50000000000000000 },
+ { 39291970835753.094, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.60000000000000009 },
+ { 3.3890331048069018e+17, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.69999999999999996 },
+ { 9.7157373454594049e+22, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.80000000000000004 },
+ { 1.5205808288860858e+32, 20.000000000000000, 20.000000000000000,
+ 10.000000000000000, 0.89999999999999991 },
+};
+
+// Test function for a=20.000000000000000, b=20.000000000000000, c=10.000000000000000.
+template <typename Tp>
+void test245()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data245)
+ / sizeof(testcase_hyperg<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::hyperg(Tp(data245[i].a), Tp(data245[i].b),
+ Tp(data245[i].c), Tp(data245[i].x));
+ const Tp f0 = data245[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000005e-05));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ test009<double>();
+ test010<double>();
+ test011<double>();
+ test012<double>();
+ test013<double>();
+ test014<double>();
+ test015<double>();
+ test016<double>();
+ test017<double>();
+ test018<double>();
+ test019<double>();
+ test020<double>();
+ test021<double>();
+ test022<double>();
+ test023<double>();
+ test024<double>();
+ test025<double>();
+ test026<double>();
+ test027<double>();
+ test028<double>();
+ test029<double>();
+ test030<double>();
+ test031<double>();
+ test032<double>();
+ test033<double>();
+ test034<double>();
+ test035<double>();
+ test036<double>();
+ test037<double>();
+ test038<double>();
+ test039<double>();
+ test040<double>();
+ test041<double>();
+ test042<double>();
+ test043<double>();
+ test044<double>();
+ test045<double>();
+ test046<double>();
+ test047<double>();
+ test048<double>();
+ test049<double>();
+ test050<double>();
+ test051<double>();
+ test052<double>();
+ test053<double>();
+ test054<double>();
+ test055<double>();
+ test056<double>();
+ test057<double>();
+ test058<double>();
+ test059<double>();
+ test060<double>();
+ test061<double>();
+ test062<double>();
+ test063<double>();
+ test064<double>();
+ test065<double>();
+ test066<double>();
+ test067<double>();
+ test068<double>();
+ test069<double>();
+ test070<double>();
+ test071<double>();
+ test072<double>();
+ test073<double>();
+ test074<double>();
+ test075<double>();
+ test076<double>();
+ test077<double>();
+ test078<double>();
+ test079<double>();
+ test080<double>();
+ test081<double>();
+ test082<double>();
+ test083<double>();
+ test084<double>();
+ test085<double>();
+ test086<double>();
+ test087<double>();
+ test088<double>();
+ test089<double>();
+ test090<double>();
+ test091<double>();
+ test092<double>();
+ test093<double>();
+ test094<double>();
+ test095<double>();
+ test096<double>();
+ test097<double>();
+ test098<double>();
+ test099<double>();
+ test100<double>();
+ test101<double>();
+ test102<double>();
+ test103<double>();
+ test104<double>();
+ test105<double>();
+ test106<double>();
+ test107<double>();
+ test108<double>();
+ test109<double>();
+ test110<double>();
+ test111<double>();
+ test112<double>();
+ test113<double>();
+ test114<double>();
+ test115<double>();
+ test116<double>();
+ test117<double>();
+ test118<double>();
+ test119<double>();
+ test120<double>();
+ test121<double>();
+ test122<double>();
+ test123<double>();
+ test124<double>();
+ test125<double>();
+ test126<double>();
+ test127<double>();
+ test128<double>();
+ test129<double>();
+ test130<double>();
+ test131<double>();
+ test132<double>();
+ test133<double>();
+ test134<double>();
+ test135<double>();
+ test136<double>();
+ test137<double>();
+ test138<double>();
+ test139<double>();
+ test140<double>();
+ test141<double>();
+ test142<double>();
+ test143<double>();
+ test144<double>();
+ test145<double>();
+ test146<double>();
+ test147<double>();
+ test148<double>();
+ test149<double>();
+ test150<double>();
+ test151<double>();
+ test152<double>();
+ test153<double>();
+ test154<double>();
+ test155<double>();
+ test156<double>();
+ test157<double>();
+ test158<double>();
+ test159<double>();
+ test160<double>();
+ test161<double>();
+ test162<double>();
+ test163<double>();
+ test164<double>();
+ test165<double>();
+ test166<double>();
+ test167<double>();
+ test168<double>();
+ test169<double>();
+ test170<double>();
+ test171<double>();
+ test172<double>();
+ test173<double>();
+ test174<double>();
+ test175<double>();
+ test176<double>();
+ test177<double>();
+ test178<double>();
+ test179<double>();
+ test180<double>();
+ test181<double>();
+ test182<double>();
+ test183<double>();
+ test184<double>();
+ test185<double>();
+ test186<double>();
+ test187<double>();
+ test188<double>();
+ test189<double>();
+ test190<double>();
+ test191<double>();
+ test192<double>();
+ test193<double>();
+ test194<double>();
+ test195<double>();
+ test196<double>();
+ test197<double>();
+ test198<double>();
+ test199<double>();
+ test200<double>();
+ test201<double>();
+ test202<double>();
+ test203<double>();
+ test204<double>();
+ test205<double>();
+ test206<double>();
+ test207<double>();
+ test208<double>();
+ test209<double>();
+ test210<double>();
+ test211<double>();
+ test212<double>();
+ test213<double>();
+ test214<double>();
+ test215<double>();
+ test216<double>();
+ test217<double>();
+ test218<double>();
+ test219<double>();
+ test220<double>();
+ test221<double>();
+ test222<double>();
+ test223<double>();
+ test224<double>();
+ test225<double>();
+ test226<double>();
+ test227<double>();
+ test228<double>();
+ test229<double>();
+ test230<double>();
+ test231<double>();
+ test232<double>();
+ test233<double>();
+ test234<double>();
+ test235<double>();
+ test236<double>();
+ test237<double>();
+ test238<double>();
+ test239<double>();
+ test240<double>();
+ test241<double>();
+ test242<double>();
+ test243<double>();
+ test244<double>();
+ test245<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/compile.cc
new file mode 100644
index 00000000000..3c322af3e1f
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/compile.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.17 hyperg
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+ float af = 2.0F, bf = 10.0F, cf = 3.0F, xf = 0.5F;
+ double ad = 2.0, bd = 10.0, cd = 3.0, xd = 0.5;
+ long double al = 2.0L, bl = 10.0L, cl = 3.0L, xl = 0.5L;
+
+ std::tr1::hyperg(af, bf, cf, xf);
+ std::tr1::hypergf(af, bf, cf, xf);
+ std::tr1::hyperg(ad, bd, cd, xd);
+ std::tr1::hyperg(al, bl, cl, xl);
+ std::tr1::hypergl(al, bl, cl, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/compile_2.cc
new file mode 100644
index 00000000000..fe51de72ce7
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/17_hyperg/compile_2.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.17 hyperg
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+ float af = 2.0F, bf = 10.0F, cf = 3.0F, xf = 0.5F;
+ double ad = 2.0, bd = 10.0, cd = 3.0, xd = 0.5;
+ long double al = 2.0L, bl = 10.0L, cl = 3.0L, xl = 0.5L;
+
+ hyperg(af, bf, cf, xf);
+ hypergf(af, bf, cf, xf);
+ hyperg(ad, bd, cd, xd);
+ hyperg(al, bl, cl, xl);
+ hypergl(al, bl, cl, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/check_nan.cc
new file mode 100644
index 00000000000..121a4528d06
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/check_nan.cc
@@ -0,0 +1,59 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.18 laguerre
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+
+ float xf = std::numeric_limits<float>::quiet_NaN();
+ double xd = std::numeric_limits<double>::quiet_NaN();
+ long double xl = std::numeric_limits<long double>::quiet_NaN();
+
+ unsigned int n = 2;
+
+ float a = std::tr1::laguerre(n, xf);
+ float b = std::tr1::laguerref(n, xf);
+ double c = std::tr1::laguerre(n, xd);
+ long double d = std::tr1::laguerre(n, xl);
+ long double e = std::tr1::laguerrel(n, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/check_value.cc
new file mode 100644
index 00000000000..ceef9d17119
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/check_value.cc
@@ -0,0 +1,470 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// laguerre
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for n=0.
+testcase_laguerre<double> data001[] = {
+ { 1.0000000000000000, 0, 0.0000000000000000 },
+ { 1.0000000000000000, 0, 5.0000000000000000 },
+ { 1.0000000000000000, 0, 10.000000000000000 },
+ { 1.0000000000000000, 0, 15.000000000000000 },
+ { 1.0000000000000000, 0, 20.000000000000000 },
+ { 1.0000000000000000, 0, 25.000000000000000 },
+ { 1.0000000000000000, 0, 30.000000000000000 },
+ { 1.0000000000000000, 0, 35.000000000000000 },
+ { 1.0000000000000000, 0, 40.000000000000000 },
+ { 1.0000000000000000, 0, 45.000000000000000 },
+ { 1.0000000000000000, 0, 50.000000000000000 },
+ { 1.0000000000000000, 0, 55.000000000000000 },
+ { 1.0000000000000000, 0, 60.000000000000000 },
+ { 1.0000000000000000, 0, 65.000000000000000 },
+ { 1.0000000000000000, 0, 70.000000000000000 },
+ { 1.0000000000000000, 0, 75.000000000000000 },
+ { 1.0000000000000000, 0, 80.000000000000000 },
+ { 1.0000000000000000, 0, 85.000000000000000 },
+ { 1.0000000000000000, 0, 90.000000000000000 },
+ { 1.0000000000000000, 0, 95.000000000000000 },
+ { 1.0000000000000000, 0, 100.00000000000000 },
+};
+
+// Test function for n=0.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::laguerre(Tp(data001[i].n), Tp(data001[i].x));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=1.
+testcase_laguerre<double> data002[] = {
+ { 1.0000000000000000, 1, 0.0000000000000000 },
+ { -4.0000000000000000, 1, 5.0000000000000000 },
+ { -9.0000000000000000, 1, 10.000000000000000 },
+ { -14.000000000000000, 1, 15.000000000000000 },
+ { -19.000000000000000, 1, 20.000000000000000 },
+ { -24.000000000000000, 1, 25.000000000000000 },
+ { -29.000000000000000, 1, 30.000000000000000 },
+ { -34.000000000000000, 1, 35.000000000000000 },
+ { -39.000000000000000, 1, 40.000000000000000 },
+ { -44.000000000000000, 1, 45.000000000000000 },
+ { -49.000000000000000, 1, 50.000000000000000 },
+ { -54.000000000000000, 1, 55.000000000000000 },
+ { -59.000000000000000, 1, 60.000000000000000 },
+ { -64.000000000000000, 1, 65.000000000000000 },
+ { -69.000000000000000, 1, 70.000000000000000 },
+ { -74.000000000000000, 1, 75.000000000000000 },
+ { -79.000000000000000, 1, 80.000000000000000 },
+ { -84.000000000000000, 1, 85.000000000000000 },
+ { -89.000000000000000, 1, 90.000000000000000 },
+ { -94.000000000000000, 1, 95.000000000000000 },
+ { -99.000000000000000, 1, 100.00000000000000 },
+};
+
+// Test function for n=1.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::laguerre(Tp(data002[i].n), Tp(data002[i].x));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=2.
+testcase_laguerre<double> data003[] = {
+ { 1.0000000000000000, 2, 0.0000000000000000 },
+ { 3.5000000000000000, 2, 5.0000000000000000 },
+ { 31.000000000000000, 2, 10.000000000000000 },
+ { 83.500000000000000, 2, 15.000000000000000 },
+ { 161.00000000000000, 2, 20.000000000000000 },
+ { 263.50000000000000, 2, 25.000000000000000 },
+ { 391.00000000000000, 2, 30.000000000000000 },
+ { 543.50000000000000, 2, 35.000000000000000 },
+ { 721.00000000000000, 2, 40.000000000000000 },
+ { 923.50000000000000, 2, 45.000000000000000 },
+ { 1151.0000000000000, 2, 50.000000000000000 },
+ { 1403.5000000000000, 2, 55.000000000000000 },
+ { 1681.0000000000000, 2, 60.000000000000000 },
+ { 1983.5000000000000, 2, 65.000000000000000 },
+ { 2311.0000000000000, 2, 70.000000000000000 },
+ { 2663.5000000000000, 2, 75.000000000000000 },
+ { 3041.0000000000000, 2, 80.000000000000000 },
+ { 3443.5000000000000, 2, 85.000000000000000 },
+ { 3871.0000000000000, 2, 90.000000000000000 },
+ { 4323.5000000000000, 2, 95.000000000000000 },
+ { 4801.0000000000000, 2, 100.00000000000000 },
+};
+
+// Test function for n=2.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::laguerre(Tp(data003[i].n), Tp(data003[i].x));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=5.
+testcase_laguerre<double> data004[] = {
+ { 1.0000000000000000, 5, 0.0000000000000000 },
+ { -3.1666666666666665, 5, 5.0000000000000000 },
+ { 34.333333333333329, 5, 10.000000000000000 },
+ { -355.25000000000000, 5, 15.000000000000000 },
+ { -4765.6666666666670, 5, 20.000000000000000 },
+ { -23040.666666666664, 5, 25.000000000000000 },
+ { -74399.000000000000, 5, 30.000000000000000 },
+ { -190559.41666666663, 5, 35.000000000000000 },
+ { -418865.66666666663, 5, 40.000000000000000 },
+ { -825411.50000000000, 5, 45.000000000000000 },
+ { -1498165.6666666665, 5, 50.000000000000000 },
+ { -2550096.9166666670, 5, 55.000000000000000 },
+ { -4122299.0000000000, 5, 60.000000000000000 },
+ { -6387115.6666666670, 5, 65.000000000000000 },
+ { -9551265.6666666679, 5, 70.000000000000000 },
+ { -13858967.750000000, 5, 75.000000000000000 },
+ { -19595065.666666664, 5, 80.000000000000000 },
+ { -27088153.166666668, 5, 85.000000000000000 },
+ { -36713699.000000000, 5, 90.000000000000000 },
+ { -48897171.916666657, 5, 95.000000000000000 },
+ { -64117165.666666664, 5, 100.00000000000000 },
+};
+
+// Test function for n=5.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::laguerre(Tp(data004[i].n), Tp(data004[i].x));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=10.
+testcase_laguerre<double> data005[] = {
+ { 1.0000000000000000, 10, 0.0000000000000000 },
+ { 1.7562761794532620, 10, 5.0000000000000000 },
+ { 27.984126984126981, 10, 10.000000000000000 },
+ { -237.51841517857147, 10, 15.000000000000000 },
+ { 3227.8077601410932, 10, 20.000000000000000 },
+ { -45786.199797453693, 10, 25.000000000000000 },
+ { 15129.571428571489, 10, 30.000000000000000 },
+ { 7764800.8179494590, 10, 35.000000000000000 },
+ { 79724066.608465582, 10, 40.000000000000000 },
+ { 469865425.65122765, 10, 45.000000000000000 },
+ { 2037190065.3738980, 10, 50.000000000000000 },
+ { 7187828002.9825764, 10, 55.000000000000000 },
+ { 21804200401.000000, 10, 60.000000000000000 },
+ { 58854343015.616211, 10, 65.000000000000000 },
+ { 144688291819.51855, 10, 70.000000000000000 },
+ { 329425241736.70038, 10, 75.000000000000000 },
+ { 703324772760.08276, 10, 80.000000000000000 },
+ { 1421627560118.6157, 10, 85.000000000000000 },
+ { 2741055412243.8569, 10, 90.000000000000000 },
+ { 5071986977681.8652, 10, 95.000000000000000 },
+ { 9051283795429.5723, 10, 100.00000000000000 },
+};
+
+// Test function for n=10.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::laguerre(Tp(data005[i].n), Tp(data005[i].x));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for n=20.
+testcase_laguerre<double> data006[] = {
+ { 1.0000000000000000, 20, 0.0000000000000000 },
+ { 2.0202257444769129, 20, 5.0000000000000000 },
+ { -11.961333867812119, 20, 10.000000000000000 },
+ { -50.151037960139455, 20, 15.000000000000000 },
+ { 2829.4728613531738, 20, 20.000000000000000 },
+ { -11583.947899113535, 20, 25.000000000000000 },
+ { -18439.424502520938, 20, 30.000000000000000 },
+ { -38838.223606979467, 20, 35.000000000000000 },
+ { 24799805.877530701, 20, 40.000000000000000 },
+ { -673953823.59913290, 20, 45.000000000000000 },
+ { 7551960453.7672529, 20, 50.000000000000000 },
+ { 31286508510.614754, 20, 55.000000000000000 },
+ { -1379223608444.9155, 20, 60.000000000000000 },
+ { -6692517968212.9727, 20, 65.000000000000000 },
+ { 165423821874449.94, 20, 70.000000000000000 },
+ { 3082390018008546.5, 20, 75.000000000000000 },
+ { 29500368536981676., 20, 80.000000000000000 },
+ { 2.0353526354974186e+17, 20, 85.000000000000000 },
+ { 1.1292309514432899e+18, 20, 90.000000000000000 },
+ { 5.3239262855563100e+18, 20, 95.000000000000000 },
+ { 2.2061882785931735e+19, 20, 100.00000000000000 },
+};
+
+// Test function for n=20.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::laguerre(Tp(data006[i].n), Tp(data006[i].x));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for n=50.
+testcase_laguerre<double> data007[] = {
+ { 1.0000000000000000, 50, 0.0000000000000000 },
+ { 1.4735258819430563, 50, 5.0000000000000000 },
+ { 17.534183446338233, 50, 10.000000000000000 },
+ { -195.62436619077388, 50, 15.000000000000000 },
+ { 980.26961889790766, 50, 20.000000000000000 },
+ { 24812.277673870871, 50, 25.000000000000000 },
+ { 293000.50735962350, 50, 30.000000000000000 },
+ { 2316195.5013375296, 50, 35.000000000000000 },
+ { -14896937.968694847, 50, 40.000000000000000 },
+ { -502066598.00813466, 50, 45.000000000000000 },
+ { 2513677852.6916885, 50, 50.000000000000000 },
+ { 45129675503.538948, 50, 55.000000000000000 },
+ { -883876565337.99207, 50, 60.000000000000000 },
+ { 9361319947203.8379, 50, 65.000000000000000 },
+ { -80967880733583.219, 50, 70.000000000000000 },
+ { 717391079438942.88, 50, 75.000000000000000 },
+ { -8217471769564850.0, 50, 80.000000000000000 },
+ { 1.2595276229009984e+17, 50, 85.000000000000000 },
+ { -2.1140031308048906e+18, 50, 90.000000000000000 },
+ { 3.2438187475835138e+19, 50, 95.000000000000000 },
+ { -3.9710103487094673e+20, 50, 100.00000000000000 },
+};
+
+// Test function for n=50.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::laguerre(Tp(data007[i].n), Tp(data007[i].x));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for n=100.
+testcase_laguerre<double> data008[] = {
+ { 1.0000000000000000, 100, 0.0000000000000000 },
+ { 1.4555271625328832, 100, 5.0000000000000000 },
+ { 13.277662844303402, 100, 10.000000000000000 },
+ { 91.737038454342013, 100, 15.000000000000000 },
+ { 1854.0367283243393, 100, 20.000000000000000 },
+ { -11281.698886837237, 100, 25.000000000000000 },
+ { 170141.86987046539, 100, 30.000000000000000 },
+ { -2950092.7025822792, 100, 35.000000000000000 },
+ { -7272442.3156007063, 100, 40.000000000000000 },
+ { 295697471.90876174, 100, 45.000000000000000 },
+ { 4847420871.2690468, 100, 50.000000000000000 },
+ { 59406998102.392273, 100, 55.000000000000000 },
+ { 693492765740.29736, 100, 60.000000000000000 },
+ { 6606192010150.3096, 100, 65.000000000000000 },
+ { 17125518672239.707, 100, 70.000000000000000 },
+ { -870493767065151.38, 100, 75.000000000000000 },
+ { -13763178176383754., 100, 80.000000000000000 },
+ { 30667078414479724., 100, 85.000000000000000 },
+ { 2.1307220490380198e+18, 100, 90.000000000000000 },
+ { -7.2706523009007862e+18, 100, 95.000000000000000 },
+ { -2.6292260693068920e+20, 100, 100.00000000000000 },
+};
+
+// Test function for n=100.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_laguerre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::laguerre(Tp(data008[i].n), Tp(data008[i].x));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/compile.cc
new file mode 100644
index 00000000000..750724cf0d0
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/compile.cc
@@ -0,0 +1,44 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.18 laguerre
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+
+ unsigned int n = 2;
+
+ std::tr1::laguerre(n, xf);
+ std::tr1::laguerref(n, xf);
+ std::tr1::laguerre(n, xd);
+ std::tr1::laguerre(n, xl);
+ std::tr1::laguerrel(n, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/compile_2.cc
new file mode 100644
index 00000000000..157cc29649c
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/18_laguerre/compile_2.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.18 laguerre
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+ unsigned int n = 2;
+
+ laguerre(n, xf);
+ laguerref(n, xf);
+ laguerre(n, xd);
+ laguerre(n, xl);
+ laguerrel(n, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/check_nan.cc
new file mode 100644
index 00000000000..e051b3cadff
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/check_nan.cc
@@ -0,0 +1,59 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.19 legendre
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+
+ float xf = std::numeric_limits<float>::quiet_NaN();
+ double xd = std::numeric_limits<double>::quiet_NaN();
+ long double xl = std::numeric_limits<long double>::quiet_NaN();
+
+ unsigned int l = 2;
+
+ float a = std::tr1::legendre(l, xf);
+ float b = std::tr1::legendref(l, xf);
+ double c = std::tr1::legendre(l, xd);
+ long double d = std::tr1::legendre(l, xl);
+ long double e = std::tr1::legendrel(l, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/check_value.cc
new file mode 100644
index 00000000000..dd70e0bd736
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/check_value.cc
@@ -0,0 +1,470 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// legendre
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for l=0.
+testcase_legendre<double> data001[] = {
+ { 1.0000000000000000, 0, -1.0000000000000000 },
+ { 1.0000000000000000, 0, -0.90000000000000002 },
+ { 1.0000000000000000, 0, -0.80000000000000004 },
+ { 1.0000000000000000, 0, -0.69999999999999996 },
+ { 1.0000000000000000, 0, -0.59999999999999998 },
+ { 1.0000000000000000, 0, -0.50000000000000000 },
+ { 1.0000000000000000, 0, -0.40000000000000002 },
+ { 1.0000000000000000, 0, -0.30000000000000004 },
+ { 1.0000000000000000, 0, -0.19999999999999996 },
+ { 1.0000000000000000, 0, -0.099999999999999978 },
+ { 1.0000000000000000, 0, 0.0000000000000000 },
+ { 1.0000000000000000, 0, 0.10000000000000009 },
+ { 1.0000000000000000, 0, 0.19999999999999996 },
+ { 1.0000000000000000, 0, 0.30000000000000004 },
+ { 1.0000000000000000, 0, 0.39999999999999991 },
+ { 1.0000000000000000, 0, 0.50000000000000000 },
+ { 1.0000000000000000, 0, 0.60000000000000009 },
+ { 1.0000000000000000, 0, 0.69999999999999996 },
+ { 1.0000000000000000, 0, 0.80000000000000004 },
+ { 1.0000000000000000, 0, 0.89999999999999991 },
+ { 1.0000000000000000, 0, 1.0000000000000000 },
+};
+
+// Test function for l=0.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::legendre(Tp(data001[i].l), Tp(data001[i].x));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=1.
+testcase_legendre<double> data002[] = {
+ { -1.0000000000000000, 1, -1.0000000000000000 },
+ { -0.90000000000000002, 1, -0.90000000000000002 },
+ { -0.80000000000000004, 1, -0.80000000000000004 },
+ { -0.69999999999999996, 1, -0.69999999999999996 },
+ { -0.59999999999999998, 1, -0.59999999999999998 },
+ { -0.50000000000000000, 1, -0.50000000000000000 },
+ { -0.40000000000000002, 1, -0.40000000000000002 },
+ { -0.30000000000000004, 1, -0.30000000000000004 },
+ { -0.19999999999999996, 1, -0.19999999999999996 },
+ { -0.099999999999999978, 1, -0.099999999999999978 },
+ { 0.0000000000000000, 1, 0.0000000000000000 },
+ { 0.10000000000000009, 1, 0.10000000000000009 },
+ { 0.19999999999999996, 1, 0.19999999999999996 },
+ { 0.30000000000000004, 1, 0.30000000000000004 },
+ { 0.39999999999999991, 1, 0.39999999999999991 },
+ { 0.50000000000000000, 1, 0.50000000000000000 },
+ { 0.60000000000000009, 1, 0.60000000000000009 },
+ { 0.69999999999999996, 1, 0.69999999999999996 },
+ { 0.80000000000000004, 1, 0.80000000000000004 },
+ { 0.89999999999999991, 1, 0.89999999999999991 },
+ { 1.0000000000000000, 1, 1.0000000000000000 },
+};
+
+// Test function for l=1.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::legendre(Tp(data002[i].l), Tp(data002[i].x));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=2.
+testcase_legendre<double> data003[] = {
+ { 1.0000000000000000, 2, -1.0000000000000000 },
+ { 0.71500000000000008, 2, -0.90000000000000002 },
+ { 0.46000000000000019, 2, -0.80000000000000004 },
+ { 0.23499999999999988, 2, -0.69999999999999996 },
+ { 0.039999999999999925, 2, -0.59999999999999998 },
+ { -0.12500000000000000, 2, -0.50000000000000000 },
+ { -0.25999999999999995, 2, -0.40000000000000002 },
+ { -0.36499999999999999, 2, -0.30000000000000004 },
+ { -0.44000000000000006, 2, -0.19999999999999996 },
+ { -0.48499999999999999, 2, -0.099999999999999978 },
+ { -0.50000000000000000, 2, 0.0000000000000000 },
+ { -0.48499999999999999, 2, 0.10000000000000009 },
+ { -0.44000000000000006, 2, 0.19999999999999996 },
+ { -0.36499999999999999, 2, 0.30000000000000004 },
+ { -0.26000000000000012, 2, 0.39999999999999991 },
+ { -0.12500000000000000, 2, 0.50000000000000000 },
+ { 0.040000000000000147, 2, 0.60000000000000009 },
+ { 0.23499999999999988, 2, 0.69999999999999996 },
+ { 0.46000000000000019, 2, 0.80000000000000004 },
+ { 0.71499999999999986, 2, 0.89999999999999991 },
+ { 1.0000000000000000, 2, 1.0000000000000000 },
+};
+
+// Test function for l=2.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::legendre(Tp(data003[i].l), Tp(data003[i].x));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=5.
+testcase_legendre<double> data004[] = {
+ { -1.0000000000000000, 5, -1.0000000000000000 },
+ { 0.041141249999999997, 5, -0.90000000000000002 },
+ { 0.39951999999999993, 5, -0.80000000000000004 },
+ { 0.36519874999999991, 5, -0.69999999999999996 },
+ { 0.15263999999999994, 5, -0.59999999999999998 },
+ { -0.089843750000000000, 5, -0.50000000000000000 },
+ { -0.27063999999999988, 5, -0.40000000000000002 },
+ { -0.34538624999999995, 5, -0.30000000000000004 },
+ { -0.30751999999999996, 5, -0.19999999999999996 },
+ { -0.17882874999999995, 5, -0.099999999999999978 },
+ { 0.0000000000000000, 5, 0.0000000000000000 },
+ { 0.17882875000000015, 5, 0.10000000000000009 },
+ { 0.30751999999999996, 5, 0.19999999999999996 },
+ { 0.34538624999999995, 5, 0.30000000000000004 },
+ { 0.27064000000000010, 5, 0.39999999999999991 },
+ { 0.089843750000000000, 5, 0.50000000000000000 },
+ { -0.15264000000000022, 5, 0.60000000000000009 },
+ { -0.36519874999999991, 5, 0.69999999999999996 },
+ { -0.39951999999999993, 5, 0.80000000000000004 },
+ { -0.041141250000000407, 5, 0.89999999999999991 },
+ { 1.0000000000000000, 5, 1.0000000000000000 },
+};
+
+// Test function for l=5.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::legendre(Tp(data004[i].l), Tp(data004[i].x));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=10.
+testcase_legendre<double> data005[] = {
+ { 1.0000000000000000, 10, -1.0000000000000000 },
+ { -0.26314561785585977, 10, -0.90000000000000002 },
+ { 0.30052979559999998, 10, -0.80000000000000004 },
+ { 0.085805795531640333, 10, -0.69999999999999996 },
+ { -0.24366274560000006, 10, -0.59999999999999998 },
+ { -0.18822860717773438, 10, -0.50000000000000000 },
+ { 0.096839064399999869, 10, -0.40000000000000002 },
+ { 0.25147634951601561, 10, -0.30000000000000004 },
+ { 0.12907202559999989, 10, -0.19999999999999996 },
+ { -0.12212499738710947, 10, -0.099999999999999978 },
+ { -0.24609375000000000, 10, 0.0000000000000000 },
+ { -0.12212499738710922, 10, 0.10000000000000009 },
+ { 0.12907202559999989, 10, 0.19999999999999996 },
+ { 0.25147634951601561, 10, 0.30000000000000004 },
+ { 0.096839064400000258, 10, 0.39999999999999991 },
+ { -0.18822860717773438, 10, 0.50000000000000000 },
+ { -0.24366274559999987, 10, 0.60000000000000009 },
+ { 0.085805795531640333, 10, 0.69999999999999996 },
+ { 0.30052979559999998, 10, 0.80000000000000004 },
+ { -0.26314561785585888, 10, 0.89999999999999991 },
+ { 1.0000000000000000, 10, 1.0000000000000000 },
+};
+
+// Test function for l=10.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::legendre(Tp(data005[i].l), Tp(data005[i].x));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=20.
+testcase_legendre<double> data006[] = {
+ { 1.0000000000000000, 20, -1.0000000000000000 },
+ { -0.14930823530984821, 20, -0.90000000000000002 },
+ { 0.22420460541741344, 20, -0.80000000000000004 },
+ { -0.20457394463834172, 20, -0.69999999999999996 },
+ { 0.15916752910098114, 20, -0.59999999999999998 },
+ { -0.048358381067373557, 20, -0.50000000000000000 },
+ { -0.10159261558628156, 20, -0.40000000000000002 },
+ { 0.18028715947998047, 20, -0.30000000000000004 },
+ { -0.098042194344594741, 20, -0.19999999999999996 },
+ { -0.082077130944527649, 20, -0.099999999999999978 },
+ { 0.17619705200195312, 20, 0.0000000000000000 },
+ { -0.082077130944528037, 20, 0.10000000000000009 },
+ { -0.098042194344594741, 20, 0.19999999999999996 },
+ { 0.18028715947998047, 20, 0.30000000000000004 },
+ { -0.10159261558628112, 20, 0.39999999999999991 },
+ { -0.048358381067373557, 20, 0.50000000000000000 },
+ { 0.15916752910098084, 20, 0.60000000000000009 },
+ { -0.20457394463834172, 20, 0.69999999999999996 },
+ { 0.22420460541741344, 20, 0.80000000000000004 },
+ { -0.14930823530984949, 20, 0.89999999999999991 },
+ { 1.0000000000000000, 20, 1.0000000000000000 },
+};
+
+// Test function for l=20.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::legendre(Tp(data006[i].l), Tp(data006[i].x));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=50.
+testcase_legendre<double> data007[] = {
+ { 1.0000000000000000, 50, -1.0000000000000000 },
+ { -0.17003765994383685, 50, -0.90000000000000002 },
+ { 0.13879737345093118, 50, -0.80000000000000004 },
+ { -0.014572731645892805, 50, -0.69999999999999996 },
+ { -0.058860798844002173, 50, -0.59999999999999998 },
+ { -0.031059099239609828, 50, -0.50000000000000000 },
+ { 0.041569033381825368, 50, -0.40000000000000002 },
+ { 0.10911051574714808, 50, -0.30000000000000004 },
+ { 0.083432272204197466, 50, -0.19999999999999996 },
+ { -0.038205812661313579, 50, -0.099999999999999978 },
+ { -0.11227517265921705, 50, 0.0000000000000000 },
+ { -0.038205812661314169, 50, 0.10000000000000009 },
+ { 0.083432272204197466, 50, 0.19999999999999996 },
+ { 0.10911051574714808, 50, 0.30000000000000004 },
+ { 0.041569033381824647, 50, 0.39999999999999991 },
+ { -0.031059099239609828, 50, 0.50000000000000000 },
+ { -0.058860798844001430, 50, 0.60000000000000009 },
+ { -0.014572731645892805, 50, 0.69999999999999996 },
+ { 0.13879737345093118, 50, 0.80000000000000004 },
+ { -0.17003765994383663, 50, 0.89999999999999991 },
+ { 1.0000000000000000, 50, 1.0000000000000000 },
+};
+
+// Test function for l=50.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::legendre(Tp(data007[i].l), Tp(data007[i].x));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=100.
+testcase_legendre<double> data008[] = {
+ { 1.0000000000000000, 100, -1.0000000000000000 },
+ { 0.10226582055871908, 100, -0.90000000000000002 },
+ { 0.050861167913584124, 100, -0.80000000000000004 },
+ { -0.077132507199778780, 100, -0.69999999999999996 },
+ { -0.023747023905133110, 100, -0.59999999999999998 },
+ { -0.060518025961861198, 100, -0.50000000000000000 },
+ { -0.072258202125684429, 100, -0.40000000000000002 },
+ { 0.057127392202801719, 100, -0.30000000000000004 },
+ { 0.014681835355659636, 100, -0.19999999999999996 },
+ { -0.063895098434750303, 100, -0.099999999999999978 },
+ { 0.079589237387178727, 100, 0.0000000000000000 },
+ { -0.063895098434749775, 100, 0.10000000000000009 },
+ { 0.014681835355659636, 100, 0.19999999999999996 },
+ { 0.057127392202801719, 100, 0.30000000000000004 },
+ { -0.072258202125685012, 100, 0.39999999999999991 },
+ { -0.060518025961861198, 100, 0.50000000000000000 },
+ { -0.023747023905134217, 100, 0.60000000000000009 },
+ { -0.077132507199778780, 100, 0.69999999999999996 },
+ { 0.050861167913584124, 100, 0.80000000000000004 },
+ { 0.10226582055871723, 100, 0.89999999999999991 },
+ { 1.0000000000000000, 100, 1.0000000000000000 },
+};
+
+// Test function for l=100.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::legendre(Tp(data008[i].l), Tp(data008[i].x));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/compile.cc
new file mode 100644
index 00000000000..c00cca67361
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/compile.cc
@@ -0,0 +1,44 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.19 legendre
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+
+ unsigned int l = 2;
+
+ std::tr1::legendre(l, xf);
+ std::tr1::legendref(l, xf);
+ std::tr1::legendre(l, xd);
+ std::tr1::legendre(l, xl);
+ std::tr1::legendrel(l, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/compile_2.cc
new file mode 100644
index 00000000000..f69dfa32543
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/19_legendre/compile_2.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.19 legendre
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+ unsigned int l = 2;
+
+ legendre(l, xf);
+ legendref(l, xf);
+ legendre(l, xd);
+ legendre(l, xl);
+ legendrel(l, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/check_nan.cc
new file mode 100644
index 00000000000..bdfa2e9af18
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/check_nan.cc
@@ -0,0 +1,57 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.20 riemann_zeta
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+
+ float xf = std::numeric_limits<float>::quiet_NaN();
+ double xd = std::numeric_limits<double>::quiet_NaN();
+ long double xl = std::numeric_limits<long double>::quiet_NaN();
+
+ float a = std::tr1::riemann_zeta(xf);
+ float b = std::tr1::riemann_zetaf(xf);
+ double c = std::tr1::riemann_zeta(xd);
+ long double d = std::tr1::riemann_zeta(xl);
+ long double e = std::tr1::riemann_zetal(xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/check_value_neg.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/check_value_neg.cc
new file mode 100644
index 00000000000..2a86846ea4a
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/check_value_neg.cc
@@ -0,0 +1,133 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// riemann_zeta
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data.
+testcase_riemann_zeta<double> data001[] = {
+ { 0.0000000000000000, -10.000000000000000 },
+ { -0.0033669820451019579, -9.8000000000000007 },
+ { -0.0058129517767319039, -9.5999999999999996 },
+ { -0.0072908732290557004, -9.4000000000000004 },
+ { -0.0078420910654484442, -9.1999999999999993 },
+ { -0.0075757575757575803, -9.0000000000000000 },
+ { -0.0066476555677551898, -8.8000000000000007 },
+ { -0.0052400095350859429, -8.5999999999999996 },
+ { -0.0035434308017674959, -8.4000000000000004 },
+ { -0.0017417330388368585, -8.1999999999999993 },
+ { 0.0000000000000000, -8.0000000000000000 },
+ { 0.0015440036789213965, -7.7999999999999998 },
+ { 0.0027852131086497423, -7.5999999999999996 },
+ { 0.0036537321227995880, -7.4000000000000004 },
+ { 0.0041147930817053468, -7.2000000000000002 },
+ { 0.0041666666666666683, -7.0000000000000000 },
+ { 0.0038369975032738366, -6.7999999999999998 },
+ { 0.0031780270571782981, -6.5999999999999996 },
+ { 0.0022611282027338573, -6.4000000000000004 },
+ { 0.0011710237049390511, -6.2000000000000002 },
+ { 0.0000000000000000, -6.0000000000000000 },
+ { -0.0011576366649881879, -5.7999999999999998 },
+ { -0.0022106784318564345, -5.5999999999999996 },
+ { -0.0030755853460586891, -5.4000000000000004 },
+ { -0.0036804380477934787, -5.2000000000000002 },
+ { -0.0039682539682539698, -5.0000000000000000 },
+ { -0.0038996891301999797, -4.7999999999999998 },
+ { -0.0034551830834302711, -4.5999999999999996 },
+ { -0.0026366345018725115, -4.4000000000000004 },
+ { -0.0014687209305056974, -4.2000000000000002 },
+ { 0.0000000000000000, -4.0000000000000000 },
+ { 0.0016960463875825209, -3.7999999999999998 },
+ { 0.0035198355903356747, -3.5999999999999996 },
+ { 0.0053441503206513421, -3.4000000000000004 },
+ { 0.0070119720770910540, -3.2000000000000002 },
+ { 0.0083333333333333350, -3.0000000000000000 },
+ { 0.0090807294856852811, -2.7999999999999998 },
+ { 0.0089824623788396681, -2.5999999999999996 },
+ { 0.0077130239874243630, -2.4000000000000004 },
+ { 0.0048792123593036068, -2.2000000000000002 },
+ { 0.0000000000000000, -2.0000000000000000 },
+ { -0.0075229347765968010, -1.8000000000000007 },
+ { -0.018448986678963775, -1.5999999999999996 },
+ { -0.033764987694047593, -1.4000000000000004 },
+ { -0.054788441243880631, -1.1999999999999993 },
+ { -0.083333333333333398, -1.0000000000000000 },
+ { -0.12198707766977103, -0.80000000000000071 },
+ { -0.17459571193801401, -0.59999999999999964 },
+ { -0.24716546083171492, -0.40000000000000036 },
+ { -0.34966628059831484, -0.19999999999999929 },
+ { -0.49999999999999994, 0.0000000000000000 },
+ { -0.73392092489633953, 0.19999999999999929 },
+ { -1.1347977838669825, 0.40000000000000036 },
+ { -1.9526614482239983, 0.59999999999999964 },
+ { -4.4375384158955677, 0.80000000000000071 },
+};
+
+// Test function.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_riemann_zeta<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::riemann_zeta(Tp(data001[i].x));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/check_value_pos.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/check_value_pos.cc
new file mode 100644
index 00000000000..3188c334f5b
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/check_value_pos.cc
@@ -0,0 +1,223 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// riemann_zeta
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data.
+testcase_riemann_zeta<double> data001[] = {
+ { 5.5915824411777502, 1.2000000000000000 },
+ { 3.1055472779775792, 1.3999999999999999 },
+ { 2.2857656656801324, 1.6000000000000001 },
+ { 1.8822296181028220, 1.8000000000000000 },
+ { 1.6449340668482275, 2.0000000000000000 },
+ { 1.4905432565068937, 2.2000000000000002 },
+ { 1.3833428588407359, 2.3999999999999999 },
+ { 1.3054778090727803, 2.6000000000000001 },
+ { 1.2470314223172541, 2.7999999999999998 },
+ { 1.2020569031595945, 3.0000000000000000 },
+ { 1.1667733709844674, 3.2000000000000002 },
+ { 1.1386637757280420, 3.3999999999999999 },
+ { 1.1159890791233376, 3.6000000000000001 },
+ { 1.0975105764590047, 3.7999999999999998 },
+ { 1.0823232337111381, 4.0000000000000000 },
+ { 1.0697514772338095, 4.2000000000000002 },
+ { 1.0592817259798355, 4.4000000000000004 },
+ { 1.0505173825665735, 4.5999999999999996 },
+ { 1.0431480133351789, 4.7999999999999998 },
+ { 1.0369277551433700, 5.0000000000000000 },
+ { 1.0316598766779168, 5.2000000000000002 },
+ { 1.0271855389203537, 5.4000000000000004 },
+ { 1.0233754792270300, 5.5999999999999996 },
+ { 1.0201237683883446, 5.7999999999999998 },
+ { 1.0173430619844492, 6.0000000000000000 },
+ { 1.0149609451852233, 6.2000000000000002 },
+ { 1.0129170887121841, 6.4000000000000004 },
+ { 1.0111610141542708, 6.5999999999999996 },
+ { 1.0096503223447120, 6.7999999999999998 },
+ { 1.0083492773819229, 7.0000000000000000 },
+ { 1.0072276664807169, 7.2000000000000002 },
+ { 1.0062598756930512, 7.4000000000000004 },
+ { 1.0054241359879634, 7.5999999999999996 },
+ { 1.0047019048164696, 7.7999999999999998 },
+ { 1.0040773561979444, 8.0000000000000000 },
+ { 1.0035369583062013, 8.1999999999999993 },
+ { 1.0030691220374448, 8.4000000000000004 },
+ { 1.0026639074861505, 8.5999999999999996 },
+ { 1.0023127779098220, 8.8000000000000007 },
+ { 1.0020083928260823, 9.0000000000000000 },
+ { 1.0017444334995897, 9.1999999999999993 },
+ { 1.0015154553480514, 9.4000000000000004 },
+ { 1.0013167628052648, 9.5999999999999996 },
+ { 1.0011443029840295, 9.8000000000000007 },
+ { 1.0009945751278182, 10.000000000000000 },
+ { 1.0008645533615086, 10.199999999999999 },
+ { 1.0007516206744649, 10.400000000000000 },
+ { 1.0006535124140847, 10.600000000000000 },
+ { 1.0005682678503411, 10.800000000000001 },
+ { 1.0004941886041194, 11.000000000000000 },
+ { 1.0004298029239944, 11.199999999999999 },
+ { 1.0003738349551168, 11.400000000000000 },
+ { 1.0003251782761946, 11.600000000000000 },
+ { 1.0002828730909989, 11.800000000000001 },
+ { 1.0002460865533080, 12.000000000000000 },
+ { 1.0002140957818750, 12.199999999999999 },
+ { 1.0001862731874056, 12.400000000000000 },
+ { 1.0001620737887460, 12.600000000000000 },
+ { 1.0001410242422089, 12.800000000000001 },
+ { 1.0001227133475783, 13.000000000000000 },
+ { 1.0001067838280169, 13.199999999999999 },
+ { 1.0000929252097515, 13.400000000000000 },
+ { 1.0000808676518718, 13.600000000000000 },
+ { 1.0000703765974504, 13.800000000000001 },
+ { 1.0000612481350588, 14.000000000000000 },
+ { 1.0000533049750668, 14.199999999999999 },
+ { 1.0000463929582293, 14.400000000000000 },
+ { 1.0000403780253397, 14.600000000000000 },
+ { 1.0000351435864272, 14.800000000000001 },
+ { 1.0000305882363070, 15.000000000000000 },
+ { 1.0000266237704787, 15.199999999999999 },
+ { 1.0000231734615617, 15.400000000000000 },
+ { 1.0000201705617975, 15.600000000000000 },
+ { 1.0000175570017611, 15.800000000000001 },
+ { 1.0000152822594086, 16.000000000000000 },
+ { 1.0000133023770337, 16.199999999999999 },
+ { 1.0000115791066830, 16.399999999999999 },
+ { 1.0000100791671644, 16.600000000000001 },
+ { 1.0000087735980010, 16.800000000000001 },
+ { 1.0000076371976379, 17.000000000000000 },
+ { 1.0000066480348633, 17.199999999999999 },
+ { 1.0000057870238734, 17.399999999999999 },
+ { 1.0000050375546607, 17.600000000000001 },
+ { 1.0000043851715013, 17.800000000000001 },
+ { 1.0000038172932648, 18.000000000000000 },
+ { 1.0000033229700953, 18.199999999999999 },
+ { 1.0000028926717153, 18.399999999999999 },
+ { 1.0000025181032419, 18.600000000000001 },
+ { 1.0000021920449287, 18.800000000000001 },
+ { 1.0000019082127167, 19.000000000000000 },
+ { 1.0000016611368951, 19.199999999999999 },
+ { 1.0000014460565094, 19.399999999999999 },
+ { 1.0000012588274738, 19.600000000000001 },
+ { 1.0000010958426055, 19.800000000000001 },
+ { 1.0000009539620338, 20.000000000000000 },
+ { 1.0000008304526344, 20.199999999999999 },
+ { 1.0000007229353187, 20.399999999999999 },
+ { 1.0000006293391575, 20.600000000000001 },
+ { 1.0000005478614529, 20.800000000000001 },
+ { 1.0000004769329869, 21.000000000000000 },
+ { 1.0000004151877719, 21.199999999999999 },
+ { 1.0000003614367254, 21.399999999999999 },
+ { 1.0000003146447527, 21.600000000000001 },
+ { 1.0000002739108020, 21.800000000000001 },
+ { 1.0000002384505029, 22.000000000000000 },
+ { 1.0000002075810521, 22.199999999999999 },
+ { 1.0000001807080625, 22.399999999999999 },
+ { 1.0000001573141093, 22.600000000000001 },
+ { 1.0000001369487659, 22.800000000000001 },
+ { 1.0000001192199262, 23.000000000000000 },
+ { 1.0000001037862520, 23.199999999999999 },
+ { 1.0000000903506006, 23.399999999999999 },
+ { 1.0000000786543011, 23.600000000000001 },
+ { 1.0000000684721728, 23.800000000000001 },
+ { 1.0000000596081891, 24.000000000000000 },
+ { 1.0000000518917020, 24.199999999999999 },
+ { 1.0000000451741575, 24.399999999999999 },
+ { 1.0000000393262332, 24.600000000000001 },
+ { 1.0000000342353501, 24.800000000000001 },
+ { 1.0000000298035037, 25.000000000000000 },
+ { 1.0000000259453767, 25.199999999999999 },
+ { 1.0000000225866978, 25.399999999999999 },
+ { 1.0000000196628109, 25.600000000000001 },
+ { 1.0000000171174297, 25.800000000000001 },
+ { 1.0000000149015549, 26.000000000000000 },
+ { 1.0000000129725304, 26.199999999999999 },
+ { 1.0000000112932221, 26.399999999999999 },
+ { 1.0000000098313035, 26.600000000000001 },
+ { 1.0000000085586331, 26.800000000000001 },
+ { 1.0000000074507118, 27.000000000000000 },
+ { 1.0000000064862125, 27.199999999999999 },
+ { 1.0000000056465688, 27.399999999999999 },
+ { 1.0000000049156179, 27.600000000000001 },
+ { 1.0000000042792894, 27.800000000000001 },
+ { 1.0000000037253340, 28.000000000000000 },
+ { 1.0000000032430887, 28.199999999999999 },
+ { 1.0000000028232703, 28.399999999999999 },
+ { 1.0000000024577977, 28.600000000000001 },
+ { 1.0000000021396356, 28.800000000000001 },
+ { 1.0000000018626598, 29.000000000000000 },
+ { 1.0000000016215385, 29.199999999999999 },
+ { 1.0000000014116306, 29.399999999999999 },
+ { 1.0000000012288952, 29.600000000000001 },
+ { 1.0000000010698147, 29.800000000000001 },
+ { 1.0000000009313275, 30.000000000000000 },
+};
+
+// Test function.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_riemann_zeta<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::riemann_zeta(Tp(data001[i].x));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/compile.cc
new file mode 100644
index 00000000000..9e39e03468b
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/compile.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.20 riemann_zeta
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+
+ std::tr1::riemann_zeta(xf);
+ std::tr1::riemann_zetaf(xf);
+ std::tr1::riemann_zeta(xd);
+ std::tr1::riemann_zeta(xl);
+ std::tr1::riemann_zetal(xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/compile_2.cc
new file mode 100644
index 00000000000..60e2667b1ec
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/20_riemann_zeta/compile_2.cc
@@ -0,0 +1,42 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.20 riemann_zeta
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+
+ riemann_zeta(xf);
+ riemann_zetaf(xf);
+ riemann_zeta(xd);
+ riemann_zeta(xl);
+ riemann_zetal(xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/21_sph_bessel/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/21_sph_bessel/check_nan.cc
new file mode 100644
index 00000000000..2b856742d0e
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/21_sph_bessel/check_nan.cc
@@ -0,0 +1,58 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.21 sph_bessel
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+ float xf = std::numeric_limits<float>::quiet_NaN();
+ double xd = std::numeric_limits<double>::quiet_NaN();
+ long double xl = std::numeric_limits<long double>::quiet_NaN();
+
+ unsigned int n = 0;
+
+ float a = std::tr1::sph_bessel(n, xf);
+ float b = std::tr1::sph_besself(n, xf);
+ double c = std::tr1::sph_bessel(n, xd);
+ long double d = std::tr1::sph_bessel(n, xl);
+ long double e = std::tr1::sph_bessell(n, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/21_sph_bessel/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/21_sph_bessel/check_value.cc
new file mode 100644
index 00000000000..939d641a3bf
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/21_sph_bessel/check_value.cc
@@ -0,0 +1,470 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// sph_bessel
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for n=0.
+testcase_sph_bessel<double> data001[] = {
+ { 1.0000000000000000, 0, 0.0000000000000000 },
+ { -0.19178485493262770, 0, 5.0000000000000000 },
+ { -0.054402111088936986, 0, 10.000000000000000 },
+ { 0.043352522677141132, 0, 15.000000000000000 },
+ { 0.045647262536381385, 0, 20.000000000000000 },
+ { -0.0052940700039109216, 0, 25.000000000000000 },
+ { -0.032934387469762058, 0, 30.000000000000000 },
+ { -0.012233790557032886, 0, 35.000000000000000 },
+ { 0.018627829011983722, 0, 40.000000000000000 },
+ { 0.018908967211869299, 0, 45.000000000000000 },
+ { -0.0052474970740785751, 0, 50.000000000000000 },
+ { -0.018177366788338544, 0, 55.000000000000000 },
+ { -0.0050801770183702783, 0, 60.000000000000000 },
+ { 0.012720441222924669, 0, 65.000000000000000 },
+ { 0.011055581165112701, 0, 70.000000000000000 },
+ { -0.0051704218054590724, 0, 75.000000000000000 },
+ { -0.012423608174042190, 0, 80.000000000000000 },
+ { -0.0020714778817480834, 0, 85.000000000000000 },
+ { 0.0099332962622284207, 0, 90.000000000000000 },
+ { 0.0071922285761696946, 0, 95.000000000000000 },
+ { -0.0050636564110975880, 0, 100.00000000000000 },
+};
+
+// Test function for n=0.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_sph_bessel<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_bessel(Tp(data001[i].n), Tp(data001[i].x));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000014e-11));
+}
+
+// Test data for n=1.
+testcase_sph_bessel<double> data002[] = {
+ { 0.0000000000000000, 1, 0.0000000000000000 },
+ { -0.095089408079170795, 1, 5.0000000000000000 },
+ { 0.078466941798751549, 1, 10.000000000000000 },
+ { 0.053536029035730834, 1, 15.000000000000000 },
+ { -0.018121739963850528, 1, 20.000000000000000 },
+ { -0.039859875274695380, 1, 25.000000000000000 },
+ { -0.0062395279119115375, 1, 30.000000000000000 },
+ { 0.025470240415270681, 1, 35.000000000000000 },
+ { 0.017139147266606137, 1, 40.000000000000000 },
+ { -0.011253622702352454, 1, 45.000000000000000 },
+ { -0.019404270511323839, 1, 50.000000000000000 },
+ { -0.00073280223727807778, 1, 55.000000000000000 },
+ { 0.015788880056613101, 1, 60.000000000000000 },
+ { 0.0088488352686322581, 1, 65.000000000000000 },
+ { -0.0088894803131598157, 1, 70.000000000000000 },
+ { -0.012358955887069445, 1, 75.000000000000000 },
+ { 0.0012245454458125673, 1, 80.000000000000000 },
+ { 0.011556531358968161, 1, 85.000000000000000 },
+ { 0.0050889656932377614, 1, 90.000000000000000 },
+ { -0.0076103298149331573, 1, 95.000000000000000 },
+ { -0.0086738252869878150, 1, 100.00000000000000 },
+};
+
+// Test function for n=1.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_sph_bessel<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_bessel(Tp(data002[i].n), Tp(data002[i].x));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000028e-11));
+}
+
+// Test data for n=2.
+testcase_sph_bessel<double> data003[] = {
+ { 0.0000000000000000, 2, 0.0000000000000000 },
+ { 0.13473121008512520, 2, 5.0000000000000000 },
+ { 0.077942193628562445, 2, 10.000000000000000 },
+ { -0.032645316869994966, 2, 15.000000000000000 },
+ { -0.048365523530958965, 2, 20.000000000000000 },
+ { 0.00051088497094747614, 2, 25.000000000000000 },
+ { 0.032310434678570907, 2, 30.000000000000000 },
+ { 0.014416954021198945, 2, 35.000000000000000 },
+ { -0.017342392966988262, 2, 40.000000000000000 },
+ { -0.019659208725359461, 2, 45.000000000000000 },
+ { 0.0040832408433991458, 2, 50.000000000000000 },
+ { 0.018137395757214285, 2, 55.000000000000000 },
+ { 0.0058696210212009327, 2, 60.000000000000000 },
+ { -0.012312033441295490, 2, 65.000000000000000 },
+ { -0.011436558892819550, 2, 70.000000000000000 },
+ { 0.0046760635699762939, 2, 75.000000000000000 },
+ { 0.012469528628260161, 2, 80.000000000000000 },
+ { 0.0024793554591234306, 2, 85.000000000000000 },
+ { -0.0097636640724538277, 2, 90.000000000000000 },
+ { -0.0074325547808517939, 2, 95.000000000000000 },
+ { 0.0048034416524879537, 2, 100.00000000000000 },
+};
+
+// Test function for n=2.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_sph_bessel<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_bessel(Tp(data003[i].n), Tp(data003[i].x));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000014e-11));
+}
+
+// Test data for n=5.
+testcase_sph_bessel<double> data004[] = {
+ { 0.0000000000000000, 5, 0.0000000000000000 },
+ { 0.10681116145650454, 5, 5.0000000000000000 },
+ { -0.055534511621452197, 5, 10.000000000000000 },
+ { 0.065968007076521964, 5, 15.000000000000000 },
+ { 0.016683908063095686, 5, 20.000000000000000 },
+ { -0.036117795989722368, 5, 25.000000000000000 },
+ { -0.020504008736827509, 5, 30.000000000000000 },
+ { 0.018499481206814564, 5, 35.000000000000000 },
+ { 0.022448773791045016, 5, 40.000000000000000 },
+ { -0.0048552694845020103, 5, 45.000000000000000 },
+ { -0.020048300563664877, 5, 50.000000000000000 },
+ { -0.0052999924455565672, 5, 55.000000000000000 },
+ { 0.014151556281331405, 5, 60.000000000000000 },
+ { 0.011354588594416765, 5, 65.000000000000000 },
+ { -0.0064983781785323642, 5, 70.000000000000000 },
+ { -0.013089909320064264, 5, 75.000000000000000 },
+ { -0.00096200450071301611, 5, 80.000000000000000 },
+ { 0.011048668899130202, 5, 85.000000000000000 },
+ { 0.0065639581708135976, 5, 90.000000000000000 },
+ { -0.0064646119368202771, 5, 95.000000000000000 },
+ { -0.0092901489349075713, 5, 100.00000000000000 },
+};
+
+// Test function for n=5.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_sph_bessel<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_bessel(Tp(data004[i].n), Tp(data004[i].x));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000028e-11));
+}
+
+// Test data for n=10.
+testcase_sph_bessel<double> data005[] = {
+ { 0.0000000000000000, 10, 0.0000000000000000 },
+ { 0.00040734424424946052, 10, 5.0000000000000000 },
+ { 0.064605154492564279, 10, 10.000000000000000 },
+ { 0.0018969790010883629, 10, 15.000000000000000 },
+ { 0.039686698644626366, 10, 20.000000000000000 },
+ { -0.036253285601128567, 10, 25.000000000000000 },
+ { -0.014529646403897820, 10, 30.000000000000000 },
+ { 0.026281264603993850, 10, 35.000000000000000 },
+ { 0.013124803182748307, 10, 40.000000000000000 },
+ { -0.017600831383728963, 10, 45.000000000000000 },
+ { -0.015039221463465962, 10, 50.000000000000000 },
+ { 0.0095256289349167356, 10, 55.000000000000000 },
+ { 0.015822719394008342, 10, 60.000000000000000 },
+ { -0.0019391391708249812, 10, 65.000000000000000 },
+ { -0.014293389028395010, 10, 70.000000000000000 },
+ { -0.0044210285031696184, 10, 75.000000000000000 },
+ { 0.010516146958338822, 10, 80.000000000000000 },
+ { 0.0086736275131325761, 10, 85.000000000000000 },
+ { -0.0052905066357239365, 10, 90.000000000000000 },
+ { -0.010258326955210765, 10, 95.000000000000000 },
+ { -0.00019565785971342893, 10, 100.00000000000000 },
+};
+
+// Test function for n=10.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_sph_bessel<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_bessel(Tp(data005[i].n), Tp(data005[i].x));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000017e-10));
+}
+
+// Test data for n=20.
+testcase_sph_bessel<double> data006[] = {
+ { 0.0000000000000000, 20, 0.0000000000000000 },
+ { 5.4277267607932098e-12, 20, 5.0000000000000000 },
+ { 2.3083719613194699e-06, 20, 10.000000000000000 },
+ { 0.0015467058510412503, 20, 15.000000000000000 },
+ { 0.038324851639805181, 20, 20.000000000000000 },
+ { 0.028500071484154683, 20, 25.000000000000000 },
+ { -0.014711593353429090, 20, 30.000000000000000 },
+ { -0.010797653070264238, 20, 35.000000000000000 },
+ { 0.026535391837540286, 20, 40.000000000000000 },
+ { -0.011582959134716381, 20, 45.000000000000000 },
+ { -0.015785029898269291, 20, 50.000000000000000 },
+ { 0.013885519185862756, 20, 55.000000000000000 },
+ { 0.011112458964023256, 20, 60.000000000000000 },
+ { -0.011938384963927570, 20, 65.000000000000000 },
+ { -0.010117695207156906, 20, 70.000000000000000 },
+ { 0.0089871214102383128, 20, 75.000000000000000 },
+ { 0.010400578884991936, 20, 80.000000000000000 },
+ { -0.0055359020656326630, 20, 85.000000000000000 },
+ { -0.010639343320787519, 20, 90.000000000000000 },
+ { 0.0018051661455979488, 20, 95.000000000000000 },
+ { 0.010107671283873054, 20, 100.00000000000000 },
+};
+
+// Test function for n=20.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_sph_bessel<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_bessel(Tp(data006[i].n), Tp(data006[i].x));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000014e-11));
+}
+
+// Test data for n=50.
+testcase_sph_bessel<double> data007[] = {
+ { 0.0000000000000000, 50, 0.0000000000000000 },
+ { 2.8574793504401511e-46, 50, 5.0000000000000000 },
+ { 2.2306960232186471e-31, 50, 10.000000000000000 },
+ { 7.6804716640080780e-23, 50, 15.000000000000000 },
+ { 5.6500807918725294e-17, 50, 20.000000000000000 },
+ { 1.2540416973758975e-12, 50, 25.000000000000000 },
+ { 2.6901637185735330e-09, 50, 30.000000000000000 },
+ { 1.0167148174422245e-06, 50, 35.000000000000000 },
+ { 9.3949174038179191e-05, 50, 40.000000000000000 },
+ { 0.0024888927213794552, 50, 45.000000000000000 },
+ { 0.018829107369282640, 50, 50.000000000000000 },
+ { 0.026373198438145548, 50, 55.000000000000000 },
+ { -0.021230978268739008, 50, 60.000000000000000 },
+ { 0.016539881802291316, 50, 65.000000000000000 },
+ { -0.015985416061436657, 50, 70.000000000000000 },
+ { 0.015462548984405593, 50, 75.000000000000000 },
+ { -0.010638570118081834, 50, 80.000000000000000 },
+ { 0.00046961239784540576, 50, 85.000000000000000 },
+ { 0.0096065882189920234, 50, 90.000000000000000 },
+ { -0.010613873910261147, 50, 95.000000000000000 },
+ { 0.00057971408822773810, 50, 100.00000000000000 },
+};
+
+// Test function for n=50.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_sph_bessel<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_bessel(Tp(data007[i].n), Tp(data007[i].x));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000017e-10));
+}
+
+// Test data for n=100.
+testcase_sph_bessel<double> data008[] = {
+ { 0.0000000000000000, 100, 0.0000000000000000 },
+ { 5.5356503033889938e-120, 100, 5.0000000000000000 },
+ { 5.8320401820058771e-90, 100, 10.000000000000000 },
+ { 1.7406387750766626e-72, 100, 15.000000000000000 },
+ { 3.5152711125317001e-60, 100, 20.000000000000000 },
+ { 9.8455459353816024e-51, 100, 25.000000000000000 },
+ { 4.0888596744301567e-43, 100, 30.000000000000000 },
+ { 8.8975854911134006e-37, 100, 35.000000000000000 },
+ { 2.1513492547733837e-31, 100, 40.000000000000000 },
+ { 9.3673586994539323e-27, 100, 45.000000000000000 },
+ { 1.0190122629310465e-22, 100, 50.000000000000000 },
+ { 3.4887804977690321e-19, 100, 55.000000000000000 },
+ { 4.4442883425555691e-16, 100, 60.000000000000000 },
+ { 2.3832619568710733e-13, 100, 65.000000000000000 },
+ { 5.8948384175608103e-11, 100, 70.000000000000000 },
+ { 7.1884446357022268e-09, 100, 75.000000000000000 },
+ { 4.5247964400094991e-07, 100, 80.000000000000000 },
+ { 1.5096093228779059e-05, 100, 85.000000000000000 },
+ { 0.00026825172647807507, 100, 90.000000000000000 },
+ { 0.0024744308520581030, 100, 95.000000000000000 },
+ { 0.010880477011438327, 100, 100.00000000000000 },
+};
+
+// Test function for n=100.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_sph_bessel<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_bessel(Tp(data008[i].n), Tp(data008[i].x));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000029e-12));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/21_sph_bessel/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/21_sph_bessel/compile.cc
new file mode 100644
index 00000000000..fdc66905f26
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/21_sph_bessel/compile.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.21 sph_bessel
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+ unsigned int n = 0;
+
+ std::tr1::sph_bessel(n, xf);
+ std::tr1::sph_besself(n, xf);
+ std::tr1::sph_bessel(n, xd);
+ std::tr1::sph_bessel(n, xl);
+ std::tr1::sph_bessell(n, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/21_sph_bessel/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/21_sph_bessel/compile_2.cc
new file mode 100644
index 00000000000..c98dee75746
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/21_sph_bessel/compile_2.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.21 sph_bessel
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+ unsigned int n = 0;
+
+ sph_bessel(n, xf);
+ sph_besself(n, xf);
+ sph_bessel(n, xd);
+ sph_bessel(n, xl);
+ sph_bessell(n, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/22_sph_legendre/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/22_sph_legendre/check_nan.cc
new file mode 100644
index 00000000000..e8bbfff188f
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/22_sph_legendre/check_nan.cc
@@ -0,0 +1,58 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.22 sph_legendre
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+
+ float thetaf = std::numeric_limits<float>::quiet_NaN();
+ double thetad = std::numeric_limits<double>::quiet_NaN();
+ long double thetal = std::numeric_limits<long double>::quiet_NaN();
+ unsigned int l = 2, m = 1;
+
+ float a = std::tr1::sph_legendre(l, m, thetaf);
+ float b = std::tr1::sph_legendref(l, m, thetaf);
+ double c = std::tr1::sph_legendre(l, m, thetad);
+ long double d = std::tr1::sph_legendre(l, m, thetal);
+ long double e = std::tr1::sph_legendrel(l, m, thetal);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/22_sph_legendre/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/22_sph_legendre/check_value.cc
new file mode 100644
index 00000000000..40433666e4c
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/22_sph_legendre/check_value.cc
@@ -0,0 +1,2746 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// sph_legendre
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for l=0, m=0.
+testcase_sph_legendre<double> data001[] = {
+ { 0.28209479177387814, 0, 0,
+ 0.0000000000000000 },
+ { 0.28209479177387814, 0, 0,
+ 0.15707963267948966 },
+ { 0.28209479177387814, 0, 0,
+ 0.31415926535897931 },
+ { 0.28209479177387814, 0, 0,
+ 0.47123889803846897 },
+ { 0.28209479177387814, 0, 0,
+ 0.62831853071795862 },
+ { 0.28209479177387814, 0, 0,
+ 0.78539816339744828 },
+ { 0.28209479177387814, 0, 0,
+ 0.94247779607693793 },
+ { 0.28209479177387814, 0, 0,
+ 1.0995574287564276 },
+ { 0.28209479177387814, 0, 0,
+ 1.2566370614359172 },
+ { 0.28209479177387814, 0, 0,
+ 1.4137166941154069 },
+ { 0.28209479177387814, 0, 0,
+ 1.5707963267948966 },
+ { 0.28209479177387814, 0, 0,
+ 1.7278759594743860 },
+ { 0.28209479177387814, 0, 0,
+ 1.8849555921538759 },
+ { 0.28209479177387814, 0, 0,
+ 2.0420352248333655 },
+ { 0.28209479177387814, 0, 0,
+ 2.1991148575128552 },
+ { 0.28209479177387814, 0, 0,
+ 2.3561944901923448 },
+ { 0.28209479177387814, 0, 0,
+ 2.5132741228718345 },
+ { 0.28209479177387814, 0, 0,
+ 2.6703537555513241 },
+ { 0.28209479177387814, 0, 0,
+ 2.8274333882308138 },
+ { 0.28209479177387814, 0, 0,
+ 2.9845130209103035 },
+ { 0.28209479177387814, 0, 0,
+ 3.1415926535897931 },
+};
+
+// Test function for l=0, m=0.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data001[i].l), Tp(data001[i].m),
+ Tp(data001[i].theta));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=1, m=0.
+testcase_sph_legendre<double> data002[] = {
+ { 0.48860251190291992, 1, 0,
+ 0.0000000000000000 },
+ { 0.48258700419201100, 1, 0,
+ 0.15707963267948966 },
+ { 0.46468860282345231, 1, 0,
+ 0.31415926535897931 },
+ { 0.43534802584032634, 1, 0,
+ 0.47123889803846897 },
+ { 0.39528773562374975, 1, 0,
+ 0.62831853071795862 },
+ { 0.34549414947133544, 1, 0,
+ 0.78539816339744828 },
+ { 0.28719335072959390, 1, 0,
+ 0.94247779607693793 },
+ { 0.22182089855280451, 1, 0,
+ 1.0995574287564276 },
+ { 0.15098647967228984, 1, 0,
+ 1.2566370614359172 },
+ { 0.076434272566846345, 1, 0,
+ 1.4137166941154069 },
+ { 2.9918275112863369e-17, 1, 0,
+ 1.5707963267948966 },
+ { -0.076434272566846179, 1, 0,
+ 1.7278759594743860 },
+ { -0.15098647967228976, 1, 0,
+ 1.8849555921538759 },
+ { -0.22182089855280446, 1, 0,
+ 2.0420352248333655 },
+ { -0.28719335072959390, 1, 0,
+ 2.1991148575128552 },
+ { -0.34549414947133544, 1, 0,
+ 2.3561944901923448 },
+ { -0.39528773562374969, 1, 0,
+ 2.5132741228718345 },
+ { -0.43534802584032628, 1, 0,
+ 2.6703537555513241 },
+ { -0.46468860282345231, 1, 0,
+ 2.8274333882308138 },
+ { -0.48258700419201095, 1, 0,
+ 2.9845130209103035 },
+ { -0.48860251190291992, 1, 0,
+ 3.1415926535897931 },
+};
+
+// Test function for l=1, m=0.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data002[i].l), Tp(data002[i].m),
+ Tp(data002[i].theta));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=1, m=1.
+testcase_sph_legendre<double> data003[] = {
+ { 0.0000000000000000, 1, 1,
+ 0.0000000000000000 },
+ { -0.054047192447077917, 1, 1,
+ 0.15707963267948966 },
+ { -0.10676356364376104, 1, 1,
+ 0.31415926535897931 },
+ { -0.15685106157558129, 1, 1,
+ 0.47123889803846897 },
+ { -0.20307636581258243, 1, 1,
+ 0.62831853071795862 },
+ { -0.24430125595146013, 1, 1,
+ 0.78539816339744828 },
+ { -0.27951063837942880, 1, 1,
+ 0.94247779607693793 },
+ { -0.30783754124787122, 1, 1,
+ 1.0995574287564276 },
+ { -0.32858446219656551, 1, 1,
+ 1.2566370614359172 },
+ { -0.34124054317667202, 1, 1,
+ 1.4137166941154069 },
+ { -0.34549414947133567, 1, 1,
+ 1.5707963267948966 },
+ { -0.34124054317667202, 1, 1,
+ 1.7278759594743860 },
+ { -0.32858446219656556, 1, 1,
+ 1.8849555921538759 },
+ { -0.30783754124787127, 1, 1,
+ 2.0420352248333655 },
+ { -0.27951063837942880, 1, 1,
+ 2.1991148575128552 },
+ { -0.24430125595146013, 1, 1,
+ 2.3561944901923448 },
+ { -0.20307636581258248, 1, 1,
+ 2.5132741228718345 },
+ { -0.15685106157558140, 1, 1,
+ 2.6703537555513241 },
+ { -0.10676356364376104, 1, 1,
+ 2.8274333882308138 },
+ { -0.054047192447078167, 1, 1,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 1, 1,
+ 3.1415926535897931 },
+};
+
+// Test function for l=1, m=1.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data003[i].l), Tp(data003[i].m),
+ Tp(data003[i].theta));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=2, m=0.
+testcase_sph_legendre<double> data004[] = {
+ { 0.63078313050504009, 2, 0,
+ 0.0000000000000000 },
+ { 0.60762858760316607, 2, 0,
+ 0.15707963267948966 },
+ { 0.54043148688396569, 2, 0,
+ 0.31415926535897931 },
+ { 0.43576954875556589, 2, 0,
+ 0.47123889803846897 },
+ { 0.30388781294457579, 2, 0,
+ 0.62831853071795862 },
+ { 0.15769578262625994, 2, 0,
+ 0.78539816339744828 },
+ { 0.011503752307944235, 2, 0,
+ 0.94247779607693793 },
+ { -0.12037798350304565, 2, 0,
+ 1.0995574287564276 },
+ { -0.22503992163144573, 2, 0,
+ 1.2566370614359172 },
+ { -0.29223702235064597, 2, 0,
+ 1.4137166941154069 },
+ { -0.31539156525252005, 2, 0,
+ 1.5707963267948966 },
+ { -0.29223702235064608, 2, 0,
+ 1.7278759594743860 },
+ { -0.22503992163144584, 2, 0,
+ 1.8849555921538759 },
+ { -0.12037798350304577, 2, 0,
+ 2.0420352248333655 },
+ { 0.011503752307944235, 2, 0,
+ 2.1991148575128552 },
+ { 0.15769578262625994, 2, 0,
+ 2.3561944901923448 },
+ { 0.30388781294457567, 2, 0,
+ 2.5132741228718345 },
+ { 0.43576954875556562, 2, 0,
+ 2.6703537555513241 },
+ { 0.54043148688396569, 2, 0,
+ 2.8274333882308138 },
+ { 0.60762858760316585, 2, 0,
+ 2.9845130209103035 },
+ { 0.63078313050504009, 2, 0,
+ 3.1415926535897931 },
+};
+
+// Test function for l=2, m=0.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data004[i].l), Tp(data004[i].m),
+ Tp(data004[i].theta));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=2, m=1.
+testcase_sph_legendre<double> data005[] = {
+ { 0.0000000000000000, 2, 1,
+ 0.0000000000000000 },
+ { -0.11936529291378727, 2, 1,
+ 0.15707963267948966 },
+ { -0.22704627929027449, 2, 1,
+ 0.31415926535897931 },
+ { -0.31250239392538215, 2, 1,
+ 0.47123889803846897 },
+ { -0.36736859691086526, 2, 1,
+ 0.62831853071795862 },
+ { -0.38627420202318979, 2, 1,
+ 0.78539816339744828 },
+ { -0.36736859691086526, 2, 1,
+ 0.94247779607693793 },
+ { -0.31250239392538226, 2, 1,
+ 1.0995574287564276 },
+ { -0.22704627929027435, 2, 1,
+ 1.2566370614359172 },
+ { -0.11936529291378740, 2, 1,
+ 1.4137166941154069 },
+ { -4.7304946510089748e-17, 2, 1,
+ 1.5707963267948966 },
+ { 0.11936529291378714, 2, 1,
+ 1.7278759594743860 },
+ { 0.22704627929027429, 2, 1,
+ 1.8849555921538759 },
+ { 0.31250239392538226, 2, 1,
+ 2.0420352248333655 },
+ { 0.36736859691086526, 2, 1,
+ 2.1991148575128552 },
+ { 0.38627420202318979, 2, 1,
+ 2.3561944901923448 },
+ { 0.36736859691086526, 2, 1,
+ 2.5132741228718345 },
+ { 0.31250239392538232, 2, 1,
+ 2.6703537555513241 },
+ { 0.22704627929027449, 2, 1,
+ 2.8274333882308138 },
+ { 0.11936529291378781, 2, 1,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 2, 1,
+ 3.1415926535897931 },
+};
+
+// Test function for l=2, m=1.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data005[i].l), Tp(data005[i].m),
+ Tp(data005[i].theta));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=2, m=2.
+testcase_sph_legendre<double> data006[] = {
+ { 0.0000000000000000, 2, 2,
+ 0.0000000000000000 },
+ { 0.0094528025561622549, 2, 2,
+ 0.15707963267948966 },
+ { 0.036885904048903795, 2, 2,
+ 0.31415926535897931 },
+ { 0.079613961366457681, 2, 2,
+ 0.47123889803846897 },
+ { 0.13345445455470123, 2, 2,
+ 0.62831853071795862 },
+ { 0.19313710101159492, 2, 2,
+ 0.78539816339744828 },
+ { 0.25281974746848851, 2, 2,
+ 0.94247779607693793 },
+ { 0.30666024065673203, 2, 2,
+ 1.0995574287564276 },
+ { 0.34938829797428600, 2, 2,
+ 1.2566370614359172 },
+ { 0.37682139946702747, 2, 2,
+ 1.4137166941154069 },
+ { 0.38627420202318979, 2, 2,
+ 1.5707963267948966 },
+ { 0.37682139946702753, 2, 2,
+ 1.7278759594743860 },
+ { 0.34938829797428606, 2, 2,
+ 1.8849555921538759 },
+ { 0.30666024065673209, 2, 2,
+ 2.0420352248333655 },
+ { 0.25281974746848851, 2, 2,
+ 2.1991148575128552 },
+ { 0.19313710101159492, 2, 2,
+ 2.3561944901923448 },
+ { 0.13345445455470126, 2, 2,
+ 2.5132741228718345 },
+ { 0.079613961366457764, 2, 2,
+ 2.6703537555513241 },
+ { 0.036885904048903795, 2, 2,
+ 2.8274333882308138 },
+ { 0.0094528025561623433, 2, 2,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 2, 2,
+ 3.1415926535897931 },
+};
+
+// Test function for l=2, m=2.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data006[i].l), Tp(data006[i].m),
+ Tp(data006[i].theta));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=5, m=0.
+testcase_sph_legendre<double> data007[] = {
+ { 0.93560257962738880, 5, 0,
+ 0.0000000000000000 },
+ { 0.77014422942080019, 5, 0,
+ 0.15707963267948966 },
+ { 0.35892185032365215, 5, 0,
+ 0.31415926535897931 },
+ { -0.090214932090594183, 5, 0,
+ 0.47123889803846897 },
+ { -0.36214460396518888, 5, 0,
+ 0.62831853071795862 },
+ { -0.35145955579226890, 5, 0,
+ 0.78539816339744828 },
+ { -0.11441703594725168, 5, 0,
+ 0.94247779607693793 },
+ { 0.17248966720808098, 5, 0,
+ 1.0995574287564276 },
+ { 0.32128384287200523, 5, 0,
+ 1.2566370614359172 },
+ { 0.24377632246714948, 5, 0,
+ 1.4137166941154069 },
+ { 1.0741712853887702e-16, 5, 0,
+ 1.5707963267948966 },
+ { -0.24377632246714906, 5, 0,
+ 1.7278759594743860 },
+ { -0.32128384287200534, 5, 0,
+ 1.8849555921538759 },
+ { -0.17248966720808118, 5, 0,
+ 2.0420352248333655 },
+ { 0.11441703594725168, 5, 0,
+ 2.1991148575128552 },
+ { 0.35145955579226890, 5, 0,
+ 2.3561944901923448 },
+ { 0.36214460396518910, 5, 0,
+ 2.5132741228718345 },
+ { 0.090214932090594724, 5, 0,
+ 2.6703537555513241 },
+ { -0.35892185032365215, 5, 0,
+ 2.8274333882308138 },
+ { -0.77014422942079797, 5, 0,
+ 2.9845130209103035 },
+ { -0.93560257962738880, 5, 0,
+ 3.1415926535897931 },
+};
+
+// Test function for l=5, m=0.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data007[i].l), Tp(data007[i].m),
+ Tp(data007[i].theta));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=5, m=1.
+testcase_sph_legendre<double> data008[] = {
+ { 0.0000000000000000, 5, 1,
+ 0.0000000000000000 },
+ { -0.36712373713318258, 5, 1,
+ 0.15707963267948966 },
+ { -0.54610329010534753, 5, 1,
+ 0.31415926535897931 },
+ { -0.45381991493631785, 5, 1,
+ 0.47123889803846897 },
+ { -0.15679720635769953, 5, 1,
+ 0.62831853071795862 },
+ { 0.16985499419838637, 5, 1,
+ 0.78539816339744828 },
+ { 0.34468004499725180, 5, 1,
+ 0.94247779607693793 },
+ { 0.28349471119605985, 5, 1,
+ 1.0995574287564276 },
+ { 0.044286619339675856, 5, 1,
+ 1.2566370614359172 },
+ { -0.21193784177193470, 5, 1,
+ 1.4137166941154069 },
+ { -0.32028164857621527, 5, 1,
+ 1.5707963267948966 },
+ { -0.21193784177193514, 5, 1,
+ 1.7278759594743860 },
+ { 0.044286619339675606, 5, 1,
+ 1.8849555921538759 },
+ { 0.28349471119605979, 5, 1,
+ 2.0420352248333655 },
+ { 0.34468004499725180, 5, 1,
+ 2.1991148575128552 },
+ { 0.16985499419838637, 5, 1,
+ 2.3561944901923448 },
+ { -0.15679720635769920, 5, 1,
+ 2.5132741228718345 },
+ { -0.45381991493631757, 5, 1,
+ 2.6703537555513241 },
+ { -0.54610329010534753, 5, 1,
+ 2.8274333882308138 },
+ { -0.36712373713318397, 5, 1,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 5, 1,
+ 3.1415926535897931 },
+};
+
+// Test function for l=5, m=1.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data008[i].l), Tp(data008[i].m),
+ Tp(data008[i].theta));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=5, m=2.
+testcase_sph_legendre<double> data009[] = {
+ { 0.0000000000000000, 5, 2,
+ 0.0000000000000000 },
+ { 0.078919441745546146, 5, 2,
+ 0.15707963267948966 },
+ { 0.26373799140437981, 5, 2,
+ 0.31415926535897931 },
+ { 0.43002359842080096, 5, 2,
+ 0.47123889803846897 },
+ { 0.45642486439050994, 5, 2,
+ 0.62831853071795862 },
+ { 0.29959604906083276, 5, 2,
+ 0.78539816339744828 },
+ { 0.023781239849532242, 5, 2,
+ 0.94247779607693793 },
+ { -0.23313989334673815, 5, 2,
+ 1.0995574287564276 },
+ { -0.33799912776303714, 5, 2,
+ 1.2566370614359172 },
+ { -0.23964508489529743, 5, 2,
+ 1.4137166941154069 },
+ { -1.0377480524338170e-16, 5, 2,
+ 1.5707963267948966 },
+ { 0.23964508489529704, 5, 2,
+ 1.7278759594743860 },
+ { 0.33799912776303714, 5, 2,
+ 1.8849555921538759 },
+ { 0.23313989334673837, 5, 2,
+ 2.0420352248333655 },
+ { -0.023781239849532242, 5, 2,
+ 2.1991148575128552 },
+ { -0.29959604906083276, 5, 2,
+ 2.3561944901923448 },
+ { -0.45642486439050978, 5, 2,
+ 2.5132741228718345 },
+ { -0.43002359842080118, 5, 2,
+ 2.6703537555513241 },
+ { -0.26373799140437981, 5, 2,
+ 2.8274333882308138 },
+ { -0.078919441745546867, 5, 2,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 5, 2,
+ 3.1415926535897931 },
+};
+
+// Test function for l=5, m=2.
+template <typename Tp>
+void test009()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data009)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data009[i].l), Tp(data009[i].m),
+ Tp(data009[i].theta));
+ const Tp f0 = data009[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=5, m=5.
+testcase_sph_legendre<double> data010[] = {
+ { 0.0000000000000000, 5, 5,
+ 0.0000000000000000 },
+ { -4.3481439097909148e-05, 5, 5,
+ 0.15707963267948966 },
+ { -0.0013078367086431812, 5, 5,
+ 0.31415926535897931 },
+ { -0.0089510818191922761, 5, 5,
+ 0.47123889803846897 },
+ { -0.032563803777573896, 5, 5,
+ 0.62831853071795862 },
+ { -0.082047757105021310, 5, 5,
+ 0.78539816339744828 },
+ { -0.16085328164143819, 5, 5,
+ 0.94247779607693793 },
+ { -0.26064303436645375, 5, 5,
+ 1.0995574287564276 },
+ { -0.36113811790820566, 5, 5,
+ 1.2566370614359172 },
+ { -0.43625592459446139, 5, 5,
+ 1.4137166941154069 },
+ { -0.46413220344085809, 5, 5,
+ 1.5707963267948966 },
+ { -0.43625592459446155, 5, 5,
+ 1.7278759594743860 },
+ { -0.36113811790820577, 5, 5,
+ 1.8849555921538759 },
+ { -0.26064303436645381, 5, 5,
+ 2.0420352248333655 },
+ { -0.16085328164143819, 5, 5,
+ 2.1991148575128552 },
+ { -0.082047757105021310, 5, 5,
+ 2.3561944901923448 },
+ { -0.032563803777573924, 5, 5,
+ 2.5132741228718345 },
+ { -0.0089510818191923004, 5, 5,
+ 2.6703537555513241 },
+ { -0.0013078367086431812, 5, 5,
+ 2.8274333882308138 },
+ { -4.3481439097910151e-05, 5, 5,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 5, 5,
+ 3.1415926535897931 },
+};
+
+// Test function for l=5, m=5.
+template <typename Tp>
+void test010()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data010)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data010[i].l), Tp(data010[i].m),
+ Tp(data010[i].theta));
+ const Tp f0 = data010[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=10, m=0.
+testcase_sph_legendre<double> data011[] = {
+ { 1.2927207364566027, 10, 0,
+ 0.0000000000000000 },
+ { 0.55288895150522632, 10, 0,
+ 0.15707963267948966 },
+ { -0.44874428379711506, 10, 0,
+ 0.31415926535897931 },
+ { -0.25532095827149692, 10, 0,
+ 0.47123889803846897 },
+ { 0.36625249688013967, 10, 0,
+ 0.62831853071795862 },
+ { 0.14880806329084145, 10, 0,
+ 0.78539816339744828 },
+ { -0.33533356797848746, 10, 0,
+ 0.94247779607693793 },
+ { -0.080639967662335818, 10, 0,
+ 1.0995574287564276 },
+ { 0.32197986450174521, 10, 0,
+ 1.2566370614359172 },
+ { 0.025713542103667848, 10, 0,
+ 1.4137166941154069 },
+ { -0.31813049373736707, 10, 0,
+ 1.5707963267948966 },
+ { 0.025713542103666668, 10, 0,
+ 1.7278759594743860 },
+ { 0.32197986450174532, 10, 0,
+ 1.8849555921538759 },
+ { -0.080639967662335416, 10, 0,
+ 2.0420352248333655 },
+ { -0.33533356797848746, 10, 0,
+ 2.1991148575128552 },
+ { 0.14880806329084145, 10, 0,
+ 2.3561944901923448 },
+ { 0.36625249688013994, 10, 0,
+ 2.5132741228718345 },
+ { -0.25532095827149576, 10, 0,
+ 2.6703537555513241 },
+ { -0.44874428379711506, 10, 0,
+ 2.8274333882308138 },
+ { 0.55288895150521977, 10, 0,
+ 2.9845130209103035 },
+ { 1.2927207364566027, 10, 0,
+ 3.1415926535897931 },
+};
+
+// Test function for l=10, m=0.
+template <typename Tp>
+void test011()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data011)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data011[i].l), Tp(data011[i].m),
+ Tp(data011[i].theta));
+ const Tp f0 = data011[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=10, m=1.
+testcase_sph_legendre<double> data012[] = {
+ { 0.0000000000000000, 10, 1,
+ 0.0000000000000000 },
+ { -0.74373723919063905, 10, 1,
+ 0.15707963267948966 },
+ { -0.29035110456209551, 10, 1,
+ 0.31415926535897931 },
+ { 0.42219282075271497, 10, 1,
+ 0.47123889803846897 },
+ { 0.17109256898931269, 10, 1,
+ 0.62831853071795862 },
+ { -0.35583574648544292, 10, 1,
+ 0.78539816339744828 },
+ { -0.10089212303543979, 10, 1,
+ 0.94247779607693793 },
+ { 0.32997652649321085, 10, 1,
+ 1.0995574287564276 },
+ { 0.047416376890033113, 10, 1,
+ 1.2566370614359172 },
+ { -0.31999356750295654, 10, 1,
+ 1.4137166941154069 },
+ { -2.0430664782290766e-16, 10, 1,
+ 1.5707963267948966 },
+ { 0.31999356750295660, 10, 1,
+ 1.7278759594743860 },
+ { -0.047416376890032523, 10, 1,
+ 1.8849555921538759 },
+ { -0.32997652649321102, 10, 1,
+ 2.0420352248333655 },
+ { 0.10089212303543979, 10, 1,
+ 2.1991148575128552 },
+ { 0.35583574648544292, 10, 1,
+ 2.3561944901923448 },
+ { -0.17109256898931186, 10, 1,
+ 2.5132741228718345 },
+ { -0.42219282075271553, 10, 1,
+ 2.6703537555513241 },
+ { 0.29035110456209551, 10, 1,
+ 2.8274333882308138 },
+ { 0.74373723919064028, 10, 1,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 10, 1,
+ 3.1415926535897931 },
+};
+
+// Test function for l=10, m=1.
+template <typename Tp>
+void test012()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data012)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data012[i].l), Tp(data012[i].m),
+ Tp(data012[i].theta));
+ const Tp f0 = data012[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=10, m=2.
+testcase_sph_legendre<double> data013[] = {
+ { 0.0000000000000000, 10, 2,
+ 0.0000000000000000 },
+ { 0.34571695599980284, 10, 2,
+ 0.15707963267948966 },
+ { 0.62485535978198059, 10, 2,
+ 0.31415926535897931 },
+ { 0.098210039644716363, 10, 2,
+ 0.47123889803846897 },
+ { -0.41494799233049656, 10, 2,
+ 0.62831853071795862 },
+ { -0.081698973831472149, 10, 2,
+ 0.78539816339744828 },
+ { 0.35253132222271272, 10, 2,
+ 0.94247779607693793 },
+ { 0.049026298555981063, 10, 2,
+ 1.0995574287564276 },
+ { -0.32791246874130797, 10, 2,
+ 1.2566370614359172 },
+ { -0.016196782433946910, 10, 2,
+ 1.4137166941154069 },
+ { 0.32106263400438328, 10, 2,
+ 1.5707963267948966 },
+ { -0.016196782433945765, 10, 2,
+ 1.7278759594743860 },
+ { -0.32791246874130797, 10, 2,
+ 1.8849555921538759 },
+ { 0.049026298555980702, 10, 2,
+ 2.0420352248333655 },
+ { 0.35253132222271272, 10, 2,
+ 2.1991148575128552 },
+ { -0.081698973831472149, 10, 2,
+ 2.3561944901923448 },
+ { -0.41494799233049667, 10, 2,
+ 2.5132741228718345 },
+ { 0.098210039644714753, 10, 2,
+ 2.6703537555513241 },
+ { 0.62485535978198059, 10, 2,
+ 2.8274333882308138 },
+ { 0.34571695599980551, 10, 2,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 10, 2,
+ 3.1415926535897931 },
+};
+
+// Test function for l=10, m=2.
+template <typename Tp>
+void test013()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data013)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data013[i].l), Tp(data013[i].m),
+ Tp(data013[i].theta));
+ const Tp f0 = data013[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for l=10, m=5.
+testcase_sph_legendre<double> data014[] = {
+ { 0.0000000000000000, 10, 5,
+ 0.0000000000000000 },
+ { -0.0030300124052750187, 10, 5,
+ 0.15707963267948966 },
+ { -0.070348585248056830, 10, 5,
+ 0.31415926535897931 },
+ { -0.30055029290703639, 10, 5,
+ 0.47123889803846897 },
+ { -0.49987818144009166, 10, 5,
+ 0.62831853071795862 },
+ { -0.28108771757150086, 10, 5,
+ 0.78539816339744828 },
+ { 0.22068081187249308, 10, 5,
+ 0.94247779607693793 },
+ { 0.33689502212592115, 10, 5,
+ 1.0995574287564276 },
+ { -0.086095515520763985, 10, 5,
+ 1.2566370614359172 },
+ { -0.33935827318511558, 10, 5,
+ 1.4137166941154069 },
+ { -1.9213014340664578e-16, 10, 5,
+ 1.5707963267948966 },
+ { 0.33935827318511552, 10, 5,
+ 1.7278759594743860 },
+ { 0.086095515520764526, 10, 5,
+ 1.8849555921538759 },
+ { -0.33689502212592098, 10, 5,
+ 2.0420352248333655 },
+ { -0.22068081187249308, 10, 5,
+ 2.1991148575128552 },
+ { 0.28108771757150086, 10, 5,
+ 2.3561944901923448 },
+ { 0.49987818144009155, 10, 5,
+ 2.5132741228718345 },
+ { 0.30055029290703678, 10, 5,
+ 2.6703537555513241 },
+ { 0.070348585248056830, 10, 5,
+ 2.8274333882308138 },
+ { 0.0030300124052750855, 10, 5,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 10, 5,
+ 3.1415926535897931 },
+};
+
+// Test function for l=10, m=5.
+template <typename Tp>
+void test014()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data014)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data014[i].l), Tp(data014[i].m),
+ Tp(data014[i].theta));
+ const Tp f0 = data014[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=10, m=10.
+testcase_sph_legendre<double> data015[] = {
+ { 0.0000000000000000, 10, 10,
+ 0.0000000000000000 },
+ { 4.7624282733343473e-09, 10, 10,
+ 0.15707963267948966 },
+ { 4.3085156534549772e-06, 10, 10,
+ 0.31415926535897931 },
+ { 0.00020182347649472368, 10, 10,
+ 0.47123889803846897 },
+ { 0.0026711045506511684, 10, 10,
+ 0.62831853071795862 },
+ { 0.016957196623256943, 10, 10,
+ 0.78539816339744828 },
+ { 0.065174916004990341, 10, 10,
+ 0.94247779607693793 },
+ { 0.17112476903017843, 10, 10,
+ 1.0995574287564276 },
+ { 0.32852414199733548, 10, 10,
+ 1.2566370614359172 },
+ { 0.47940582314838287, 10, 10,
+ 1.4137166941154069 },
+ { 0.54263029194422152, 10, 10,
+ 1.5707963267948966 },
+ { 0.47940582314838309, 10, 10,
+ 1.7278759594743860 },
+ { 0.32852414199733571, 10, 10,
+ 1.8849555921538759 },
+ { 0.17112476903017854, 10, 10,
+ 2.0420352248333655 },
+ { 0.065174916004990341, 10, 10,
+ 2.1991148575128552 },
+ { 0.016957196623256943, 10, 10,
+ 2.3561944901923448 },
+ { 0.0026711045506511706, 10, 10,
+ 2.5132741228718345 },
+ { 0.00020182347649472493, 10, 10,
+ 2.6703537555513241 },
+ { 4.3085156534549772e-06, 10, 10,
+ 2.8274333882308138 },
+ { 4.7624282733345673e-09, 10, 10,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 10, 10,
+ 3.1415926535897931 },
+};
+
+// Test function for l=10, m=10.
+template <typename Tp>
+void test015()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data015)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data015[i].l), Tp(data015[i].m),
+ Tp(data015[i].theta));
+ const Tp f0 = data015[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=20, m=0.
+testcase_sph_legendre<double> data016[] = {
+ { 1.8062879984608917, 20, 0,
+ 0.0000000000000000 },
+ { -0.58906549291415966, 20, 0,
+ 0.15707963267948966 },
+ { 0.45624611402342408, 20, 0,
+ 0.31415926535897931 },
+ { -0.39955402700466724, 20, 0,
+ 0.47123889803846897 },
+ { 0.36818552901640750, 20, 0,
+ 0.62831853071795862 },
+ { -0.34873131330857787, 20, 0,
+ 0.78539816339744828 },
+ { 0.33600882829186501, 20, 0,
+ 0.94247779607693793 },
+ { -0.32759286308122904, 20, 0,
+ 1.0995574287564276 },
+ { 0.32222458068091320, 20, 0,
+ 1.2566370614359172 },
+ { -0.31922731037135960, 20, 0,
+ 1.4137166941154069 },
+ { 0.31826262039531755, 20, 0,
+ 1.5707963267948966 },
+ { -0.31922731037135965, 20, 0,
+ 1.7278759594743860 },
+ { 0.32222458068091336, 20, 0,
+ 1.8849555921538759 },
+ { -0.32759286308122937, 20, 0,
+ 2.0420352248333655 },
+ { 0.33600882829186501, 20, 0,
+ 2.1991148575128552 },
+ { -0.34873131330857787, 20, 0,
+ 2.3561944901923448 },
+ { 0.36818552901640839, 20, 0,
+ 2.5132741228718345 },
+ { -0.39955402700466852, 20, 0,
+ 2.6703537555513241 },
+ { 0.45624611402342408, 20, 0,
+ 2.8274333882308138 },
+ { -0.58906549291416699, 20, 0,
+ 2.9845130209103035 },
+ { 1.8062879984608917, 20, 0,
+ 3.1415926535897931 },
+};
+
+// Test function for l=20, m=0.
+template <typename Tp>
+void test016()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data016)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data016[i].l), Tp(data016[i].m),
+ Tp(data016[i].theta));
+ const Tp f0 = data016[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=20, m=1.
+testcase_sph_legendre<double> data017[] = {
+ { 0.0000000000000000, 20, 1,
+ 0.0000000000000000 },
+ { -0.45905213045060206, 20, 1,
+ 0.15707963267948966 },
+ { 0.31166370423309170, 20, 1,
+ 0.31415926535897931 },
+ { -0.23278757741246814, 20, 1,
+ 0.47123889803846897 },
+ { 0.17937240823504183, 20, 1,
+ 0.62831853071795862 },
+ { -0.13857299972299736, 20, 1,
+ 0.78539816339744828 },
+ { 0.10495324841927710, 20, 1,
+ 0.94247779607693793 },
+ { -0.075707774352164178, 20, 1,
+ 1.0995574287564276 },
+ { 0.049168697683476620, 20, 1,
+ 1.2566370614359172 },
+ { -0.024216050551253254, 20, 1,
+ 1.4137166941154069 },
+ { 3.9938443510694349e-16, 20, 1,
+ 1.5707963267948966 },
+ { 0.024216050551250898, 20, 1,
+ 1.7278759594743860 },
+ { -0.049168697683475482, 20, 1,
+ 1.8849555921538759 },
+ { 0.075707774352163332, 20, 1,
+ 2.0420352248333655 },
+ { -0.10495324841927710, 20, 1,
+ 2.1991148575128552 },
+ { 0.13857299972299736, 20, 1,
+ 2.3561944901923448 },
+ { -0.17937240823504039, 20, 1,
+ 2.5132741228718345 },
+ { 0.23278757741246658, 20, 1,
+ 2.6703537555513241 },
+ { -0.31166370423309170, 20, 1,
+ 2.8274333882308138 },
+ { 0.45905213045059318, 20, 1,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 20, 1,
+ 3.1415926535897931 },
+};
+
+// Test function for l=20, m=1.
+template <typename Tp>
+void test017()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data017)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data017[i].l), Tp(data017[i].m),
+ Tp(data017[i].theta));
+ const Tp f0 = data017[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for l=20, m=2.
+testcase_sph_legendre<double> data018[] = {
+ { 0.0000000000000000, 20, 2,
+ 0.0000000000000000 },
+ { 0.87399805141574682, 20, 2,
+ 0.15707963267948966 },
+ { -0.55116854080894984, 20, 2,
+ 0.31415926535897931 },
+ { 0.44520137308557534, 20, 2,
+ 0.47123889803846897 },
+ { -0.39321637877908228, 20, 2,
+ 0.62831853071795862 },
+ { 0.36312025711350970, 20, 2,
+ 0.78539816339744828 },
+ { -0.34427103004873094, 20, 2,
+ 0.94247779607693793 },
+ { 0.33214917638387625, 20, 2,
+ 1.0995574287564276 },
+ { -0.32455734448839091, 20, 2,
+ 1.2566370614359172 },
+ { 0.32036529628513238, 20, 2,
+ 1.4137166941154069 },
+ { -0.31902310563819986, 20, 2,
+ 1.5707963267948966 },
+ { 0.32036529628513266, 20, 2,
+ 1.7278759594743860 },
+ { -0.32455734448839102, 20, 2,
+ 1.8849555921538759 },
+ { 0.33214917638387670, 20, 2,
+ 2.0420352248333655 },
+ { -0.34427103004873094, 20, 2,
+ 2.1991148575128552 },
+ { 0.36312025711350970, 20, 2,
+ 2.3561944901923448 },
+ { -0.39321637877908278, 20, 2,
+ 2.5132741228718345 },
+ { 0.44520137308557639, 20, 2,
+ 2.6703537555513241 },
+ { -0.55116854080894984, 20, 2,
+ 2.8274333882308138 },
+ { 0.87399805141574360, 20, 2,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 20, 2,
+ 3.1415926535897931 },
+};
+
+// Test function for l=20, m=2.
+template <typename Tp>
+void test018()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data018)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data018[i].l), Tp(data018[i].m),
+ Tp(data018[i].theta));
+ const Tp f0 = data018[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=20, m=5.
+testcase_sph_legendre<double> data019[] = {
+ { 0.0000000000000000, 20, 5,
+ 0.0000000000000000 },
+ { -0.10024848623504846, 20, 5,
+ 0.15707963267948966 },
+ { -0.68115361075940595, 20, 5,
+ 0.31415926535897931 },
+ { 0.31774532551156237, 20, 5,
+ 0.47123889803846897 },
+ { -0.16011868165390564, 20, 5,
+ 0.62831853071795862 },
+ { 0.085844143304116230, 20, 5,
+ 0.78539816339744828 },
+ { -0.047467540840864686, 20, 5,
+ 0.94247779607693793 },
+ { 0.026283575189471282, 20, 5,
+ 1.0995574287564276 },
+ { -0.013891104052597331, 20, 5,
+ 1.2566370614359172 },
+ { 0.0059873308239496931, 20, 5,
+ 1.4137166941154069 },
+ { 3.9355286582083095e-16, 20, 5,
+ 1.5707963267948966 },
+ { -0.0059873308239519040, 20, 5,
+ 1.7278759594743860 },
+ { 0.013891104052598531, 20, 5,
+ 1.8849555921538759 },
+ { -0.026283575189472212, 20, 5,
+ 2.0420352248333655 },
+ { 0.047467540840864686, 20, 5,
+ 2.1991148575128552 },
+ { -0.085844143304116230, 20, 5,
+ 2.3561944901923448 },
+ { 0.16011868165390636, 20, 5,
+ 2.5132741228718345 },
+ { -0.31774532551156448, 20, 5,
+ 2.6703537555513241 },
+ { 0.68115361075940595, 20, 5,
+ 2.8274333882308138 },
+ { 0.10024848623505037, 20, 5,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 20, 5,
+ 3.1415926535897931 },
+};
+
+// Test function for l=20, m=5.
+template <typename Tp>
+void test019()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data019)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data019[i].l), Tp(data019[i].m),
+ Tp(data019[i].theta));
+ const Tp f0 = data019[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for l=20, m=10.
+testcase_sph_legendre<double> data020[] = {
+ { 0.0000000000000000, 20, 10,
+ 0.0000000000000000 },
+ { 3.0595797603706485e-05, 20, 10,
+ 0.15707963267948966 },
+ { 0.015924453916397008, 20, 10,
+ 0.31415926535897931 },
+ { 0.26588079118745700, 20, 10,
+ 0.47123889803846897 },
+ { 0.54045081420686825, 20, 10,
+ 0.62831853071795862 },
+ { -0.28215279394285597, 20, 10,
+ 0.78539816339744828 },
+ { 0.0085297337582246665, 20, 10,
+ 0.94247779607693793 },
+ { 0.16930127953533775, 20, 10,
+ 1.0995574287564276 },
+ { -0.27215134048018352, 20, 10,
+ 1.2566370614359172 },
+ { 0.32456597088029526, 20, 10,
+ 1.4137166941154069 },
+ { -0.34057893241353715, 20, 10,
+ 1.5707963267948966 },
+ { 0.32456597088029449, 20, 10,
+ 1.7278759594743860 },
+ { -0.27215134048018308, 20, 10,
+ 1.8849555921538759 },
+ { 0.16930127953533725, 20, 10,
+ 2.0420352248333655 },
+ { 0.0085297337582246665, 20, 10,
+ 2.1991148575128552 },
+ { -0.28215279394285597, 20, 10,
+ 2.3561944901923448 },
+ { 0.54045081420686658, 20, 10,
+ 2.5132741228718345 },
+ { 0.26588079118745822, 20, 10,
+ 2.6703537555513241 },
+ { 0.015924453916397008, 20, 10,
+ 2.8274333882308138 },
+ { 3.0595797603707854e-05, 20, 10,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 20, 10,
+ 3.1415926535897931 },
+};
+
+// Test function for l=20, m=10.
+template <typename Tp>
+void test020()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data020)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data020[i].l), Tp(data020[i].m),
+ Tp(data020[i].theta));
+ const Tp f0 = data020[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for l=20, m=20.
+testcase_sph_legendre<double> data021[] = {
+ { 0.0000000000000000, 20, 20,
+ 0.0000000000000000 },
+ { 4.9264471419245886e-17, 20, 20,
+ 0.15707963267948966 },
+ { 4.0321091681531780e-11, 20, 20,
+ 0.31415926535897931 },
+ { 8.8474944184471664e-08, 20, 20,
+ 0.47123889803846897 },
+ { 1.5497395129387764e-05, 20, 20,
+ 0.62831853071795862 },
+ { 0.00062457564282984723, 20, 20,
+ 0.78539816339744828 },
+ { 0.0092265192458967603, 20, 20,
+ 0.94247779607693793 },
+ { 0.063606673236323269, 20, 20,
+ 1.0995574287564276 },
+ { 0.23442909509776308, 20, 20,
+ 1.2566370614359172 },
+ { 0.49921030481087009, 20, 20,
+ 1.4137166941154069 },
+ { 0.63956545825776223, 20, 20,
+ 1.5707963267948966 },
+ { 0.49921030481087064, 20, 20,
+ 1.7278759594743860 },
+ { 0.23442909509776344, 20, 20,
+ 1.8849555921538759 },
+ { 0.063606673236323352, 20, 20,
+ 2.0420352248333655 },
+ { 0.0092265192458967603, 20, 20,
+ 2.1991148575128552 },
+ { 0.00062457564282984723, 20, 20,
+ 2.3561944901923448 },
+ { 1.5497395129387818e-05, 20, 20,
+ 2.5132741228718345 },
+ { 8.8474944184472617e-08, 20, 20,
+ 2.6703537555513241 },
+ { 4.0321091681531780e-11, 20, 20,
+ 2.8274333882308138 },
+ { 4.9264471419250786e-17, 20, 20,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 20, 20,
+ 3.1415926535897931 },
+};
+
+// Test function for l=20, m=20.
+template <typename Tp>
+void test021()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data021)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data021[i].l), Tp(data021[i].m),
+ Tp(data021[i].theta));
+ const Tp f0 = data021[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=50, m=0.
+testcase_sph_legendre<double> data022[] = {
+ { 2.8350175706934717, 50, 0,
+ 0.0000000000000000 },
+ { 0.53157537495174845, 50, 0,
+ 0.15707963267948966 },
+ { -0.46056183476301349, 50, 0,
+ 0.31415926535897931 },
+ { -0.24876032079677909, 50, 0,
+ 0.47123889803846897 },
+ { 0.36926172901532522, 50, 0,
+ 0.62831853071795862 },
+ { 0.14571730283563306, 50, 0,
+ 0.78539816339744828 },
+ { -0.33636199170850811, 50, 0,
+ 0.94247779607693793 },
+ { -0.079132716267092035, 50, 0,
+ 1.0995574287564276 },
+ { 0.32232921941301440, 50, 0,
+ 1.2566370614359172 },
+ { 0.025253991969481446, 50, 0,
+ 1.4137166941154069 },
+ { -0.31830208724152359, 50, 0,
+ 1.5707963267948966 },
+ { 0.025253991969476128, 50, 0,
+ 1.7278759594743860 },
+ { 0.32232921941301479, 50, 0,
+ 1.8849555921538759 },
+ { -0.079132716267090078, 50, 0,
+ 2.0420352248333655 },
+ { -0.33636199170850811, 50, 0,
+ 2.1991148575128552 },
+ { 0.14571730283563306, 50, 0,
+ 2.3561944901923448 },
+ { 0.36926172901532717, 50, 0,
+ 2.5132741228718345 },
+ { -0.24876032079677393, 50, 0,
+ 2.6703537555513241 },
+ { -0.46056183476301349, 50, 0,
+ 2.8274333882308138 },
+ { 0.53157537495172380, 50, 0,
+ 2.9845130209103035 },
+ { 2.8350175706934717, 50, 0,
+ 3.1415926535897931 },
+};
+
+// Test function for l=50, m=0.
+template <typename Tp>
+void test022()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data022)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data022[i].l), Tp(data022[i].m),
+ Tp(data022[i].theta));
+ const Tp f0 = data022[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for l=50, m=1.
+testcase_sph_legendre<double> data023[] = {
+ { 0.0000000000000000, 50, 1,
+ 0.0000000000000000 },
+ { -0.63751752155226116, 50, 1,
+ 0.15707963267948966 },
+ { -0.32616619317604312, 50, 1,
+ 0.31415926535897931 },
+ { 0.40649930826162706, 50, 1,
+ 0.47123889803846897 },
+ { 0.18473991408344026, 50, 1,
+ 0.62831853071795862 },
+ { -0.35083930302013211, 50, 1,
+ 0.78539816339744828 },
+ { -0.10755382110947098, 50, 1,
+ 0.94247779607693793 },
+ { 0.32822568316499862, 50, 1,
+ 1.0995574287564276 },
+ { 0.050286056609798180, 50, 1,
+ 1.2566370614359172 },
+ { -0.31935368562159638, 50, 1,
+ 1.4137166941154069 },
+ { -9.8421602686195941e-16, 50, 1,
+ 1.5707963267948966 },
+ { 0.31935368562159705, 50, 1,
+ 1.7278759594743860 },
+ { -0.050286056609795383, 50, 1,
+ 1.8849555921538759 },
+ { -0.32822568316499923, 50, 1,
+ 2.0420352248333655 },
+ { 0.10755382110947098, 50, 1,
+ 2.1991148575128552 },
+ { 0.35083930302013211, 50, 1,
+ 2.3561944901923448 },
+ { -0.18473991408343632, 50, 1,
+ 2.5132741228718345 },
+ { -0.40649930826163039, 50, 1,
+ 2.6703537555513241 },
+ { 0.32616619317604312, 50, 1,
+ 2.8274333882308138 },
+ { 0.63751752155227837, 50, 1,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 50, 1,
+ 3.1415926535897931 },
+};
+
+// Test function for l=50, m=1.
+template <typename Tp>
+void test023()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data023)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data023[i].l), Tp(data023[i].m),
+ Tp(data023[i].theta));
+ const Tp f0 = data023[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for l=50, m=2.
+testcase_sph_legendre<double> data024[] = {
+ { 0.0000000000000000, 50, 2,
+ 0.0000000000000000 },
+ { -0.37230261163839168, 50, 2,
+ 0.15707963267948966 },
+ { 0.50051599680315972, 50, 2,
+ 0.31415926535897931 },
+ { 0.21724795180329545, 50, 2,
+ 0.47123889803846897 },
+ { -0.37948127307610940, 50, 2,
+ 0.62831853071795862 },
+ { -0.13187372121003119, 50, 2,
+ 0.78539816339744828 },
+ { 0.33959009162400194, 50, 2,
+ 0.94247779607693793 },
+ { 0.072537503112490409, 50, 2,
+ 1.0995574287564276 },
+ { -0.32310306941855271, 50, 2,
+ 1.2566370614359172 },
+ { -0.023259822816436588, 50, 2,
+ 1.4137166941154069 },
+ { 0.31842698506357275, 50, 2,
+ 1.5707963267948966 },
+ { -0.023259822816431144, 50, 2,
+ 1.7278759594743860 },
+ { -0.32310306941855299, 50, 2,
+ 1.8849555921538759 },
+ { 0.072537503112488369, 50, 2,
+ 2.0420352248333655 },
+ { 0.33959009162400194, 50, 2,
+ 2.1991148575128552 },
+ { -0.13187372121003119, 50, 2,
+ 2.3561944901923448 },
+ { -0.37948127307611074, 50, 2,
+ 2.5132741228718345 },
+ { 0.21724795180328935, 50, 2,
+ 2.6703537555513241 },
+ { 0.50051599680315972, 50, 2,
+ 2.8274333882308138 },
+ { -0.37230261163836298, 50, 2,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 50, 2,
+ 3.1415926535897931 },
+};
+
+// Test function for l=50, m=2.
+template <typename Tp>
+void test024()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data024)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data024[i].l), Tp(data024[i].m),
+ Tp(data024[i].theta));
+ const Tp f0 = data024[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000015e-12));
+}
+
+// Test data for l=50, m=5.
+testcase_sph_legendre<double> data025[] = {
+ { 0.0000000000000000, 50, 5,
+ 0.0000000000000000 },
+ { -0.57750385903193069, 50, 5,
+ 0.15707963267948966 },
+ { 0.077360497065584566, 50, 5,
+ 0.31415926535897931 },
+ { 0.47707267400540210, 50, 5,
+ 0.47123889803846897 },
+ { 0.055370615126630537, 50, 5,
+ 0.62831853071795862 },
+ { -0.37629451847202855, 50, 5,
+ 0.78539816339744828 },
+ { -0.048042277801960624, 50, 5,
+ 0.94247779607693793 },
+ { 0.33619379362228685, 50, 5,
+ 1.0995574287564276 },
+ { 0.025265227185719726, 50, 5,
+ 1.2566370614359172 },
+ { -0.32083679430964518, 50, 5,
+ 1.4137166941154069 },
+ { -9.8189201019751884e-16, 50, 5,
+ 1.5707963267948966 },
+ { 0.32083679430964590, 50, 5,
+ 1.7278759594743860 },
+ { -0.025265227185716856, 50, 5,
+ 1.8849555921538759 },
+ { -0.33619379362228730, 50, 5,
+ 2.0420352248333655 },
+ { 0.048042277801960624, 50, 5,
+ 2.1991148575128552 },
+ { 0.37629451847202855, 50, 5,
+ 2.3561944901923448 },
+ { -0.055370615126626936, 50, 5,
+ 2.5132741228718345 },
+ { -0.47707267400540210, 50, 5,
+ 2.6703537555513241 },
+ { -0.077360497065584566, 50, 5,
+ 2.8274333882308138 },
+ { 0.57750385903191004, 50, 5,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 50, 5,
+ 3.1415926535897931 },
+};
+
+// Test function for l=50, m=5.
+template <typename Tp>
+void test025()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data025)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data025[i].l), Tp(data025[i].m),
+ Tp(data025[i].theta));
+ const Tp f0 = data025[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for l=50, m=10.
+testcase_sph_legendre<double> data026[] = {
+ { 0.0000000000000000, 50, 10,
+ 0.0000000000000000 },
+ { 0.15606941844800759, 50, 10,
+ 0.15707963267948966 },
+ { -0.53748868836814601, 50, 10,
+ 0.31415926535897931 },
+ { -0.49304919025183896, 50, 10,
+ 0.47123889803846897 },
+ { -0.26267582750428264, 50, 10,
+ 0.62831853071795862 },
+ { 0.22058983666314402, 50, 10,
+ 0.78539816339744828 },
+ { 0.32936725160671759, 50, 10,
+ 0.94247779607693793 },
+ { -0.092053311559446988, 50, 10,
+ 1.0995574287564276 },
+ { -0.32542913495935555, 50, 10,
+ 1.2566370614359172 },
+ { 0.025673223789103500, 50, 10,
+ 1.4137166941154069 },
+ { 0.32150019350255743, 50, 10,
+ 1.5707963267948966 },
+ { 0.025673223789108864, 50, 10,
+ 1.7278759594743860 },
+ { -0.32542913495935494, 50, 10,
+ 1.8849555921538759 },
+ { -0.092053311559448570, 50, 10,
+ 2.0420352248333655 },
+ { 0.32936725160671759, 50, 10,
+ 2.1991148575128552 },
+ { 0.22058983666314402, 50, 10,
+ 2.3561944901923448 },
+ { -0.26267582750427909, 50, 10,
+ 2.5132741228718345 },
+ { -0.49304919025184119, 50, 10,
+ 2.6703537555513241 },
+ { -0.53748868836814601, 50, 10,
+ 2.8274333882308138 },
+ { 0.15606941844801259, 50, 10,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 50, 10,
+ 3.1415926535897931 },
+};
+
+// Test function for l=50, m=10.
+template <typename Tp>
+void test026()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data026)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data026[i].l), Tp(data026[i].m),
+ Tp(data026[i].theta));
+ const Tp f0 = data026[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=50, m=20.
+testcase_sph_legendre<double> data027[] = {
+ { 0.0000000000000000, 50, 20,
+ 0.0000000000000000 },
+ { 3.0409598712833082e-07, 50, 20,
+ 0.15707963267948966 },
+ { 0.030940518122882305, 50, 20,
+ 0.31415926535897931 },
+ { 0.64134588721659935, 50, 20,
+ 0.47123889803846897 },
+ { 0.29895244392136394, 50, 20,
+ 0.62831853071795862 },
+ { 0.25309324781874065, 50, 20,
+ 0.78539816339744828 },
+ { 0.34368634714931712, 50, 20,
+ 0.94247779607693793 },
+ { 0.33996764360663956, 50, 20,
+ 1.0995574287564276 },
+ { 0.12866267745104118, 50, 20,
+ 1.2566370614359172 },
+ { -0.18201114398922874, 50, 20,
+ 1.4137166941154069 },
+ { -0.33216683431510857, 50, 20,
+ 1.5707963267948966 },
+ { -0.18201114398923304, 50, 20,
+ 1.7278759594743860 },
+ { 0.12866267745103846, 50, 20,
+ 1.8849555921538759 },
+ { 0.33996764360663906, 50, 20,
+ 2.0420352248333655 },
+ { 0.34368634714931712, 50, 20,
+ 2.1991148575128552 },
+ { 0.25309324781874065, 50, 20,
+ 2.3561944901923448 },
+ { 0.29895244392136738, 50, 20,
+ 2.5132741228718345 },
+ { 0.64134588721659791, 50, 20,
+ 2.6703537555513241 },
+ { 0.030940518122882305, 50, 20,
+ 2.8274333882308138 },
+ { 3.0409598712835877e-07, 50, 20,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 50, 20,
+ 3.1415926535897931 },
+};
+
+// Test function for l=50, m=20.
+template <typename Tp>
+void test027()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data027)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data027[i].l), Tp(data027[i].m),
+ Tp(data027[i].theta));
+ const Tp f0 = data027[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for l=50, m=50.
+testcase_sph_legendre<double> data028[] = {
+ { 0.0000000000000000, 50, 50,
+ 0.0000000000000000 },
+ { 4.1649039898151844e-41, 50, 50,
+ 0.15707963267948966 },
+ { 2.5240684647724192e-26, 50, 50,
+ 0.31415926535897931 },
+ { 5.6927376423967334e-18, 50, 50,
+ 0.47123889803846897 },
+ { 2.3116239814797057e-12, 50, 50,
+ 0.62831853071795862 },
+ { 2.3835981241325311e-08, 50, 50,
+ 0.78539816339744828 },
+ { 1.9992410287270356e-05, 50, 50,
+ 0.94247779607693793 },
+ { 0.0024947505670829791, 50, 50,
+ 1.0995574287564276 },
+ { 0.065057774647971175, 50, 50,
+ 1.2566370614359172 },
+ { 0.43050607056732243, 50, 50,
+ 1.4137166941154069 },
+ { 0.79980281171531975, 50, 50,
+ 1.5707963267948966 },
+ { 0.43050607056732360, 50, 50,
+ 1.7278759594743860 },
+ { 0.065057774647971384, 50, 50,
+ 1.8849555921538759 },
+ { 0.0024947505670829856, 50, 50,
+ 2.0420352248333655 },
+ { 1.9992410287270356e-05, 50, 50,
+ 2.1991148575128552 },
+ { 2.3835981241325311e-08, 50, 50,
+ 2.3561944901923448 },
+ { 2.3116239814797222e-12, 50, 50,
+ 2.5132741228718345 },
+ { 5.6927376423968544e-18, 50, 50,
+ 2.6703537555513241 },
+ { 2.5240684647724192e-26, 50, 50,
+ 2.8274333882308138 },
+ { 4.1649039898161316e-41, 50, 50,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 50, 50,
+ 3.1415926535897931 },
+};
+
+// Test function for l=50, m=50.
+template <typename Tp>
+void test028()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data028)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data028[i].l), Tp(data028[i].m),
+ Tp(data028[i].theta));
+ const Tp f0 = data028[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=100, m=0.
+testcase_sph_legendre<double> data029[] = {
+ { 3.9993839251484076, 100, 0,
+ 0.0000000000000000 },
+ { -0.60770160285935471, 100, 0,
+ 0.15707963267948966 },
+ { 0.46193027883956100, 100, 0,
+ 0.31415926535897931 },
+ { -0.40218718869815234, 100, 0,
+ 0.47123889803846897 },
+ { 0.36960201406910737, 100, 0,
+ 0.62831853071795862 },
+ { -0.34953726547378611, 100, 0,
+ 0.78539816339744828 },
+ { 0.33646959352497846, 100, 0,
+ 0.94247779607693793 },
+ { -0.32784733067663169, 100, 0,
+ 1.0995574287564276 },
+ { 0.32235624474047936, 100, 0,
+ 1.2566370614359172 },
+ { -0.31929330706601283, 100, 0,
+ 1.4137166941154069 },
+ { 0.31830791662110325, 100, 0,
+ 1.5707963267948966 },
+ { -0.31929330706601389, 100, 0,
+ 1.7278759594743860 },
+ { 0.32235624474048052, 100, 0,
+ 1.8849555921538759 },
+ { -0.32784733067663291, 100, 0,
+ 2.0420352248333655 },
+ { 0.33646959352497846, 100, 0,
+ 2.1991148575128552 },
+ { -0.34953726547378611, 100, 0,
+ 2.3561944901923448 },
+ { 0.36960201406911114, 100, 0,
+ 2.5132741228718345 },
+ { -0.40218718869815695, 100, 0,
+ 2.6703537555513241 },
+ { 0.46193027883956100, 100, 0,
+ 2.8274333882308138 },
+ { -0.60770160285939478, 100, 0,
+ 2.9845130209103035 },
+ { 3.9993839251484076, 100, 0,
+ 3.1415926535897931 },
+};
+
+// Test function for l=100, m=0.
+template <typename Tp>
+void test029()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data029)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data029[i].l), Tp(data029[i].m),
+ Tp(data029[i].theta));
+ const Tp f0 = data029[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for l=100, m=1.
+testcase_sph_legendre<double> data030[] = {
+ { 0.0000000000000000, 100, 1,
+ 0.0000000000000000 },
+ { -0.50851949013719622, 100, 1,
+ 0.15707963267948966 },
+ { 0.33129641402221310, 100, 1,
+ 0.31415926535897931 },
+ { -0.24390405750942562, 100, 1,
+ 0.47123889803846897 },
+ { 0.18659755088414165, 100, 1,
+ 0.62831853071795862 },
+ { -0.14355908970516640, 100, 1,
+ 0.78539816339744828 },
+ { 0.10844906813251093, 100, 1,
+ 0.94247779607693793 },
+ { -0.078100088690859812, 100, 1,
+ 1.0995574287564276 },
+ { 0.050670002998304528, 100, 1,
+ 1.2566370614359172 },
+ { -0.024941251747138762, 100, 1,
+ 1.4137166941154069 },
+ { 1.9587949830851639e-15, 100, 1,
+ 1.5707963267948966 },
+ { 0.024941251747127649, 100, 1,
+ 1.7278759594743860 },
+ { -0.050670002998298595, 100, 1,
+ 1.8849555921538759 },
+ { 0.078100088690855676, 100, 1,
+ 2.0420352248333655 },
+ { -0.10844906813251093, 100, 1,
+ 2.1991148575128552 },
+ { 0.14355908970516640, 100, 1,
+ 2.3561944901923448 },
+ { -0.18659755088413349, 100, 1,
+ 2.5132741228718345 },
+ { 0.24390405750941485, 100, 1,
+ 2.6703537555513241 },
+ { -0.33129641402221310, 100, 1,
+ 2.8274333882308138 },
+ { 0.50851949013714548, 100, 1,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 100, 1,
+ 3.1415926535897931 },
+};
+
+// Test function for l=100, m=1.
+template <typename Tp>
+void test030()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data030)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data030[i].l), Tp(data030[i].m),
+ Tp(data030[i].theta));
+ const Tp f0 = data030[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for l=100, m=2.
+testcase_sph_legendre<double> data031[] = {
+ { 0.0000000000000000, 100, 2,
+ 0.0000000000000000 },
+ { 0.67166274297194040, 100, 2,
+ 0.15707963267948966 },
+ { -0.48226933687995144, 100, 2,
+ 0.31415926535897931 },
+ { 0.41175421895715447, 100, 2,
+ 0.47123889803846897 },
+ { -0.37475021787822460, 100, 2,
+ 0.62831853071795862 },
+ { 0.35242909383605475, 100, 2,
+ 0.78539816339744828 },
+ { -0.33807110409160002, 100, 2,
+ 0.94247779607693793 },
+ { 0.32867180390709999, 100, 2,
+ 1.0995574287564276 },
+ { -0.32271583790278469, 100, 2,
+ 1.2566370614359172 },
+ { 0.31940354677687433, 100, 2,
+ 1.4137166941154069 },
+ { -0.31833943693772526, 100, 2,
+ 1.5707963267948966 },
+ { 0.31940354677687521, 100, 2,
+ 1.7278759594743860 },
+ { -0.32271583790278524, 100, 2,
+ 1.8849555921538759 },
+ { 0.32867180390710143, 100, 2,
+ 2.0420352248333655 },
+ { -0.33807110409160002, 100, 2,
+ 2.1991148575128552 },
+ { 0.35242909383605475, 100, 2,
+ 2.3561944901923448 },
+ { -0.37475021787822771, 100, 2,
+ 2.5132741228718345 },
+ { 0.41175421895716069, 100, 2,
+ 2.6703537555513241 },
+ { -0.48226933687995144, 100, 2,
+ 2.8274333882308138 },
+ { 0.67166274297196804, 100, 2,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 100, 2,
+ 3.1415926535897931 },
+};
+
+// Test function for l=100, m=2.
+template <typename Tp>
+void test031()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data031)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data031[i].l), Tp(data031[i].m),
+ Tp(data031[i].theta));
+ const Tp f0 = data031[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000020e-13));
+}
+
+// Test data for l=100, m=5.
+testcase_sph_legendre<double> data032[] = {
+ { 0.0000000000000000, 100, 5,
+ 0.0000000000000000 },
+ { 0.062564361105907143, 100, 5,
+ 0.15707963267948966 },
+ { 0.14179554455880186, 100, 5,
+ 0.31415926535897931 },
+ { -0.14356866942906019, 100, 5,
+ 0.47123889803846897 },
+ { 0.12355483388448507, 100, 5,
+ 0.62831853071795862 },
+ { -0.10090029999681098, 100, 5,
+ 0.78539816339744828 },
+ { 0.078905134460230564, 100, 5,
+ 0.94247779607693793 },
+ { -0.058040182398187236, 100, 5,
+ 1.0995574287564276 },
+ { 0.038142759389484152, 100, 5,
+ 1.2566370614359172 },
+ { -0.018906264170660277, 100, 5,
+ 1.4137166941154069 },
+ { 1.9576303042914544e-15, 100, 5,
+ 1.5707963267948966 },
+ { 0.018906264170649747, 100, 5,
+ 1.7278759594743860 },
+ { -0.038142759389478524, 100, 5,
+ 1.8849555921538759 },
+ { 0.058040182398182996, 100, 5,
+ 2.0420352248333655 },
+ { -0.078905134460230564, 100, 5,
+ 2.1991148575128552 },
+ { 0.10090029999681098, 100, 5,
+ 2.3561944901923448 },
+ { -0.12355483388447780, 100, 5,
+ 2.5132741228718345 },
+ { 0.14356866942904903, 100, 5,
+ 2.6703537555513241 },
+ { -0.14179554455880186, 100, 5,
+ 2.8274333882308138 },
+ { -0.062564361105959004, 100, 5,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 100, 5,
+ 3.1415926535897931 },
+};
+
+// Test function for l=100, m=5.
+template <typename Tp>
+void test032()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data032)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data032[i].l), Tp(data032[i].m),
+ Tp(data032[i].theta));
+ const Tp f0 = data032[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000029e-12));
+}
+
+// Test data for l=100, m=10.
+testcase_sph_legendre<double> data033[] = {
+ { 0.0000000000000000, 100, 10,
+ 0.0000000000000000 },
+ { -0.75366545187995670, 100, 10,
+ 0.15707963267948966 },
+ { -0.35914570017277186, 100, 10,
+ 0.31415926535897931 },
+ { 0.43480692911578245, 100, 10,
+ 0.47123889803846897 },
+ { -0.40862111080315705, 100, 10,
+ 0.62831853071795862 },
+ { 0.37832688692909400, 100, 10,
+ 0.78539816339744828 },
+ { -0.35484056194773472, 100, 10,
+ 0.94247779607693793 },
+ { 0.33821981171196336, 100, 10,
+ 1.0995574287564276 },
+ { -0.32729120767830605, 100, 10,
+ 1.2566370614359172 },
+ { 0.32110336937091455, 100, 10,
+ 1.4137166941154069 },
+ { -0.31910064020036194, 100, 10,
+ 1.5707963267948966 },
+ { 0.32110336937091488, 100, 10,
+ 1.7278759594743860 },
+ { -0.32729120767830577, 100, 10,
+ 1.8849555921538759 },
+ { 0.33821981171196341, 100, 10,
+ 2.0420352248333655 },
+ { -0.35484056194773472, 100, 10,
+ 2.1991148575128552 },
+ { 0.37832688692909400, 100, 10,
+ 2.3561944901923448 },
+ { -0.40862111080315433, 100, 10,
+ 2.5132741228718345 },
+ { 0.43480692911577806, 100, 10,
+ 2.6703537555513241 },
+ { -0.35914570017277186, 100, 10,
+ 2.8274333882308138 },
+ { -0.75366545187998180, 100, 10,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 100, 10,
+ 3.1415926535897931 },
+};
+
+// Test function for l=100, m=10.
+template <typename Tp>
+void test033()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data033)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data033[i].l), Tp(data033[i].m),
+ Tp(data033[i].theta));
+ const Tp f0 = data033[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000008e-12));
+}
+
+// Test data for l=100, m=20.
+testcase_sph_legendre<double> data034[] = {
+ { 0.0000000000000000, 100, 20,
+ 0.0000000000000000 },
+ { 0.053569660841553138, 100, 20,
+ 0.15707963267948966 },
+ { 0.57154926874732426, 100, 20,
+ 0.31415926535897931 },
+ { 0.47536909969585828, 100, 20,
+ 0.47123889803846897 },
+ { -0.28882554564109014, 100, 20,
+ 0.62831853071795862 },
+ { 0.020116179014049645, 100, 20,
+ 0.78539816339744828 },
+ { 0.14752195931706580, 100, 20,
+ 0.94247779607693793 },
+ { -0.24069428588868527, 100, 20,
+ 1.0995574287564276 },
+ { 0.29031796025014395, 100, 20,
+ 1.2566370614359172 },
+ { -0.31437256851143475, 100, 20,
+ 1.4137166941154069 },
+ { 0.32153954851141792, 100, 20,
+ 1.5707963267948966 },
+ { -0.31437256851143192, 100, 20,
+ 1.7278759594743860 },
+ { 0.29031796025014112, 100, 20,
+ 1.8849555921538759 },
+ { -0.24069428588868211, 100, 20,
+ 2.0420352248333655 },
+ { 0.14752195931706580, 100, 20,
+ 2.1991148575128552 },
+ { 0.020116179014049645, 100, 20,
+ 2.3561944901923448 },
+ { -0.28882554564109658, 100, 20,
+ 2.5132741228718345 },
+ { 0.47536909969585378, 100, 20,
+ 2.6703537555513241 },
+ { 0.57154926874732426, 100, 20,
+ 2.8274333882308138 },
+ { 0.053569660841557065, 100, 20,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 100, 20,
+ 3.1415926535897931 },
+};
+
+// Test function for l=100, m=20.
+template <typename Tp>
+void test034()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data034)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data034[i].l), Tp(data034[i].m),
+ Tp(data034[i].theta));
+ const Tp f0 = data034[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000015e-12));
+}
+
+// Test data for l=100, m=50.
+testcase_sph_legendre<double> data035[] = {
+ { 0.0000000000000000, 100, 50,
+ 0.0000000000000000 },
+ { 3.3047910392590630e-21, 100, 50,
+ 0.15707963267948966 },
+ { 1.0592655372554983e-07, 100, 50,
+ 0.31415926535897931 },
+ { 0.080418744223952635, 100, 50,
+ 0.47123889803846897 },
+ { -0.56450600580393062, 100, 50,
+ 0.62831853071795862 },
+ { 0.33338739844741766, 100, 50,
+ 0.78539816339744828 },
+ { 0.39741714816514678, 100, 50,
+ 0.94247779607693793 },
+ { 0.35223993750972293, 100, 50,
+ 1.0995574287564276 },
+ { 0.17885891940721749, 100, 50,
+ 1.2566370614359172 },
+ { -0.15341660126461953, 100, 50,
+ 1.4137166941154069 },
+ { -0.34175924303503102, 100, 50,
+ 1.5707963267948966 },
+ { -0.15341660126462864, 100, 50,
+ 1.7278759594743860 },
+ { 0.17885891940721332, 100, 50,
+ 1.8849555921538759 },
+ { 0.35223993750972149, 100, 50,
+ 2.0420352248333655 },
+ { 0.39741714816514678, 100, 50,
+ 2.1991148575128552 },
+ { 0.33338739844741766, 100, 50,
+ 2.3561944901923448 },
+ { -0.56450600580392785, 100, 50,
+ 2.5132741228718345 },
+ { 0.080418744223953439, 100, 50,
+ 2.6703537555513241 },
+ { 1.0592655372554983e-07, 100, 50,
+ 2.8274333882308138 },
+ { 3.3047910392597871e-21, 100, 50,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 100, 50,
+ 3.1415926535897931 },
+};
+
+// Test function for l=100, m=50.
+template <typename Tp>
+void test035()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data035)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data035[i].l), Tp(data035[i].m),
+ Tp(data035[i].theta));
+ const Tp f0 = data035[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+// Test data for l=100, m=100.
+testcase_sph_legendre<double> data036[] = {
+ { 0.0000000000000000, 100, 100,
+ 0.0000000000000000 },
+ { 2.5744136608862186e-81, 100, 100,
+ 0.15707963267948966 },
+ { 9.4551974868956498e-52, 100, 100,
+ 0.31415926535897931 },
+ { 4.8096190703396912e-35, 100, 100,
+ 0.47123889803846897 },
+ { 7.9305393636343450e-24, 100, 100,
+ 0.62831853071795862 },
+ { 8.4320740610946652e-16, 100, 100,
+ 0.78539816339744828 },
+ { 5.9319660146027522e-10, 100, 100,
+ 0.94247779607693793 },
+ { 9.2368225946796921e-06, 100, 100,
+ 1.0995574287564276 },
+ { 0.0062815489742043982, 100, 100,
+ 1.2566370614359172 },
+ { 0.27505966018176986, 100, 100,
+ 1.4137166941154069 },
+ { 0.94936713998764621, 100, 100,
+ 1.5707963267948966 },
+ { 0.27505966018177136, 100, 100,
+ 1.7278759594743860 },
+ { 0.0062815489742044433, 100, 100,
+ 1.8849555921538759 },
+ { 9.2368225946797582e-06, 100, 100,
+ 2.0420352248333655 },
+ { 5.9319660146027522e-10, 100, 100,
+ 2.1991148575128552 },
+ { 8.4320740610946652e-16, 100, 100,
+ 2.3561944901923448 },
+ { 7.9305393636344581e-24, 100, 100,
+ 2.5132741228718345 },
+ { 4.8096190703399648e-35, 100, 100,
+ 2.6703537555513241 },
+ { 9.4551974868956498e-52, 100, 100,
+ 2.8274333882308138 },
+ { 2.5744136608873895e-81, 100, 100,
+ 2.9845130209103035 },
+ { 0.0000000000000000, 100, 100,
+ 3.1415926535897931 },
+};
+
+// Test function for l=100, m=100.
+template <typename Tp>
+void test036()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data036)
+ / sizeof(testcase_sph_legendre<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_legendre(Tp(data036[i].l), Tp(data036[i].m),
+ Tp(data036[i].theta));
+ const Tp f0 = data036[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000039e-13));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ test009<double>();
+ test010<double>();
+ test011<double>();
+ test012<double>();
+ test013<double>();
+ test014<double>();
+ test015<double>();
+ test016<double>();
+ test017<double>();
+ test018<double>();
+ test019<double>();
+ test020<double>();
+ test021<double>();
+ test022<double>();
+ test023<double>();
+ test024<double>();
+ test025<double>();
+ test026<double>();
+ test027<double>();
+ test028<double>();
+ test029<double>();
+ test030<double>();
+ test031<double>();
+ test032<double>();
+ test033<double>();
+ test034<double>();
+ test035<double>();
+ test036<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/22_sph_legendre/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/22_sph_legendre/compile.cc
new file mode 100644
index 00000000000..9e6be450dff
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/22_sph_legendre/compile.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.22 sph_legendre
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+ float thetaf = 0.5F;
+ double thetad = 0.5;
+ long double thetal = 0.5L;
+ unsigned int l = 2, m = 1;
+
+ std::tr1::sph_legendre(l, m, thetaf);
+ std::tr1::sph_legendref(l, m, thetaf);
+ std::tr1::sph_legendre(l, m, thetad);
+ std::tr1::sph_legendre(l, m, thetal);
+ std::tr1::sph_legendrel(l, m, thetal);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/22_sph_legendre/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/22_sph_legendre/compile_2.cc
new file mode 100644
index 00000000000..177e6205b1c
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/22_sph_legendre/compile_2.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.22 sph_legendre
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+ float thetaf = 0.5F;
+ double thetad = 0.5;
+ long double thetal = 0.5L;
+ unsigned int l = 2, m = 1;
+
+ sph_legendre(l, m, thetaf);
+ sph_legendref(l, m, thetaf);
+ sph_legendre(l, m, thetad);
+ sph_legendre(l, m, thetal);
+ sph_legendrel(l, m, thetal);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/23_sph_neumann/check_nan.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/23_sph_neumann/check_nan.cc
new file mode 100644
index 00000000000..17f8ca6b0ac
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/23_sph_neumann/check_nan.cc
@@ -0,0 +1,58 @@
+// { dg-require-c-std "" }
+
+// 2007-01-10 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.23 sph_neumann
+
+#include <tr1/cmath>
+#include <testsuite_hooks.h>
+
+void
+test01()
+{
+ float xf = std::numeric_limits<float>::quiet_NaN();
+ double xd = std::numeric_limits<double>::quiet_NaN();
+ long double xl = std::numeric_limits<long double>::quiet_NaN();
+
+ unsigned int n = 0;
+
+ float a = std::tr1::sph_neumann(n, xf);
+ float b = std::tr1::sph_neumannf(n, xf);
+ double c = std::tr1::sph_neumann(n, xd);
+ long double d = std::tr1::sph_neumann(n, xl);
+ long double e = std::tr1::sph_neumannl(n, xl);
+
+ VERIFY(std::tr1::isnan<float>(a));
+ VERIFY(std::tr1::isnan<float>(b));
+ VERIFY(std::tr1::isnan<double>(c));
+ VERIFY(std::tr1::isnan<long double>(d));
+ VERIFY(std::tr1::isnan<long double>(e));
+
+ return;
+}
+
+int
+main()
+{
+ test01();
+ return 0;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/23_sph_neumann/check_value.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/23_sph_neumann/check_value.cc
new file mode 100644
index 00000000000..e399323f1a7
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/23_sph_neumann/check_value.cc
@@ -0,0 +1,462 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// sph_neumann
+
+
+// Compare against values generated by the GNU Scientific Library.
+// The GSL can be found on the web: http://www.gnu.org/software/gsl/
+
+#include <tr1/cmath>
+#if defined(__TEST_DEBUG)
+#include <iostream>
+#define VERIFY(A) \
+if (!(A)) \
+ { \
+ std::cout << "line " << __LINE__ \
+ << " max_abs_frac = " << max_abs_frac \
+ << std::endl; \
+ }
+#else
+#include <testsuite_hooks.h>
+#endif
+#include "../testcase.h"
+
+
+// Test data for n=0.
+testcase_sph_neumann<double> data001[] = {
+ { -0.056732437092645263, 0, 5.0000000000000000 },
+ { 0.083907152907645249, 0, 10.000000000000000 },
+ { 0.050645860857254754, 0, 15.000000000000000 },
+ { -0.020404103090669597, 0, 20.000000000000000 },
+ { -0.039648112474538942, 0, 25.000000000000000 },
+ { -0.0051417149962528020, 0, 30.000000000000000 },
+ { 0.025819777288328762, 0, 35.000000000000000 },
+ { 0.016673451541306544, 0, 40.000000000000000 },
+ { -0.011673821973727327, 0, 45.000000000000000 },
+ { -0.019299320569842265, 0, 50.000000000000000 },
+ { -0.00040230465930828606, 0, 55.000000000000000 },
+ { 0.015873549673585938, 0, 60.000000000000000 },
+ { 0.0086531361728949541, 0, 65.000000000000000 },
+ { -0.0090474171869471404, 0, 70.000000000000000 },
+ { -0.012290016929663325, 0, 75.000000000000000 },
+ { 0.0013798405479880946, 0, 80.000000000000000 },
+ { 0.011580901686988727, 0, 85.000000000000000 },
+ { 0.0049785957347685574, 0, 90.000000000000000 },
+ { -0.0076860374841559963, 0, 95.000000000000000 },
+ { -0.0086231887228768386, 0, 100.00000000000000 },
+};
+
+// Test function for n=0.
+template <typename Tp>
+void test001()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data001)
+ / sizeof(testcase_sph_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_neumann(Tp(data001[i].n), Tp(data001[i].x));
+ const Tp f0 = data001[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000028e-11));
+}
+
+// Test data for n=1.
+testcase_sph_neumann<double> data002[] = {
+ { 0.18043836751409864, 1, 5.0000000000000000 },
+ { 0.062792826379701516, 1, 10.000000000000000 },
+ { -0.039976131953324147, 1, 15.000000000000000 },
+ { -0.046667467690914864, 1, 20.000000000000000 },
+ { 0.0037081455049293634, 1, 25.000000000000000 },
+ { 0.032762996969886965, 1, 30.000000000000000 },
+ { 0.012971498479556564, 1, 35.000000000000000 },
+ { -0.018210992723451058, 1, 40.000000000000000 },
+ { -0.019168385477952129, 1, 45.000000000000000 },
+ { 0.0048615106626817301, 1, 50.000000000000000 },
+ { 0.018170052158169303, 1, 55.000000000000000 },
+ { 0.0053447361795967109, 1, 60.000000000000000 },
+ { -0.012587316051033977, 1, 65.000000000000000 },
+ { -0.011184829982069090, 1, 70.000000000000000 },
+ { 0.0050065549130635621, 1, 75.000000000000000 },
+ { 0.012440856180892041, 1, 80.000000000000000 },
+ { 0.0022077237839479508, 1, 85.000000000000000 },
+ { -0.0098779785318421041, 1, 90.000000000000000 },
+ { -0.0072731342338976518, 1, 95.000000000000000 },
+ { 0.0049774245238688201, 1, 100.00000000000000 },
+};
+
+// Test function for n=1.
+template <typename Tp>
+void test002()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data002)
+ / sizeof(testcase_sph_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_neumann(Tp(data002[i].n), Tp(data002[i].x));
+ const Tp f0 = data002[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000014e-11));
+}
+
+// Test data for n=2.
+testcase_sph_neumann<double> data003[] = {
+ { 0.16499545760110443, 2, 5.0000000000000000 },
+ { -0.065069304993734797, 2, 10.000000000000000 },
+ { -0.058641087247919589, 2, 15.000000000000000 },
+ { 0.013403982937032370, 2, 20.000000000000000 },
+ { 0.040093089935130465, 2, 25.000000000000000 },
+ { 0.0084180146932414986, 2, 30.000000000000000 },
+ { -0.024707934561509628, 2, 35.000000000000000 },
+ { -0.018039275995565374, 2, 40.000000000000000 },
+ { 0.010395929608530519, 2, 45.000000000000000 },
+ { 0.019591011209603170, 2, 50.000000000000000 },
+ { 0.0013933984133902479, 2, 55.000000000000000 },
+ { -0.015606312864606103, 2, 60.000000000000000 },
+ { -0.0092340892214042153, 2, 65.000000000000000 },
+ { 0.0085680673305727519, 2, 70.000000000000000 },
+ { 0.012490279126185866, 2, 75.000000000000000 },
+ { -0.00091330844120464307, 2, 80.000000000000000 },
+ { -0.011502982024025860, 2, 85.000000000000000 },
+ { -0.0053078616858299602, 2, 90.000000000000000 },
+ { 0.0074563595609802805, 2, 95.000000000000000 },
+ { 0.0087725114585929034, 2, 100.00000000000000 },
+};
+
+// Test function for n=2.
+template <typename Tp>
+void test003()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data003)
+ / sizeof(testcase_sph_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_neumann(Tp(data003[i].n), Tp(data003[i].x));
+ const Tp f0 = data003[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000028e-11));
+}
+
+// Test data for n=5.
+testcase_sph_neumann<double> data004[] = {
+ { -0.32046504674973919, 5, 5.0000000000000000 },
+ { 0.093833541678691818, 5, 10.000000000000000 },
+ { 0.020475698281859061, 5, 15.000000000000000 },
+ { -0.048172347757372780, 5, 20.000000000000000 },
+ { -0.018309489232548347, 5, 25.000000000000000 },
+ { 0.026639390496569996, 5, 30.000000000000000 },
+ { 0.022006038985576210, 5, 35.000000000000000 },
+ { -0.011268975348057965, 5, 40.000000000000000 },
+ { -0.021770388372274862, 5, 45.000000000000000 },
+ { -0.00069711319645853712, 5, 50.000000000000000 },
+ { 0.017439589450220897, 5, 55.000000000000000 },
+ { 0.0088699170919343089, 5, 60.000000000000000 },
+ { -0.010421334444951861, 5, 65.000000000000000 },
+ { -0.012746769858008551, 5, 70.000000000000000 },
+ { 0.0026282888028967737, 5, 75.000000000000000 },
+ { 0.012477658581324189, 5, 80.000000000000000 },
+ { 0.0040771816818182642, 5, 85.000000000000000 },
+ { -0.0089777759570579801, 5, 90.000000000000000 },
+ { -0.0083184557896676149, 5, 95.000000000000000 },
+ { 0.0037206784862748965, 5, 100.00000000000000 },
+};
+
+// Test function for n=5.
+template <typename Tp>
+void test004()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data004)
+ / sizeof(testcase_sph_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_neumann(Tp(data004[i].n), Tp(data004[i].x));
+ const Tp f0 = data004[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000028e-11));
+}
+
+// Test data for n=10.
+testcase_sph_neumann<double> data005[] = {
+ { -26.656114405718704, 10, 5.0000000000000000 },
+ { -0.17245367208805784, 10, 10.000000000000000 },
+ { 0.078461689849642580, 10, 15.000000000000000 },
+ { -0.036843410496289961, 10, 20.000000000000000 },
+ { -0.021158339301097472, 10, 25.000000000000000 },
+ { 0.031219591064754935, 10, 30.000000000000000 },
+ { 0.012840593422414804, 10, 35.000000000000000 },
+ { -0.021803068636888072, 10, 40.000000000000000 },
+ { -0.014071636804469047, 10, 45.000000000000000 },
+ { 0.013524687511158756, 10, 50.000000000000000 },
+ { 0.015684932653180592, 10, 55.000000000000000 },
+ { -0.0056356895567262122, 10, 60.000000000000000 },
+ { -0.015364490270315362, 10, 65.000000000000000 },
+ { -0.0014525575672261291, 10, 70.000000000000000 },
+ { 0.012648951699549433, 10, 75.000000000000000 },
+ { 0.0068571608061120358, 10, 80.000000000000000 },
+ { -0.0080151152941401460, 10, 85.000000000000000 },
+ { -0.0098139742219019131, 10, 90.000000000000000 },
+ { 0.0025002854072314951, 10, 95.000000000000000 },
+ { 0.010025777373636153, 10, 100.00000000000000 },
+};
+
+// Test function for n=10.
+template <typename Tp>
+void test005()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data005)
+ / sizeof(testcase_sph_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_neumann(Tp(data005[i].n), Tp(data005[i].x));
+ const Tp f0 = data005[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(5.0000000000000028e-11));
+}
+
+// Test data for n=20.
+testcase_sph_neumann<double> data006[] = {
+ { -926795140.30575454, 20, 5.0000000000000000 },
+ { -1211.2106053526034, 20, 10.000000000000000 },
+ { -1.5559965765652188, 20, 15.000000000000000 },
+ { -0.093401132250914426, 20, 20.000000000000000 },
+ { 0.044031985675276435, 20, 25.000000000000000 },
+ { -0.036078033606613907, 20, 30.000000000000000 },
+ { 0.029828405631319641, 20, 35.000000000000000 },
+ { -0.0048414810986760785, 20, 40.000000000000000 },
+ { -0.020504694681516944, 20, 45.000000000000000 },
+ { 0.013759531302541211, 20, 50.000000000000000 },
+ { 0.012783038861734196, 20, 55.000000000000000 },
+ { -0.013117009421906418, 20, 60.000000000000000 },
+ { -0.010338106075674407, 20, 65.000000000000000 },
+ { 0.010538610814111246, 20, 70.000000000000000 },
+ { 0.010200029094273743, 20, 75.000000000000000 },
+ { -0.0073123450945617122, 20, 80.000000000000000 },
+ { -0.010581510354950906, 20, 85.000000000000000 },
+ { 0.0036866374015298714, 20, 90.000000000000000 },
+ { 0.010498384318338270, 20, 95.000000000000000 },
+ { 5.6317293788333982e-05, 20, 100.00000000000000 },
+};
+
+// Test function for n=20.
+template <typename Tp>
+void test006()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data006)
+ / sizeof(testcase_sph_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_neumann(Tp(data006[i].n), Tp(data006[i].x));
+ const Tp f0 = data006[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(1.0000000000000007e-09));
+}
+
+// Test data for n=50.
+testcase_sph_neumann<double> data007[] = {
+ { -6.9641091882698388e+42, 50, 5.0000000000000000 },
+ { -4.5282272723512023e+27, 50, 10.000000000000000 },
+ { -9.0004902645887027e+18, 50, 15.000000000000000 },
+ { -9542541667002.5098, 50, 20.000000000000000 },
+ { -363518140.71026677, 50, 25.000000000000000 },
+ { -152551.57233157745, 50, 30.000000000000000 },
+ { -386.26599186208625, 50, 35.000000000000000 },
+ { -4.3290507947291035, 50, 40.000000000000000 },
+ { -0.19968460851503764, 50, 45.000000000000000 },
+ { -0.041900001504607758, 50, 50.000000000000000 },
+ { 0.010696040672421900, 50, 55.000000000000000 },
+ { 0.0078198768555268507, 50, 60.000000000000000 },
+ { -0.010088474938191242, 50, 65.000000000000000 },
+ { 0.0062423671279824801, 50, 70.000000000000000 },
+ { 0.0011284242794941733, 50, 75.000000000000000 },
+ { -0.0093934266037485562, 50, 80.000000000000000 },
+ { 0.013108079602843424, 50, 85.000000000000000 },
+ { -0.0075396607225722626, 50, 90.000000000000000 },
+ { -0.0042605703552836558, 50, 95.000000000000000 },
+ { 0.010747822973682470, 50, 100.00000000000000 },
+};
+
+// Test function for n=50.
+template <typename Tp>
+void test007()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data007)
+ / sizeof(testcase_sph_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_neumann(Tp(data007[i].n), Tp(data007[i].x));
+ const Tp f0 = data007[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000014e-11));
+}
+
+// Test data for n=100.
+testcase_sph_neumann<double> data008[] = {
+ { -1.7997139826259744e+116, 100, 5.0000000000000000 },
+ { -8.5732263093296254e+85, 100, 10.000000000000000 },
+ { -1.9270658593711675e+68, 100, 15.000000000000000 },
+ { -7.2208893582952363e+55, 100, 20.000000000000000 },
+ { -2.0868752613007946e+46, 100, 25.000000000000000 },
+ { -4.2496124023612646e+38, 100, 30.000000000000000 },
+ { -1.7042898348910271e+32, 100, 35.000000000000000 },
+ { -6.3021565260724554e+26, 100, 40.000000000000000 },
+ { -1.3199917400494369e+22, 100, 45.000000000000000 },
+ { -1.1256928913265985e+18, 100, 50.000000000000000 },
+ { -309801083340341.00, 100, 55.000000000000000 },
+ { -232585620046.64737, 100, 60.000000000000000 },
+ { -421135935.93756086, 100, 65.000000000000000 },
+ { -1680637.4531202619, 100, 70.000000000000000 },
+ { -13868.302591128842, 100, 75.000000000000000 },
+ { -227.24385709173322, 100, 80.000000000000000 },
+ { -7.2807038787139486, 100, 85.000000000000000 },
+ { -0.46648154448250878, 100, 90.000000000000000 },
+ { -0.067270772720654542, 100, 95.000000000000000 },
+ { -0.022983850491562267, 100, 100.00000000000000 },
+};
+
+// Test function for n=100.
+template <typename Tp>
+void test008()
+{
+ const Tp eps = std::numeric_limits<Tp>::epsilon();
+ Tp max_abs_diff = -Tp(1);
+ Tp max_abs_frac = -Tp(1);
+ unsigned int num_datum = sizeof(data008)
+ / sizeof(testcase_sph_neumann<double>);
+ for (unsigned int i = 0; i < num_datum; ++i)
+ {
+ const Tp f = std::tr1::sph_neumann(Tp(data008[i].n), Tp(data008[i].x));
+ const Tp f0 = data008[i].f0;
+ const Tp diff = f - f0;
+ if (std::abs(diff) > max_abs_diff)
+ max_abs_diff = std::abs(diff);
+ if (std::abs(f0) > Tp(10) * eps
+ && std::abs(f) > Tp(10) * eps)
+ {
+ const Tp frac = diff / f0;
+ if (std::abs(frac) > max_abs_frac)
+ max_abs_frac = std::abs(frac);
+ }
+ }
+ VERIFY(max_abs_frac < Tp(2.5000000000000015e-12));
+}
+
+int main(int, char**)
+{
+ test001<double>();
+ test002<double>();
+ test003<double>();
+ test004<double>();
+ test005<double>();
+ test006<double>();
+ test007<double>();
+ test008<double>();
+ return 0;
+}
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/23_sph_neumann/compile.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/23_sph_neumann/compile.cc
new file mode 100644
index 00000000000..7a26872203e
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/23_sph_neumann/compile.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.23 sph_neumann
+
+#include <tr1/cmath>
+
+void
+test01()
+{
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+ unsigned int n = 0;
+
+ std::tr1::sph_neumann(n, xf);
+ std::tr1::sph_neumannf(n, xf);
+ std::tr1::sph_neumann(n, xd);
+ std::tr1::sph_neumann(n, xl);
+ std::tr1::sph_neumannl(n, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/23_sph_neumann/compile_2.cc b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/23_sph_neumann/compile_2.cc
new file mode 100644
index 00000000000..f9428c256e3
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/23_sph_neumann/compile_2.cc
@@ -0,0 +1,43 @@
+// { dg-do compile }
+
+// 2006-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2006-2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// 5.2.1.23 sph_neumann
+
+#include <tr1/math.h>
+
+void
+test01()
+{
+ float xf = 0.5F;
+ double xd = 0.5;
+ long double xl = 0.5L;
+ unsigned int n = 0;
+
+ sph_neumann(n, xf);
+ sph_neumannf(n, xf);
+ sph_neumann(n, xd);
+ sph_neumann(n, xl);
+ sph_neumannl(n, xl);
+
+ return;
+}
+
diff --git a/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/testcase.h b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/testcase.h
new file mode 100644
index 00000000000..8c5aa829946
--- /dev/null
+++ b/libstdc++-v3/testsuite/tr1/5_numerical_facilities/special_functions/testcase.h
@@ -0,0 +1,259 @@
+// 2007-02-04 Edward Smith-Rowland <3dw4rd@verizon.net>
+//
+// Copyright (C) 2007 Free Software Foundation, Inc.
+//
+// This file is part of the GNU ISO C++ Library. This library is free
+// software; you can redistribute it and/or modify it under the
+// terms of the GNU General Public License as published by the
+// Free Software Foundation; either version 2, or (at your option)
+// any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this library; see the file COPYING. If not, write to the Free
+// Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307,
+// USA.
+
+// testcase.h
+
+//
+// These are little PODs for special function inputs and
+// expexted results for the testsuite.
+//
+
+// 5.2.1.1 Associated Laguerre polynomials.
+template <typename _Tp>
+struct testcase_assoc_laguerre
+{
+ _Tp f0;
+ unsigned int n;
+ unsigned int m;
+ _Tp x;
+ _Tp f;
+};
+
+// 5.2.1.2 Associated Legendre functions.
+template <typename _Tp>
+struct testcase_assoc_legendre
+{
+ _Tp f0;
+ unsigned int l;
+ unsigned int m;
+ _Tp x;
+ _Tp f;
+};
+
+// 5.2.1.3 Beta function.
+template <typename _Tp>
+struct testcase_beta
+{
+ _Tp f0;
+ _Tp x;
+ _Tp y;
+ _Tp f;
+};
+
+// 5.2.1.4 Complete elliptic integrals of the first kind.
+template <typename _Tp>
+struct testcase_comp_ellint_1
+{
+ _Tp f0;
+ _Tp k;
+ _Tp f;
+};
+
+// 5.2.1.5 Complete elliptic integrals of the second kind.
+template <typename _Tp>
+struct testcase_comp_ellint_2
+{
+ _Tp f0;
+ _Tp k;
+ _Tp f;
+};
+
+// 5.2.1.6 Complete elliptic integrals of the third kind.
+template <typename _Tp>
+struct testcase_comp_ellint_3
+{
+ _Tp f0;
+ _Tp k;
+ _Tp nu;
+ _Tp f;
+};
+
+// 5.2.1.7 Confluent hypergeometric functions.
+template <typename _Tp>
+struct testcase_conf_hyperg
+{
+ _Tp f0;
+ _Tp a;
+ _Tp c;
+ _Tp x;
+ _Tp f;
+};
+
+// 5.2.1.8 Regular modified cylindrical Bessel functions.
+template <typename _Tp>
+struct testcase_cyl_bessel_i
+{
+ _Tp f0;
+ _Tp nu;
+ _Tp x;
+ _Tp f;
+};
+
+// 5.2.1.9 Cylindrical Bessel functions (of the first kind).
+template <typename _Tp>
+struct testcase_cyl_bessel_j
+{
+ _Tp f0;
+ _Tp nu;
+ _Tp x;
+ _Tp f;
+};
+
+// 5.2.1.10 Irregular modified cylindrical Bessel functions.
+template <typename _Tp>
+struct testcase_cyl_bessel_k
+{
+ _Tp f0;
+ _Tp nu;
+ _Tp x;
+ _Tp f;
+};
+
+// 5.2.1.11 Cylindrical Neumann functions.
+template <typename _Tp>
+struct testcase_cyl_neumann
+{
+ _Tp f0;
+ _Tp nu;
+ _Tp x;
+ _Tp f;
+};
+
+// 5.2.1.12 Elliptic integrals of the first kind.
+template <typename _Tp>
+struct testcase_ellint_1
+{
+ _Tp f0;
+ _Tp k;
+ _Tp phi;
+ _Tp f;
+};
+
+// 5.2.1.13 Elliptic integrals of the second kind.
+template <typename _Tp>
+struct testcase_ellint_2
+{
+ _Tp f0;
+ _Tp k;
+ _Tp phi;
+ _Tp f;
+};
+
+// 5.2.1.14 Elliptic integrals of the third kind.
+template <typename _Tp>
+struct testcase_ellint_3
+{
+ _Tp f0;
+ _Tp k;
+ _Tp nu;
+ _Tp phi;
+ _Tp f;
+};
+
+// 5.2.1.15 Exponential integral.
+template <typename _Tp>
+struct testcase_expint
+{
+ _Tp f0;
+ _Tp x;
+ _Tp f;
+};
+
+// 5.2.1.16 Hermite polynomials
+template <typename _Tp>
+struct testcase_hermite
+{
+ _Tp f0;
+ unsigned int n;
+ _Tp x;
+ _Tp f;
+};
+
+// 5.2.1.17 Hypergeometric functions.
+template <typename _Tp>
+struct testcase_hyperg
+{
+ _Tp f0;
+ _Tp a;
+ _Tp b;
+ _Tp c;
+ _Tp x;
+ _Tp f;
+};
+
+// 5.2.1.18 Laguerre polynomials.
+template <typename _Tp>
+struct testcase_laguerre
+{
+ _Tp f0;
+ unsigned int n;
+ _Tp x;
+ _Tp f;
+};
+
+// 5.2.1.19 Legendre polynomials.
+template <typename _Tp>
+struct testcase_legendre
+{
+ _Tp f0;
+ unsigned int l;
+ _Tp x;
+ _Tp f;
+};
+
+// 5.2.1.20 Riemann zeta function.
+template <typename _Tp>
+struct testcase_riemann_zeta
+{
+ _Tp f0;
+ _Tp x;
+ _Tp f;
+};
+
+// 5.2.1.21 Spherical Bessel functions.
+template <typename _Tp>
+struct testcase_sph_bessel
+{
+ _Tp f0;
+ unsigned int n;
+ _Tp x;
+ _Tp f;
+};
+
+// 5.2.1.22 Spherical Legendre functions.
+template <typename _Tp>
+struct testcase_sph_legendre
+{
+ _Tp f0;
+ unsigned int l;
+ unsigned int m;
+ _Tp theta;
+ _Tp f;
+};
+
+// 5.2.1.23 Spherical Neumann functions.
+template <typename _Tp>
+struct testcase_sph_neumann
+{
+ _Tp f0;
+ unsigned int n;
+ _Tp x;
+ _Tp f;
+};