How to resolve the algorithm Jensen's Device step by step in the OCaml programming language
How to resolve the algorithm Jensen's Device step by step in the OCaml 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 OCaml programming language
Source code in the ocaml programming language
let i = ref 42 (* initial value doesn't matter *)
let sum' i lo hi term =
let result = ref 0. in
i := lo;
while !i <= hi do
result := !result +. term ();
incr i
done;
!result
let () =
Printf.printf "%f\n" (sum' i 1 100 (fun () -> 1. /. float !i))
You may also check:How to resolve the algorithm Compare length of two strings step by step in the BQN programming language
You may also check:How to resolve the algorithm Dragon curve step by step in the Openscad programming language
You may also check:How to resolve the algorithm Animation step by step in the Scala programming language
You may also check:How to resolve the algorithm Empty program step by step in the Raven programming language
You may also check:How to resolve the algorithm Function frequency step by step in the LiveCode programming language