Savitch teoremi

Savitch Teoremi, uzay karmaşıklığını konu edinen ve bu hususta sonuca varan en eski teoremlerden biridir. Belirlenimsiz makinelerin belirlenimli makinelere dönüştürülmesinde, gerekli olan uzay karmaşıklığını incelemiştir ve beklenenden çok daha küçük uzay gereksinimi olduğunu ortaya koymuştur. Daha formal bir ifadeyle, f ( n ) {\displaystyle f(n)} uzay kullanan bir belirlenimsiz Turing makinesi (nondeterministic turing machine N T M {\displaystyle NTM} ), belirlenimli bir turing makinesine (deterministic turing machine T M {\displaystyle TM} ) dönüştürülürken f ( n ) 2 {\displaystyle f(n)^{2}} uzay gerektirir.[1]

Teorem

Herhangi bir f : N R + {\displaystyle f:N\to R^{+}} fonksiyonu için, f ( n ) n {\displaystyle f(n)\geq n} gereksinimi karşılamak koşuluyla,
N S P A C E ( f ( n ) ) S P A C E ( f ( n ) ) {\displaystyle NSPACE(f(n))\subseteq SPACE(f(n))} dir.

İspat fikri

f ( n ) {\displaystyle f(n)} uzay kullanan bir N T M {\displaystyle NTM} simule ederken, akla ilk gelen yol N T M {\displaystyle NTM} 'nin tüm kollarını tek tek hesaplayarak, işlemi ilerletmektir. Bu yolu kullanırken, işlenen kola ait bilgilerin tutulması gerekmektedir. f ( n ) {\displaystyle f(n)} uzay kullanan bir kol, en kötü ihtimalle 2 O ( f ( n ) ) {\displaystyle 2^{O(f(n))}} adımda, hesaplanabilir. Bütün kolların sırayla hesaplanması ise, hepsinin kayıt altında tutulması manasına gelir ki bu 2 O ( f ( n ) ) {\displaystyle 2^{O(f(n))}} uzay gerektirir. Üssel bir ilişki kuran bu yöntem, Savitch teoreminin iddia ettiği uzaydan çok daha fazla uzay gerektirmiş olur.

Bunun yerine, çözümü yinelemeli bir algoritma olan, yieldability probleminin yöntemi uygulanmıştır. c 1 {\displaystyle c_{1}} 'i başlangıç, c 2 {\displaystyle c_{2}} 'yi kabul konfigurasyonu ve t'yi N T M {\displaystyle NTM} 'nin kullanabileceği maksimum adım sayısı olarak kabul edersek, yieldability probleminin çözümü, N T M {\displaystyle NTM} 'nin verilen katarı kabul edip etmediğine karar verebilir.

Yieldability problemi

Yinelemeli bir algoritma mantığıyla çözülebilecek olan yieldability probleminin çözümünde aşağıdaki algoritma kullanılır.
CANYIELD( c 1 , c 2 , t {\displaystyle c_{1},c_{2},t} ) # c 1 v e c 2 {\displaystyle c_{1}vec_{2}} başlangıç ve kabul konfigürasyonları, t {\displaystyle t} adım sayısı

  • 1. Eğer t = 1 {\displaystyle t=1} ise c 1 = c 2 {\displaystyle c_{1}=c_{2}} olup olmadığına veya c 1 {\displaystyle c_{1}} 'den c 2 {\displaystyle c_{2}} 'ye tek bir adımda geçip geçmediğine bakılır. Eğer ikisinden biri doğru ise kabul, ikisi de yanlış ise ret döner
  • 2. Eğer t > 1 {\displaystyle t>1} ise bütün f ( n ) {\displaystyle f(n)} uzay kullanan ara konfigürasyonlar( c m {\displaystyle c_{m}} ) için:
  • 3. CANYIELD( c 1 , c m , t / 2 {\displaystyle c_{1},c_{m},t/2} ) çağır
  • 4. CANYIELD( c m , c 2 , t / 2 {\displaystyle c_{m},c_{2},t/2} ) çağır
  • 5. Eğer 3. ve 4. adım kabulse, kabul eder
  • 6. Eğer kabul değilse ret döner

İspat

N {\displaystyle N} makinesi f ( n ) {\displaystyle f(n)} uzayda A {\displaystyle A} diline karar veren bir N T M {\displaystyle NTM} olsun. A {\displaystyle A} diline karar veren bir belirlenimli T M {\displaystyle TM} M {\displaystyle M} makinesi oluşturalım. M {\displaystyle M} makinesi, N {\displaystyle N} makinesinin herhangi bir konfigürasyonunun belirli adımda çözülüp çözülmediğini test etmek için yukarıda bahsedilen CANYIELD algortimasını kullanır.
w {\displaystyle w} katarı N {\displaystyle N} makinesi için bir girdi katarı olsun. w {\displaystyle w} katarı üzerinde c 1 {\displaystyle c_{1}} ve c 2 {\displaystyle c_{2}} konfigürasyonları için, N {\displaystyle N} makinesi c 1 {\displaystyle c_{1}} 'den c 2 {\displaystyle c_{2}} 'ye t {\displaystyle t} veya daha az adımda geliyorsa, CANYIELD algoritması kabul döner, değilse ret döner.
Şimdi de N {\displaystyle N} makinesini simüle eden bir M {\displaystyle M} makinesi oluşturalım:

M {\displaystyle M} ( w {\displaystyle w} )

  • 1. CANYIELD( c 1 {\displaystyle c_{1}} , c 2 {\displaystyle c_{2}} , 2 f ( n ) {\displaystyle 2^{f(n)}} ) sonucu çıktı olarak döner.


CANYIELD algoritması kendisini yinelemeli olarak çağırdığında, mevcut durumu; c 1 {\displaystyle c_{1}} ve c 2 {\displaystyle c_{2}} değerlerini tutmak zorunda kalır. Öyleyse her bir yineleme adımında, ekstra O ( f ( n ) ) {\displaystyle O(f(n))} uzay gereklidir. Ayrıca, her bir yineleme adımında, t {\displaystyle t} adım yarıya düştüğünden, toplamda, l o g 2 2 f ( n ) = f ( n ) {\displaystyle log_{2}2^{f(n)}=f(n)} uzay gereklidir. O zaman bütün simüle için gerekli olan uzay, f ( n ) f ( n ) = f ( n ) 2 {\displaystyle f(n)f(n)=f(n)^{2}} olur. Bu da Savitch'in iddia ettiği gibi O ( f ( n ) 2 ) {\displaystyle O(f(n)^{2})} uzayda, bir O ( f ( n ) ) {\displaystyle O(f(n))} uzay N T M {\displaystyle NTM} bir T M {\displaystyle TM} 'e dönüştürülebilir.

Kaynakça

  1. ^ Sipser 2006 Introduction to the Theory of Computation, Second

Dış bağlantılar