How to resolve the algorithm Jensen's Device step by step in the Sidef programming language

Published on 12 May 2024 09:40 PM

How to resolve the algorithm Jensen's Device step by step in the Sidef programming language

Table of Contents

Problem Statement

This task is an exercise in call by name. Jensen's Device is a computer programming technique devised by Danish computer scientist Jørn Jensen after studying the ALGOL 60 Report. The following program was proposed to illustrate the technique. It computes the 100th harmonic number: The above exploits call by name to produce the correct answer (5.187...). It depends on the assumption that an expression passed as an actual parameter to a procedure would be re-evaluated in the caller's context every time the corresponding formal parameter's value was required. If the last parameter to sum had been passed by value, and assuming the initial value of i were 1, the result would have been 100 × 1/1 = 100. Moreover, the first parameter to sum, representing the "bound" variable of the summation, must also be passed by name (or at least by reference), otherwise changes to it (made within sum) would not be visible in the caller's context when computing each of the values to be added. (On the other hand, the global variable does not have to use the same identifier, in this case i, as the formal parameter.) Donald Knuth later proposed the Man or Boy Test as a more rigorous exercise.

Let's start with the solution:

Step by Step solution about How to resolve the algorithm Jensen's Device step by step in the Sidef programming language

Source code in the sidef programming language

var i
func sum (i, lo, hi, term) {
    var temp = 0
    for (*i = lo; *i <= hi; (*i)++) {
        temp += term.run
    }
    return temp
}
say sum(\i, 1, 100, { 1 / i })


  

You may also check:How to resolve the algorithm Y combinator step by step in the Scheme programming language
You may also check:How to resolve the algorithm Thue-Morse step by step in the Phixmonti programming language
You may also check:How to resolve the algorithm Increment a numerical string step by step in the jq programming language
You may also check:How to resolve the algorithm Forest fire step by step in the Wren programming language
You may also check:How to resolve the algorithm Runge-Kutta method step by step in the Java programming language