Recursion
Recursion occurs when the definition of a concept or process depends on a simpler or previous version of itself.[1] Recursion is used in a variety of disciplines ranging from linguistics to logic. The most common application of recursion is in mathematics and computer science, where a function being defined is applied within its own definition. While this apparently defines an infinite number of instances (function values), it is often done in such a way that no infinite loop or infinite chain of references can occur.
A process that exhibits recursion is recursive. Video feedback displays recursive images, as does an infinity mirror.
Formal definitions
In mathematics and computer science, a class of objects or methods exhibits recursive behavior when it can be defined by two properties:
- A simple base case (or cases) — a terminating scenario that does not use recursion to produce an answer
- A recursive step — a set of rules that reduces all successive cases toward the base case.
For example, the following is a recursive definition of a person's ancestor. One's ancestor is either:
- One's parent (base case), or
- One's parent's ancestor (recursive step).
The Fibonacci sequence is another classic example of recursion:
- Fib(0) = 0 as base case 1,
- Fib(1) = 1 as base case 2,
- For all integers n > 1, Fib(n) = Fib(n − 1) + Fib(n − 2).
Many mathematical axioms are based upon recursive rules. For example, the formal definition of the natural numbers by the Peano axioms can be described as: "Zero is a natural number, and each natural number has a successor, which is also a natural number."[2] By this base case and recursive rule, one can generate the set of all natural numbers.
Other recursively defined mathematical objects include
There are various more tongue-in-cheek definitions of recursion; see recursive humor.
Informal definition
Recursion is the process a procedure goes through when one of the steps of the procedure involves invoking the procedure itself. A procedure that goes through recursion is said to be 'recursive'.[3]
To understand recursion, one must recognize the distinction between a procedure and the running of a procedure. A procedure is a set of steps based on a set of rules, while the running of a procedure involves actually following the rules and performing the steps.
Recursion is related to, but not the same as, a reference within the specification of a procedure to the execution of some other procedure.
When a procedure is thus defined, this immediately creates the possibility of an endless loop; recursion can only be properly used in a definition if the step in question is skipped in certain cases so that the procedure can complete.
Even if it is properly defined, a recursive procedure is not easy for humans to perform, as it requires distinguishing the new from the old, partially executed invocation of the procedure; this requires some administration as to how far various simultaneous instances of the procedures have progressed. For this reason, recursive definitions are very rare in everyday situations.
In language
Linguist Noam Chomsky, among many others, has argued that the lack of an upper bound on the number of grammatical sentences in a language, and the lack of an upper bound on grammatical sentence length (beyond practical constraints such as the time available to utter one), can be explained as the consequence of recursion in natural language.[4][5]
This can be understood in terms of a recursive definition of a syntactic category, such as a sentence. A sentence can have a structure in which what follows the verb is another sentence: Dorothy thinks witches are dangerous, in which the sentence witches are dangerous occurs in the larger one. So a sentence can be defined recursively (very roughly) as something with a structure that includes a noun phrase, a verb, and optionally another sentence. This is really just a special case of the mathematical definition of recursion.
This provides a way of understanding the creativity of language—the unbounded number of grammatical sentences—because it immediately predicts that sentences can be of arbitrary length: Dorothy thinks that Toto suspects that Tin Man said that.... There are many structures apart from sentences that can be defined recursively, and therefore many ways in which a sentence can embed instances of one category inside another.[6] Over the years, languages in general have proved amenable to this kind of analysis.
The generally accepted idea that recursion is an essential property of human language has been challenged by Daniel Everett on the basis of his claims about the Pirahã language. Andrew Nevins, David Pesetsky and Cilene Rodrigues are among many who have argued against this.[7] Literary self-reference can in any case be argued to be different in kind from mathematical or logical recursion.[8]
Recursion plays a crucial role not only in syntax, but also in
A recursive grammar is a formal grammar that contains recursive production rules.[10]
Recursive humor
Recursion is sometimes used humorously in computer science, programming, philosophy, or mathematics textbooks, generally by giving a circular definition or self-reference, in which the putative recursive step does not get closer to a base case, but instead leads to an infinite regress. It is not unusual for such books to include a joke entry in their glossary along the lines of:
- Recursion, see Recursion.[11]
A variation is found on page 269 in the
Another joke is that "To understand recursion, you must understand recursion."[11] In the English-language version of the Google web search engine, when a search for "recursion" is made, the site suggests "Did you mean: recursion."[14] An alternative form is the following, from Andrew Plotkin: "If you already know what recursion is, just remember the answer. Otherwise, find someone who is standing closer to Douglas Hofstadter than you are; then ask him or her what recursion is."
Recursive acronyms are other examples of recursive humor. PHP, for example, stands for "PHP Hypertext Preprocessor", WINE stands for "WINE Is Not an Emulator", GNU stands for "GNU's not Unix", and SPARQL denotes the "SPARQL Protocol and RDF Query Language".
In mathematics
Recursively defined sets
Example: the natural numbers
The canonical example of a recursively defined set is given by the
- 0 is in
- if n is in , then n + 1 is in
- The set of natural numbers is the smallest set satisfying the previous two properties.
In mathematical logic, the Peano axioms (or Peano postulates or Dedekind–Peano axioms), are axioms for the natural numbers presented in the 19th century by the German mathematician Richard Dedekind and by the Italian mathematician Giuseppe Peano. The Peano Axioms define the natural numbers referring to a recursive successor function and addition and multiplication as recursive functions.
Example: Proof procedure
Another interesting example is the set of all "provable" propositions in an axiomatic system that are defined in terms of a proof procedure which is inductively (or recursively) defined as follows:
- If a proposition is an axiom, it is a provable proposition.
- If a proposition can be derived from true reachable propositions by means of inference rules, it is a provable proposition.
- The set of provable propositions is the smallest set of propositions satisfying these conditions.
Finite subdivision rules
Finite subdivision rules are a geometric form of recursion, which can be used to create fractal-like images. A subdivision rule starts with a collection of polygons labelled by finitely many labels, and then each polygon is subdivided into smaller labelled polygons in a way that depends only on the labels of the original polygon. This process can be iterated. The standard `middle thirds' technique for creating the Cantor set is a subdivision rule, as is barycentric subdivision.
Functional recursion
A
Proofs involving recursive definitions
Applying the standard technique of
Recursive optimization
The recursion theorem
In set theory, this is a theorem guaranteeing that recursively defined functions exist. Given a set X, an element a of X and a function f: X → X, the theorem states that there is a unique function (where denotes the set of natural numbers including zero) such that
for any natural number n.
Dedekind was the first to pose the problem of unique definition of set-theoretical functions on by recursion, and gave a sketch of an argument in the 1888 essay "Was sind und was sollen die Zahlen?" [15]
Proof of uniqueness
Take two functions and such that:
where a is an element of X.
It can be proved by mathematical induction that F(n) = G(n) for all natural numbers n:
- Base Case: F(0) = a = G(0) so the equality holds for n = 0.
- Inductive Step: Suppose F(k) = G(k) for some . Then F(k + 1) = f(F(k)) = f(G(k)) = G(k + 1).
- Hence F(k) = G(k) implies F(k + 1) = G(k + 1).
By induction, F(n) = G(n) for all .
In computer science
A common method of simplification is to divide a problem into subproblems of the same type. As a
A classic example of recursion is the definition of the factorial function, given here in Python code:
def factorial(n):
if n > 0:
return n * factorial(n - 1)
else:
return 1
The function calls itself recursively on a smaller version of the input (n - 1)
and multiplies the result of the recursive call by n
, until reaching the
Recursion in computer programming is exemplified when a function is defined in terms of simpler, often smaller versions of itself. The solution to the problem is then devised by combining the solutions obtained from the simpler versions of the problem. One example application of recursion is in
Recurrence relations are equations which define one or more sequences recursively. Some specific kinds of recurrence relation can be "solved" to obtain a non-recursive definition (e.g., a closed-form expression).
Use of recursion in an algorithm has both advantages and disadvantages. The main advantage is usually the simplicity of instructions. The main disadvantage is that the memory usage of recursive algorithms may grow very quickly, rendering them impractical for larger instances.
In biology
Shapes that seem to have been created by recursive processes sometimes appear in plants and animals, such as in branching structures in which one large part branches out into two or more similar smaller parts. One example is Romanesco broccoli.[16]
In the social sciences
Authors use the concept of recursivity to foreground the situation in which specifically social scientists find themselves when producing knowledge about the world they are always already part of.[17][18] According to Audrey Alejandro, “as social scientists, the recursivity of our condition deals with the fact that we are both subjects (as discourses are the medium through which we analyse) and objects of the academic discourses we produce (as we are social agents belonging to the world we analyse).”[19] From this basis, she identifies in recursivity a fundamental challenge in the production of emancipatory knowledge which calls for the exercise of reflexive efforts:
we are socialised into discourses and dispositions produced by the socio-political order we aim to challenge, a socio-political order that we may, therefore, reproduce unconsciously while aiming to do the contrary. The recursivity of our situation as scholars – and, more precisely, the fact that the dispositional tools we use to produce knowledge about the world are themselves produced by this world – both evinces the vital necessity of implementing reflexivity in practice and poses the main challenge in doing so.
— Audrey Alejandro, Alejandro (2021)
In business
Recursion is sometimes referred to in management science as the process of iterating through levels of abstraction in large business entities.[20] A common example is the recursive nature of management hierarchies, ranging from line management to senior management via middle management. It also encompasses the larger issue of capital structure in corporate governance.[21]
In art
The Matryoshka doll is a physical artistic example of the recursive concept.[22]
Recursion has been used in paintings since Giotto's Stefaneschi Triptych, made in 1320. Its central panel contains the kneeling figure of Cardinal Stefaneschi, holding up the triptych itself as an offering.[23][24] This practice is more generally known as the Droste effect, an example of the Mise en abyme technique.
In culture
The film Inception has colloquialized the appending of the suffix -ception to a noun to jokingly indicate the recursion of something.[26]
See also
- Corecursion – Type of algorithm in computer science
- Course-of-values recursion – Technique for defining number-theoretic functions by recursion
- Digital infinity – Term in theoretical linguistics
- A Dream Within a Dream (poem)– Poem by Edgar Allan Poe
- Droste effect – Recursive visual effect
- False awakening – Vivid and convincing dream about awakening from sleep
- Fixed point combinator– Higher-order function Y for which Y f = f (Y f)
- Infinite compositions of analytic functions – Mathematical theory about infinitely iterated function composition
- Infinite loop – Programming idiom
- Infinite regress – Philosophical problem
- Infinitism – Philosophical view that knowledge may be justified by an infinite chain of reasons
- Infinity mirror – Parallel or angled mirrors, creating smaller reflections that appear to recede to infinity
- Iterated function – Result of repeatedly applying a mathematical function
- Mathematical induction – Form of mathematical proof
- Mise en abyme – Technique of placing a copy of an image within itself, or a story within a story
- Reentrant (subroutine)– Concept in computer programming
- Self-reference – Sentence, idea or formula that refers to itself
- Spiegel im Spiegel – 1978 musical composition by Arvo Pärt
- Strange loop – Cyclic structure that goes through several levels in a hierarchical system
- Tail recursion– Subroutine call performed as final action of a procedure
- Tupper's self-referential formula – Formula that visually represents itself when graphed
- Turtles all the way down – Statement of infinite regress
References
- OCLC 62093042.
- ^ "Peano axioms | mathematics". Encyclopedia Britannica. Retrieved 2019-10-24.
- ^ "Definition of RECURSIVE". www.merriam-webster.com. Retrieved 2019-10-24.
- ^ Pinker, Steven (1994). The Language Instinct. William Morrow.
- S2CID 1599505.
- ^ Nordquist, Richard. "What Is Recursion in English Grammar?". ThoughtCo. Retrieved 2019-10-24.
- S2CID 16915455. Archived from the original(PDF) on 2012-01-06.
- ISBN 978-0-8176-4768-1.
- ^ Barbara Partee and Mats Rooth. 1983. In Rainer Bäuerle et al., Meaning, Use, and Interpretation of Language. Reprinted in Paul Portner and Barbara Partee, eds. 2002. Formal Semantics: The Essential Readings. Blackwell.
- .
- ^ ISBN 9781449604424.
- ^ Shaffer, Eric. "CS 173:Discrete Structures" (PDF). University of Illinois at Urbana-Champaign. Retrieved 7 July 2023.
- ^ "Introduction to Computer Science and Programming in C; Session 8: September 25, 2008" (PDF). Columbia University. Retrieved 7 July 2023.
- ^ "recursion - Google Search". www.google.com. Retrieved 2019-10-24.
- ^ A. Kanamori, "In Praise of Replacement", pp.50--52. Bulletin of Symbolic Logic, vol. 18, no. 1 (2012). Accessed 21 August 2023.
- ^ "Picture of the Day: Fractal Cauliflower". 28 December 2012. Retrieved 19 April 2020.
- ^ Bourdieu, Pierre (1992). "Double Bind et Conversion". Pour Une Anthropologie Réflexive. Paris: Le Seuil.
- ^ Giddens, Anthony (1987). Social Theory and Modern Sociology. Polity Press.
- S2CID 229461433.
- .
- ISBN 978-0471948391.
- ^ Tang, Daisy. "Recursion". Retrieved 24 September 2015.
More examples of recursion: Russian Matryoshka dolls. Each doll is made of solid wood or is hollow and contains another Matryoshka doll inside it.
- ^ "Giotto di Bondone and assistants: Stefaneschi triptych". The Vatican. Retrieved 16 September 2015.
- ISBN 9783319708157.
- ^ Cooper, Jonathan (5 September 2007). "Art and Mathematics". Retrieved 5 July 2020.
- ^ "-ception – The Rice University Neologisms Database". Rice University. Archived from the original on July 5, 2017. Retrieved December 23, 2016.
Bibliography
- S2CID 127891023.
- ISBN 978-0-13-117686-7.
- ISBN 978-0-465-02656-2.
- ISBN 978-1-56881-149-9.
- ISBN 978-0-7637-1695-0.
- Cori, Rene; Lascar, Daniel; Pelletier, Donald H. (2001). Recursion Theory, Gödel's Theorems, Set Theory, Model Theory. Oxford University Press. ISBN 978-0-19-850050-6.
- ISBN 978-0-19-850050-6. - offers a treatment of corecursion.
- Rosen, Kenneth H. (2002). Discrete Mathematics and Its Applications. McGraw-Hill College. ISBN 978-0-07-293033-7.
- Cormen, Thomas H.; Leiserson, Charles E.; Rivest, Ronald L.; Stein, Clifford (2001). Introduction to Algorithms. Mit Pr. ISBN 978-0-262-03293-3.
- Kernighan, B.; Ritchie, D. (1988). The C programming Language. Prentice Hall. ISBN 978-0-13-110362-7.
- Stokey, Nancy; Robert Lucas; Edward Prescott (1989). Recursive Methods in Economic Dynamics. Harvard University Press. ISBN 978-0-674-75096-8.
- Hungerford (1980). Algebra. Springer. ISBN 978-0-387-90518-1., first chapter on set theory.