How to resolve the algorithm Y combinator step by step in the Elena programming language
How to resolve the algorithm Y combinator step by step in the Elena programming language
Table of Contents
Problem Statement
In strict functional programming and the lambda calculus, functions (lambda expressions) don't have state and are only allowed to refer to arguments of enclosing functions. This rules out the usual definition of a recursive function wherein a function is associated with the state of a variable and this variable's state is used in the body of the function. The Y combinator is itself a stateless function that, when applied to another stateless function, returns a recursive version of the function. The Y combinator is the simplest of the class of such functions, called fixed-point combinators.
Define the stateless Y combinator and use it to compute factorials and Fibonacci numbers from other stateless functions or lambda expressions.
Let's start with the solution:
Step by Step solution about How to resolve the algorithm Y combinator step by step in the Elena programming language
Source code in the elena programming language
import extensions;
singleton YCombinator
{
fix(func)
= (f){(x){ x(x) }((g){ f((x){ (g(g))(x) })})}(func);
}
public program()
{
var fib := YCombinator.fix:(f => (i => (i <= 1) ? i : (f(i-1) + f(i-2)) ));
var fact := YCombinator.fix:(f => (i => (i == 0) ? 1 : (f(i-1) * i) ));
console.printLine("fib(10)=",fib(10));
console.printLine("fact(10)=",fact(10));
}
You may also check:How to resolve the algorithm Mandelbrot set step by step in the DWScript programming language
You may also check:How to resolve the algorithm Pragmatic directives step by step in the 8086 Assembly programming language
You may also check:How to resolve the algorithm Move-to-front algorithm step by step in the Icon and Unicon programming language
You may also check:How to resolve the algorithm Identity matrix step by step in the K programming language
You may also check:How to resolve the algorithm Walk a directory/Non-recursively step by step in the Common Lisp programming language