If (1,2) hold, but (3) does not, then *. Let’s assume that , and we’ll see that we have a way to accept any finite languages in (and thus, the set of all these languages is RE), thus condition (3) holds and we reach a contradiction. How to decide if a finite belongs to or not? Easily – we use the description of to construct a machine that accepts only the words in , and now we run the machine of on (remember - we assumed , so there is a machine that accepts !). If then and since , its machine will say yes on the input , and we are done.
If (2,3) hold, but (1) does not, then *. We assume that and we’ll show that we have a way to decide , leading to a contradiction.
Because condition (1) doesn’t hold, there is a language and a superset of it, so that . Now we are going to repeat the argument used in Section 4 to decide : given an input for , we construct a machine whose language is if or otherwise, its language is . Then, we can decide : either halts on , or the RE-machine for accepts ; we can run both in parallel and are guaranteed that at least one will halt.
Let’s give the details of constructing (on input ):
1. Do the following in parallel: 1.1 run on . 1.2 run the machine of on 2. If 1.2 halts and accepts - accept. 3. If 1.1 halts: run the machine of on .
Why does this work? If then 1.1 never halts, and accepts exactly all the inputs that are being accepted at step 1.2, so . On the other hand, if then, at some point step 1.1 halts and accepts exactly . It may happen that accepts beforehand, but since , this doesn’t change the language of in this case.
If (1,3) hold, but (2) does not, then *. Again, we will assume and show that becomes decidable, which is a contradiction.
If condition (2) doesn’t hold, then for any , all its finite subsets satisfy (note that must be infinite, since ). As in the above, in order to decide for a given input , we construct a machine whose language is if and some finite otherwise. The contradiction follows in a similar way as above.
The construction of this machine is quite similar to the previous we constructed. The machine (on input ) does:
1. Runs on for steps. 2. If halts during step 1 – reject 3. Otherwise, run the machine of on .
It holds that, if , then at some point, say after 1000 steps, halts on . Therefore, step 1 will halt on (and reject) any input of length . Therefore, in this case, is **finite**. Also note that , and in particular, by our assumptions on the invalidity of condition (2), we have that .
On the other hand, if , then step 1 never halts, and we never reject at step 2. In this case it is easy to see that and in particular, .
We are left to show the other direction of the extended theorem. That is, we need to show that if all the conditions (1,2,3) hold, then we have a TM that accepts , that is, . In other words, we need to show a machine so that for any input for which , the machine accepts this input, .
Here is how the machine behaves (on input ):
1. Let be the machine that enumerates all the finite languages in , guaranteed by condition (3). 2. Run the following in parallel for 2.1 Run until it outputs the language 2.2. Check if accepts all the words of (run on these words, again in parallel). 2.3. If for some , accepts all the words of – accept.
Why does it work? If then it has a finite subset , and once outputs that subset, step 2.2/2.3 will find that accepts all the words in that language and accept.
On the other hand, if it cannot be accepting all the words in for any . Indeed, by condition (1), any is also in , so if accepts all the words in for some , then and thus , in contradiction. □
Given a non trivial property , so that , the language >
> is not recursively-enumerable, that is, .