File: SuffixSum.sml

package info (click to toggle)
smlsharp 4.1.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 123,732 kB
  • sloc: ansic: 16,725; sh: 4,347; makefile: 2,191; java: 742; haskell: 493; ruby: 305; cpp: 284; pascal: 256; ml: 255; lisp: 141; asm: 97; sql: 74
file content (46 lines) | stat: -rw-r--r-- 1,103 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
datatype 'a par_list =
    NIL
  | CELL of {head : 'a, cham: ForeachData.index, tail: ForeachData.index}

fun initialize nest nil = NIL
  | initialize nest (h::t) =
    let
      val t = nest t
    in
      CELL {head = h, cham = t, tail = t}
    end

fun finalize nest NIL = nil
  | finalize nest (CELL {head, tail, ...}) = head :: nest tail

fun suffixSum l =
    _foreach id in l
    where
      {finalize = finalize,
       initialize = initialize}
    with
      {value, newValue, ...}
    do
      case value id of
        NIL => NIL
      | c as CELL {head=h1, tail, cham} =>
        case value cham of
          CELL {head=h2, tail=_, cham} =>
          CELL {head = h1 + h2 : int,  cham = cham, tail = tail}
        | NIL => c
    while
      case newValue id of
        NIL => false
      | CELL {head, cham, tail} =>
        case newValue cham of
          NIL => false
        | CELL _ => true
    end

val n = valOf (Int.fromString (valOf (OS.Process.getEnv "SIZE")))

val l1 = List.tabulate (n, fn i => 1)
val l2 = suffixSum l1
(*
val _ = app (fn i => print (Int.toString i ^ "\n")) l2
*)