Subversion Repositories Kolibri OS

Rev

Go to most recent revision | Blame | Last modification | View Log | Download | RSS feed

  1. /*                                                      sinhl.c
  2.  *
  3.  *      Hyperbolic sine, long double precision
  4.  *
  5.  *
  6.  *
  7.  * SYNOPSIS:
  8.  *
  9.  * long double x, y, sinhl();
  10.  *
  11.  * y = sinhl( x );
  12.  *
  13.  *
  14.  *
  15.  * DESCRIPTION:
  16.  *
  17.  * Returns hyperbolic sine of argument in the range MINLOGL to
  18.  * MAXLOGL.
  19.  *
  20.  * The range is partitioned into two segments.  If |x| <= 1, a
  21.  * rational function of the form x + x**3 P(x)/Q(x) is employed.
  22.  * Otherwise the calculation is sinh(x) = ( exp(x) - exp(-x) )/2.
  23.  *
  24.  *
  25.  *
  26.  * ACCURACY:
  27.  *
  28.  *                      Relative error:
  29.  * arithmetic   domain     # trials      peak         rms
  30.  *    IEEE       -2,2       10000       1.5e-19     3.9e-20
  31.  *    IEEE     +-10000      30000       1.1e-19     2.8e-20
  32.  *
  33.  */
  34. /*
  35. Cephes Math Library Release 2.7:  January, 1998
  36. Copyright 1984, 1991, 1998 by Stephen L. Moshier
  37. */
  38.  
  39. /*
  40. Modified for mingw
  41. 2002-07-22 Danny Smith <dannysmith@users.sourceforge.net>
  42. */
  43.  
  44. #ifdef __MINGW32__
  45. #include "cephes_mconf.h"
  46. #else
  47. #include "mconf.h"
  48. #endif
  49.  
  50. #ifndef _SET_ERRNO
  51. #define _SET_ERRNO(x)
  52. #endif
  53.  
  54. #ifdef UNK
  55. static long double P[] = {
  56.  1.7550769032975377032681E-6L,
  57.  4.1680702175874268714539E-4L,
  58.  3.0993532520425419002409E-2L,
  59.  9.9999999999999999998002E-1L,
  60. };
  61. static long double Q[] = {
  62.  1.7453965448620151484660E-8L,
  63. -5.9116673682651952419571E-6L,
  64.  1.0599252315677389339530E-3L,
  65. -1.1403880487744749056675E-1L,
  66.  6.0000000000000000000200E0L,
  67. };
  68. #endif
  69.  
  70. #ifdef IBMPC
  71. static const unsigned short P[] = {
  72. 0xec6a,0xd942,0xfbb3,0xeb8f,0x3feb, XPD
  73. 0x365e,0xb30a,0xe437,0xda86,0x3ff3, XPD
  74. 0x8890,0x01f6,0x2612,0xfde6,0x3ff9, XPD
  75. 0x0000,0x0000,0x0000,0x8000,0x3fff, XPD
  76. };
  77. static const unsigned short Q[] = {
  78. 0x4edd,0x4c21,0xad09,0x95ed,0x3fe5, XPD
  79. 0x4376,0x9b70,0xd605,0xc65c,0xbfed, XPD
  80. 0xc8ad,0x5d21,0x3069,0x8aed,0x3ff5, XPD
  81. 0x9c32,0x6374,0x2d4b,0xe98d,0xbffb, XPD
  82. 0x0000,0x0000,0x0000,0xc000,0x4001, XPD
  83. };
  84. #endif
  85.  
  86. #ifdef MIEEE
  87. static long P[] = {
  88. 0x3feb0000,0xeb8ffbb3,0xd942ec6a,
  89. 0x3ff30000,0xda86e437,0xb30a365e,
  90. 0x3ff90000,0xfde62612,0x01f68890,
  91. 0x3fff0000,0x80000000,0x00000000,
  92. };
  93. static long Q[] = {
  94. 0x3fe50000,0x95edad09,0x4c214edd,
  95. 0xbfed0000,0xc65cd605,0x9b704376,
  96. 0x3ff50000,0x8aed3069,0x5d21c8ad,
  97. 0xbffb0000,0xe98d2d4b,0x63749c32,
  98. 0x40010000,0xc0000000,0x00000000,
  99. };
  100. #endif
  101.  
  102. #ifndef __MINGW32__
  103. extern long double MAXNUML, MAXLOGL, MINLOGL, LOGE2L;
  104. #ifdef ANSIPROT
  105. extern long double fabsl ( long double );
  106. extern long double expl ( long double );
  107. extern long double polevll ( long double, void *, int );
  108. extern long double p1evll ( long double, void *, int );
  109. #else
  110. long double fabsl(), expl(), polevll(), p1evll();
  111. #endif
  112. #ifdef INFINITIES
  113. extern long double INFINITYL;
  114. #endif
  115. #ifdef NANS
  116. extern long double NANL;
  117. #endif
  118. #endif /* __MINGW32__ */
  119.  
  120. long double sinhl(x)
  121. long double x;
  122. {
  123. long double a;
  124.  
  125. #ifdef MINUSZERO
  126. if( x == 0.0 )
  127.         return(x);
  128. #endif
  129. #ifdef NANS
  130. if (isnanl(x))
  131.         {
  132.         _SET_ERRNO(EDOM);
  133.         }
  134. #endif
  135. a = fabsl(x);
  136. if( (x > (MAXLOGL + LOGE2L)) || (x > -(MINLOGL-LOGE2L) ) )
  137.         {
  138.         mtherr( "sinhl", DOMAIN );
  139.         _SET_ERRNO(ERANGE);
  140. #ifdef INFINITIES
  141.         if( x > 0.0L )
  142.                 return( INFINITYL );
  143.         else
  144.                 return( -INFINITYL );
  145. #else
  146.         if( x > 0.0L )
  147.                 return( MAXNUML );
  148.         else
  149.                 return( -MAXNUML );
  150. #endif
  151.         }
  152. if( a > 1.0L )
  153.         {
  154.         if( a >= (MAXLOGL - LOGE2L) )
  155.                 {
  156.                 a = expl(0.5L*a);
  157.                 a = (0.5L * a) * a;
  158.                 if( x < 0.0L )
  159.                         a = -a;
  160.                 return(a);
  161.                 }
  162.         a = expl(a);
  163.         a = 0.5L*a - (0.5L/a);
  164.         if( x < 0.0L )
  165.                 a = -a;
  166.         return(a);
  167.         }
  168.  
  169. a *= a;
  170. return( x + x * a * (polevll(a,P,3)/polevll(a,Q,4)) );
  171. }
  172.