Jump to content

PR (complexity)

From Wikipedia, the free encyclopedia
This is an old revision of this page, as edited by 192.38.109.188 (talk) at 12:08, 20 October 2011 (wikilink tetration; the others may be assumed commonly known). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

PR is the complexity class of all primitive recursive functions – or, equivalently, the set of all formal languages that can be decided by such a function. This includes addition, multiplication, exponentiation, tetration, etc.

The Ackermann function is an example of a function that is not primitive recursive, showing that PR is strictly contained in R.

PR functions can be explicitly enumerated, whereas not all functions R can be. This shows that 'PR' has a syntactic definition, whereas R lacks one.

On the other hand, we can "enumerate" any recursively enumerable set (see also its complexity class RE) by a primitive-recursive function in the following sense: given an input (M, k), where M is a Turing machine and k is an integer, if M halts within k steps then output M; otherwise output nothing. Then the union of the outputs, over all possible inputs (M, k), is exactly the set of M that halt.

PR strictly contains ELEMENTARY.

References