# A Step by Step Guide to Gödel’s Incompleteness Proof:

5: Primitive Recursive Relations

5: Primitive Recursive Relations

Page last updated 28 Dec 2022

This guide is intended to assist in attaining a full understanding of Gödel’s proof. If there is any difficulty in following any part of the proof, please contact me and I will try to help. And if you have any suggestions as to how this guide might be improved, please contact me. This guide is intended to be read alongside the English translation of Gödel’s original proof which can be viewed online at English translation of Gödel’s original proof.

## Primitive Recursive Relations and Functions

In Gödel’s section *‘Recursive Relations’*, the first paragraph (beginning *“We now introduce a parenthetic consideration…”*) refers to recursive functions and relations of number-theory. Nowadays we call such functions and relations ‘primitive recursive’ functions and relations, rather than simply ‘recursive’ number-theoretic functions and relations.

Gödel’s primitive recursive functions and relations are all number-theoretic, that is, they are functions/relations where the entities that the function or relation refers to are all natural numbers, or variables for natural numbers (“*A number-theoretic function is said to be recursively defined by the number-theoretic functions …*”).

Gödel had two principal reasons for using primitive recursive relations:

- For given values of its free variables, every primitive recursive relation is provable, or else its negation is provable from the axioms of number theory, and
- Every primitive recursive relation can be expressed in the formal system
**P**.

Both of these properties are used in the proof of Gödel’s Proposition V (which we will come to later, see Part 8: Gödel’s Proposition V).

Primitive recursive relations (for given values of the free variables) are always provable from the axioms of number theory since a primitive recursive relation can always be calculated as being a correct or incorrect proposition, using the axioms of number theory, by a method that always has a finite number of precisely defined steps. (Footnote: Note: There are relations and functions that can be calculated by a finite number of steps, but which do not fall within the strict definition of primitive recursion. Gödel did not use such relations or functions in his proof.)

When it is asserted that every primitive recursive relation can be expressed in the formal system, what is being asserted is that:

- since a number-theoretic relation is a relation where the entities that the relation refers to are all natural numbers or variables for natural numbers, then there is a formula of the formal system that corresponds to that number-theoretic relation, and
- given any primitive recursive relation with
free variables, there is always a corresponding formula in the formal system which also has**n**free variables - and it has the property that:**n** - whenever the free variables of the primitive recursive relation are substituted by specific values, if the resulting relation is provable, then the corresponding formula of the formal system is also provable; if the negation of the resulting relation is provable, then the corresponding negation formula of the formal system is also provable.

In this guide we will not go into the details of Gödel’s definitions of primitive recursive relations; at this point it is sufficient to understand the principles of the main properties of primitive recursive relations/

### The Epsilon notation ε

Note: Gödel introduces the **ε** notation in this section, and the **ε** notation is used in subsequent sections:

**εx R(x, y)** is defined to be a function with one free variable **y**, and whose value is *the smallest value of* **x** *for which the relation* **R(x, y)** *holds*. If there is no such smallest number, then the value of **εx R(x, y)** is **0**. The function **εx R(x, y)** is a primitive recursive function if the relation **R(x, y)** is primitive recursive *and* provided the relation **R(x, y)** includes an upper bound on the value of **x**.

A brief overview of primitive recursion is given below. If you wish to go into the details of the definition and treatment of primitive recursion, there are plenty of sources of such information available; the reason it is not included here is that such details will not significantly assist your understanding of the thrust of Gödel’s argument. (Footnote: You may read elsewhere that a comprehensive knowledge of the details of primitive recursion is essential to an understanding of Gödel’s paper, but this is not the case. In fact, if you arrive at a full understanding of the paper up to and including Gödel’s Proposition V, you will see that primitive recursion is a peripheral matter.)

#### Primitive Recursive *Functions*

A primitive recursive function can always be evaluated by a method that always has a finite number of precisely defined steps.

For example, the ‘factorial’ function is defined as:

**0! = 1**

**(n+1)! = (n+1) · n!**

where **· **indicates multiplication.

The intention of the factorial function **n!** is that, for any natural number **n**, it gives the value of **n** multiplied by all the natural numbers less than **n** (except zero). For example,

**1! = 1**

**2! = 2 · 1**

**3! = 3 · 2 · 1**

**4! = 4 · 3 · 2 · 1**, and so on.

So when we have **(n+1)! = (n+1) · n!**, then that indicates that **n! = n · (n-1)!**, providing **n-1** is greater than zero, so that:

**(n+1)! = (n+1) · n!** = **(n+1) · n · (n-1)!** (providing **n**, **n-1**, **n-2**, **n-3**, … are all greater than **0**)

or we might say that:

**n! = n · (n-1)! = n · (n-1) · (n-2) · (n-3) · …** (again, providing **n**, **n-1**, **n-2**, **n-3**, … are all greater than **0**)

For any value of **n**, the value of **n!** can be calculated by a simple method, like this:

1: Let **w = n**

2: Let **y = n**

3: **y = y - 1**

4: If **y > 1** then **w = y · w** and return to step 3

5: Otherwise the value of **n!** is **w**.

Suppose we use this method to calculate **4!**, as follows:

1: **w = 4**

2: **y = 4**

3: **y = 3**

4: **y > 1** so **w = 4 · 3**, hence return to step 3

3: **y = 2**

4: **y > 1** so **w = 4 · 3 · 2**, hence return to step 3

3: **y = 1**

4: Since **y = 1**, do not return to step 3

5: **4! = w = 4 · 3 · 2**

So, given any value of **n**, the value of the function **n!** can always be determined in a finite number of steps of calculation. We know that the calculation must stop at some point, since we must always reach the point where **y = 1**, and so **n!** is a primitive recursive function. This method could be made into a computer program, and every primitive recursive function can be calculated by a simple computer program (but you should be aware that there are functions that evaluate as natural numbers by computer programs, but which are not primitive recursive functions).

Simple primitive recursive functions include the addition function **x + y**, the multiplier function **x · y** and the exponential function **x ^{y}**. Gödel’s section

*‘Recursive Relations’*introduces more complex primitive recursive functions which he defines in terms of simpler primitive recursive functions.

#### Primitive Recursive *Relations*

Gödel gives a precise definition of primitive recursive *relations* in terms of primitive recursive *functions*. The definitions are such that, for every primitive recursive relation, there is always a method with a finite number of steps that can calculate if the relation or its negation can be proved to follow from the axioms of number theory. For example, using the simple factorial function above, we could have the relation

**x = (y + 3)!**

Given any **x** and any **y**, it can be calculated, in a finite number of steps, if the relation is correct or incorrect for those values of **x** and **y**.

Simple primitive recursive relations include the ‘less than’ relation **x < y** and the equality relation **x = y**. Gödel’s section *‘Recursive Relations’* introduces more complex primitive recursive relations which he defines in terms of simpler primitive recursive functions and relations.

Footnotes:

Rationale: Every logical argument must be defined in some language, and every language has limitations. Attempting to construct a logical argument while ignoring how the limitations of language might affect that argument is a bizarre approach. The correct acknowledgment of the interactions of logic and language explains almost all of the paradoxes, and resolves almost all of the contradictions, conundrums, and contentious issues in modern philosophy and mathematics.Site MissionPlease see the menu for numerous articles of interest. Please leave a comment or send an email if you are interested in the material on this site.

Interested in supporting this site?You can help by sharing the site with others. You can also donate at

_{}where there are full details.