Teorema di SavitchNella teoria della complessità computazionale, il teorema di Savitch, dimostrato da Walter Savitch nel 1970[1], afferma che per ogni funzione :
In altre parole, se una macchina di Turing non deterministica è in grado di risolvere un problema in spazio f(n), una macchina di Turing deterministica può risolvere lo stesso problema nel quadrato dello spazio. Un importante corollario del teorema è che PSPACE = NPSPACE. Ciò deriva dal fatto che il quadrato di una funzione polinomiale è a sua volta una funzione polinomiale. Grafo orientato delle configurazioni della macchina di TuringIl teorema di Savitch codifica attraverso un grafo orientato le configurazioni di una macchina di Turing. Ogni nodo del grafo rappresenta una configurazione. Tra due nodi u e v esiste un arco orientato se dalla configurazione u è possibile raggiungere la configurazione v. Il problema di decidere un linguaggio si trasforma in un problema di raggiungibilità su grafi orientati. Nello specifico si tratta di capire se dalla configurazione iniziale è possibile raggiungere una qualunque configurazione di accettazione. Algoritmo usato per la dimostrazioneViene presentato un algoritmo che in base ad una stringa w data come ingresso ad una macchina di Turing N, due configurazioni c1, c2 ed un ingresso t, restituisce true se dalla configurazione c1 è possibile raggiungere la configurazione c2 in almeno t passi. PuoRaggiungere(c1, c2,t)
In questo algoritmo, la funzione ParteInteraSuperiore restituisce la parte intera superiore del valore che viene passato come argomento. La prima chiamata a questa funzione ricorsiva viene fatta con la tripletta di parametri (ciniziale, cfinale,2df(n)), dove d è una costante scelta appositamente in modo che la macchina di Turing N non abbia più di 2df(n) configurazioni usando un nastro di f(n) celle. Note
Bibliografia
|