summaryrefslogtreecommitdiff
path: root/testsuite/tests/numeric/should_run/arith002.hs
blob: b7f5acf136e3ab9bd65de81495d6efdd7889fee2 (plain)
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
-- !!! basic Rational operations
--
import Data.Ratio

main
  = putStr
       (-- Ratio Ints
	show [i0a, i0b, i0c, i2a, i2b, im2a, im2b, i_pi, i_misc]
    ++  "\n"
	-- the Ints
    ++  show ((map numerator   [i0a, i0b, i0c, i2a, i2b, im2a, im2b, i_pi, i_misc])
	    ++(map denominator [i0a, i0b, i0c, i2a, i2b, im2a, im2b, i_pi, i_misc]))
    ++  "\n"
	-- Booleans
--  ++	show []
--  ++  "\n"

	-- Rationals (Ratio Integers)
    ++	show [r0a, r0b, r0c, r2a, r2b, rm2a, rm2b, r_pi, r_misc]
    ++  "\n"
	-- the Integers
    ++  show ((map numerator   [r0a, r0b, r0c, r2a, r2b, rm2a, rm2b, r_pi, r_misc])
	    ++(map denominator [r0a, r0b, r0c, r2a, r2b, rm2a, rm2b, r_pi, r_misc]))
    ++  "\n"
	-- Booleans
--  ++	show []
--  ++  "\n"
	)
  where  
    i0a, i0b, i0c, i2a, i2b, im2a, im2b, i_pi, i_misc :: Ratio Int

    i0a	    =    0 % 1
    i0b	    = (-0) % 1
    i0c	    =    0 % (-1)
    i2a	    =    4 % 2
    i2b	    = (-4) % (-2)
    im2a    = (-4) % 2
    im2b    =    4 % (-2)
    i_pi    =   22 % 7
    i_misc  =    2 % 10000

    r0a, r0b, r0c, r2a, r2b, rm2a, rm2b, r_pi, r_misc :: Rational

    r0a	    =    0 % 1
    r0b	    = (-0) % 1
    r0c	    =    0 % (-1)
    r2a	    =    4 % 2
    r2b	    = (-4) % (-2)
    rm2a    = (-4) % 2
    rm2b    =    4 % (-2)
    r_pi    =   22 % 7
    r_misc  =    2 % 10000