2 Copyright © 1995-2003, The AROS Development Team. All rights reserved.
6 #include "mathtrans_intern.h"
10 Calculate the sine of a given FFP number in radians
13 Motorola fast floating point number
17 negative : result is negative
29 Algorithm for Calculation of sin(y):
31 z = floor ( |y| / pi );
32 y_1 = |y| - z * pi; => 0 <= y_1 < pi
34 if (y_1 > pi/2 ) then y_1 = pi - y_1;
38 Res = y - y^3/3! + y^5/5! - y^7/7! + y^9/9! - y^11/11! =
39 = y(1+y^2(-1/3!+y^2(1/5!+y^2(-1/7!+y^2(1/9!-1/11!y^2)))));
44 if (z was an odd number)
52 AROS_LH1(float, SPSin
,
53 AROS_LHA(float, fnum1
, D0
),
54 struct Library
*, MathTransBase
, 6, MathTrans
59 LONG z
,Res
,ysquared
,yabs
,tmp
;
60 yabs
= fnum1
& (FFPMantisse_Mask
+ FFPExponent_Mask
);
62 if ((LONG
)FFP_Pinfty
== yabs
)
64 SetSR(Overflow_Bit
, Zero_Bit
| Negative_Bit
| Overflow_Bit
);
68 z
= SPFloor(SPDiv(pi
, yabs
));
70 tmp
|= FFPSign_Mask
; /* tmp = -tmp; */
71 yabs
= SPAdd(yabs
, tmp
);
73 if ( (char)yabs
> (char)pio2
&& (yabs
& FFPMantisse_Mask
) > (pio2
& FFPMantisse_Mask
) )
76 yabs
= SPAdd(pi
, yabs
);
78 ysquared
= SPMul(yabs
,yabs
);
89 SPMul(ysquared
, sinf6
)))))))))));
91 if ((char)fnum1
< 0 ) Res
^= FFPSign_Mask
;
93 if (TRUE
== intern_SPisodd(z
)) Res
^= FFPSign_Mask
;
97 SetSR(Zero_Bit
, Zero_Bit
| Negative_Bit
| Overflow_Bit
);
103 SetSR(Negative_Bit
, Zero_Bit
| Negative_Bit
| Overflow_Bit
);