Recursion: Difference between revisions

Content deleted Content added
revert (count+1);
archive deadlink
 
(819 intermediate revisions by more than 100 users not shown)
Line 1:
{{Short description|Process of repeating items in a self-similar way}}
{{Other uses|Recursive (disambiguation)}}
{{Other uses}}
{{No footnotes|date=February 2010}}
{{pp-vandalism|small=yes}}
[[Image:Droste.jpg|thumb|A visual form of recursion known as the ''[[Droste effect]]''. The woman in this image is holding an object which contains a smaller image of her holding the same object, which in turn contains a smaller image of herself holding the same object, and so forth.]]
<!-- Making the Recursion article link to itself will not display correctly, and is considered to break [[WP:ASTONISH]]. The joke itself is already featured in the "Recursive humor" section. See discussion on the talk page. -->
'''Recursion''' is the process of repeating items in a [[Self-similarity|self-similar]] way. For instance, when the surfaces of two mirrors are exactly parallel with each other the nested images that occur are a form of infinite recursion. The term has a variety of meanings specific to a variety of disciplines ranging from [[linguistics]] to [[logic]]. The most common application of recursion is in [[mathematics]] and [[computer science]], in which it refers to a method of defining [[function (mathematics)|functions]] in which the function being defined is applied within its own definition. Specifically this defines an infinite number of instances (function values), using a finite expression that for some instances may refer to other instances, but in such a way that no loop or infinite chain of references can occur. The term is also used more generally to describe a process of repeating objects in a self-similar way.
 
[[File:Droste Cacao Alcalinise blikje, foto4.JPG|thumb|A visual form of recursion known as the [[Droste effect]]. The woman in this image holds an object that contains a smaller image of her holding an identical object, which in turn contains a smaller image of herself holding an identical object, and so forth. 1904 Droste [[hot chocolate|cocoa]] tin, designed by Jan Misset.]]
==Formal definitions of recursion==
[[File:Screenshot Recursion via vlc.png|thumb|Recursion in a screen recording program, where the smaller window contains a snapshot of the entire screen.]]
In [[mathematics]] and [[computer science]], a class of objects or methods exhibit recursive behavior when they can be defined by two properties:
 
'''Recursion''' occurs when the definition of a concept or process depends on a simpler or previous version of itself.<ref>{{Cite book |last=Causey |first=Robert L. |title=Logic, sets, and recursion |date=2006 |publisher=Jones and Bartlett Publishers |isbn=0-7637-3784-4 |edition=2nd|___location=Sudbury, Mass. |oclc=62093042}}</ref> 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 (mathematics)|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 simple base case (or cases), and
# A set of rules which reduce all other cases toward the base case.
 
A process that exhibits recursion is ''recursive''. [[Video feedback]] displays recursive images, as does an [[infinity mirror]].
For example, the following is a recursive definition of a person's ancestors:
*One's [[parent]]s are one's [[ancestor]]s (''base case'').
*The parents of one's ancestors are also one's ancestors (''recursion step'').
 
==Formal definitions==
The [[Fibonacci sequence]] is a classic example of recursion:
[[File:Serpiente alquimica.jpg|thumb|[[Ouroboros]], an ancient symbol depicting a serpent or dragon eating its own tail]]
In mathematics and computer science, a class of objects or methods exhibits recursive behavior when it can be defined by two properties:
* {{anchor|base case}}A simple ''base case'' (or cases) — a terminating scenario that does not use recursion to produce an answer
* {{anchor|recursive step}}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:
* Fib(0) is 0 [base case]
*One's parent Fib(1) is 1 [''base case]''), ''or''
*One's parent's ancestor (''recursive step'').
* For all integers n > 1: Fib(n) is (Fib(n-1) + Fib(n-2)) [recursive definition]
 
The [[Fibonacci sequence]] is another classic example of recursion:
Many mathematical axioms are based upon recursive rules. For example, the formal definition of the [[natural number]]s in [[set theory]] follows: 1 is a natural number, and each natural number has a successor, which is also a natural number. By this base case and recursive rule, one can generate the set of all natural numbers
 
:{{math|1=Fib(0) = 0}} as base case 1,
A more humorous illustration goes: ''"To understand recursion, you must first understand recursion."'' Or perhaps more accurate 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."''
 
:{{math|1=Fib(1) = 1}} as base case 2,
Recursively defined mathematical objects include [[function (mathematics)|function]]s, [[set (mathematics)|sets]], and especially [[fractal]]s.
 
:For all [[integer]]s {{math|''n'' > 1}}, {{math|1=Fib(''n'') = Fib(''n'' − 1) + Fib(''n'' − 2)}}.
==Recursion in language==
Linguist [[Noam Chomsky]] theorizes that unlimited extension of a language such as [[English language|English]] is possible using the recursive device of embedding phrases within sentences. Thus, a chatty person may say, ''"Dorothy, who met the wicked Witch of the West in Munchkin Land where her wicked Witch sister was killed, liquidated her with a pail of water."'' Clearly, two simple sentences—''"Dorothy met the Wicked Witch of the West in Munchkin Land"'' and ''"Her sister was killed in Munchkin Land"''—can be embedded in a third sentence, ''"Dorothy liquidated her with a pail of water,"'' to obtain a very verbose sentence.
 
Many mathematical axioms are based upon recursive rules. For example, the formal definition of the [[natural number]]s 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."<ref>{{Cite web|url=https://www.britannica.com/science/Peano-axioms|title=Peano axioms {{!}} mathematics|website=Encyclopedia Britannica|language=en|access-date=2019-10-24}}</ref> By this base case and recursive rule, one can generate the set of all natural numbers.
The idea that recursion is an essential property of human language (as Chomsky suggests) is challenged by [[linguistics|linguist]] [[Daniel Everett]] in his work ''Cultural Constraints on Grammar and Cognition in Pirahã: Another Look at the Design Features of Human Language'', in which he hypothesizes that cultural factors made recursion unnecessary in the development of the [[Pirahã language]]. This concept, which challenges Chomsky's idea that recursion is the only trait which differentiates human and animal communication, is currently under debate.
Nevins, Andrew and David Pesetsky and Cilene Rodrigues provide a debate against this proposal in Evidence and Argumentation: A Reply to Everett (2009). Language 85.3: 671--681 (2009). Indirect proof that Everett's ideas are wrong comes from works in neurolinguistics where it appears that all human beings are endowed with the very same neurobiological structures to manage with all and only recursive languages. For a review, see Kaan et al. (2002)
 
Other recursively defined mathematical objects include [[factorial]]s, [[function (mathematics)|function]]s (e.g., [[recurrence relation]]s), [[set (mathematics)|sets]] (e.g., [[Cantor ternary set]]), and [[fractal]]s.
Recursion in linguistics enables 'discrete infinity' by embedding phrases within phrases of the same type in a hierarchical structure. Without recursion, language does not have 'discrete infinity' and cannot embed sentences into infinity (with a '[[Matryoshka doll|Russian nesting doll]]' effect). Everett contests that language must have discrete infinity, and that the Pirahã language - which he claims lacks recursion - is in fact finite. He likens it to the finite game of [[chess]], which has a finite number of moves but is nevertheless very productive, with novel moves being discovered throughout history.
 
There are various more tongue-in-cheek definitions of recursion; see [[#Recursive humor|recursive humor]].
===Recursion in plain English===
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'.
 
==Informal definition==
To understand recursion, one must recognize the distinction between a procedure and the running of a procedure. A procedure is a set of steps that are to be taken based on a set of rules. The running of a procedure involves actually following the rules and performing the steps. An analogy might be that a procedure is like a cookbook in that it is the possible steps, while running a procedure is actually preparing the meal.
[[File:Mixing Sourdough starter into the flour.jpg|thumb|[[Sourdough starter]] being stirred into flour to produce sourdough: the recipe calls for some sourdough left over from the last time the same recipe was made.]]
 
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'.<ref>{{Cite web|url=https://www.merriam-webster.com/dictionary/recursive|title=Definition of RECURSIVE|website=www.merriam-webster.com|language=en|access-date=2019-10-24}}</ref>
Recursion is related to, but not the same as, a reference within the specification of a procedure to the execution of some other procedure. For instance, a recipe might refer to cooking vegetables, which is another procedure that in turn requires heating water, and so forth. However, a recursive procedure is special in that (at least) one of its steps calls for a new instance of the very same procedure. This of course immediately creates the danger 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 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 of how far various simultaneous instances of the procedures have progressed. For this reason recursive definitions are very rare in everyday situations. An example could be the following procedure to find a way through a [[maze]]. Proceed forward until reaching either an exit or a branching point (a dead end is considered a branching point with 0 branches). If the point reached is an exit, terminate. Otherwise try each branch in turn, using the procedure recursively; if every trial fails by reaching only dead ends, return on the path that led to this branching point and report failure. Whether this actually defines a terminating procedure depends on the nature of the maze: it must not allow loops. In any case, executing the procedure requires carefully recording all currently explored branching points, and which of their branches have already been exhaustively tried.
 
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.
===Recursive humor===
A common joke is the following "definition" of recursion.<ref>{{cite web|url=http://catb.org/~esr/jargon/html/R/recursion.html |title=recursion |publisher=Catb.org |date= |accessdate=2010-04-07}}</ref>
 
Recursion is related to, but not the same as, a reference within the specification of a procedure to the execution of some other procedure.
:'''Recursion'''
::See "Recursion".
 
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.
A variation on this joke is:
 
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.
: '''Recursion'''
:: If you still don't get it, see: "Recursion".
 
==In language==
which actually ''does'' terminate, as soon as the reader "gets it".
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.<ref>{{cite book|last=Pinker|first=Steven|title=The Language Instinct|year=1994|publisher=William Morrow}}</ref><ref>{{cite journal | doi = 10.1016/j.cognition.2004.08.004 | title = The faculty of language: What's so special about it? | year = 2005 | last1 = Pinker | first1=Steven | last2 = Jackendoff | first2=Ray | journal = Cognition | volume = 95 | issue = 2 | pages = 201–236 | pmid=15694646| citeseerx = 10.1.1.116.7784 | s2cid = 1599505 }}</ref>
 
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.{{Clarification needed|date=August 2025}}
Another example occurs in an index entry on page 269 of some editions of Kernighan and Ritchie's book "[[The C Programming Language (book)|The C Programming Language]]":
 
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.<ref>{{Cite web|url=https://www.thoughtco.com/recursion-grammar-1691901|title=What Is Recursion in English Grammar?|last=Nordquist|first=Richard|website=ThoughtCo|language=en|access-date=2019-10-24}}</ref> Over the years, languages in general have proved amenable to this kind of analysis.
::''recursion 86, 139, 141, 182, 202, 269''
 
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.<ref>{{cite journal |doi=10.1353/lan.0.0140 |title=Evidence and argumentation: A reply to Everett (2009) |url=http://web.mit.edu/linguistics/people/faculty/pesetsky/Nevins_Pesetsky_Rodrigues_2_Evidence_and_Argumentation_Reply_to_Everett.pdf |year=2009 |last1=Nevins |first1=Andrew |last2=Pesetsky |first2=David |last3=Rodrigues |first3=Cilene |journal=Language |volume=85 |issue=3 |pages=671–681 |s2cid=16915455 |archive-url=https://web.archive.org/web/20120106154616/http://web.mit.edu/linguistics/people/faculty/pesetsky/Nevins_Pesetsky_Rodrigues_2_Evidence_and_Argumentation_Reply_to_Everett.pdf |archive-date=2012-01-06}}</ref> Literary [[self-reference]] can in any case be argued to be different in kind from mathematical or logical recursion.<ref name="Drucker2008">{{cite book |last=Drucker|first=Thomas |title=Perspectives on the History of Mathematical Logic |url=https://books.google.com/books?id=R70M4zsVgREC&pg=PA110 |date=4 January 2008 |publisher=Springer Science & Business Media |isbn=978-0-8176-4768-1 |page=110}}</ref>
The earliest version of this joke was in "Software Tools" by Kernighan and Plauger, and also appears in "The UNIX Programming Environment" by Kernighan and Pike. It did not appear in the first edition of The C Programming Language.
 
Recursion plays a crucial role not only in syntax, but also in [[natural language semantics]]. The word ''and'', for example, can be construed as a function that can apply to sentence meanings to create new sentences, and likewise for noun phrase meanings, verb phrase meanings, and others. It can also apply to intransitive verbs, transitive verbs, or ditransitive verbs. In order to provide a single denotation for it that is suitably flexible, ''and'' is typically defined so that it can take any of these different types of meanings as arguments. This can be done by defining it for a simple case in which it combines sentences, and then defining the other cases recursively in terms of the simple one.<ref>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.</ref>
A Google search for '''Recursion''' suggests ''Did you mean: Recursion'' <ref>[http://www.google.com/search?q=recursion Google Search for word ''recursion'']</ref>
 
A [[recursive grammar]] is a [[formal grammar]] that contains recursive [[production (computer science)|production rules]].<ref name="ns02">{{citation
Other examples are [[recursive acronym]]s, such as [[GNU]], [[PHP]], [[YAML]], [[HURD]] or [[Wine_(software)|WINE]].
| last1 = Nederhof | first1 = Mark-Jan
| last2 = Satta | first2 = Giorgio
| contribution = Parsing Non-recursive Context-free Grammars
| doi = 10.3115/1073083.1073104
| ___location = Stroudsburg, PA, USA
| pages = 112–119
| publisher = Association for Computational Linguistics
| title = Proceedings of the 40th Annual Meeting on Association for Computational Linguistics (ACL '02)
| year = 2002| doi-access = free
}}.</ref>
 
===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''.<ref name=Hunter>{{cite book|last=Hunter|first=David|title=Essentials of Discrete Mathematics|year=2011|publisher=Jones and Bartlett|pages=494|url=https://books.google.com/books?id=kuwhTxCVovQC&q=recursion+joke|isbn=9781449604424}}</ref>
 
A variation is found on page 269 in the [[Back-of-the-book index|index]] of some editions of [[Brian Kernighan]] and [[Dennis Ritchie]]'s book ''[[The C Programming Language]]''; the index entry recursively references itself ("recursion 86, 139, 141, 182, 202, 269"). Early versions of this joke can be found in ''Let's talk Lisp'' by Laurent Siklóssy (published by Prentice Hall PTR on December 1, 1975, with a copyright date of 1976) and in ''Software Tools'' by Kernighan and Plauger (published by Addison-Wesley Professional on January 11, 1976). The joke also appears in ''The UNIX Programming Environment'' by Kernighan and Pike. It did not appear in the first edition of ''The C Programming Language''. The joke is part of the [[functional programming]] folklore and was already widespread in the functional programming community before the publication of the aforementioned books. <ref name="Grainger College">{{cite web |last1=Shaffer |first1=Eric |title=CS 173:Discrete Structures |url=https://courses.engr.illinois.edu/cs173/sp2009/Lectures/lect_19.pdf |publisher=University of Illinois at Urbana-Champaign |access-date=7 July 2023}}</ref><ref name="Columbia University">{{cite web |title=Introduction to Computer Science and Programming in C; Session 8: September 25, 2008 |url=http://www.cs.columbia.edu/~bert/courses/1003/lecture8.pdf |publisher=Columbia University |access-date=7 July 2023}}</ref>
 
[[File:Toronto recursive history plaque.jpg|thumb|A plaque commemorates the Toronto Recursive History Project of Toronto's Recursive History.]]
 
Another joke is that "To understand recursion, you must understand recursion."<ref name=Hunter/> 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''."<ref>{{Cite web|url=https://www.google.com/search?q=recursion|title=recursion - Google Search|website=www.google.com|access-date=2019-10-24}}</ref> 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 acronym]]s are other examples of recursive humor. [[PHP]], for example, stands for "PHP Hypertext Preprocessor", [[Wine (software)|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==
[[File:Sierpinski triangle.svg|thumb|250px|The [[Sierpiński triangle]]—a confined recursion of triangles that form a fractal]]
 
==Recursion in mathematics==
[[Image:Sierpinski Triangle.svg|right|thumb|250px|A [[Sierpinski triangle]]—a confined recursion of triangles to form a geometric [[lattice (group)|lattice]].]]
===Recursively defined sets===
{{Main|Recursive definition}}
 
====Example: the natural numbers====
{{See also|Closure (mathematics)}}
The canonical example of a recursively defined set is given by the [[natural numbers]]:
 
:10 is in <math>\mathbb{N}</math>
:if ''n'' is in <math>\mathbb{N}</math>, then ''n'' + 1 is in <math>\mathbb{N}</math>
: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: The set of true reachable propositions====
Another interesting example is the set of all "true reachable" propositions in an [[axiomatic system]].
 
====Example: Proof procedure ====
*if a proposition is an axiom, it is a true reachable proposition.
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 can be obtained from true reachable propositions by means of inference rules, it is a true reachable proposition.
*The set of true reachable propositions is the smallest set of propositions satisfying these conditions.
 
*If a proposition is an axiom, it is a provable proposition.
This set is called 'true reachable propositions' because in non-constructive approaches to the foundations of mathematics, the set of true propositions may be larger than the set recursively constructed from the axioms and rules of inference. See also [[Gödel's incompleteness theorems]].
*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===
{{Main|Finite subdivision rule}}
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 [[function (mathematics)|function]] may be partlyrecursively defined in terms of itself. A familiar example is the [[Fibonacci number]] sequence: ''F''(''n'') = ''F''(''n'' &minus; 1) + ''F''(''n'' &minus; 2). For such a definition to be useful, it must leadbe reducible to values which are non-recursively defined, values: in this case ''F''(0) = 0 and ''F''(1) = 1.
 
===Proofs involving recursive definitions===
A famous recursive function is the [[Ackermann function]] which, unlike the Fibonacci sequence, cannot easily be expressed without recursion.
Applying the standard technique of [[proof by cases]] to recursively defined sets or functions, as in the preceding sections, yields [[structural induction]] — a powerful generalization of [[mathematical induction]] widely used to derive proofs in [[mathematical logic]] and computer science.
 
=== Proofs involving recursive definitions ===
Applying the standard technique of [[proof by cases]] to recursively-defined sets or functions, as in the preceding sections, yields [[structural induction]], a powerful generalization of [[mathematical induction]] which is widely used to derive proofs in [[mathematical logic]] and [[computer science]].
 
===Recursive optimization===
[[Dynamic programming]] is an approach to [[optimization (mathematics)|optimization]] whichthat restates a multiperiod or multistep optimization problem in recursive form. The key result in dynamic programming is the [[Bellman equation]], which writes the value of the optimization problem at an earlier time (or earlier step) in terms of its value at a later time (or later step).
 
which writes the value of the optimization problem at an earlier time (or earlier step)
===The recursion theorem===
in terms of its value at a later time (or later step).
In [[set theory]], this is a theorem guaranteeing that recursively defined functions exist. Given a set {{mvar|X}}, an element {{mvar|a}} of {{mvar|X}} and a function {{math|''f'': ''X'' → ''X''}}, the theorem states that there is a unique function <math>F: \N \to X</math> (where <math>\N</math> denotes the set of natural numbers including zero) such that
:<math>F(0) = a</math>
:<math>F(n + 1) = f(F(n))</math>
for any natural number {{mvar|n}}.
 
Dedekind was the first to pose the problem of unique definition of set-theoretical functions on <math>\mathbb N</math> by recursion, and gave a sketch of an argument in the 1888 essay "Was sind und was sollen die Zahlen?" <ref>A. Kanamori, "[https://math.bu.edu/people/aki/20.pdf In Praise of Replacement]", pp.50--52. Bulletin of Symbolic Logic, vol. 18, no. 1 (2012). Accessed 21 August 2023.</ref>
 
====Proof of uniqueness====
Take two functions <math>F: \N \to X</math> and <math>G: \N \to X</math> such that:
 
:<math>F(0) = a</math>
:<math>G(0) = a</math>
:<math>F(n + 1) = f(F(n))</math>
:<math>G(n + 1) = f(G(n))</math>
 
where {{mvar|a}} is an element of {{mvar|X}}.
 
It can be proved by [[mathematical induction]] that {{math|1=''F''(''n'') = ''G''(''n'')}} for all natural numbers
{{mvar|n}}:
 
:'''Base Case''': {{math|1=''F''(0) = ''a'' = ''G''(0)}} so the equality holds for {{math|1=''n'' = 0}}.
 
:'''Inductive Step''': Suppose {{math|1=''F''(''k'') = ''G''(''k'')}} for some {{nowrap|<math>k \in \N</math>.}} Then {{math|1=''F''(''k'' + 1) = ''f''(''F''(''k'')) = ''f''(''G''(''k'')) = ''G''(''k'' + 1)}}.
::Hence {{math|1=''F''(''k'') = ''G''(''k'')}} implies {{math|1=''F''(''k'' + 1) = ''G''(''k'' + 1)}}.
 
By induction, {{math|1=''F''(''n'') = ''G''(''n'')}} for all <math>n \in \N</math>.
 
==Recursion inIn computer science==
[[File:Web Page.png|thumb|alt=|This screenshot of a web page includes the screen shot itself.]]
{{Main|Recursion (computer science)}}
A common method of simplification is to divide a problem into subproblems of the same type. As a [[computer programming]] technique, this is called [[divide and conquer algorithm|divide and conquer]] and is key to the design of many important algorithms. Divide and conquer serves as a top-down approach to problem solving, where problems are solved by solving smaller and smaller instances. A contrary approach is [[dynamic programming]]. This approach serves as a bottom-up approach, where problems are solved by solving larger and larger instances, until the desired size is reached.
 
A classic example of recursion is the definition of the [[factorial]] function, given here in C[[Python (programming language)|Python]] code:
 
<sourcesyntaxhighlight lang="cpython3">def factorial(n):
if n > 0:
unsigned int factorial(unsigned int n)
return n * factorial(n - 1)
{
if (n <= 1) else:
return 1;
</syntaxhighlight>
else
return n * factorial(n-1);
}
</source>
 
The function calls itself recursively on a smaller version of the input {{code|(n - 1)}} and multiplies the result of the recursive call by {{code|n}}, until reaching the [[base case (recursion)|base case]], analogously to the mathematical definition of factorial.
 
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 [[parser]]s for programming languages. The great advantage of recursion is that an infinite set of possible sentences, designs or other data can be defined, parsed or produced by a finite computer program.
 
[[Recurrence relation]]s are equations towhich 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 often that the algorithmmemory mayusage requireof largerecursive amountsalgorithms ofmay memorygrow ifvery thequickly, depthrendering ofthem theimpractical recursionfor is verylarger largeinstances.
 
==In biology==
==The recursion theorem==
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]].<ref>{{cite web |title=Picture of the Day: Fractal Cauliflower |date=28 December 2012 |url=https://twistedsifter.com/2012/12/fractal-cauliflower-romanesco-broccoli/ |access-date=19 April 2020}}</ref>
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 <math>f: X \rightarrow X</math>, the theorem states that there is a unique function <math>F: \mathbb{N} \rightarrow X</math> (where <math>\mathbb{N}</math> denotes the set of natural numbers including zero) such that
:<math>F(0) = a</math>
:<math>F(n + 1) = f(F(n))</math>
for any natural number ''n''.
 
== In the social sciences ==
===Proof of uniqueness===
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.<ref>{{Cite journal |last=Bourdieu |first=Pierre |year=1992 |title=Double Bind et Conversion |journal=Pour Une Anthropologie Réflexive |publisher=Le Seuil |publication-place=Paris}}</ref><ref>{{Cite book |last=Giddens |first=Anthony |title=Social Theory and Modern Sociology |publisher=Polity Press |year=1987}}</ref> 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).”<ref name="Alejandro2021">{{Cite journal |last=Alejandro |first=Audrey |date=2021 |title=Reflexive discourse analysis: A methodology for the practice of reflexivity |journal=[[European Journal of International Relations]] |language=en |volume=27 |issue=1 |page=171 |doi=10.1177/1354066120969789 |s2cid=229461433 |issn=1354-0661|doi-access=free }}</ref> From this basis, she identifies in recursivity a fundamental challenge in the production of emancipatory knowledge which calls for the exercise of [[Reflexivity (social theory)|reflexive]] efforts:{{quote|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| {{Harvp|Alejandro|2021}}}}
Take two functions <math>F: \mathbb{N} \rightarrow X</math> and <math>G: \mathbb{N} \rightarrow X</math> such that:
 
==In business==
:<math>F(0) = a</math>
{{Further information|Management cybernetics}}
:<math>G(0) = a</math>
:<math>F(n + 1) = f(F(n))</math>
:<math>G(n + 1) = f(G(n))</math>
 
Recursion is sometimes referred to in [[management science]] as the process of iterating through levels of abstraction in large business entities.<ref>{{cite journal |title=The Canadian Small Business–Bank Interface: A Recursive Model |date=1994 |url=https://journals.sagepub.com/doi/pdf/10.1177/104225879401800401 |publisher=SAGE Journals|doi=10.1177/104225879401800401 |last1=Riding |first1=Allan |last2=Haines |first2=George H. |last3=Thomas |first3=Roland |journal=Entrepreneurship Theory and Practice |volume=18 |issue=4 |pages=5–24 |url-access=subscription }}</ref> A common example is the recursive nature of management [[hierarchy|hierarchies]], ranging from [[line management]] to [[senior management]] via [[middle management]]. It also encompasses the larger issue of [[capital structure]] in [[corporate governance]].<ref>{{cite book |last1=Beer |first1=Stafford |title=Brain Of The Firm |date=1972 |publisher=John Wiley & Sons |isbn=978-0471948391}}</ref>
where ''a'' is an element of ''X''.
 
==In art==
It can be proved by [[mathematical induction]] that <math>F(n) = G(n)</math> for all natural numbers ''n'':
[[File:First matryoshka museum doll open.jpg|thumb|Recursive dolls: the original set of [[Matryoshka doll]]s by [[Vasily Zvyozdochkin|Zvyozdochkin]] and [[Sergey Malyutin|Malyutin]], 1892]]
[[File:Giotto. The Stefaneschi Triptych (verso) c.1330 220x245cm. Pinacoteca, Vatican..jpg|thumb|left|Front face of [[Giotto]]'s ''[[Stefaneschi Triptych]]'', 1320, recursively contains an image of itself (held up by the kneeling figure in the central panel).]]
{{See also|Mathematics and art|Infinity mirror}}
 
The [[Matryoshka doll]] is a physical artistic example of the recursive concept.<ref>{{cite web |last1=Tang |first1=Daisy |title=CS240 -- Lecture Notes: Recursion|date=March 2013|publisher=California State Polytechnic University, Pomona |url=http://www.cpp.edu/~ftang/courses/CS240/lectures/recursion.htm|archive-url=https://web.archive.org/web/20180317100946/https://www.cpp.edu/~ftang/courses/CS240/lectures/recursion.htm|archive-date=2018-03-17 |access-date=24 September 2015 |quote=More examples of recursion: Russian Matryoshka dolls. Each doll is made of solid wood or is hollow and contains another Matryoshka doll inside it. }}</ref>
:'''Base Case''': <math>F(0) = a = G(0)</math> so the equality holds for <math>n = 0</math>.
 
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.<ref>{{cite web |title=Giotto di Bondone and assistants: Stefaneschi triptych |url=http://mv.vatican.va/3_EN/pages/PIN/PIN_Sala02_03.html |publisher=The Vatican |access-date=16 September 2015}}</ref><ref>{{Cite book |title=Physical (A)Causality: Determinism, Randomness and Uncaused Events |url=https://books.google.com/books?id=gxBMDwAAQBAJ&pg=PA12 |first=Karl |last=Svozil |year=2018 |publisher=Springer |pages=12| isbn=9783319708157 }}</ref> This practice is more generally known as the [[Droste effect]], an example of the [[Mise en abyme]] technique.
:'''Inductive Step''': Suppose <math>F(k) = G(k)</math> for some <math>k \in \mathbb{N}</math>. Then <math>F(k+1) = f(F(k)) = f(G(k)) = G(k+1).</math>
::Hence F(k) = G(k) implies F(k+1) = G(k+1).
 
[[M. C. Escher]]'s ''[[Print Gallery (M. C. Escher)|Print Gallery]]'' (1956) is a print which depicts a distorted city containing a gallery which [[recursive]]ly contains the picture, and so ''[[ad infinitum]]''.<ref>{{cite web |last1=Cooper |first1=Jonathan |title=Art and Mathematics |url=https://unwrappingart.com/art/art-and-mathematics/ |access-date=5 July 2020 |date=5 September 2007}}</ref>
By Induction, <math>F(n) = G(n)</math> for all <math>n \in \mathbb{N}</math>.
{{Clear}}
 
===Examples= In culture ==
The film ''[[Inception]]'' has colloquialized the appending of the suffix ''[[wiktionary:-ception|-ception]]'' to a noun to jokingly indicate the recursion of something.<ref>{{cite web |title=-ception – The Rice University Neologisms Database |url=http://neologisms.rice.edu/index.php?a=term&d=1&t=17573 |url-status=live |archive-url=https://web.archive.org/web/20170705153941/http://neologisms.rice.edu/index.php?a=term&d=1&t=17573 |archive-date=July 5, 2017 |access-date=December 23, 2016 |publisher=Rice University}}</ref>
Some common recurrence relations are:
{{col-begin}}
{{col-break}}
*[[Factorial]]: <math>n! = n (n - 1)! = n (n - 1)\cdots 1</math>
*[[Fibonacci numbers]]: <math>f (n) = f (n - 1) + f (n - 2)</math>
*[[Catalan number]]s: <math>C_0=1</math>, <math>C_{n+1} = (4n+2)C_n/(n+2)</math>
*Computing compound [[interest]]
*The [[Tower of Hanoi]]
*[[Ackermann function]]
{{col-end}}
 
== See also ==<!-- Making the Recursion article link to itself will not display correctly, and is considered to break [[WP:ASTONISH]]. The joke itself is already featured in the "Recursive humor" section. See discussion on the talk page. -->
==Bibliography==
* {{Annotated link|Corecursion}}
*{{cite book | author=Johnsonbaugh, Richard | title=Discrete Mathematics | publisher=Prentice Hall | year=2004 | isbn=0-13-117686-2 }}
* {{Annotated link|Course-of-values recursion}}
*{{cite book | author=Hofstadter, Douglas | title=Gödel, Escher, Bach: an Eternal Golden Braid | publisher=Basic Books | year=1999 | isbn=0-465-02656-7 }}
* {{Annotated link|Digital infinity}}
*{{cite book | author=Shoenfield, Joseph R. | title=Recursion Theory | publisher=A K Peters Ltd | year=2000 | isbn=1-56881-149-7 }}
* {{Annotated link|A Dream Within a Dream (poem)}}
*{{cite book | author=Causey, Robert L. | title=Logic, Sets, and Recursion | publisher=Jones & Bartlett | year=2001 | isbn=0-7637-1695-2 }}
* {{Annotated link|Droste effect}}
*{{cite book | author=Cori, Rene; Lascar, Daniel; Pelletier, Donald H. | title=Recursion Theory, Godel's Theorems, Set Theory, Model Theory | publisher=Oxford University Press | year=2001 | isbn=0-19-850050-5 }}
* {{Annotated link|False awakening}}
*{{cite book | author=Barwise, Jon; Moss, Lawrence S. | title=Vicious Circles | publisher=Stanford Univ Center for the Study of Language and Information | year=1996 | isbn=0-19-850050-5 }} - offers a treatment of [[corecursion]].
* {{Annotated link|Fixed point combinator}}
*{{cite book | author=Rosen, Kenneth H. | title=Discrete Mathematics and Its Applications | publisher=McGraw-Hill College | year=2002 | isbn=0-07-293033-0 }}
* {{Annotated link|Infinite compositions of analytic functions}}
*{{cite book | author=Cormen, Thomas H., Charles E. Leiserson, Ronald L. Rivest, Clifford Stein | title=Introduction to Algorithms | publisher=Mit Pr | year=2001 | isbn=0-262-03293-7 }}
* {{Annotated link|Infinite loop}}
*{{cite book | author = Kernighan, B.; Ritchie, D. | title=The C programming Language | publisher=Prentice Hall | year = 1988 | isbn = 0-13-110362-8 }}
* {{Annotated link|Infinite regress}}
*{{cite book | author=Stokey, Nancy,; Robert Lucas; Edward Prescott | title=Recursive Methods in Economic Dynamics | publisher=Harvard University Press | year=1989 | isbn=0674750969}}
* {{Annotated link|Infinitism}}
*{{cite book | author=Hungerford; title=Algebra | publisher=Springer|year=1980|isbn=978-0387905181}}, first chapter on set theory.
* {{Annotated link|Infinity mirror}}
 
* {{Annotated link|Iterated function}}
==See also==
* {{Annotated link|Mathematical induction}}
<div style="-moz-column-count:4; column-count:4;">
* {{Annotated link|Mise en abyme}}
* [[Church-Turing thesis]]
<!-- {{Annotated link|Recursion}} and [[Recursion]] will not display correctly in this list, and including it
* [[Continuous predicate]]
is considered to break [[WP:ASTONISH]]. See discussion on the talk page.-->
* [[Corecursion]]
* {{Annotated link|Reentrant (subroutine)}}
* [[Course-of-values recursion]]
* {{Annotated link|Self-reference}}
* [[Droste effect]]
* {{Annotated link|Spiegel im Spiegel}}
* [[Fixed point combinator]]
* [[Infinite{{Annotated link|Strange loop]]}}
* {{Annotated link|Tail recursion}}
* [[Infinitism]]
* {{Annotated link|Tupper's self-referential formula}}
* [[Iterated function]]
* {{Annotated link|Turtles all the way down}}
* [[Mise en abyme]]
* [[Primitive recursive function]]
<!--
Your radical ideas about adding [[Recursion]] have
already occurred to other people and been removed by
people with no sense of humor.. See the subsection
"Recursive humor" for details. Also the system does not
allow the link to work.
-->
* [[Reentrant (subroutine)]]
* [[Self-reference]]
* [[Strange loop]]
* [[Tail recursion]]
* [[Tupper's self-referential formula]]
* [[Turtles all the way down]]
* [[Viable System Model]]
</div>
 
==References==
{{Reflist}}
<references/>
 
==Bibliography==
{{refbegin}}
* {{cite journal|first=Edsger W.|last=Dijkstra|author-link=Edsger W. Dijkstra|title=Recursive Programming|journal=Numerische Mathematik|volume=2|issue=1|year=1960|pages=312–318|doi=10.1007/BF01386232|s2cid=127891023}}
*{{cite book | author=Johnsonbaugh, Richard|author-link=Richard Johnsonbaugh | title=Discrete Mathematics | publisher=Prentice Hall | year=2004 | isbn=978-0-13-117686-7 }}
*{{cite book | author=Hofstadter, Douglas | author-link=Douglas Hofstadter | title=Gödel, Escher, Bach: an Eternal Golden Braid | publisher=Basic Books | year=1999 | isbn=978-0-465-02656-2 | url=https://archive.org/details/gdelescherbachet00hofs }}
*{{cite book | author=Shoenfield, Joseph R. |author-link=Joseph R. Shoenfield| title=Recursion Theory | url=https://archive.org/details/recursiontheory0000shoe | url-access=registration | publisher=A K Peters Ltd | year=2000 | isbn=978-1-56881-149-9 }}
*{{cite book | author=[[Causey, Robert L.]] | title=Logic, Sets, and Recursion | url=https://archive.org/details/logicsetsrecursi0000caus | url-access=registration | publisher=Jones & Bartlett | year=2001 | isbn=978-0-7637-1695-0 }}
*{{cite book |author1=Cori, Rene |author2=Lascar, Daniel |author3=Pelletier, Donald H. | title=Recursion Theory, Gödel's Theorems, Set Theory, Model Theory | publisher=Oxford University Press | year=2001 | isbn=978-0-19-850050-6 }}
*{{cite book | author1=Barwise, Jon| author2=Moss, Lawrence S. |author1-link=Jon Barwise| title=Vicious Circles | publisher=Stanford Univ Center for the Study of Language and Information | year=1996 | isbn=978-0-19-850050-6 }} - offers a treatment of [[corecursion]].
*{{cite book | author=Rosen, Kenneth H. | title=Discrete Mathematics and Its Applications | publisher=McGraw-Hill College | year=2002 | isbn=978-0-07-293033-7 }}
*{{cite book | last1=Cormen |first1=Thomas H. |first2=Charles E. |last2=Leiserson |first3=Ronald L. |last3=Rivest |first4=Clifford |last4=Stein | title=Introduction to Algorithms | publisher=Mit Pr | year=2001 | isbn=978-0-262-03293-3 }}
*{{cite book |author1=Kernighan, B. |author2=Ritchie, D. |title=The C programming Language |publisher=Prentice Hall |year=1988 |isbn=978-0-13-110362-7 |url=https://archive.org/details/cprogramminglang00bria }}
*{{cite book |author1=Stokey, Nancy |author2=Robert Lucas |author3=Edward Prescott | title=Recursive Methods in Economic Dynamics | publisher=Harvard University Press | year=1989 | isbn=978-0-674-75096-8}}
*{{cite book | author=Hungerford |title=Algebra | publisher=Springer|year=1980|isbn=978-0-387-90518-1}}, first chapter on set theory.
{{refend}}
 
==External links==
{{Commons category}}
{{Wiktionary|recursion|recursivity}}
* [https://web.archive.org/web/20050206051223/http://www.freenetpages.co.uk/hp/alan.gauld/tutrecur.htm Recursion] - tutorial by Alan Gauld
* [http://amitksaha.files.wordpress.com/2009/05/recursion-primer.pdf A Primer on Recursion]- contains pointers to recursion in Formal Languages, Linguistics, Math and Computer Science
* [http://research.swtch.com/2010/03/zip-files-all-way-down.html Zip Files All The Way Down]
*[http://www.ucl.ac.uk/psychlangsci/staff/linguistics-staff/nevins-publications/npr09b Nevins, Andrew and David Pesetsky and Cilene Rodrigues. Evidence and Argumentation: A Reply to Everett (2009). Language 85.3: 671--681 (2009)]
*[http://faculty.washington.edu/losterho/kaan_and_swaab.pdf Kaan, E. – Swaab, T. Y. (2002) “The brain circuitry of syntactic comprehension”, Trends in Cognitive Sciences, vol. 6, Issue 8, 350-356.]
 
{{logicFractals}}
{{Mathematical logic}}
{{Authority control}}
 
[[Category:MathematicalRecursion| logic]]
[[Category:Theory of computation]]
[[Category:Programming idioms]]
[[Category:Recursion]]
[[Category:Self-reference]]
[[Category:Feedback]]
 
[[Category:Articles with example C code]]
[[ar:استدعاء ذاتي]]
[[bg:Рекурсия]]
[[ca:Recursivitat]]
[[cs:Rekurze]]
[[da:Rekursiv]]
[[de:Rekursion]]
[[el:Αναδρομή]]
[[es:Recursión]]
[[eo:Rikuro]]
[[fr:Récursivité]]
[[hi:पुनर्गमनवाद]]
[[hr:Rekurzija]]
[[io:Rekurso]]
[[id:Rekursi]]
[[is:Endurkvæmt fall]]
[[he:רקורסיה]]
[[lt:Rekursija]]
[[hu:Rekurzió]]
[[ro:Recursivitate]]
[[nl:Recursie]]
[[ja:再帰]]
[[no:Rekursjon]]
[[pl:Rekurencja]]
[[pt:Recursividade]]
[[rue:Рекурзія]]
[[ru:Рекурсия]]
[[sa:पुनर्गमनवाद]]
[[simple:Recursion]]
[[sl:Rekurzija]]
[[sr:Рекурзија]]
[[fi:Rekursio]]
[[sv:Rekursion]]
[[ta:சுழல்]]
[[th:การเรียกซ้ำ]]
[[tg:Рекурсия]]
[[tr:Özyineleme]]
[[uk:Рекурсія]]
[[ur:Recursion]]
[[zh:递归]]