jbarnette-johnson 1.0.0.200806240111 → 1.0.0.200807291507
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/MANIFEST +1 -0
- data/Rakefile +3 -10
- data/bin/johnson +2 -1
- data/ext/spidermonkey/context.c +3 -4
- data/ext/spidermonkey/context.h +1 -1
- data/ext/spidermonkey/conversions.c +39 -33
- data/ext/spidermonkey/debugger.c +5 -5
- data/ext/spidermonkey/immutable_node.c.erb +11 -11
- data/ext/spidermonkey/jroot.h +4 -4
- data/ext/spidermonkey/js_land_proxy.c +9 -8
- data/ext/spidermonkey/ruby_land_proxy.c +5 -4
- data/ext/spidermonkey/runtime.c +1 -1
- data/johnson.gemspec +36 -0
- data/lib/hoe.rb +0 -7
- data/lib/johnson/cli/options.rb +10 -4
- data/lib/johnson/spidermonkey/runtime.rb +2 -2
- data/lib/johnson/version.rb +4 -2
- data/lib/johnson.rb +1 -0
- data/test/johnson/runtime_test.rb +11 -0
- data/test/johnson/spidermonkey/ruby_land_proxy_test.rb +6 -0
- data/vendor/spidermonkey/.cvsignore +9 -0
- data/vendor/spidermonkey/Makefile.in +462 -0
- data/vendor/spidermonkey/Makefile.ref +364 -0
- data/vendor/spidermonkey/README.html +820 -0
- data/vendor/spidermonkey/SpiderMonkey.rsp +12 -0
- data/vendor/spidermonkey/Y.js +19 -0
- data/vendor/spidermonkey/build.mk +43 -0
- data/vendor/spidermonkey/config/AIX4.1.mk +65 -0
- data/vendor/spidermonkey/config/AIX4.2.mk +64 -0
- data/vendor/spidermonkey/config/AIX4.3.mk +65 -0
- data/vendor/spidermonkey/config/Darwin.mk +83 -0
- data/vendor/spidermonkey/config/Darwin1.3.mk +81 -0
- data/vendor/spidermonkey/config/Darwin1.4.mk +41 -0
- data/vendor/spidermonkey/config/Darwin5.2.mk +81 -0
- data/vendor/spidermonkey/config/Darwin5.3.mk +81 -0
- data/vendor/spidermonkey/config/HP-UXB.10.10.mk +77 -0
- data/vendor/spidermonkey/config/HP-UXB.10.20.mk +77 -0
- data/vendor/spidermonkey/config/HP-UXB.11.00.mk +80 -0
- data/vendor/spidermonkey/config/IRIX.mk +87 -0
- data/vendor/spidermonkey/config/IRIX5.3.mk +44 -0
- data/vendor/spidermonkey/config/IRIX6.1.mk +44 -0
- data/vendor/spidermonkey/config/IRIX6.2.mk +44 -0
- data/vendor/spidermonkey/config/IRIX6.3.mk +44 -0
- data/vendor/spidermonkey/config/IRIX6.5.mk +44 -0
- data/vendor/spidermonkey/config/Linux_All.mk +103 -0
- data/vendor/spidermonkey/config/Mac_OS10.0.mk +82 -0
- data/vendor/spidermonkey/config/OSF1V4.0.mk +72 -0
- data/vendor/spidermonkey/config/OSF1V5.0.mk +69 -0
- data/vendor/spidermonkey/config/SunOS4.1.4.mk +101 -0
- data/vendor/spidermonkey/config/SunOS5.10.mk +50 -0
- data/vendor/spidermonkey/config/SunOS5.3.mk +91 -0
- data/vendor/spidermonkey/config/SunOS5.4.mk +92 -0
- data/vendor/spidermonkey/config/SunOS5.5.1.mk +44 -0
- data/vendor/spidermonkey/config/SunOS5.5.mk +87 -0
- data/vendor/spidermonkey/config/SunOS5.6.mk +89 -0
- data/vendor/spidermonkey/config/SunOS5.7.mk +44 -0
- data/vendor/spidermonkey/config/SunOS5.8.mk +44 -0
- data/vendor/spidermonkey/config/SunOS5.9.mk +44 -0
- data/vendor/spidermonkey/config/WINNT4.0.mk +117 -0
- data/vendor/spidermonkey/config/WINNT5.0.mk +117 -0
- data/vendor/spidermonkey/config/WINNT5.1.mk +117 -0
- data/vendor/spidermonkey/config/WINNT5.2.mk +117 -0
- data/vendor/spidermonkey/config/WINNT6.0.mk +117 -0
- data/vendor/spidermonkey/config/dgux.mk +64 -0
- data/vendor/spidermonkey/config.mk +192 -0
- data/vendor/spidermonkey/editline/Makefile.ref +144 -0
- data/vendor/spidermonkey/editline/README +83 -0
- data/vendor/spidermonkey/editline/editline.3 +175 -0
- data/vendor/spidermonkey/editline/editline.c +1369 -0
- data/vendor/spidermonkey/editline/editline.h +135 -0
- data/vendor/spidermonkey/editline/sysunix.c +182 -0
- data/vendor/spidermonkey/editline/unix.h +82 -0
- data/vendor/spidermonkey/fdlibm/.cvsignore +7 -0
- data/vendor/spidermonkey/fdlibm/Makefile.in +127 -0
- data/vendor/spidermonkey/fdlibm/Makefile.ref +192 -0
- data/vendor/spidermonkey/fdlibm/e_acos.c +147 -0
- data/vendor/spidermonkey/fdlibm/e_acosh.c +105 -0
- data/vendor/spidermonkey/fdlibm/e_asin.c +156 -0
- data/vendor/spidermonkey/fdlibm/e_atan2.c +165 -0
- data/vendor/spidermonkey/fdlibm/e_atanh.c +110 -0
- data/vendor/spidermonkey/fdlibm/e_cosh.c +133 -0
- data/vendor/spidermonkey/fdlibm/e_exp.c +202 -0
- data/vendor/spidermonkey/fdlibm/e_fmod.c +184 -0
- data/vendor/spidermonkey/fdlibm/e_gamma.c +71 -0
- data/vendor/spidermonkey/fdlibm/e_gamma_r.c +70 -0
- data/vendor/spidermonkey/fdlibm/e_hypot.c +173 -0
- data/vendor/spidermonkey/fdlibm/e_j0.c +524 -0
- data/vendor/spidermonkey/fdlibm/e_j1.c +523 -0
- data/vendor/spidermonkey/fdlibm/e_jn.c +315 -0
- data/vendor/spidermonkey/fdlibm/e_lgamma.c +71 -0
- data/vendor/spidermonkey/fdlibm/e_lgamma_r.c +347 -0
- data/vendor/spidermonkey/fdlibm/e_log.c +184 -0
- data/vendor/spidermonkey/fdlibm/e_log10.c +134 -0
- data/vendor/spidermonkey/fdlibm/e_pow.c +386 -0
- data/vendor/spidermonkey/fdlibm/e_rem_pio2.c +222 -0
- data/vendor/spidermonkey/fdlibm/e_remainder.c +120 -0
- data/vendor/spidermonkey/fdlibm/e_scalb.c +89 -0
- data/vendor/spidermonkey/fdlibm/e_sinh.c +122 -0
- data/vendor/spidermonkey/fdlibm/e_sqrt.c +497 -0
- data/vendor/spidermonkey/fdlibm/fdlibm.h +273 -0
- data/vendor/spidermonkey/fdlibm/fdlibm.mak +1453 -0
- data/vendor/spidermonkey/fdlibm/fdlibm.mdp +0 -0
- data/vendor/spidermonkey/fdlibm/k_cos.c +135 -0
- data/vendor/spidermonkey/fdlibm/k_rem_pio2.c +354 -0
- data/vendor/spidermonkey/fdlibm/k_sin.c +114 -0
- data/vendor/spidermonkey/fdlibm/k_standard.c +785 -0
- data/vendor/spidermonkey/fdlibm/k_tan.c +170 -0
- data/vendor/spidermonkey/fdlibm/s_asinh.c +101 -0
- data/vendor/spidermonkey/fdlibm/s_atan.c +175 -0
- data/vendor/spidermonkey/fdlibm/s_cbrt.c +133 -0
- data/vendor/spidermonkey/fdlibm/s_ceil.c +120 -0
- data/vendor/spidermonkey/fdlibm/s_copysign.c +72 -0
- data/vendor/spidermonkey/fdlibm/s_cos.c +118 -0
- data/vendor/spidermonkey/fdlibm/s_erf.c +356 -0
- data/vendor/spidermonkey/fdlibm/s_expm1.c +267 -0
- data/vendor/spidermonkey/fdlibm/s_fabs.c +70 -0
- data/vendor/spidermonkey/fdlibm/s_finite.c +71 -0
- data/vendor/spidermonkey/fdlibm/s_floor.c +121 -0
- data/vendor/spidermonkey/fdlibm/s_frexp.c +99 -0
- data/vendor/spidermonkey/fdlibm/s_ilogb.c +85 -0
- data/vendor/spidermonkey/fdlibm/s_isnan.c +74 -0
- data/vendor/spidermonkey/fdlibm/s_ldexp.c +66 -0
- data/vendor/spidermonkey/fdlibm/s_lib_version.c +73 -0
- data/vendor/spidermonkey/fdlibm/s_log1p.c +211 -0
- data/vendor/spidermonkey/fdlibm/s_logb.c +79 -0
- data/vendor/spidermonkey/fdlibm/s_matherr.c +64 -0
- data/vendor/spidermonkey/fdlibm/s_modf.c +132 -0
- data/vendor/spidermonkey/fdlibm/s_nextafter.c +124 -0
- data/vendor/spidermonkey/fdlibm/s_rint.c +131 -0
- data/vendor/spidermonkey/fdlibm/s_scalbn.c +107 -0
- data/vendor/spidermonkey/fdlibm/s_signgam.c +40 -0
- data/vendor/spidermonkey/fdlibm/s_significand.c +68 -0
- data/vendor/spidermonkey/fdlibm/s_sin.c +118 -0
- data/vendor/spidermonkey/fdlibm/s_tan.c +112 -0
- data/vendor/spidermonkey/fdlibm/s_tanh.c +122 -0
- data/vendor/spidermonkey/fdlibm/w_acos.c +78 -0
- data/vendor/spidermonkey/fdlibm/w_acosh.c +78 -0
- data/vendor/spidermonkey/fdlibm/w_asin.c +80 -0
- data/vendor/spidermonkey/fdlibm/w_atan2.c +79 -0
- data/vendor/spidermonkey/fdlibm/w_atanh.c +81 -0
- data/vendor/spidermonkey/fdlibm/w_cosh.c +77 -0
- data/vendor/spidermonkey/fdlibm/w_exp.c +88 -0
- data/vendor/spidermonkey/fdlibm/w_fmod.c +78 -0
- data/vendor/spidermonkey/fdlibm/w_gamma.c +85 -0
- data/vendor/spidermonkey/fdlibm/w_gamma_r.c +81 -0
- data/vendor/spidermonkey/fdlibm/w_hypot.c +78 -0
- data/vendor/spidermonkey/fdlibm/w_j0.c +105 -0
- data/vendor/spidermonkey/fdlibm/w_j1.c +106 -0
- data/vendor/spidermonkey/fdlibm/w_jn.c +128 -0
- data/vendor/spidermonkey/fdlibm/w_lgamma.c +85 -0
- data/vendor/spidermonkey/fdlibm/w_lgamma_r.c +81 -0
- data/vendor/spidermonkey/fdlibm/w_log.c +78 -0
- data/vendor/spidermonkey/fdlibm/w_log10.c +81 -0
- data/vendor/spidermonkey/fdlibm/w_pow.c +99 -0
- data/vendor/spidermonkey/fdlibm/w_remainder.c +77 -0
- data/vendor/spidermonkey/fdlibm/w_scalb.c +95 -0
- data/vendor/spidermonkey/fdlibm/w_sinh.c +77 -0
- data/vendor/spidermonkey/fdlibm/w_sqrt.c +77 -0
- data/vendor/spidermonkey/javascript-trace.d +73 -0
- data/vendor/spidermonkey/js.c +3951 -0
- data/vendor/spidermonkey/js.mak +4438 -0
- data/vendor/spidermonkey/js.mdp +0 -0
- data/vendor/spidermonkey/js.msg +307 -0
- data/vendor/spidermonkey/js.pkg +2 -0
- data/vendor/spidermonkey/js3240.rc +79 -0
- data/vendor/spidermonkey/jsOS240.def +654 -0
- data/vendor/spidermonkey/jsapi.c +5836 -0
- data/vendor/spidermonkey/jsapi.h +2624 -0
- data/vendor/spidermonkey/jsarena.c +450 -0
- data/vendor/spidermonkey/jsarena.h +318 -0
- data/vendor/spidermonkey/jsarray.c +2988 -0
- data/vendor/spidermonkey/jsarray.h +124 -0
- data/vendor/spidermonkey/jsatom.c +1045 -0
- data/vendor/spidermonkey/jsatom.h +442 -0
- data/vendor/spidermonkey/jsbit.h +253 -0
- data/vendor/spidermonkey/jsbool.c +176 -0
- data/vendor/spidermonkey/jsbool.h +73 -0
- data/vendor/spidermonkey/jsclist.h +139 -0
- data/vendor/spidermonkey/jscntxt.c +1348 -0
- data/vendor/spidermonkey/jscntxt.h +1120 -0
- data/vendor/spidermonkey/jscompat.h +57 -0
- data/vendor/spidermonkey/jsconfig.h +248 -0
- data/vendor/spidermonkey/jsconfig.mk +181 -0
- data/vendor/spidermonkey/jscpucfg.c +383 -0
- data/vendor/spidermonkey/jscpucfg.h +212 -0
- data/vendor/spidermonkey/jsdate.c +2398 -0
- data/vendor/spidermonkey/jsdate.h +124 -0
- data/vendor/spidermonkey/jsdbgapi.c +1799 -0
- data/vendor/spidermonkey/jsdbgapi.h +464 -0
- data/vendor/spidermonkey/jsdhash.c +868 -0
- data/vendor/spidermonkey/jsdhash.h +592 -0
- data/vendor/spidermonkey/jsdtoa.c +3167 -0
- data/vendor/spidermonkey/jsdtoa.h +130 -0
- data/vendor/spidermonkey/jsdtracef.c +317 -0
- data/vendor/spidermonkey/jsdtracef.h +77 -0
- data/vendor/spidermonkey/jsemit.c +6909 -0
- data/vendor/spidermonkey/jsemit.h +741 -0
- data/vendor/spidermonkey/jsexn.c +1371 -0
- data/vendor/spidermonkey/jsexn.h +96 -0
- data/vendor/spidermonkey/jsfile.c +2736 -0
- data/vendor/spidermonkey/jsfile.h +56 -0
- data/vendor/spidermonkey/jsfile.msg +90 -0
- data/vendor/spidermonkey/jsfun.c +2634 -0
- data/vendor/spidermonkey/jsfun.h +254 -0
- data/vendor/spidermonkey/jsgc.c +3554 -0
- data/vendor/spidermonkey/jsgc.h +403 -0
- data/vendor/spidermonkey/jshash.c +476 -0
- data/vendor/spidermonkey/jshash.h +151 -0
- data/vendor/spidermonkey/jsify.pl +485 -0
- data/vendor/spidermonkey/jsinterp.c +6981 -0
- data/vendor/spidermonkey/jsinterp.h +521 -0
- data/vendor/spidermonkey/jsinvoke.c +43 -0
- data/vendor/spidermonkey/jsiter.c +1067 -0
- data/vendor/spidermonkey/jsiter.h +122 -0
- data/vendor/spidermonkey/jskeyword.tbl +124 -0
- data/vendor/spidermonkey/jskwgen.c +460 -0
- data/vendor/spidermonkey/jslibmath.h +266 -0
- data/vendor/spidermonkey/jslock.c +1309 -0
- data/vendor/spidermonkey/jslock.h +313 -0
- data/vendor/spidermonkey/jslocko.asm +60 -0
- data/vendor/spidermonkey/jslog2.c +94 -0
- data/vendor/spidermonkey/jslong.c +264 -0
- data/vendor/spidermonkey/jslong.h +412 -0
- data/vendor/spidermonkey/jsmath.c +568 -0
- data/vendor/spidermonkey/jsmath.h +57 -0
- data/vendor/spidermonkey/jsnum.c +1228 -0
- data/vendor/spidermonkey/jsnum.h +283 -0
- data/vendor/spidermonkey/jsobj.c +5266 -0
- data/vendor/spidermonkey/jsobj.h +709 -0
- data/vendor/spidermonkey/jsopcode.c +5245 -0
- data/vendor/spidermonkey/jsopcode.h +394 -0
- data/vendor/spidermonkey/jsopcode.tbl +523 -0
- data/vendor/spidermonkey/jsotypes.h +202 -0
- data/vendor/spidermonkey/jsparse.c +6680 -0
- data/vendor/spidermonkey/jsparse.h +511 -0
- data/vendor/spidermonkey/jsprf.c +1262 -0
- data/vendor/spidermonkey/jsprf.h +150 -0
- data/vendor/spidermonkey/jsproto.tbl +128 -0
- data/vendor/spidermonkey/jsprvtd.h +267 -0
- data/vendor/spidermonkey/jspubtd.h +744 -0
- data/vendor/spidermonkey/jsregexp.c +4352 -0
- data/vendor/spidermonkey/jsregexp.h +183 -0
- data/vendor/spidermonkey/jsreops.tbl +145 -0
- data/vendor/spidermonkey/jsscan.c +2003 -0
- data/vendor/spidermonkey/jsscan.h +387 -0
- data/vendor/spidermonkey/jsscope.c +1948 -0
- data/vendor/spidermonkey/jsscope.h +418 -0
- data/vendor/spidermonkey/jsscript.c +1832 -0
- data/vendor/spidermonkey/jsscript.h +287 -0
- data/vendor/spidermonkey/jsshell.msg +50 -0
- data/vendor/spidermonkey/jsstddef.h +83 -0
- data/vendor/spidermonkey/jsstr.c +5004 -0
- data/vendor/spidermonkey/jsstr.h +641 -0
- data/vendor/spidermonkey/jstypes.h +475 -0
- data/vendor/spidermonkey/jsutil.c +345 -0
- data/vendor/spidermonkey/jsutil.h +157 -0
- data/vendor/spidermonkey/jsxdrapi.c +800 -0
- data/vendor/spidermonkey/jsxdrapi.h +218 -0
- data/vendor/spidermonkey/jsxml.c +8471 -0
- data/vendor/spidermonkey/jsxml.h +349 -0
- data/vendor/spidermonkey/lock_SunOS.s +119 -0
- data/vendor/spidermonkey/perfect.js +39 -0
- data/vendor/spidermonkey/plify_jsdhash.sed +36 -0
- data/vendor/spidermonkey/prmjtime.c +846 -0
- data/vendor/spidermonkey/prmjtime.h +103 -0
- data/vendor/spidermonkey/resource.h +15 -0
- data/vendor/spidermonkey/rules.mk +197 -0
- data/vendor/spidermonkey/win32.order +384 -0
- metadata +4 -3
@@ -0,0 +1,222 @@
|
|
1
|
+
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
|
2
|
+
*
|
3
|
+
* ***** BEGIN LICENSE BLOCK *****
|
4
|
+
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
5
|
+
*
|
6
|
+
* The contents of this file are subject to the Mozilla Public License Version
|
7
|
+
* 1.1 (the "License"); you may not use this file except in compliance with
|
8
|
+
* the License. You may obtain a copy of the License at
|
9
|
+
* http://www.mozilla.org/MPL/
|
10
|
+
*
|
11
|
+
* Software distributed under the License is distributed on an "AS IS" basis,
|
12
|
+
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
13
|
+
* for the specific language governing rights and limitations under the
|
14
|
+
* License.
|
15
|
+
*
|
16
|
+
* The Original Code is Mozilla Communicator client code, released
|
17
|
+
* March 31, 1998.
|
18
|
+
*
|
19
|
+
* The Initial Developer of the Original Code is
|
20
|
+
* Sun Microsystems, Inc.
|
21
|
+
* Portions created by the Initial Developer are Copyright (C) 1998
|
22
|
+
* the Initial Developer. All Rights Reserved.
|
23
|
+
*
|
24
|
+
* Contributor(s):
|
25
|
+
*
|
26
|
+
* Alternatively, the contents of this file may be used under the terms of
|
27
|
+
* either of the GNU General Public License Version 2 or later (the "GPL"),
|
28
|
+
* or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
29
|
+
* in which case the provisions of the GPL or the LGPL are applicable instead
|
30
|
+
* of those above. If you wish to allow use of your version of this file only
|
31
|
+
* under the terms of either the GPL or the LGPL, and not to allow others to
|
32
|
+
* use your version of this file under the terms of the MPL, indicate your
|
33
|
+
* decision by deleting the provisions above and replace them with the notice
|
34
|
+
* and other provisions required by the GPL or the LGPL. If you do not delete
|
35
|
+
* the provisions above, a recipient may use your version of this file under
|
36
|
+
* the terms of any one of the MPL, the GPL or the LGPL.
|
37
|
+
*
|
38
|
+
* ***** END LICENSE BLOCK ***** */
|
39
|
+
|
40
|
+
/* @(#)e_rem_pio2.c 1.4 95/01/18 */
|
41
|
+
/*
|
42
|
+
* ====================================================
|
43
|
+
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
44
|
+
*
|
45
|
+
* Developed at SunSoft, a Sun Microsystems, Inc. business.
|
46
|
+
* Permission to use, copy, modify, and distribute this
|
47
|
+
* software is freely granted, provided that this notice
|
48
|
+
* is preserved.
|
49
|
+
* ====================================================
|
50
|
+
*
|
51
|
+
*/
|
52
|
+
|
53
|
+
/* __ieee754_rem_pio2(x,y)
|
54
|
+
*
|
55
|
+
* return the remainder of x rem pi/2 in y[0]+y[1]
|
56
|
+
* use __kernel_rem_pio2()
|
57
|
+
*/
|
58
|
+
|
59
|
+
#include "fdlibm.h"
|
60
|
+
|
61
|
+
/*
|
62
|
+
* Table of constants for 2/pi, 396 Hex digits (476 decimal) of 2/pi
|
63
|
+
*/
|
64
|
+
#ifdef __STDC__
|
65
|
+
static const int two_over_pi[] = {
|
66
|
+
#else
|
67
|
+
static int two_over_pi[] = {
|
68
|
+
#endif
|
69
|
+
0xA2F983, 0x6E4E44, 0x1529FC, 0x2757D1, 0xF534DD, 0xC0DB62,
|
70
|
+
0x95993C, 0x439041, 0xFE5163, 0xABDEBB, 0xC561B7, 0x246E3A,
|
71
|
+
0x424DD2, 0xE00649, 0x2EEA09, 0xD1921C, 0xFE1DEB, 0x1CB129,
|
72
|
+
0xA73EE8, 0x8235F5, 0x2EBB44, 0x84E99C, 0x7026B4, 0x5F7E41,
|
73
|
+
0x3991D6, 0x398353, 0x39F49C, 0x845F8B, 0xBDF928, 0x3B1FF8,
|
74
|
+
0x97FFDE, 0x05980F, 0xEF2F11, 0x8B5A0A, 0x6D1F6D, 0x367ECF,
|
75
|
+
0x27CB09, 0xB74F46, 0x3F669E, 0x5FEA2D, 0x7527BA, 0xC7EBE5,
|
76
|
+
0xF17B3D, 0x0739F7, 0x8A5292, 0xEA6BFB, 0x5FB11F, 0x8D5D08,
|
77
|
+
0x560330, 0x46FC7B, 0x6BABF0, 0xCFBC20, 0x9AF436, 0x1DA9E3,
|
78
|
+
0x91615E, 0xE61B08, 0x659985, 0x5F14A0, 0x68408D, 0xFFD880,
|
79
|
+
0x4D7327, 0x310606, 0x1556CA, 0x73A8C9, 0x60E27B, 0xC08C6B,
|
80
|
+
};
|
81
|
+
|
82
|
+
#ifdef __STDC__
|
83
|
+
static const int npio2_hw[] = {
|
84
|
+
#else
|
85
|
+
static int npio2_hw[] = {
|
86
|
+
#endif
|
87
|
+
0x3FF921FB, 0x400921FB, 0x4012D97C, 0x401921FB, 0x401F6A7A, 0x4022D97C,
|
88
|
+
0x4025FDBB, 0x402921FB, 0x402C463A, 0x402F6A7A, 0x4031475C, 0x4032D97C,
|
89
|
+
0x40346B9C, 0x4035FDBB, 0x40378FDB, 0x403921FB, 0x403AB41B, 0x403C463A,
|
90
|
+
0x403DD85A, 0x403F6A7A, 0x40407E4C, 0x4041475C, 0x4042106C, 0x4042D97C,
|
91
|
+
0x4043A28C, 0x40446B9C, 0x404534AC, 0x4045FDBB, 0x4046C6CB, 0x40478FDB,
|
92
|
+
0x404858EB, 0x404921FB,
|
93
|
+
};
|
94
|
+
|
95
|
+
/*
|
96
|
+
* invpio2: 53 bits of 2/pi
|
97
|
+
* pio2_1: first 33 bit of pi/2
|
98
|
+
* pio2_1t: pi/2 - pio2_1
|
99
|
+
* pio2_2: second 33 bit of pi/2
|
100
|
+
* pio2_2t: pi/2 - (pio2_1+pio2_2)
|
101
|
+
* pio2_3: third 33 bit of pi/2
|
102
|
+
* pio2_3t: pi/2 - (pio2_1+pio2_2+pio2_3)
|
103
|
+
*/
|
104
|
+
|
105
|
+
#ifdef __STDC__
|
106
|
+
static const double
|
107
|
+
#else
|
108
|
+
static double
|
109
|
+
#endif
|
110
|
+
zero = 0.00000000000000000000e+00, /* 0x00000000, 0x00000000 */
|
111
|
+
half = 5.00000000000000000000e-01, /* 0x3FE00000, 0x00000000 */
|
112
|
+
two24 = 1.67772160000000000000e+07, /* 0x41700000, 0x00000000 */
|
113
|
+
invpio2 = 6.36619772367581382433e-01, /* 0x3FE45F30, 0x6DC9C883 */
|
114
|
+
pio2_1 = 1.57079632673412561417e+00, /* 0x3FF921FB, 0x54400000 */
|
115
|
+
pio2_1t = 6.07710050650619224932e-11, /* 0x3DD0B461, 0x1A626331 */
|
116
|
+
pio2_2 = 6.07710050630396597660e-11, /* 0x3DD0B461, 0x1A600000 */
|
117
|
+
pio2_2t = 2.02226624879595063154e-21, /* 0x3BA3198A, 0x2E037073 */
|
118
|
+
pio2_3 = 2.02226624871116645580e-21, /* 0x3BA3198A, 0x2E000000 */
|
119
|
+
pio2_3t = 8.47842766036889956997e-32; /* 0x397B839A, 0x252049C1 */
|
120
|
+
|
121
|
+
#ifdef __STDC__
|
122
|
+
int __ieee754_rem_pio2(double x, double *y)
|
123
|
+
#else
|
124
|
+
int __ieee754_rem_pio2(x,y)
|
125
|
+
double x,y[];
|
126
|
+
#endif
|
127
|
+
{
|
128
|
+
fd_twoints u, ux, uz;
|
129
|
+
double z = 0;
|
130
|
+
double w,t,r,fn;
|
131
|
+
double tx[3];
|
132
|
+
int e0,i,j,nx,n,ix,hx;
|
133
|
+
|
134
|
+
u.d = x;
|
135
|
+
hx = __HI(u); /* high word of x */
|
136
|
+
ix = hx&0x7fffffff;
|
137
|
+
if(ix<=0x3fe921fb) /* |x| ~<= pi/4 , no need for reduction */
|
138
|
+
{y[0] = x; y[1] = 0; return 0;}
|
139
|
+
if(ix<0x4002d97c) { /* |x| < 3pi/4, special case with n=+-1 */
|
140
|
+
if(hx>0) {
|
141
|
+
z = x - pio2_1;
|
142
|
+
if(ix!=0x3ff921fb) { /* 33+53 bit pi is good enough */
|
143
|
+
y[0] = z - pio2_1t;
|
144
|
+
y[1] = (z-y[0])-pio2_1t;
|
145
|
+
} else { /* near pi/2, use 33+33+53 bit pi */
|
146
|
+
z -= pio2_2;
|
147
|
+
y[0] = z - pio2_2t;
|
148
|
+
y[1] = (z-y[0])-pio2_2t;
|
149
|
+
}
|
150
|
+
return 1;
|
151
|
+
} else { /* negative x */
|
152
|
+
z = x + pio2_1;
|
153
|
+
if(ix!=0x3ff921fb) { /* 33+53 bit pi is good enough */
|
154
|
+
y[0] = z + pio2_1t;
|
155
|
+
y[1] = (z-y[0])+pio2_1t;
|
156
|
+
} else { /* near pi/2, use 33+33+53 bit pi */
|
157
|
+
z += pio2_2;
|
158
|
+
y[0] = z + pio2_2t;
|
159
|
+
y[1] = (z-y[0])+pio2_2t;
|
160
|
+
}
|
161
|
+
return -1;
|
162
|
+
}
|
163
|
+
}
|
164
|
+
if(ix<=0x413921fb) { /* |x| ~<= 2^19*(pi/2), medium size */
|
165
|
+
t = fd_fabs(x);
|
166
|
+
n = (int) (t*invpio2+half);
|
167
|
+
fn = (double)n;
|
168
|
+
r = t-fn*pio2_1;
|
169
|
+
w = fn*pio2_1t; /* 1st round good to 85 bit */
|
170
|
+
if(n<32&&ix!=npio2_hw[n-1]) {
|
171
|
+
y[0] = r-w; /* quick check no cancellation */
|
172
|
+
} else {
|
173
|
+
j = ix>>20;
|
174
|
+
y[0] = r-w;
|
175
|
+
u.d = y[0];
|
176
|
+
i = j-(((__HI(u))>>20)&0x7ff);
|
177
|
+
if(i>16) { /* 2nd iteration needed, good to 118 */
|
178
|
+
t = r;
|
179
|
+
w = fn*pio2_2;
|
180
|
+
r = t-w;
|
181
|
+
w = fn*pio2_2t-((t-r)-w);
|
182
|
+
y[0] = r-w;
|
183
|
+
u.d = y[0];
|
184
|
+
i = j-(((__HI(u))>>20)&0x7ff);
|
185
|
+
if(i>49) { /* 3rd iteration need, 151 bits acc */
|
186
|
+
t = r; /* will cover all possible cases */
|
187
|
+
w = fn*pio2_3;
|
188
|
+
r = t-w;
|
189
|
+
w = fn*pio2_3t-((t-r)-w);
|
190
|
+
y[0] = r-w;
|
191
|
+
}
|
192
|
+
}
|
193
|
+
}
|
194
|
+
y[1] = (r-y[0])-w;
|
195
|
+
if(hx<0) {y[0] = -y[0]; y[1] = -y[1]; return -n;}
|
196
|
+
else return n;
|
197
|
+
}
|
198
|
+
/*
|
199
|
+
* all other (large) arguments
|
200
|
+
*/
|
201
|
+
if(ix>=0x7ff00000) { /* x is inf or NaN */
|
202
|
+
y[0]=y[1]=x-x; return 0;
|
203
|
+
}
|
204
|
+
/* set z = scalbn(|x|,ilogb(x)-23) */
|
205
|
+
ux.d = x; uz.d = z;
|
206
|
+
__LO(uz) = __LO(ux);
|
207
|
+
z = uz.d;
|
208
|
+
e0 = (ix>>20)-1046; /* e0 = ilogb(z)-23; */
|
209
|
+
uz.d = z;
|
210
|
+
__HI(uz) = ix - (e0<<20);
|
211
|
+
z = uz.d;
|
212
|
+
for(i=0;i<2;i++) {
|
213
|
+
tx[i] = (double)((int)(z));
|
214
|
+
z = (z-tx[i])*two24;
|
215
|
+
}
|
216
|
+
tx[2] = z;
|
217
|
+
nx = 3;
|
218
|
+
while(tx[nx-1]==zero) nx--; /* skip zero term */
|
219
|
+
n = __kernel_rem_pio2(tx,y,e0,nx,2,two_over_pi);
|
220
|
+
if(hx<0) {y[0] = -y[0]; y[1] = -y[1]; return -n;}
|
221
|
+
return n;
|
222
|
+
}
|
@@ -0,0 +1,120 @@
|
|
1
|
+
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
|
2
|
+
*
|
3
|
+
* ***** BEGIN LICENSE BLOCK *****
|
4
|
+
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
5
|
+
*
|
6
|
+
* The contents of this file are subject to the Mozilla Public License Version
|
7
|
+
* 1.1 (the "License"); you may not use this file except in compliance with
|
8
|
+
* the License. You may obtain a copy of the License at
|
9
|
+
* http://www.mozilla.org/MPL/
|
10
|
+
*
|
11
|
+
* Software distributed under the License is distributed on an "AS IS" basis,
|
12
|
+
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
13
|
+
* for the specific language governing rights and limitations under the
|
14
|
+
* License.
|
15
|
+
*
|
16
|
+
* The Original Code is Mozilla Communicator client code, released
|
17
|
+
* March 31, 1998.
|
18
|
+
*
|
19
|
+
* The Initial Developer of the Original Code is
|
20
|
+
* Sun Microsystems, Inc.
|
21
|
+
* Portions created by the Initial Developer are Copyright (C) 1998
|
22
|
+
* the Initial Developer. All Rights Reserved.
|
23
|
+
*
|
24
|
+
* Contributor(s):
|
25
|
+
*
|
26
|
+
* Alternatively, the contents of this file may be used under the terms of
|
27
|
+
* either of the GNU General Public License Version 2 or later (the "GPL"),
|
28
|
+
* or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
29
|
+
* in which case the provisions of the GPL or the LGPL are applicable instead
|
30
|
+
* of those above. If you wish to allow use of your version of this file only
|
31
|
+
* under the terms of either the GPL or the LGPL, and not to allow others to
|
32
|
+
* use your version of this file under the terms of the MPL, indicate your
|
33
|
+
* decision by deleting the provisions above and replace them with the notice
|
34
|
+
* and other provisions required by the GPL or the LGPL. If you do not delete
|
35
|
+
* the provisions above, a recipient may use your version of this file under
|
36
|
+
* the terms of any one of the MPL, the GPL or the LGPL.
|
37
|
+
*
|
38
|
+
* ***** END LICENSE BLOCK ***** */
|
39
|
+
|
40
|
+
/* @(#)e_remainder.c 1.3 95/01/18 */
|
41
|
+
/*
|
42
|
+
* ====================================================
|
43
|
+
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
44
|
+
*
|
45
|
+
* Developed at SunSoft, a Sun Microsystems, Inc. business.
|
46
|
+
* Permission to use, copy, modify, and distribute this
|
47
|
+
* software is freely granted, provided that this notice
|
48
|
+
* is preserved.
|
49
|
+
* ====================================================
|
50
|
+
*/
|
51
|
+
|
52
|
+
/* __ieee754_remainder(x,p)
|
53
|
+
* Return :
|
54
|
+
* returns x REM p = x - [x/p]*p as if in infinite
|
55
|
+
* precise arithmetic, where [x/p] is the (infinite bit)
|
56
|
+
* integer nearest x/p (in half way case choose the even one).
|
57
|
+
* Method :
|
58
|
+
* Based on fmod() return x-[x/p]chopped*p exactlp.
|
59
|
+
*/
|
60
|
+
|
61
|
+
#include "fdlibm.h"
|
62
|
+
|
63
|
+
#ifdef __STDC__
|
64
|
+
static const double zero = 0.0;
|
65
|
+
#else
|
66
|
+
static double zero = 0.0;
|
67
|
+
#endif
|
68
|
+
|
69
|
+
|
70
|
+
#ifdef __STDC__
|
71
|
+
double __ieee754_remainder(double x, double p)
|
72
|
+
#else
|
73
|
+
double __ieee754_remainder(x,p)
|
74
|
+
double x,p;
|
75
|
+
#endif
|
76
|
+
{
|
77
|
+
fd_twoints u;
|
78
|
+
int hx,hp;
|
79
|
+
unsigned sx,lx,lp;
|
80
|
+
double p_half;
|
81
|
+
|
82
|
+
u.d = x;
|
83
|
+
hx = __HI(u); /* high word of x */
|
84
|
+
lx = __LO(u); /* low word of x */
|
85
|
+
u.d = p;
|
86
|
+
hp = __HI(u); /* high word of p */
|
87
|
+
lp = __LO(u); /* low word of p */
|
88
|
+
sx = hx&0x80000000;
|
89
|
+
hp &= 0x7fffffff;
|
90
|
+
hx &= 0x7fffffff;
|
91
|
+
|
92
|
+
/* purge off exception values */
|
93
|
+
if((hp|lp)==0) return (x*p)/(x*p); /* p = 0 */
|
94
|
+
if((hx>=0x7ff00000)|| /* x not finite */
|
95
|
+
((hp>=0x7ff00000)&& /* p is NaN */
|
96
|
+
(((hp-0x7ff00000)|lp)!=0)))
|
97
|
+
return (x*p)/(x*p);
|
98
|
+
|
99
|
+
|
100
|
+
if (hp<=0x7fdfffff) x = __ieee754_fmod(x,p+p); /* now x < 2p */
|
101
|
+
if (((hx-hp)|(lx-lp))==0) return zero*x;
|
102
|
+
x = fd_fabs(x);
|
103
|
+
p = fd_fabs(p);
|
104
|
+
if (hp<0x00200000) {
|
105
|
+
if(x+x>p) {
|
106
|
+
x-=p;
|
107
|
+
if(x+x>=p) x -= p;
|
108
|
+
}
|
109
|
+
} else {
|
110
|
+
p_half = 0.5*p;
|
111
|
+
if(x>p_half) {
|
112
|
+
x-=p;
|
113
|
+
if(x>=p_half) x -= p;
|
114
|
+
}
|
115
|
+
}
|
116
|
+
u.d = x;
|
117
|
+
__HI(u) ^= sx;
|
118
|
+
x = u.d;
|
119
|
+
return x;
|
120
|
+
}
|
@@ -0,0 +1,89 @@
|
|
1
|
+
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
|
2
|
+
*
|
3
|
+
* ***** BEGIN LICENSE BLOCK *****
|
4
|
+
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
5
|
+
*
|
6
|
+
* The contents of this file are subject to the Mozilla Public License Version
|
7
|
+
* 1.1 (the "License"); you may not use this file except in compliance with
|
8
|
+
* the License. You may obtain a copy of the License at
|
9
|
+
* http://www.mozilla.org/MPL/
|
10
|
+
*
|
11
|
+
* Software distributed under the License is distributed on an "AS IS" basis,
|
12
|
+
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
13
|
+
* for the specific language governing rights and limitations under the
|
14
|
+
* License.
|
15
|
+
*
|
16
|
+
* The Original Code is Mozilla Communicator client code, released
|
17
|
+
* March 31, 1998.
|
18
|
+
*
|
19
|
+
* The Initial Developer of the Original Code is
|
20
|
+
* Sun Microsystems, Inc.
|
21
|
+
* Portions created by the Initial Developer are Copyright (C) 1998
|
22
|
+
* the Initial Developer. All Rights Reserved.
|
23
|
+
*
|
24
|
+
* Contributor(s):
|
25
|
+
*
|
26
|
+
* Alternatively, the contents of this file may be used under the terms of
|
27
|
+
* either of the GNU General Public License Version 2 or later (the "GPL"),
|
28
|
+
* or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
29
|
+
* in which case the provisions of the GPL or the LGPL are applicable instead
|
30
|
+
* of those above. If you wish to allow use of your version of this file only
|
31
|
+
* under the terms of either the GPL or the LGPL, and not to allow others to
|
32
|
+
* use your version of this file under the terms of the MPL, indicate your
|
33
|
+
* decision by deleting the provisions above and replace them with the notice
|
34
|
+
* and other provisions required by the GPL or the LGPL. If you do not delete
|
35
|
+
* the provisions above, a recipient may use your version of this file under
|
36
|
+
* the terms of any one of the MPL, the GPL or the LGPL.
|
37
|
+
*
|
38
|
+
* ***** END LICENSE BLOCK ***** */
|
39
|
+
|
40
|
+
/* @(#)e_scalb.c 1.3 95/01/18 */
|
41
|
+
/*
|
42
|
+
* ====================================================
|
43
|
+
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
44
|
+
*
|
45
|
+
* Developed at SunSoft, a Sun Microsystems, Inc. business.
|
46
|
+
* Permission to use, copy, modify, and distribute this
|
47
|
+
* software is freely granted, provided that this notice
|
48
|
+
* is preserved.
|
49
|
+
* ====================================================
|
50
|
+
*/
|
51
|
+
|
52
|
+
/*
|
53
|
+
* __ieee754_scalb(x, fn) is provide for
|
54
|
+
* passing various standard test suite. One
|
55
|
+
* should use scalbn() instead.
|
56
|
+
*/
|
57
|
+
|
58
|
+
#include "fdlibm.h"
|
59
|
+
|
60
|
+
#ifdef _SCALB_INT
|
61
|
+
#ifdef __STDC__
|
62
|
+
double __ieee754_scalb(double x, int fn)
|
63
|
+
#else
|
64
|
+
double __ieee754_scalb(x,fn)
|
65
|
+
double x; int fn;
|
66
|
+
#endif
|
67
|
+
#else
|
68
|
+
#ifdef __STDC__
|
69
|
+
double __ieee754_scalb(double x, double fn)
|
70
|
+
#else
|
71
|
+
double __ieee754_scalb(x,fn)
|
72
|
+
double x, fn;
|
73
|
+
#endif
|
74
|
+
#endif
|
75
|
+
{
|
76
|
+
#ifdef _SCALB_INT
|
77
|
+
return fd_scalbn(x,fn);
|
78
|
+
#else
|
79
|
+
if (fd_isnan(x)||fd_isnan(fn)) return x*fn;
|
80
|
+
if (!fd_finite(fn)) {
|
81
|
+
if(fn>0.0) return x*fn;
|
82
|
+
else return x/(-fn);
|
83
|
+
}
|
84
|
+
if (fd_rint(fn)!=fn) return (fn-fn)/(fn-fn);
|
85
|
+
if ( fn > 65000.0) return fd_scalbn(x, 65000);
|
86
|
+
if (-fn > 65000.0) return fd_scalbn(x,-65000);
|
87
|
+
return fd_scalbn(x,(int)fn);
|
88
|
+
#endif
|
89
|
+
}
|
@@ -0,0 +1,122 @@
|
|
1
|
+
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
|
2
|
+
*
|
3
|
+
* ***** BEGIN LICENSE BLOCK *****
|
4
|
+
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
5
|
+
*
|
6
|
+
* The contents of this file are subject to the Mozilla Public License Version
|
7
|
+
* 1.1 (the "License"); you may not use this file except in compliance with
|
8
|
+
* the License. You may obtain a copy of the License at
|
9
|
+
* http://www.mozilla.org/MPL/
|
10
|
+
*
|
11
|
+
* Software distributed under the License is distributed on an "AS IS" basis,
|
12
|
+
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
13
|
+
* for the specific language governing rights and limitations under the
|
14
|
+
* License.
|
15
|
+
*
|
16
|
+
* The Original Code is Mozilla Communicator client code, released
|
17
|
+
* March 31, 1998.
|
18
|
+
*
|
19
|
+
* The Initial Developer of the Original Code is
|
20
|
+
* Sun Microsystems, Inc.
|
21
|
+
* Portions created by the Initial Developer are Copyright (C) 1998
|
22
|
+
* the Initial Developer. All Rights Reserved.
|
23
|
+
*
|
24
|
+
* Contributor(s):
|
25
|
+
*
|
26
|
+
* Alternatively, the contents of this file may be used under the terms of
|
27
|
+
* either of the GNU General Public License Version 2 or later (the "GPL"),
|
28
|
+
* or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
29
|
+
* in which case the provisions of the GPL or the LGPL are applicable instead
|
30
|
+
* of those above. If you wish to allow use of your version of this file only
|
31
|
+
* under the terms of either the GPL or the LGPL, and not to allow others to
|
32
|
+
* use your version of this file under the terms of the MPL, indicate your
|
33
|
+
* decision by deleting the provisions above and replace them with the notice
|
34
|
+
* and other provisions required by the GPL or the LGPL. If you do not delete
|
35
|
+
* the provisions above, a recipient may use your version of this file under
|
36
|
+
* the terms of any one of the MPL, the GPL or the LGPL.
|
37
|
+
*
|
38
|
+
* ***** END LICENSE BLOCK ***** */
|
39
|
+
|
40
|
+
/* @(#)e_sinh.c 1.3 95/01/18 */
|
41
|
+
/*
|
42
|
+
* ====================================================
|
43
|
+
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
44
|
+
*
|
45
|
+
* Developed at SunSoft, a Sun Microsystems, Inc. business.
|
46
|
+
* Permission to use, copy, modify, and distribute this
|
47
|
+
* software is freely granted, provided that this notice
|
48
|
+
* is preserved.
|
49
|
+
* ====================================================
|
50
|
+
*/
|
51
|
+
|
52
|
+
/* __ieee754_sinh(x)
|
53
|
+
* Method :
|
54
|
+
* mathematically sinh(x) if defined to be (exp(x)-exp(-x))/2
|
55
|
+
* 1. Replace x by |x| (sinh(-x) = -sinh(x)).
|
56
|
+
* 2.
|
57
|
+
* E + E/(E+1)
|
58
|
+
* 0 <= x <= 22 : sinh(x) := --------------, E=expm1(x)
|
59
|
+
* 2
|
60
|
+
*
|
61
|
+
* 22 <= x <= lnovft : sinh(x) := exp(x)/2
|
62
|
+
* lnovft <= x <= ln2ovft: sinh(x) := exp(x/2)/2 * exp(x/2)
|
63
|
+
* ln2ovft < x : sinh(x) := x*shuge (overflow)
|
64
|
+
*
|
65
|
+
* Special cases:
|
66
|
+
* sinh(x) is |x| if x is +INF, -INF, or NaN.
|
67
|
+
* only sinh(0)=0 is exact for finite x.
|
68
|
+
*/
|
69
|
+
|
70
|
+
#include "fdlibm.h"
|
71
|
+
|
72
|
+
#ifdef __STDC__
|
73
|
+
static const double one = 1.0, shuge = 1.0e307;
|
74
|
+
#else
|
75
|
+
static double one = 1.0, shuge = 1.0e307;
|
76
|
+
#endif
|
77
|
+
|
78
|
+
#ifdef __STDC__
|
79
|
+
double __ieee754_sinh(double x)
|
80
|
+
#else
|
81
|
+
double __ieee754_sinh(x)
|
82
|
+
double x;
|
83
|
+
#endif
|
84
|
+
{
|
85
|
+
fd_twoints u;
|
86
|
+
double t,w,h;
|
87
|
+
int ix,jx;
|
88
|
+
unsigned lx;
|
89
|
+
|
90
|
+
/* High word of |x|. */
|
91
|
+
u.d = x;
|
92
|
+
jx = __HI(u);
|
93
|
+
ix = jx&0x7fffffff;
|
94
|
+
|
95
|
+
/* x is INF or NaN */
|
96
|
+
if(ix>=0x7ff00000) return x+x;
|
97
|
+
|
98
|
+
h = 0.5;
|
99
|
+
if (jx<0) h = -h;
|
100
|
+
/* |x| in [0,22], return sign(x)*0.5*(E+E/(E+1))) */
|
101
|
+
if (ix < 0x40360000) { /* |x|<22 */
|
102
|
+
if (ix<0x3e300000) /* |x|<2**-28 */
|
103
|
+
if(shuge+x>one) return x;/* sinh(tiny) = tiny with inexact */
|
104
|
+
t = fd_expm1(fd_fabs(x));
|
105
|
+
if(ix<0x3ff00000) return h*(2.0*t-t*t/(t+one));
|
106
|
+
return h*(t+t/(t+one));
|
107
|
+
}
|
108
|
+
|
109
|
+
/* |x| in [22, log(maxdouble)] return 0.5*exp(|x|) */
|
110
|
+
if (ix < 0x40862E42) return h*__ieee754_exp(fd_fabs(x));
|
111
|
+
|
112
|
+
/* |x| in [log(maxdouble), overflowthresold] */
|
113
|
+
lx = *( (((*(unsigned*)&one)>>29)) + (unsigned*)&x);
|
114
|
+
if (ix<0x408633CE || (ix==0x408633ce)&&(lx<=(unsigned)0x8fb9f87d)) {
|
115
|
+
w = __ieee754_exp(0.5*fd_fabs(x));
|
116
|
+
t = h*w;
|
117
|
+
return t*w;
|
118
|
+
}
|
119
|
+
|
120
|
+
/* |x| > overflowthresold, sinh(x) overflow */
|
121
|
+
return x*shuge;
|
122
|
+
}
|