File: Test003.ML

package info (click to toggle)
polyml 5.6-8
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 31,892 kB
  • ctags: 34,453
  • sloc: cpp: 44,983; ansic: 24,520; asm: 14,850; sh: 11,730; makefile: 551; exp: 484; python: 253; awk: 91; sed: 9
file content (38 lines) | stat: -rw-r--r-- 1,929 bytes parent folder | download | duplicates (5)
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
(* A few random tests for BoolVector and BoolArray. *)
fun verify true = ()
|   verify false = raise Fail "wrong";

val a = BoolVector.tabulate(20, fn i => i mod 2 = 1);

(* While working on converting these tests I actually discovered a new bug. *)
verify(a = BoolVector.fromList[false, true, false, true, false, true, false, true, false, true,
            false, true, false, true, false, true, false, true, false, true]);

val b = BoolArray.tabulate(20, fn i => i mod 2 = 1);
verify(BoolArray.vector b = BoolArray.vector(BoolArray.fromList[false, true, false, true, false, true, false, true, false, true,
            false, true, false, true, false, true, false, true, false, true]));


val b = BoolArray.tabulate(20, fn i => i mod 4 = 1);
verify(BoolArray.vector b = BoolArray.vector (BoolArray.fromList[false, true, false, false, false, true, false, false,
        false, true, false, false, false, true, false, false, false, true, false, false]));

verify(not(BoolVector.sub(a, 0)));
verify(BoolVector.sub(a, 9));

verify((BoolVector.sub(a, 20); false) handle Subscript => true);
verify((BoolVector.sub(a, ~1); false) handle Subscript => true);
verify(BoolVector.map (fn i => not i) a =
     BoolVector.fromList[true, false, true, false, true, false, true, false, true, false,
            true, false, true, false, true, false, true, false, true, false]);
verify(BoolVector.foldl (fn(a, b) => a orelse b) false a);
verify(BoolVector.foldr (fn(a, b) => a orelse b) false a);
val d = BoolVector.fromList [true, true, false, true, true];
val c = BoolVector.foldl (fn(a, b) => a :: b) [] a;
verify(BoolArray.vector(BoolArray.fromList c) =
    BoolVector.fromList[true, false, true, false, true, false, true, false, true, false,
         true, false, true, false, true, false, true, false, true, false]);
verify(BoolVector.concat[d, d] =
    BoolVector.fromList[true, true, false, true, true, true, true, false, true, true]);