2 Copyright © 1995-2003, The AROS Development Team. All rights reserved.
6 #include "mathtrans_intern.h"
8 /*****************************************************************************
12 AROS_LH1(float, SPSinh
,
15 AROS_LHA(float, fnum1
, D0
),
18 struct Library
*, MathTransBase
, 10, MathTrans
)
21 Calculate the hyperbolic sine of the ffp number
26 Motorola fast floating point number
30 negative : result is negative
31 overflow : result is too big for ffp format
36 sinh(x) = (1/2)*( e^x- e^(-x) )
38 sinh( |x| >= 44 ) = infinity;
39 sinh( |x| >= 9 ) = (1/2) * (e^x);
41 *****************************************************************************/
48 /* sinh(-x) = -sinh(x) */
49 Res
= SPExp(fnum1
& (FFPMantisse_Mask
+ FFPExponent_Mask
) );
51 if ( FFP_Pinfty
== Res
)
53 SetSR(Overflow_Bit
, Zero_Bit
| Negative_Bit
| Overflow_Bit
);
57 tmp
= (fnum1
& FFPExponent_Mask
) - 0x41;
59 if ( tmp
<= 2 || (tmp
== 3 && (fnum1
& FFPMantisse_Mask
) < 0x90000000) )
61 Res
= SPAdd(Res
, ((ULONG
)SPDiv(Res
, one
) | FFPSign_Mask
));
66 /* should be (char(Res))-- , but gcc on Linux screws up the result! */
68 tmp
= Res
& 0xFFFFFF00;
72 if ( 0 == Res
|| (char)Res
< 0 )
74 SetSR(Zero_Bit
, Zero_Bit
| Negative_Bit
| Overflow_Bit
);
78 /* if the argument was negative, the result is also negative */
81 SetSR(Negative_Bit
, Zero_Bit
| Negative_Bit
| Overflow_Bit
);
82 return (Res
| FFPSign_Mask
);