Teorema di Turing
Il teorema di Turing asserisce l'esistenza di problemi non decidibili, per i quali cioè non esiste alcun algoritmo in grado di dare una risposta in tempo finito su tutte le istanze del problema. La dimostrazione di questo risultato si deve ad Alan Turing, che lo provò in un articolo del 1937. Il Teorema di Turing è in un certo senso la "versione informatica" del teorema di incompletezza di Gödel.
Dimostrazione
modificaUn accenno di dimostrazione viene dato di seguito.
Supponiamo di avere alcuni programmi che stampano sempre o "sì" o "no" in output, qualsiasi sia il loro input. Il problema è definito come segue:
- Dato sotto forma di codice un programma P che stampa sempre "sì" oppure "no" ed un input I, stabilire l'output P(I).
Si dimostrerà per assurdo che non esiste alcun algoritmo in grado di dare una risposta per tutte le possibili coppie (P,I) di programmi ed input. Si supponga quindi per assurdo l'esistenza di un programma che, preso il codice di un altro programma P, dica se esso stampa "sì" oppure "no" quando esso riceve un certo input I; l'input del nostro ipotetico programma è quindi una coppia (P,I), mentre l'output è P(I). Si chiami questo programma . Ora si modifichi leggermente il programma creando un nuovo programma che prende in input il codice di un programma P e quindi calcola ; questo nuovo programma stabilisce cosa stampa P quando riceve come input il codice di sé stesso. A questo punto modifichiamo ancora leggermente in modo che esso stampi "no" quando il programma analizzato stampa "sì" e viceversa; chiamiamo tale programma N (non esistente); notiamo che questo è appunto un programma che stampa sempre o "sì" o "no". A questo punto chiediamoci lecitamente:
- Cosa stampa N quando riceve in input N?
In pratica N è input di sé stesso, chiedendogli dunque di dire cosa farebbe sé stesso ricevendo sé stesso come input. Ora, se la copia di N che viene analizzata stampasse "sì" quando riceve N in input, allora il programma N analizzatore, che ha ricevuto proprio N in input, stamperebbe "no"; ma questo è assurdo. Viceversa, se l'N analizzato stampasse "no", allora N stamperebbe "sì"; ma anche questo è assurdo. Pertanto tale programma non può esistere.
La versione originale della dimostrazione di Turing è in realtà basata sul problema della fermata, detto anche problema dell'arresto; si dimostra cioè che non può esistere un programma che possa decidere se un qualsiasi programma si arresti o continui a procedere all'infinito.
Una dimostrazione più formale richiede alcune nozioni di informatica teorica, come la conoscenza dei linguaggi formali e delle Macchine di Turing.