The Grzegorczyk hierarchy (/ɡrɛˈɡɔːrək/, Polish pronunciation: [ɡʐɛˈɡɔrt͡ʂɨk]), named after the Polish logician Andrzej Grzegorczyk, is a hierarchy of functions used in computability theory.[1] Every function in the Grzegorczyk hierarchy is a primitive recursive function, and every primitive recursive function appears in the hierarchy at some level. The hierarchy deals with the rate at which the values of the functions grow; intuitively, functions in lower levels of the hierarchy grow slower than functions in the higher levels.

Definition

edit

First we introduce an infinite set of functions, denoted Ei for some natural number i. We define

 

  is the addition function, and   is a unary function which squares its argument and adds two. Then, for each n greater than 1,  , i.e. the x-th iterate of   evaluated at 2.

From these functions we define the Grzegorczyk hierarchy.  , the n-th set in the hierarchy, contains the following functions:

  1. Ek for k < n
  2. the zero function (Z(x) = 0);
  3. the successor function (S(x) = x + 1);
  4. the projection functions ( );
  5. the (generalized) compositions of functions in the set (if h, g1, g2, ... and gm are in  , then   is as well);[note 1] and
  6. the results of limited (primitive) recursion applied to functions in the set, (if g, h and j are in   and   for all t and  , and further   and  , then f is in   as well).[note 1]

In other words,   is the closure of set   with respect to function composition and limited recursion (as defined above).

Properties

edit

These sets clearly form the hierarchy

 

because they are closures over the  's and  .

They are strict subsets.[2][3] In other words

 

because the hyperoperation   is in   but not in  .

  •   includes functions such as x+1, x+2, ...
    • Every unary function f(x) in   is upper bounded by some x+n. However,   also includes more complicated functions like x∸1, xy (where ∸ is the monus sign defined as xy = max(x-y, 0)), x mod y, etc.
  •   provides all addition functions, such as x+y, 4x, ...
  •   provides all multiplication functions, such as xy, x4
  •   provides all exponentiation functions, such as xy, 222x, and is exactly the elementary recursive functions.
  •   provides all tetration functions, and so on.

Notably, both the function   and the characteristic function of the predicate   from the Kleene normal form theorem are definable in a way such that they lie at level   of the Grzegorczyk hierarchy. This implies in particular that every recursively enumerable set is enumerable by some  -function.

Relation to primitive recursive functions

edit

The definition of   is the same as that of the primitive recursive functions, PR, except that recursion is limited (  for some j in  ) and the functions   are explicitly included in  . Thus the Grzegorczyk hierarchy can be seen as a way to limit the power of primitive recursion to different levels.

It is clear from this fact that all functions in any level of the Grzegorczyk hierarchy are primitive recursive functions (i.e.  ) and thus:

 

It can also be shown that all primitive recursive functions are in some level of the hierarchy,[2][3] thus

 

and the sets   partition the set of primitive recursive functions, PR.

Meyer and Ritchie introduced another hierarchy subdividing the primitive recursive functions, based on the nesting depth of loops needed to write a LOOP program that computes the function. For a natural number  , let   denote the set of functions computable by a LOOP program with LOOP and END commands nested no deeper than   levels.[4] Fachini and Maggiolo-Schettini showed that   coincides with   for all integers  .[5]p.63

Extensions

edit

The Grzegorczyk hierarchy can be extended to transfinite ordinals. Such extensions define a fast-growing hierarchy. To do this, the generating functions   must be recursively defined for limit ordinals (note they have already been recursively defined for successor ordinals by the relation  ). If there is a standard way of defining a fundamental sequence  , whose limit ordinal is  , then the generating functions can be defined  . However, this definition depends upon a standard way of defining the fundamental sequence. Rose (1984) suggests a standard way for all ordinals α < ε0.

The original extension was due to Martin Löb and Stan S. Wainer and is sometimes called the Löb–Wainer hierarchy.[6]

See also

edit

Notes

edit
  1. ^ a b Here   represents a tuple of inputs to f. The notation   means that f takes some arbitrary number of arguments and if  , then  . In the notation  , the first argument, t, is specified explicitly and the rest as the arbitrary tuple  . Thus, if  , then  . This notation allows composition and limited recursion to be defined for functions, f, of any number of arguments.

References

edit
  1. ^ Wagner & Wechsung 1986, p. 43.
  2. ^ a b Rose 1984.
  3. ^ a b Gakwaya 1997.
  4. ^ A. R. Meyer, D. M. Ritchie, "The complexity of loop programs". Proceedings A.C.M. National Meeting, 1967.
  5. ^ E. Fachini, A. Maggiolo-Schettini, "[A hierarchy of primitive recursive sequence functions]". From Informatique théorique, book 13, no. 1 (1979), pp.49--67.
  6. ^ Löb & Wainer 1970.

Bibliography

edit
  • Brainerd, Walter S.; Landweber, Lawrence H. (1974). Theory of computation. Wiley. ISBN 9780471095859.
  • Gakwaya, Jean-Sylvestre (1997). "A survey on the Grzegorczyk Hierarchy and its Extension through the BSS Model of Computability". CiteSeerX 10.1.1.69.4621.
  • Wagner, K.; Wechsung, G. (1986). "Computational Complexity". Mathematics and Its Applications. 21. Springer. ISBN 978-90-277-2146-4.