 
              Local definitions and lexical scope Readings: HtDP , Intermezzo 3 (Section 18). Language level: Intermediate Student Topics: Motivating local definitions Semantics of local Reasons to use local Terminology Motivation Semantics Reasons Terminology 1/39 12: Local Definitions CS 135 Local definitions The functions and special forms we’ve seen so far can be arbitrarily nested—except define and check-expect . So far, definitions have to be made “at the top level”, outside any expression. The Intermediate language provides the special form local , which contains a series of local definitions plus an expression using them. ( local [( define x_1 exp_1) ... ( define x_n exp_n)] bodyexp) What use is this? Motivation Semantics Reasons Terminology 2/39 12: Local Definitions CS 135 Motivating local definitions Consider Heron’s formula for the area of a triangle with sides a , b , c : � s ( s − a )( s − b )( s − c ) , where s = ( a + b + c ) / 2 It is not hard to create a Racket function to compute this function, but it is difficult to do so in a clear and natural fashion. We will describe several possibilities, starting with a direct implementation. Motivation Semantics Reasons Terminology 3/39 12: Local Definitions CS 135
> Motivation: direct translation ( define (t-area-v0 a b c) (sqrt (* (/ (+ a b c) 2) (- (/ (+ a b c) 2) a) (- (/ (+ a b c) 2) b) (- (/ (+ a b c) 2) c)))) The repeated computation of s = ( a + b + c ) / 2 is awkward. Motivation Semantics Reasons Terminology 4/39 12: Local Definitions CS 135 > Motivation: rewrite expressions We could notice that s − a = ( − a + b + c ) / 2, and make similar substitutions. ( define (t-area-v1 a b c) (sqrt (* (/ (+ a b c) 2) (/ (+ (- a) b c) 2) (/ (+ a (- b) c) 2) (/ (+ a b (- c)) 2)))) This is slightly shorter, but its relationship to Heron’s formula is unclear from just reading the code, and the technique does not generalize. Motivation Semantics Reasons Terminology 5/39 12: Local Definitions CS 135 > Motivation: use a helper function (v1) We could instead use a helper function. This generalizes well to formulas that ( define (t-area-v2 a b c) define several intermediate quantities. (sqrt (* (s a b c) But the helper functions need (- (s a b c) a) parameters, which again makes the (- (s a b c) b) relationship to Heron’s formula hard to (- (s a b c) c)))) see. And there’s still repeated code ( define (s a b c) and repeated computations. (/ (+ a b c) 2)) Motivation Semantics Reasons Terminology 6/39 12: Local Definitions CS 135
> Motivation: use a helper function (v2) We could instead move the computation with a known value of s into a helper function, and provide the value of s as a parameter. ( define (t-area/s a b c s) (sqrt (* s (- s a) (- s b) (- s c)))) ( define (t-area-v3 a b c) (t-area/s a b c (/ (+ a b c) 2))) This is more readable, and shorter, but it is still awkward. The value of s is defined in one function and used in another. Motivation Semantics Reasons Terminology 7/39 12: Local Definitions CS 135 > Motivation: use local The local special form we introduced provides a natural way to bring the definition and use together. ( define (t-area-v4 a b c) ( local [( define s (/ (+ a b c) 2))] (sqrt (* s (- s a) (- s b) (- s c))))) Since local is another special form (like This is nice and short! cond ) that results in double parentheses, It looks like Heron’s formula. we will use square brackets to improve No repeated code or computations. readability. This is another convention . Motivation Semantics Reasons Terminology 8/39 12: Local Definitions CS 135 Semantics of local Local definitions permit reuse of names. This is not new to us: ( define n 10) ( define (myfn n) (+ 2 n)) (myfn 6) gives the answer 8, not 12. The substitution specified in the semantics of function application ensures that the correct value is used while evaluating the last line. Motivation Semantics Reasons Terminology 9/39 12: Local Definitions CS 135
> Reusing names The name of a formal parameter to a function may reuse (within the body of that function) a name which is bound to a value through define . Similarly, a define within a local expression may rebind a name which has already been bound to another value or expression. The substitution rules we define for local as part of the semantic model must handle this. The resulting substitution rule for local is the most complicated one we will see in this course. Motivation Semantics Reasons Terminology 10/39 12: Local Definitions CS 135 > Informal substitution rule for local The substitution rule works by replacing every name defined in the local with a fresh name (a.k.a. fresh identifier ) – a new, unique name that has not been used anywhere else in the program. Each old name within the local is replaced by the corresponding new name. Because the new name hasn’t been used elsewhere in the program, the local definitions (with the new name) can now be “promoted” to the top level of the program without affecting anything outside of the local . We can now use our existing rules to evaluate the program. The next slide shows an example (the last version of Heron’s formula). Then we’ll state the rule more rigourously. Motivation Semantics Reasons Terminology 11/39 12: Local Definitions CS 135 > Example: evaluating t-area4 We’ll need a fresh identifier to replace s . We’ll use s_47 , which we just made up. (t-area4 3 4 5) ⇒ ( local [( define s (/ (+ 3 4 5) 2))] (sqrt (* s (- s 3) (- s 4) (- s 5)))) ⇒ ( define s_47 (/ (+ 3 4 5) 2)) (sqrt (* s_47 (- s_47 3) (- s_47 4) (- s_47 5))) ⇒ ( define s_47 (/ 12 2)) (sqrt (* s_47 (- s_47 3) (- s_47 4) (- s_47 5))) ⇒ ( define s_47 6) (sqrt (* s_47 (- s_47 3) (- s_47 4) (- s_47 5))) ⇒ ... 6 Motivation Semantics Reasons Terminology 12/39 12: Local Definitions CS 135
> Substitution rule for local In general, an expression of the form ( local [( define x_1 exp_1) ... ( define x_n exp_n)] bodyexp) is handled as follows: x_i is replaced with a fresh identifier (call it x_i_new ) everywhere in the local expression, for 1 ≤ i ≤ n . The definitions ( define x_1_new exp_1) ... ( define x_n_new exp_n) are then lifted out (all at once) to the top level of the program, preserving their ordering. What remains looks like ( local [] bodyexp') , where bodyexp' is the rewritten version of bodyexp . Replace the local expression with bodyexp' . All of this (the renaming, the lifting, and removing the local with an empty definitions list) is a single step . Motivation Semantics Reasons Terminology 13/39 12: Local Definitions CS 135 > Revising function substitution Our previous statement about using ( define (foo x y) our existing rules isn’t quite correct. ( local [( define x y) ( define z (+ x y))] Consider the code on the right. (+ x z))) Where is 2 substituted for x ? (foo 2 3) (f v_1 ... v_n) ⇒ exp' where ( define (f x_1 ... x_n) exp) occurs to the left, and exp' is obtained by substituting into the expression exp , with all occurrences of the formal parameter x_i replaced by the value v_i (for i from 1 to n) except where x_1 has been redefined within exp (e.g. within a local ). Motivation Semantics Reasons Terminology 14/39 12: Local Definitions CS 135 Reasons to use local Clarity: Naming subexpressions Efficiency: Avoid recomputation Encapsulation: Hiding stuff Scope: Reusing parameters Motivation Semantics Reasons Terminology 15/39 12: Local Definitions CS 135
> Clarity: naming subexpressions A subexpression used twice within a function body always yields the same value. Using local to give the reused subexpression a name improves the readability of the code. This was a motivating factor in t-area . Naming the subexpression made the relationship to Heron’s Formula clear. ( define (t-area-v4 a b c) ( local [( define s (/ (+ a b c) 2))] (sqrt (* s (- s a) (- s b) (- s c))))) Motivation Semantics Reasons Terminology 16/39 12: Local Definitions CS 135 > Clarity: mnemonic names Sometimes we choose to use local in order to name subexpressions mnemonically to make the code more readable, even if they are not reused. This may make the code longer. ( define-struct coord (x y)) ( define (distance p1 p2) (sqrt (+ (sqr (- (coord-x p1) (coord-x p2))) (sqr (- (coord-y p1) (coord-y p2)))))) ( define (distance p1 p2) ( local [( define delta-x (- (coord-x p1) (coord-x p2))) ( define delta-y (- (coord-y p1) (coord-y p2)))] (sqrt (+ (sqr delta-x) (sqr delta-y))))) Motivation Semantics Reasons Terminology 17/39 12: Local Definitions CS 135 Exercise 1 Write a function (sum-odds-or-evens L) that consumes a (listof Int) . If there are more evens than odds, the function returns the sum of the evens. Otherwise, it returns the sum of the odds. Start by creating a local constant that contains a list of even numbers, and another that contains a list of odd numbers. (sum-odds-or-evens '(1 3 5 20 30)) ⇒ 9
Recommend
More recommend