File: float.fs

package info (click to toggle)
gforth 0.7.3%2Bdfsg-9
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, buster, sid
  • size: 5,992 kB
  • sloc: ansic: 8,535; sh: 3,666; lisp: 1,778; makefile: 1,019; yacc: 186; sed: 141; lex: 102; awk: 21
file content (80 lines) | stat: -rw-r--r-- 2,788 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
\ float wordset test suite

\ Copyright (C) 2002,2006,2007 Free Software Foundation, Inc.

\ This file is part of Gforth.

\ Gforth 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 3
\ of the License, or (at your option) any later version.

\ This program 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 program. If not, see http://www.gnu.org/licenses/.

decimal

\ d>f d>d

{  4503599627370497. 2dup d>f f>d d= -> true }
{ -4503599627370497. 2dup d>f f>d d= -> true }
{  9007199254740991. 2dup d>f f>d d= -> true }
{ -9007199254740991. 2dup d>f f>d d= -> true }

\ fround
{ 0.5e fround 0e f= -> true }
{ 1.5e fround 2e f= -> true }
{ 2.5e fround 2e f= -> true }
{ -0.5e fround -0e f= -> true }
{ -1.5e fround -2e f= -> true }
{ -2.5e fround -2e f= -> true }
{ 4503599627370495. d>f 0.5e f+ fround 4503599627370496. d>f f= -> true }
{ 4503599627370494. d>f 0.5e f+ fround 4503599627370494. d>f f= -> true }
{ 4503599627370497. d>f fdup fround f= -> true }
{ 9007199254740991. d>f fdup fround f= -> true }
{ -4503599627370495. d>f -0.5e f+ fround -4503599627370496. d>f f= -> true }
{ -4503599627370495. d>f  0.5e f+ fround -4503599627370494. d>f f= -> true }
{ -4503599627370497. d>f fdup fround f= -> true }
{ -9007199254740991. d>f fdup fround f= -> true }
{ 1.49999e fround 1e f= -> true }

\ >float (very incomplete, just a regression test)
{ s" -" >float -> false }
{ s" +" >float -> false }
{ s"   " >float 0e f= -> true true }
{ s" 2e+3e" >float -> false }
{ s" 2+3" >float -> 2000e true }

set-near
\ transcendenal and other functions, mainly test effect on TOS (not FTOS)
{ 12345 2e 3e f** -> 12345 8e }
{ 12345 1.8e floor -> 12345 1e }
{ 12345 1.8e fround -> 12345 2e }
{ 12345 -1.8e fabs -> 12345 1.8e }
{ 12345 1e facos -> 12345 0e }
{ 12345 1e fasin -> 12345 pi 2e f/ }
{ 12345 0e fatan -> 12345 0e }
{ 12345 1e 0e fatan2 -> 12345 pi 2e f/ }
{ 12345 pi fcos -> 12345 -1e }
{ 12345 0e fexp -> 12345 1e }
{ 12345 0e fexpm1 -> 12345 0e }
{ 12345 1e fln -> 12345 0e }
{ 12345 0e flnp1 -> 12345 0e }
{ 12345 1e flog -> 12345 0e }
{ 12345 0e falog -> 12345 1e }
{ 12345 pi f2/ fsin -> 12345 1e }
{ 12345 0e fsincos -> 12345 0e 1e }
{ 12345 4e fsqrt -> 12345 2e }
{ 12345 pi 4e f/ ftan -> 12345 1e }
{ 12345 0e fsinh -> 12345 0e }
{ 12345 0e fcosh -> 12345 1e }
{ 12345 0e ftanh -> 12345 0e }
{ 12345 0e fasinh -> 12345 0e }
{ 12345 1e facosh -> 12345 0e }
{ 12345 0e fatanh -> 12345 0e }