mirror of git://gcc.gnu.org/git/gcc.git
				
				
				
			
		
			
				
	
	
		
			417 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			417 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			C++
		
	
	
	
// Copyright (C) 2015 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 COPYING3.  If not see
 | 
						|
// <http://www.gnu.org/licenses/>.
 | 
						|
 | 
						|
//  testcase.h
 | 
						|
 | 
						|
//
 | 
						|
//  These are little PODs for special function inputs and
 | 
						|
//  expexted results for the testsuite.
 | 
						|
//
 | 
						|
 | 
						|
#ifndef _GLIBCXX_SPECFUN_TESTCASE_H
 | 
						|
#define _GLIBCXX_SPECFUN_TESTCASE_H
 | 
						|
 | 
						|
//  Associated Laguerre polynomials.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_assoc_laguerre
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    unsigned int n;
 | 
						|
    unsigned int m;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Associated Legendre functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_assoc_legendre
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    unsigned int l;
 | 
						|
    unsigned int m;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Beta function.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_beta
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp x;
 | 
						|
    _Tp y;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Complete elliptic integrals of the first kind.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_comp_ellint_1
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp k;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Complete elliptic integrals of the second kind.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_comp_ellint_2
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp k;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Complete elliptic integrals of the third kind.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_comp_ellint_3
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp k;
 | 
						|
    _Tp nu;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Confluent hypergeometric functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_conf_hyperg
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp a;
 | 
						|
    _Tp c;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Generic cylindrical Bessel functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_cyl_bessel
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp nu;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Regular modified cylindrical Bessel functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_cyl_bessel_i
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp nu;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Cylindrical Bessel functions (of the first kind).
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_cyl_bessel_j
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp nu;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Irregular modified cylindrical Bessel functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_cyl_bessel_k
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp nu;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Cylindrical Neumann functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_cyl_neumann
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp nu;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Elliptic integrals of the first kind.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_ellint_1
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp k;
 | 
						|
    _Tp phi;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Elliptic integrals of the second kind.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_ellint_2
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp k;
 | 
						|
    _Tp phi;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Elliptic integrals of the third kind.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_ellint_3
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp k;
 | 
						|
    _Tp nu;
 | 
						|
    _Tp phi;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Exponential integral.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_expint
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Hermite polynomials
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_hermite
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    unsigned int n;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Hypergeometric functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_hyperg
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp a;
 | 
						|
    _Tp b;
 | 
						|
    _Tp c;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Laguerre polynomials.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_laguerre
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    unsigned int n;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Legendre polynomials.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_legendre
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    unsigned int l;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Riemann zeta function.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_riemann_zeta
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp s;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Hurwitz zeta function.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_hurwitz_zeta
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp s;
 | 
						|
    _Tp a;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Spherical Bessel functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_sph_bessel
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    unsigned int n;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Regular modified spherical Bessel functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_sph_bessel_i
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    unsigned int n;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Irregular modified spherical Bessel functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_sph_bessel_k
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    unsigned int n;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Spherical Legendre functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_sph_legendre
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    unsigned int l;
 | 
						|
    unsigned int m;
 | 
						|
    _Tp theta;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Spherical Neumann functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_sph_neumann
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    unsigned int n;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Airy Ai functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_airy_ai
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Airy Bi functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_airy_bi
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Upper incomplete gamma functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_gamma_u
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp n;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Lower incomplete gamma functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_gamma_l
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp n;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Dilogarithm functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_dilog
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
//  Digamma functions.
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_gamma
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp x;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_comp_ellint_rf
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp x;
 | 
						|
    _Tp y;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_ellint_rf
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp x;
 | 
						|
    _Tp y;
 | 
						|
    _Tp z;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_ellint_rj
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp x;
 | 
						|
    _Tp y;
 | 
						|
    _Tp z;
 | 
						|
    _Tp p;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_ellint_rd
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp x;
 | 
						|
    _Tp y;
 | 
						|
    _Tp z;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_comp_ellint_rg
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp x;
 | 
						|
    _Tp y;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
template<typename _Tp>
 | 
						|
  struct testcase_ellint_rg
 | 
						|
  {
 | 
						|
    _Tp f0;
 | 
						|
    _Tp x;
 | 
						|
    _Tp y;
 | 
						|
    _Tp z;
 | 
						|
    _Tp f;
 | 
						|
  };
 | 
						|
 | 
						|
#endif // _GLIBCXX_SPECFUN_TESTCASE_H
 |