File: Ch07_05_01_RecordProgrammingExample.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 (16 lines) | stat: -rw-r--r-- 458 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
fun moveX (p as {X:real,Vx:real,...}, t:real) = p # {X = X + Vx};
fun moveY (p as {Y:real,Vy:real,...}, t:real) = p # {Y = Y + Vy};
fun accelerateX (p as {Vx:real,...}, t:real) = p;
fun accelerateY (p as {Vy:real,...}, t:real) = p # {Vy = Vy + 9.8};

fun tic (p, t) =
let
  val p = accelerateX (p, t)
  val p = accelerateY (p, t)
  val p = moveX (p, t)
  val p = moveY (p, t)
in
  p
end;

fun accelerateX (p as {Vx:real,...}, t:real) = p # {Vx = Vx * 0.90};