Reference no: EM131041802
Because internal definitions look sequential but are actually simultaneous, some people prefer to avoid them entirely, and use the special form letrec instead. Letrec looks like let, so it is not surprising that the variables it binds are bound simultaneously and have the same scope as each other. The sample procedure f above can be written without internal definitions, but with exactly the same meaning, as
data:image/s3,"s3://crabby-images/849af/849af8c4ab3a485763570a4787c2627cd99f79b3" alt="1242_kk.jpg"
are a variation on let in which the expressions that provide the initial values for the variables are evaluated in an environment that includes all the letrec bindings. This permits recursion in the bindings, such as the mutual recursion of even? and odd? in the example above, or the evaluation of 10 factorial with
data:image/s3,"s3://crabby-images/eae2b/eae2b7e52a81fa3913ab96062a739101662bd37d" alt="1533_kk.jpg"
a. Implement letrec as a derived expression, by transforming a letrec expression into a let expression as shown in the text above or in exercise 4.18. That is, the letrec variables should be created with a let and then be assigned their values with set!.
b. Louis Reasoner is confused by all this fuss about internal definitions. The way he sees it, if you don't like to use define inside a procedure, you can just use let. Illustrate what is loose about his reasoning by drawing an environment diagram that shows the environment in which the is evaluated during evaluation of the expression (f 5), with f defined as in this exercise. Draw an environment diagram for the same evaluation, but with let in place of letrec in the definition of f.
exercise 4.18
Consider an alternative strategy for scanning out definitions that translates the example in the text to
data:image/s3,"s3://crabby-images/b5f5e/b5f5e876308f92df2aa336111909180f97d06cd9" alt="728_kk.jpg"
Here a and b are meant to represent new variable names, created by the interpreter, that do not appear in the user's program. Consider the solve procedure from section 3.5.4.
data:image/s3,"s3://crabby-images/056e1/056e1ad6980a1065e5d9ab9d5e7f46244731c508" alt="1657_kk.jpg"
Will this procedure work if internal definitions are scanned out as shown in this exercise? What if they are scanned out as shown in the text? Explain
What is the projects average accounting return
: You’re trying to determine whether or not to expand your business by building a new manufacturing plant. The plant has an installation cost of $21.4 million, which will be depreciated straight-line to zero over its four-year life. Required: If the pl..
|
Accrual accounting principles are applied
: Adjusting Entries are required at the end of the period to ensure that accrual accounting principles are applied. At the beginning of the month, $1,350 of office supplies were purchased. There was not a beginning balance and the one purchase was the ..
|
Develop a simple map application similar to uber app
: Develop a simple map application similar to Uber app. Display the Taxi ID and the distance to the customer for the nearest taxi.
|
Interest paid semiannually
: Rell Computers has 5.25 percent coupon bonds outstanding with a current market price of $546.19. The yield to maturity is 16.28 percent and the face value is $1,000. Interest paid semiannually. How many years is it until these bonds mature?
|
Internal definitions look sequential
: Because internal definitions look sequential but are actually simultaneous, some people prefer to avoid them entirely, and use the special form letrec instead. Letrec looks like let, so it is not surprising that the variables it binds are bound si..
|
Amount of the loan payment in year
: Home Repair, LLC just took out a $52,000, 10 year, 8%, interest only loan from the bank. Interest only payments are made annually. The entire principle due in year 10. What is the amount of the loan payment in year 10?
|
Room-selection sequence of property management system
: Intentional bias can be programmed (through computer algorithms) into the room-selection sequence of a property management system. Rooms will then appear in a prescribed order rather than in sequence or at random, certain rooms can be offered first, ..
|
Shopping today for new furniture
: You went shopping today for new furniture. You purchased some new furniture for $6,200 and paid for with your credit card. The interest rate is 14.9 percent, compounded monthly. How long will it take you to pay off this debt assuming that you do n..
|
Explain the difference between an invitation to treat
: Discuss and explain the difference between an invitation to treat and an offer with decided cases. Mr Lau owns a boat. On 18 May, he wrote to Mr Wen. In his letter, he said ‘I am interested in selling my boat for $350,000. The terms are: a deposit of..
|