1 (define (make-point x y)
8 (define (make-segment start end)
10 (define (start-segment seg)
12 (define (end-segment seg)
14 (define (midpoint-segment seg)
17 (let ((x1 (x-point (start-segment seg)))
18 (x2 (x-point (end-segment seg)))
19 (y1 (y-point (start-segment seg)))
20 (y2 (y-point (end-segment seg))))
21 (make-point (average x1 x2)
24 (define (print-point p)
32 (define x1y2 (make-point 1 2))
33 (define x-4y-3 (make-point -4 -3))
34 (define x1y2tox-4y-3 (make-segment x1y2 x-4y-3))
35 (print-point (midpoint-segment x1y2tox-4y-3))
36 (display "=(-3/2,-1/2)")
38 ;; Exercise 2.3. Implement a representation for rectangles in a plane. (Hint: You may want to make use of exercise 2.2.) In terms of your constructors and selectors, create procedures that compute the perimeter and the area of a given rectangle. Now implement a different representation for rectangles. Can you design your system with suitable abstraction barriers, so that the same perimeter and area procedures will work using either representation?
40 ;; makes rectangle given 2 points: top-left and bottom-right
41 (define (make-rect tl br)
42 (let ((tr (make-point (x-point br) (y-point tl)))
43 (bl (make-point (x-point tl) (y-point br))))
46 (define (top-left rect)
48 (define (bot-right rect)
50 (define (top-right rect)
52 (define (bot-left rect)
56 (- (x-point (top-right rect)) (x-point (top-left rect))))
58 (- (y-point (top-left rect)) (y-point (bot-left rect))))
60 (define (perimeter rect)
64 (* (width rect) (height rect)))
66 (define (test-case actual expected)
69 (format #t "Actual: ~A Expected: ~A" actual expected))
71 (define tl (make-point 1 6))
72 (define br (make-point 10 3))
73 (define rect (make-rect tl br))
74 (test-case (perimeter rect) 24)
75 (test-case (area rect) 27)
77 ;; makes rectangle given top-left corner, width, and height
78 (define (make-rect top-left width height)
79 (cons top-left (cons width height)))
80 (define (top-left rect)
82 (define (bot-right rect)
83 (make-rect (+ (x-point (top-left rect))
85 (- (y-point (top-left rect))
87 (define (top-right rect)
88 (make-rect (+ (x-point (top-left rect))
90 (y-point (top-left rect))))
91 (define (bot-left rect)
92 (make-rect (x-point (top-left rect))
93 (- (y-point (top-left rect))
101 (define rect (make-rect tl 9 3))
102 (test-case (perimeter rect) 24)
103 (test-case (area rect) 27)