???
???
8.9.900
 
 
#lang racket
 
;; this code defines the sim-VVQS5 language as a module
(module sim-VVQS5 racket
  (provide
   [rename-out (#%lam-app #%app)]
   #%module-begin
   #%datum
   + - * / = equal? <= => if else
   true false)
 
  (define-syntax (#%lam-app stx)
    (syntax-case stx (=> if else where :=)
      [(_ (args ...) => body)
       #'(lambda (args ...) body)]
      [(_ e1 if e2 else e3)
       #'(if e2 e1 e3)]
      [(_ eb where ([v := e] ...))
       #'((lambda (v ...) eb) e ...)]
      [(_ e ...)
       #'(#%app e ...)]))
 
  )
 
;; this module uses the sim-VVQS5 language. That is, its
;; contents are written *in* the sim-VVQS5 language.
;; the only edits you should make are inside this module:
(module my-mod1 (submod ".." sim-VVQS5)
 
  1234
 
  4567
 
  (+ 4 5)
 
  {34 if true else 39}
 
  ({+ x y}
   where
   {[x := 14]
    [y := 7]})
 
  ;; exercise 0: Give the name `f` to the function that
  ;; accepts an argument `x` and computes x^2 + 4x + 4.
  ;; apply `f` to seven.
 
  ;; exercise 1: Use the trick discussed in class to define
  ;; a `fact` function that computes the factorial of a given
  ;; number. Use it to compute the factorial of 12.
 
  ;; exercise 2: Define a 'pow' function that accepts a base
  ;; and a (natural number) exponent, and computes the base to
  ;; the power of the exponent. Don't worry about non-natural
  ;; number exponents (6^1.5, 5^-4).
 
  ;; exercise 3: use `fact` and `pow` to build a "sin" function
  ;; that accepts a number x and a number of terms `n`, and computes
  ;; (sin x) using `n` terms of the taylor expansion. (Note that
  ;; this is a little ambigious; do zero-coefficient terms count?
  ;; You can go either way on this.) Use this function to compute
  ;; the sine of 1 radian to an error of no more than ten to the minus
  ;; 30th.
 
  )
 
;; this code actually invokes the 'my-mod1 module, so that the
;; code runs.
(require 'my-mod1)