Turings kanıtı - Turings proof - Wikipedia

Turing'in kanıtı bir kanıtı Alan Turing, ilk olarak Ocak 1937'de yayınlandı "Hesaplanabilir Sayılarda, Entscheidungsproblem. "Bu ikinci kanıttı ( Kilise teoremi ) bazı tamamen matematiksel evet-hayır sorularının hesaplama yoluyla asla cevaplanamayacağı varsayımı; daha teknik olarak, karar problemleri vardırkarar verilemez "problemin her bir örneğine hatasız bir şekilde doğru" evet "veya" hayır "cevabı veren tek bir algoritma olmaması anlamında. Turing'in kendi sözleriyle:" ... kanıtlayacağım şey kuyudan oldukça farklı ... Gödel'in bilinen sonuçları ... Verilen bir formülün var olup olmadığını söyleyen genel bir yöntem olmadığını şimdi göstereceğim. U kanıtlanabilir K [Principia Mathematica ]..." (Kararsız, s. 145).

Turing bu kanıtı diğer iki kişiyle birlikte takip etti. İkinci ve üçüncü her ikisi de ilkine güveniyor. Hepsi, onun basit bir kurallar dizisine uyan yazı yazarı benzeri "bilgisayar makineleri" geliştirmesine ve ardından "evrensel hesaplama makinesi" geliştirmesine güveniyor.

Richard'ın paradoksu

1905'te, Jules Richard bu derin paradoksu sundu. Alan Turing'in ilk kanıtı, bu paradoksu sözde bilgisayar makinesi ile inşa ediyor ve bu makinenin basit bir soruyu yanıtlayamayacağını kanıtlıyor: bu makine, hiç bilgisayar makinesi (kendisi dahil) verimsiz bir "sonsuz döngü" içinde sıkışıp kalacaktır (yani, köşegen sayıyı hesaplamaya devam edemez).

Kısa ve öz bir tanımı Richard'ın paradoksu Whitehead ve Russell'da bulunur Principia Mathematica:

Richard'ın paradoksu aşağıdaki gibidir. Sonlu sayıda kelimeyle tanımlanabilen tüm ondalık sayıları düşünün; E bu tür ondalık sayıların sınıfı olsun. O zaman E'nin şartlar; dolayısıyla üyeleri 1., 2., 3. olarak sıralanabilir ... N aşağıdaki gibi tanımlanan bir sayı olsun [Whitehead & Russell şimdi Kantor çapraz yöntemi ]; n'inci ondalık sayıdaki n'inci rakam p ise, N'deki n'inci rakam p + 1 (veya p = 9 ise 0) olsun. O halde N, E'nin tüm üyelerinden farklıdır, çünkü, n'nin sahip olduğu sonlu değer ne olursa olsun, N'deki n'inci rakam, E'yi oluşturan ondalık sayıların n'inci rakamından farklıdır ve bu nedenle N, n'inci ondalıktan farklıdır. Yine de, N'yi sınırlı sayıda kelimeyle tanımladık [ör. tam da bu kelime tanımı yukarıda!] ve bu nedenle N, E'nin bir üyesi olmalıdır. Dolayısıyla, N hem E'nin bir üyesidir hem de değildir (Principia Mathematica, 2. baskı 1927, s. 61).

Komplikasyonlar

Turing'in kanıtı, çok sayıda tanımla karmaşıktır ve Martin Davis "küçük teknik ayrıntılar" ve "... teknik ayrıntılar [verildiği gibi yanlış" olarak adlandırılır (Davis'in açıklaması Kararsız, s. 115). Turing, 1937'de "Bir düzeltme" yayınladı: "Yazar, P. Bernays bu hataları işaret etmek için "(Kararsız, s. 152).

Spesifik olarak, orijinal haliyle üçüncü kanıt, teknik hatalarla kötü bir şekilde bozulmuştur. Ve Bernays'in önerilerinden ve Turing'in düzeltmelerinden sonra bile, hatalar evrensel makine. Ve kafa karıştırıcı bir şekilde, Turing orijinal makalesini düzeltemediği için, vücuttaki bazı metinler Turing'in kusurlu ilk çabasına işaret ediyor.

Bernays'ın düzeltmeleri şurada bulunabilir: Kararsız, s. 152–154; orijinal şu ​​şekilde bulunur:

"Hesaplanabilir Sayılar Üzerine, Entscheidungsproblem İçin Bir Uygulama ile. Bir Düzeltme," Londra Matematik Derneği Bildirileri (2), 43 (1936–37), 544-546.

Turing'in makalesinin çevrimiçi versiyonu bu düzeltmeleri bir ek olarak içermektedir; ancak, Evrensel Makinede yapılan düzeltmeler, aşağıdaki kuruluş tarafından sağlanan bir analizde bulunmalıdır: Emil Post.

İlk başta, ispatın ayrıntılarına yakından dikkat eden tek matematikçi Post idi (çapraz başvuru Hodges s. 125) - esas olarak "algoritmanın" ilkel makine benzeri eylemlere benzer bir indirgemesine aynı anda ulaştığı için, bu yüzden o kanıta kişisel bir ilgi gösterdi. Garip bir şekilde (belki de II.Dünya Savaşı müdahale etti), Post'u Ek onun kağıdına Bir Sorun Sorunun Özyinelemeli Çözümlenemezliği, 1947 (yeniden basıldı Kararsız, s. 293).

Diğer sorunlar kendilerini gösterir: Ek Gönderi dolaylı olarak kağıdın zorluğuna ve doğrudan "ana hatlarının doğasına" yorum yaptı (Post in Kararsız, s. 299) ve ispatların "sezgisel formu" (ibid.). Gönderi çeşitli noktalara varmak zorundaydı:

"Eleştirimiz doğruysa, sonsuz sayıda 0'lar ve 1'ler yazdıran bir Turing hesaplama makinesiyse bir makinenin dairesiz olduğu söylenir. Ve Turing'in iki teoremi gerçekten aşağıdaki gibidir. keyfi bir pozitif tamsayı n ile sağlandığında, n'nin çember içermeyen bir Turing hesaplama makinesinin DN'si olup olmadığını belirleyecek bir Turing ... makinesi değildir. [İkincisi], Turing konvansiyon makinesi yoktur. bu, rastgele bir pozitif tamsayı n ile sağlandığında, n'nin Turing hesaplama işleminin DN'si olup olmadığını belirleyecektir ... herhangi bir sembolü basan (0 diyelim) "(Post in Kararsız, s. 300)

Gazeteyi okumaya çalışan herkes Hodges'ın şikayetini anlayacaktır:

"Makale çekici bir şekilde başladı, ancak kısa süre sonra (tipik Turing tarzında), evrensel makine için talimat tablosunu geliştirmek için belirsiz bir Alman Gotik türü çalılığa daldı. Ona en son göz atan kişiler, bunu yapan uygulamalı matematikçiler olacaktı. pratik hesaplamaya başvurmak ... "(Hodges s. 124)

İspatların özeti

Entscheidungsproblem'in çözümü olamayacağına dair ispatında Turing, son ispatına götüren iki ispattan yola çıktı. İlk teoremi en çok durdurma sorunu ikincisi daha alakalı Rice teoremi.

İlk kanıt: keyfi bir "bilgi işlem makinesinin" (1, 2, 3, ... bir tamsayı ile temsil edildiği gibi) "daire içermeyen" olup olmadığına karar verebilecek bir "bilgi işlem makinesi" bulunmadığı (yani, binary ad infinitum): "... bunu sınırlı sayıda adımda yapmak için genel bir sürecimiz yok" (s. 132, ibid.). Turing'in kanıtı, her ne kadar "köşegen işlemi" kullanıyor gibi görünse de, aslında, makinesinin (H olarak adlandırılır), köşegen sayısının tamamını (Cantor'un çapraz argümanı ): "Argümandaki yanılgı, B'nin [köşegen sayı] hesaplanabilir olduğu varsayımında yatmaktadır" (Kararsız, s. 132). İspat fazla matematik gerektirmez.

İkinci kanıt: Bu, okuyuculara belki daha aşina olduğu için Rice teoremi: "Bunu daha da gösterebiliriz rasgele bir M makinesinin S.D'si ["programı"] ile birlikte verildiğinde, M'nin verilen bir sembolü yazdırıp yazdırmayacağını belirleyecek olan E makinesi olamaz (0 diyelim)"(italik, Kararsız, s. 134).

Üçüncü kanıt: "Her bir M hesaplama makinesine karşılık olarak bir Un (M) formülü oluşturuyoruz ve Un (M) 'nin kanıtlanabilir olup olmadığını belirlemek için genel bir yöntem varsa, M'nin hiç 0 yazdırıp yazdırmadığını belirlemek için genel bir yöntem olduğunu gösteriyoruz. "(Kararsız, s. 145).

Üçüncü kanıt, bir ilk lemmayı kanıtlamak için biçimsel mantığın kullanılmasını ve ardından ikincinin kısa bir sözcük ispatını gerektirir:

"Lemma 1: M'nin bazı tam konfigürasyonlarında bantta S1 [sembol" 0 "] görünürse, Un (M) kanıtlanabilir" (Kararsız, s. 147)
"Lemma 2: [Tersi] Un (M) kanıtlanabilirse, bantta S1 [simgesi" 0 "], M'nin bazı tam yapılandırmasında görünür" (Kararsız, s. 148)

Son olarak, sadece 64 kelime ve sembolle Turing, Redüktör reklamı absurdum "Hilbert Entscheidungsproblemin çözümü olamaz" (Kararsız, s. 145).

İlk kanıtın özeti

Turing bir kısaltma çalılığı yarattı. Tanımlar için makalenin sonundaki sözlüğe bakın.

Bazı önemli açıklamalar:

Turing'in makinesi H, çapraz sayıda 0'lar ve 1'ler basmaya çalışıyor.
Bu diyagonal sayı, H aslında değerlendirilmekte olan her "başarılı" makineyi "simüle ettiğinde" ve R-th "başarılı" makinenin R-th "rakamını" (1 veya 0) yazdırdığında oluşturulur.
  • Turing, makalesinin çoğunu, bizi gerçeklerine ikna etmek için makinelerini "inşa etmek" için harcadı. Bu onun kullanımı için gerekliydi Redüktör reklamı absurdum kanıt formu.
  • Bu kanıtın "yapıcı" niteliğini vurgulamalıyız. Turing, gerçek bir makinenin gerçekten üretilebilir ne olabileceğini anlatıyor. Tek şüpheli unsur, bu kanıtın sonunda imkansız olduğunu göstereceği D makinesinin varlığıdır.

Turing, kanıta bir "karar / belirleme" makinesi D'nin varlığının iddiasıyla başlar. Herhangi bir SD (A, C, D, L, R, N, noktalı virgül ";") ile beslendiğinde, bunun olup olmadığını belirleyecektir. SD (sembol dizisi), "dairesel" - ve dolayısıyla "tatmin edici olmayan u" - veya "daire içermeyen" - ve dolayısıyla "tatmin edici s" olan bir "bilgi işlem makinesini" temsil eder.

Turing daha önce yaptığı yorumda, tüm "bilgi işlem makinelerinin - sonsuza kadar 1'ler ve 0'lar olarak bir sayıyı hesaplayan makineler - "evrensel makine" U'nun kasetine bir S.D olarak yazılabilir. İlk kanıtına giden çalışmalarının çoğu, evrensel bir makinenin gerçekten var olduğunu göstermekle harcanmıştır, yani.
Gerçekten evrensel bir makine var U
Her N sayısı için gerçekten benzersiz bir S.D vardır,
Her Turing makinesinin bir S.D'si vardır
U'nun bandındaki her S.D, U tarafından "çalıştırılabilir" ve orijinal makine ile aynı "çıktıyı" (şekil 1, 0) üretir.

Turing, D makinesinin işini nasıl yürüttüğü hakkında yorum yapmıyor. Tartışma adına, D'nin önce sembol dizisinin "iyi biçimlendirilmiş" olup olmadığını (yani bir algoritma biçiminde ve sadece bir semboller karmaşası değil) olup olmadığına bakacağını ve değilse onu atacağını varsayıyoruz. Sonra “daire avına” giderdi. Bunu yapmak için belki de "buluşsal yöntemler" (hileler: öğretilmiş veya öğrenilmiş) kullanırdı. İspat amacıyla bu detaylar önemli değildir.

Turing daha sonra H olarak adlandırdığı bir makine tarafından izlenecek algoritmayı (yöntemi) (oldukça gevşek bir şekilde) açıklar. Makine H, içinde karar makinesi D'yi içerir (dolayısıyla D, H'nin bir "alt yordamıdır"). Makine H’nin algoritması, H’nin talimat tablosunda veya belki H’nin Standart Açıklamasında kaset üzerinde ifade edilir ve evrensel makine U ile birleştirilir; Turing bunu belirtmiyor.

Evrensel U makinesini tanımlarken, Turing, bir makinenin S.D'sinin (bir “programa” benzeyen harf dizileri) bir tamsayıya (taban 8) dönüştürülebileceğini ve bunun tersi olduğunu göstermiştir. Herhangi bir N sayısı (8 tabanında) aşağıdaki değiştirmelerle bir S.D'ye dönüştürülebilir: 1 ile A, 2 ile C, 3 ile D, 4 ile L, 5 ile R, 6 ile N, 7 noktalı virgülle ";".
Görünüşe göre, H makinesinin benzersiz numarası (D.N) "K" sayısıdır. K'nin oldukça uzun bir sayı, belki de on binlerce basamak uzunluğunda olduğu sonucuna varabiliriz. Ancak bu, bundan sonra gelenler için önemli değil.

Makine H dönüştürme işleminden sorumludur hiç N sayısını, alt makine D'nin test etmesi için eşdeğer bir S.D sembol dizisine çevirin. (Programlama dilinde: H keyfi bir "SD" yi D'ye geçirir ve D, "tatmin edici" veya "yetersiz" döndürür.) Makine H aynı zamanda başarılı sayıların bir R ("Kayıt"?) Kaydını tutmaktan da sorumludur (varsayalım ki "başarılı" S.D'lerin sayısı, yani R, test edilen SD'lerin sayısından çok daha azdır, yani N) Son olarak, H, bandının bir kısmına diyagonal bir sayı "beta astarlı" B "yazdırır. H, her bir "tatmin edici" makinenin / numaranın "hareketlerini" (bilgisayar anlamında) "simüle ederek" bu B'yi oluşturur; sonunda test edilen bu makine / numara, Rth "rakamına" (1 veya 0) ulaşacaktır, H, simülasyonun bıraktığı "pisliği temizlemekten", N'yi arttırmaktan ve testlerine devam etmekten sorumludur. sonsuza dek.

Not: H'nin peşinde olduğu tüm bu makineler, Turing'in "bilgisayar makineleri" dediği şeydir. Bunlar, Turing'in "rakamlar" olarak adlandırdığı sonsuz bir akışta ikili ondalık sayıları hesaplar: sadece 1 ve 0 sembolleri.

İlk kanıtı göstermek için bir örnek

Örnek: H makinesinin 13472 sayıyı test ettiğini ve 5 tatmin edici sayı ürettiğini varsayalım, yani H, 1'den 13472'ye kadar olan sayıları S.D'lere (sembol dizileri) dönüştürdü ve test için D'ye geçirdi. Sonuç olarak H, 5 tatmin edici sayıyı saydı ve birinciyi 1. rakamına, ikincisini 2. rakamına, üçüncüsünden 3. rakamına, dördüncü rakamdan 4. rakamına ve beşinci rakamdan 5. rakamına kadar koştu. Sayı şimdi N = 13472, R = 5 ve B '= ".10011" (örneğin) olarak duruyor. H kasetindeki pisliği temizler ve devam eder:

H artışlar N = 13473 ve "13473" ADRLD sembol dizesine dönüştürür. Alt makine D, ADLRD'yi tatmin edici bulmazsa, o zaman H, sayım kaydı R'yi 5'te bırakır. H, N sayısını 13474'e çıkaracak ve ilerleyecektir. Öte yandan, D, ADRLD'yi tatmin edici bulursa, H, R'yi 6'ya çıkaracaktır. H, N'yi (tekrar) ADLRD'ye dönüştürecektir [bu sadece bir örnektir, ADLRD muhtemelen işe yaramazdır] ve U evrensel makineyi kullanarak "çalıştıracaktır". Bu makine test altında (U "çalışıyor" ADRLD) 6. "rakamını" yani 1 veya 0'ı yazdırır. H, bu 6. sayıyı (örn. "0") bandının "çıktı" bölgesine yazdırır (örn. B '= ".100110").

H dağınıklığı temizler ve ardından sayıyı artırır N 13474'e kadar.

H kendi numarasına K geldiğinde tüm süreç çözülür. Örneğimizle devam edeceğiz. Başarılı skor / rekor R'nin 12'de olduğunu varsayalım. H nihayet kendi numarası eksi 1'e varıyor, yani N = K-1 = 4335 ... 3214ve bu numara başarısız. Sonra H, K = 4355 ... 321'i üretmek için N'yi artırır5, yani kendi numarası. H bunu "LDDR ... DCAR" olarak dönüştürür ve karar makinesi D'ye iletir. Karar makinesi D "tatmin edici" olarak döndürmelidir (yani: H tanım olarak devam edin ve test edin, sonsuza dek, çünkü "daire içermeyen"). Yani H şimdi tally R'yi 12'den 13'e yükseltir ve ardından test edilen sayıyı S.D'sine dönüştürür ve simüle etmek için U kullanır. Ancak bu, H'nin kendi hareketlerini simüle edeceği anlamına gelir. Simülasyonun yapacağı ilk şey nedir? Bu K-aka-H simülasyonu ya yeni bir N oluşturur ya da "eski" N'yi 1'e "sıfırlar". Bu "K-aka-H", yeni bir R oluşturur veya "eski" R'yi 0'a "sıfırlar". Eski -H, 12. rakamına gelene kadar yeni "K-aka-H" yi "çalıştırır".

Ama asla 13. rakama ulaşamaz; K-aka-H sonunda 4355 ... 321'e ulaşır.5, tekrar ve K-aka-H testi tekrar etmelidir. K-aka-H 13. rakama asla ulaşamayacak. H-makinesi muhtemelen sadece kendi kopyalarını basıyor sonsuza dek boş bant boyunca. Ancak bu, H'nin köşegen sayıların 1 ve 0'larını sonsuza kadar basmaya devam eden tatmin edici, dairesel olmayan bir bilgisayar makinesi olduğu önermesiyle çelişiyor. (N 1'e sıfırlanırsa ve R, 0'a sıfırlanırsa aynı şeyi göreceğiz)

Okuyucu buna inanmazsa, karar makinesi D için bir "saplama" yazabilir (saplama "D" "tatmin edici" olarak dönecektir) ve sonra H makinesinin kendi sayısıyla karşılaştığı anda ne olduğunu kendi gözleriyle görebilir.

İkinci ispatın özeti

Bir sayfadan daha kısa, öncüllerden sonuca geçiş belirsizdir.

Turing, Redüktör reklamı absurdum. O, rastgele bir M makinesinin S.D'si (Standart Açıklama, yani "program") verildiğinde, M'nin verilen bir sembolü (örneğin 0) yazdırıp yazdırmayacağını belirleyen bir E makinesinin varlığını ileri sürer. Bu M'nin bir "bilgisayar makinesi" olduğunu iddia etmiyor.

E makinesinin varlığı göz önüne alındığında, Turing şu şekilde ilerler:

  1. E makinesi varsa, M'nin 0'ı sonsuz sıklıkta yazdırıp yazdırmadığını belirleyen bir G makinesi vardır VE
  2. E mevcutsa, M'nin sonsuz sıklıkta 1 yazdırıp yazdırmadığını belirleyen başka bir süreç çıkar [referans için G 'sürecini / makinesini çağırabiliriz].
  3. G ile G'yi birleştirdiğimizde, M'nin sonsuz sayıda rakam yazdırıp yazdırmadığını belirleyen bir işleme sahibiz, VE
  4. EĞER "G ile G" işlemi M'nin sonsuz sayıda rakam yazdırdığını belirlerse, SONRA "G ile G" M'nin daire içermediğini belirlemiştir, ANCAK
  5. Kanıt 1 ile M'nin daire içermediğini belirleyen bu "G ile G" süreci var olamaz, BU NEDENLE
  6. Makine E mevcut değil.

İkinci kanıtın detayları

İspattaki zorluk 1. adımdır. Okuyucu, Turing'in ince el işçiliğini açıklamadığını fark ederek yardımcı olacaktır. (Özetle: "varoluşsal" ve "evrensel operatörler" arasında, mantıksal operatörlerle yazılan eşdeğer ifadeleriyle birlikte belirli eşdeğerlikleri kullanıyor.)

İşte bir örnek: Önümüzde yüzlerce arabalık bir park yeri gördüğümüzü varsayalım. “Düz (kötü) lastikli arabalar” arayarak tüm arsayı dolaşmaya karar verdik. Yaklaşık bir saat sonra iki "kötü lastikli araba" bulduk. Artık kesin olarak şunu söyleyebiliriz: "Bazı arabaların lastikleri kötüdür". Ya da şöyle diyebiliriz: "Tüm arabaların iyi lastikleri vardır" doğru değildir. Veya: "Şu doğrudur:" tüm arabaların iyi lastikleri yoktur ". Başka bir yere gidelim. Burada "Tüm arabaların iyi lastikleri var" olduğunu keşfediyoruz. "Kötü bir lastiği olan tek bir araba örneği bile yoktur" diyebiliriz. Böylece, her bir araba hakkında ayrı ayrı bir şeyler söyleyebiliyorsak, TÜMÜ hakkında toplu olarak bir şeyler söyleyebileceğimizi görüyoruz.

Turing'in yaptığı budur: M bir makine koleksiyonu yaratıyor {M1, M2, M3, M4, ..., Mn} ve her biri hakkında bir cümle yazar: "X en az bir 0 ”yazdırır ve yalnızca iki"gerçek değerler ”, Doğru = boş veya Yanlış =: 0 :. Teker teker her makine için cümlenin doğruluk değerini belirler ve bir dizi boşluk veya: 0: veya bunların bir kombinasyonunu oluşturur. Şöyle bir şey elde edebiliriz: "M1, 0 "= True AND" yazdırırM2, 0 "= True AND" yazdırırM3, 0 "= True AND" yazdırırM4, 0 ”= False, ... VE“Mn 0 ”= False yazdırır. İpleri alıyor

BBB: 0 :: 0 :: 0: ...: 0: ... sonsuza kadar

sonsuz sayıda makine varsa Mn. Öte yandan, her makine bir "True" üretmiş olsaydı, kasetteki ifade

BBBBB .... BBBB ... ve sonsuz

Böylelikle Turing, ayrı ayrı ele alınan her makine hakkındaki ifadeleri hepsi hakkında tek bir "ifadeye" (dizge) dönüştürmüştür. Bu ifadeyi yaratan makineye (G olarak adlandırır) bakılırsa, onu E makinesiyle test edebilir ve hiç 0 üretip üretmediğini belirleyebilir. Yukarıdaki ilk örneğimizde gerçekten de öyle olduğunu görüyoruz, bu nedenle hepsinin olmadığını biliyoruz. Dizimizdeki M'ler 0s yazdırır. Ancak ikinci örnek, dizge boşluk olduğundan, dizimizdeki her Mn'nin bir 0 ürettiğini gösterir.

Turing'in yapması gereken tek şey, tek bir M'den Mn dizisini oluşturmak için bir süreç oluşturmaktır.

Varsayalım M bu deseni yazdırır:

M => ... AB01AB0010AB…

Turing, M'yi alan ve ilk n 0'ları art arda "0-çubuğuna" dönüştüren bir Mn dizisi çıkaran başka bir F makinesi oluşturur (0):

M1 = ... AB01AB0010AB ...
M2 = ... AB01AB0010AB ...
M3 = ... AB01AB0010AB ...
M4 = ... AB01AB0010AB ...

Ayrıntıları göstermeden, bu F makinesinin gerçekten üretilebilir olduğunu iddia ediyor. Birkaç şeyden birinin olabileceğini görebiliriz. F, 0'a sahip makineler bitebilir veya devam etmesi gerekebilir sonsuza dek "sıfırları iptal etmek" için makineler yaratmak.

Turing şimdi E ve F makinelerini bir kompozit makine G'de birleştiriyor. G, orijinal M ile başlıyor, ardından tüm ardıl makineleri M1, M2'yi oluşturmak için F kullanıyor. . ., Mn. Daha sonra G, M ile başlayan her makineyi test etmek için E'yi kullanır. E, bir makinenin hiçbir zaman sıfır yazdırmadığını algılarsa, G, o makine için: 0: yazdırır. E bir makinenin bir 0 yazdığını algılarsa (Turing'in söylemediğini varsayıyoruz) o zaman G: yazdırır veya bu girişi atlayarak kareleri boş bırakır. Birkaç şeyin olabileceğini görebiliriz.

Mn'nin tüm baskıları 0 ise G, hiçbir zaman 0'lar basmaz VEYA,
Tüm M’nin yazdırılması 0’lar değilse G, reklam sonsuz 0’ları yazdırır VEYA,
G bir süre 0’ları yazdıracak ve sonra duracaktır.

Şimdi, E'yi G'nin kendisine uyguladığımızda ne olur?

E (G), G'nin hiçbir zaman 0 yazdırmadığını belirlerse, tüm Mn'lerin 0’ları yazdırdığını biliriz. Ve bu, tüm Mn M'den geldiğinden, M'nin kendisinin 0’ları yazdırdığı anlamına gelir. sonsuza dek, VEYA
E (G), G'nin 0 yazdırdığını belirlerse, tüm Mn'nin yazdırma 0'larının olmadığını biliyoruz; bu nedenle M, 0’ları yazdırmaz sonsuza dek.

M'nin sonsuz sıklıkta 1 yazdırıp yazdırmadığını belirlemek için aynı işlemi uygulayabiliriz. Bu süreçleri birleştirdiğimizde, M'nin 1'leri ve 0'ları yazdırmaya devam edip etmediğini belirleyebiliriz. sonsuza dek. Böylece M'nin daire içermediğini belirlemek için bir yöntemimiz var. Kanıt 1'e göre bu imkansızdır. Dolayısıyla, E'nin var olduğuna dair ilk iddia yanlıştır: E yoktur.

Üçüncü ispatın özeti

Burada Turing, " Hilbert Entscheidungsproblem çözümü olamaz "(Kararsız, s. 145). İşte o

"… İşlevsel K hesabının verilen bir U formülünün kanıtlanabilir olup olmadığını belirlemek için genel bir süreç olamayacağını gösterir." (ibid.)
"Bir E kümesi, ancak ve ancak hem E hem de onun tamamlayıcısı hesaplanabilir şekilde numaralandırılabilirse hesaplanabilir şekilde karar verilebilir" (Franzén, s. 67)

Turing bir formülün varlığını gösterir Un(M) diyor ki, aslında "M'nin tam bir konfigürasyonunda, 0 kasette belirir "(s. 146). Bu formül DOĞRUDUR, yani" oluşturulabilir "ve bunu nasıl yapacağını gösteriyor.

Sonra Turing, ilki tüm sıkı çalışmayı gerektiren iki Lemmayı kanıtlar. (İkincisi, birincinin sohbetidir.) Sonra kullanır Redüktör reklamı absurdum nihai sonucunu kanıtlamak için:

  1. Bir formül var Un(M). Bu formül DOĞRUDUR VE
  2. Eğer Entscheidungsproblem çözülebilir SONRA mekanik bir süreç olup olmadığını belirlemek için Un(M) kanıtlanabilir (türetilebilir), AND
  3. Lemmas 1 ve 2'ye göre: Un(M) kanıtlanabilir ANCAK VE ANCAK 0 M'nin bazı "tam yapılandırmasında" görünür, AND
  4. EĞER 0 M'nin bazı "tam konfigürasyonlarında" görünür, SONRA rasgele M'nin yazdırılıp yazdırılmayacağını belirleyecek mekanik bir süreç mevcuttur. 0, VE
  5. Proof 2'ye göre, rastgele M'nin hiç yazdırılıp yazdırılmayacağını belirleyecek hiçbir mekanik işlem yoktur 0BU NEDENLE
  6. Un(M) değil kanıtlanabilir (DOĞRUDUR, ancak değil kanıtlanabilir) bu şu anlama gelir: Entscheidungsproblem çözülemez.

Üçüncü kanıtın ayrıntıları

[Okuyucular ispatı ayrıntılı olarak incelemek istiyorlarsa, üçüncü ispat sayfalarının kopyalarını Turing'in sağladığı düzeltmelerle düzeltmelidirler. Okuyucular ayrıca (i) mantık (ii) belgesinde sağlam bir arka plana sahip olmalıdır. Kurt Gödel: "Principia Mathematica ve İlgili Sistemlerin Resmi Olarak Karar Verilemeyen Önerileri Üzerine "(yeniden basıldı Kararsız, s. 5). Gödel'in makalesi ile ilgili yardım için, ör. Ernest Nagel ve James R. Newman, Gödel'in Kanıtı, New York University Press, 1958.]

Teknik ayrıntıları takip etmek için okuyucunun "kanıtlanabilir" kelimesinin tanımını anlaması ve önemli "ipuçlarından" haberdar olması gerekir.

"Provable", Gödel anlamında, (i) aksiyom sisteminin kendisinin "Bu cümle ispatlanabilir" cümlesini üretecek (ifade edecek) kadar güçlü olduğu ve (ii) herhangi bir keyfi "iyi biçimlendirilmiş" kanıtta olduğu anlamına gelir. semboller aksiyomlar, tanımlar ve sonucun sembollerinin ikamesi ile yönlendirilir.

İlk ipucu: "M'nin açıklamasını §6'nın ilk standart biçimine koyalım". Bölüm 6, bir "evrensel makinenin" U bandında M makinesinin çok özel "kodlamasını" açıklar. Bu, okuyucunun Turing'in evrensel U makinesinin bazı özelliklerini ve kodlama şemasını bilmesini gerektirir.

(i) Evrensel makine, bir "talimat tablosunda" bulunan bir "evrensel" talimatlar kümesidir. Bundan ayrı olarak, U'nun bandında bir "bilgisayar makinesi" M "M-kodu" olarak yer alacaktır. Evrensel talimatlar tablosu kasete sembolleri yazdırabilir A, C, D, 0, 1, u, v, w, x, y, z,: . Çeşitli makineler M, bu sembolleri sadece dolaylı olarak U komutu vererek yazdırabilir.

(ii) M'nin "makine kodu" yalnızca birkaç harf ve noktalı virgülden oluşur, yani D, C, A, R, L, N; . M'nin "kodu" içinde hiçbir yerde sayısal "şekiller" (semboller) olmayacaktır. 1 ve 0 hiç görünmez. M, U'nun koleksiyondan bir sembol yazdırmasını isterse boş, 0, 1 daha sonra U'ya bunları yazdırmasını söylemek için aşağıdaki kodlardan birini kullanır. İşleri daha kafa karıştırıcı hale getirmek için, Turing bu sembolleri S0, S1 ve S2 olarak adlandırır, yani.

boş = S0 = D
0 = S1 = DC
1 = S2 = DCC

(iii) Bir "bilgi işlem makinesi", ister doğrudan bir masaya (ilk örneklerinin gösterdiği gibi), ister evrensel makine U'nun şeridinde makine kodu M olarak oluşturulmuş olsun, numarasını boş banda (M'nin sağında) yazar. -kod, varsa) olarak 1s ve 0sonsuza kadar sağa ilerliyor.

(iv) Bir "bilgisayar makinesi" U + "M-kodu" ise, "M-kodu" kaset üzerinde ilk olarak belirir; bandın bir sol ucu vardır ve "M kodu" orada başlar ve alternatif karelerde sağa doğru ilerler. M kodu sona erdiğinde (ve bu M kodlarının sonlu algoritmalar olduğu varsayımından dolayı olmalıdır), "rakamlar" şu şekilde başlayacaktır: 1s ve 0s alternatif karelerde, sonsuza kadar sağa ilerler. Turing, U + "M kodunun" hesaplamaların nerede olduğunu takip etmesine yardımcı olmak için (boş) alternatif kareleri ("E" - "silinebilir" - kareler olarak adlandırılır) kullanır, hem M kodunda hem de makine yazdırıyor.

(v) "Tam konfigürasyon", taranan figürle birlikte M kodu ve o noktaya kadar "rakamlar" da dahil olmak üzere kasetteki tüm sembollerin (sol tarafına basılmış bir işaretçi karakteriyle) bir baskısıdır. taranmış sembol?). Turing'in anlamını doğru yorumladıysak, bu çok uzun bir semboller dizisi olacaktır. Ancak tüm M kodunun tekrarlanması gerekip gerekmediği belirsizdir; sadece mevcut M kodu talimatının bir baskısı ve ayrıca tüm şekillerin bir şekil işaretleyici ile basılması gereklidir).

(vi) Turing, "M kodu" ndaki (yine: kasette görünen M kodu) olası çok sayıda talimatı, şuna benzer üçten biri olan küçük bir kanonik kümeye indirgedi: {qi Sj Sk R ql} Örneğin Makine #qi komutunu yürütüyorsa ve Sj sembolü taranan karede ise, Sk sembolünü yazdırın ve Sağa gidin ve ardından ql komutuna gidin: Diğer talimatlar benzerdir, "Sol" L ve "Hareket yok" N'yi kodlar. Qi = DA ... A, Sj = DC ... C, Sk = sembol dizisiyle kodlanan bu kümedir. DC ... C, R, ql = DA .... A. Her komut, noktalı virgülle diğerinden ayrılır. Örneğin, {q5, S1 S0 L q3} şu anlama gelir: Talimat # 5: Taranan simge ise 0 sonra yazdır boş, Sola gidin, ardından 3 numaralı talimata gidin. Aşağıdaki gibi kodlanmıştır

; D A A A A A D C D L D A A A

İkinci ipucu: Turing, Gödel'in makalesinde ortaya atılan fikirleri, yani formülün (en azından bir kısmının) "Gödelizasyonu" nu kullanıyor. Un(M). Bu ipucu, sayfa 138'de yalnızca bir dipnot olarak görünür (Kararsız): "Bir r asal dizisi ^ (r) "(ibid.) [Burada, parantez içindeki r "yükseltilmiş" dir.] Bu "asal sayı dizisi", F ^ (n) adlı bir formülde görünür.

Üçüncü ipucu: Bu, ikinci ipucunu pekiştiriyor. Turing'in ispattaki orijinal girişimi şu ifadeyi kullanır:

(Eu) N (u) & (x) (... vb ...) (Kararsız, s. 146)

Yazının başlarında Turing daha önce bu ifadeyi kullanmıştı (s. 138) ve N (u) 'yu "u, negatif olmayan bir tam sayıdır" (ibid.) (yani bir Gödel numarası). Ancak, Bernays düzeltmeleriyle Turing, bu yaklaşımı terk etti (yani N (u) kullanımı) ve "Gödel sayısının" açıkça göründüğü tek yer F ^ (n) kullandığı yerdir.

Bu kanıt için ne anlama geliyor? İlk ipucu, kasetteki M kodunun basit bir incelemesinin bir sembol varsa ortaya çıkmayacağı anlamına gelir. 0 hiç U + "M kodu" ile basılmıştır. Bir test makinesi, DC bir talimatı temsil eden sembol dizilerinden birinde. Ama bu talimat hiç "uygulanacak mı?" Bir şeyin öğrenmek için "kodu çalıştırması" gerekir. Bu bir şey bir makine olabilir veya resmi bir kanıttaki satırlar, yani Lemma # 1 olabilir.

İkinci ve üçüncü ipuçları, temeli Gödel'in makalesi olduğu için kanıtın zor olduğu anlamına gelir.

Aşağıdaki örnekte aslında basit bir "teorem" oluşturacağız - biraz Post – Turing makinesi programı "çalıştır". Düzgün tasarlanmış bir teoremin ne kadar mekanik olabileceğini göreceğiz. Göreceğimiz bir kanıt, başlangıca bir "kanıt örneği" ekleyerek ve sonunda neyin ortaya çıktığını görerek yaptığımız teoremin bir "testi" dir.

Hem Lemma # 1 hem de # 2, ispatın gerektirdiği gerekli "IF AND ONLY IF" (yani mantıksal eşdeğerlik) oluşturmak için gereklidir:

"Bir E kümesi, ancak ve ancak hem E hem de onun tamamlayıcısı hesaplanabilir şekilde numaralandırılabilirse hesaplanabilir şekilde karar verilebilir" (Franzén, s. 67)
  • Franzén'den alıntı yapacak olursak:
"A cümlesinin bir resmi sistem S, eğer A ya da onun olumsuzlaması S'de kanıtlanabilirse "(Franzén, s. 65)

Franzén kitabında daha önce "kanıtlanabilir" ifadesini tanımlamıştır:

"Resmi bir sistem, aksiyomlar (resmi olarak tanımlanmış bazı dillerde ifade edilmiştir) ve akıl yürütme kuralları (çıkarım kuralları da denir), teoremler sistemin. Bir teorem aksiyomlardan başlayarak akıl yürütme kurallarının bir dizi uygulamasıyla elde edilebilen sistem dilinde herhangi bir ifadedir. Bir kanıt sonuç olarak bir teoremi götüren bu tür uygulamaların sonlu bir dizisidir "(ibid. s. 17).

Dolayısıyla, bir "cümle" bir sembol dizisidir ve bir teorem bir sembol dizileri dizisidir.

Turing şu görevle karşı karşıyadır:

  • dönüştürmek için Evrensel Turing makinesi "program" ve kasetteki sayısal semboller (Turing'in "rakamları", "1" ve "0" sembolleri), bir "teorem" e yani a (canavarca uzun) cümle dizisi makinenin ardışık eylemlerini, (tümü) bandın şekillerini ve "bant kafasının" konumunu tanımlayan.

Bu nedenle "cümleler dizisi", sembol dizilerinin dizileri olacaktır. İzin verilen tek tek semboller Gödel'in kağıdında tanımlanan sembollerinden gelecektir. (Aşağıdaki örnekte, "şekil" in makine tarafından taranan sembol olduğunu belirtmek için "şekil" etrafında "<" ve ">" kullanıyoruz. ).

Üçüncü kanıtı göstermek için bir örnek

Aşağıda, Turing'in "bilgi işlem makinelerinin" her birinin "boş kaset" üzerinde çalışmaya başlayan bir ikili sayı üreteci / yaratıcısı olduğunu kendimize hatırlatmalıyız. Düzgün bir şekilde inşa edildiğinde, her zaman sonsuza kadar uzaklaşır, ancak talimatları her zaman sonludur. Turing'in ispatlarında, Turing'in kasetinin "sol ucu" vardı, ancak sonsuza kadar sağa uzanıyordu. Aşağıdaki örnek olması açısından, "makinenin" Evrensel bir makine olmadığını, daha ziyade Tablodaki talimatlarla daha basit "özel makine" olduğunu varsayacağız.

Örneğimiz bir değiştirilmiş Post – Turing makinesi Turing Makinesinin modeli. Bu model yalnızca 0 ve 1 sembollerini yazdırır. Boş bant, tüm b'ler olarak kabul edilir. Değiştirilmiş modelimiz, 7 Post-Turing talimatına iki talimat daha eklememizi gerektiriyor. Kullanacağımız kısaltmalar şunlardır:

R, SAĞ: sağa bakın ve bandı sola hareket ettirin veya bant kafasını sağa hareket ettirin
L, SOL: sola bakın ve bandı sağa hareket ettirmek veya bant kafasını sola hareket ettirmek için
E, ERASE kare tarandı (ör. Kareyi boşaltın)
P0 ,: Taranan karede YAZDIR 0
P1 ,: Taranan karede 1. YAZDIR
Jb_n, JUMP-IF-boş-talimat_ # n,
J0_n, JUMP-IF-0-to-talimat_ # n,
J1_n, JUMP-IF-1-to-Instrucntion_ # n,
HALT.

R, L, E, P0 ve P1 durumlarında görevini yaptıktan sonra makine sayısal sırayla bir sonraki talimata devam eder; Testleri başarısız olursa atlamalar için aynen.

Ancak, kısalık olması açısından örneklerimiz yalnızca üç kare kullanacaktır. Ve bunlar her zaman solda taranan kare ile boşluklar olduğu gibi başlayacaktır: yani bbb. 1, 0 ve boş iki sembolle 27 farklı konfigürasyona sahip olabiliriz:

bbb, bb0, bb1, b0b, b00, b01, b1b, b10, b11, 0bb, 0b0, 0b1, 00b, 000, 001, 01b, 010, 011, 1bb, 1b0, 1b1, 10b, 100, 101, 11b, 110, 111

Burada dikkatli olmalıyız, çünkü bir algoritmanın şekiller arasında (geçici olarak) boşluk bırakıp, sonra geri gelip bir şeyi doldurması oldukça olasıdır. Büyük olasılıkla, bir algoritma bunu kasıtlı olarak yapabilir. Aslında, Turing'in makinesi bunu yapıyor - yer belirleyici sembollerini yazdırabilmesi için şekiller arasında boşluklar bırakarak alternatif karelere yazdırıyor.

Döndürmek her zaman alternatif kareleri boş bıraktı, böylece makinesi bir şeklin soluna bir sembol (veya makine evrensel makineyse ve taranan kare aslında "programda" ise bir harf) yerleştirebilirdi. Küçük örneğimizde bundan vazgeçeceğiz ve taranan sembolün etrafına aşağıdaki gibi semboller () koyacağız:

b (b) 0 bu, "Bant soldan boşluğun solunda boşluktur, ancak boş bırakılan" oyunda ", taranan kare boştur," 0 ", sağa doğru boşluktur"
1 (0) 1 bu, "Bant sola boşluktur, ardından 1, taranan kare" 0 "anlamına gelir

Basit bir program yazalım:

başlangıç: P1, R, P1, R, P1, H

Her zaman boş bantla başladığımızı unutmayın. The complete configuration prints the symbols on the tape followed by the next instruction:

start config: (b) P1,
config #1: (1) R,
config #2: 1(b) P1,
config #3: 1(1) R,
config #4: 11(b) P1,
config #5: 11(1) H

Let us add “jump” into the formula. When we do this we discover why the complete configuration must include the tape symbols. (Actually, we see this better, below.) This little program prints three “1”s to the right, reverses direction and moves left printing 0’s until it hits a blank. We will print all the symbols that our machine uses:

start: P1, R, P1, R, P1, P0, L, J1_7, H
(b)bb P1,
(1)bb R,
1(b)b P1,
1(1)b R,
11(b) P1,
11(1) P0,
11(0) L,
1(1)0 J1_7
1(1)0 L
(1)10 J0_7
(1)10 L
(b)110 J0_7
(b)110 H

Here at the end we find that a blank on the left has “come into play” so we leave it as part of the total configuration.

Given that we have done our job correctly, we add the starting conditions and see “where the theorem goes”. The resulting configuration—the number 110—is the PROOF.

  • Turing's first task had to write a generalized expression using logic symbols to express exactly what his Un(M) would do.
  • Turing's second task is to "Gödelize" this hugely long string-of-string-of-symbols using Gödel's technique of assigning primes to the symbols and raising the primes to prime-powers, per Gödel's method.

Glossary of terms used by Turing

1 computable number — a number whose decimal is computable by a machine (i.e., by finite means such as an algorithm)

2 M — a machine with a finite instruction table and a scanning/printing head. M moves an infinite tape divided into squares each “capable of bearing a symbol”. The machine-instructions are only the following: move one square left, move one square right, on the scanned square print symbol p, erase the scanned square, if the symbol is p then do instruction aaa, if the scanned symbol is not p then do instruction aaa, if the scanned symbol is none then do instruction aaa, if the scanned symbol is any do instruction aaa [where “aaa” is an instruction-identifier].

3 computing machine — an M that prints two kinds of symbols, symbols of the first type are called “figures” and are only binary symbols 1 and 0; symbols of the second type are any other symbols.

4 rakamlar — symbols 1 ve 0, a.k.a. “symbols of the first kind”

5 m-configuration — the instruction-identifier, either a symbol in the instruction table, or a string of symbols representing the instruction- number on the tape of the universal machine (e.g. "DAAAAA = #5")

6 symbols of the second kind — any symbols other than 1 ve 0

7 circular — an unsuccessful computating machine. It fails to print, ad infinitum, the figures 0 veya 1 that represent in binary the number it computes

8 circle-free — a successful computating machine. It prints, ad infinitum, the figures 0 veya 1 that represent in binary the number it computes

9 sıra — as in “sequence computed by the machine”: symbols of the first kind a.k.a. figures a.k.a. symbols 0 and 1.

10 computable sequence — can be computed by a circle-free machine

11 SD – Standard Description: a sequence of symbols A, C, D, L, R, N, “;” on a Turing machine tape

12 D.N — Description Number: an S.D converted to a number: 1=A, 2=C, 3 =D, 4=L, 5=R, 6=N, 7=;

13 M(n) — a machine whose D.N is number “n”

14 tatmin edici — a S.D or D.N that represents a circle-free machine

15 U — a machine equipped with a “universal” table of instructions. If U is “supplied with a tape on the beginning of which is written the S.D of some computing machine M, U will compute the same sequence as M.”

16 β’—“beta-primed”: A so-called “diagonal number” made up of the n-th figure (i.e. 0 or 1) of the n-th computable sequence [also: the computable number of H, see below]

17 sen — an unsatisfactory, i.e. circular, S.D

18 s — satisfactory, i.e. circle-free S.D

19 D — a machine contained in H (see below). When supplied with the S.D of any computing machine M, D will test M's S.D and if circular mark it with “u” and if circle-free mark it with “s”

20 H — a computing machine. H computes B’, maintains R and N. H contains D and U and an unspecified machine (or process) that maintains N and R and provides D with the equivalent S.D of N. E also computes the figures of B’ and assembles the figures of B’.

21 R — a record, or tally, of the quantity of successful (circle-free) S.D tested by D

22 N — a number, starting with 1, to be converted into an S.D by machine E. E maintains N.

23 K — a number. The D.N of H.

Required for Proof #3

5 m-configuration — the instruction-identifier, either a symbol in the instruction table, or a string of symbols representing the instruction's number on the tape of the universal machine (e.g. "DAAAAA = instruction #5"). In Turing's S.D the m-configuration appears twice in each instruction, the left-most string is the "current instruction"; the right-most string is the next instruction.

24 tam konfigürasyon — the number (figure 1 veya 0) of the scanned square, the complete sequence of all symbols on the tape, and the m-configuration (the instruction-identifier, either a symbol or a string of symbols representing a number, e.g. "instruction DAAAA = #5")

25 RSi(x, y) — "in the complete configuration x of M the symbol on square y is Si; "complete configuration" is definition #5

26 I(x, y) — "in the complete configuration x of M the square y is scanned"

27 Kqm(x) — "in the complete configuration x of M the machine-configuration (instruction number) is qm"

28 F (x, y) — "y is the hemen successor of x" (follows Gödel's use of "f" as the successor-function).

29 G(x,y) — "x precedes y", not necessarily immediately

30 Inst{qi, Sj Sk L ql} is an abbreviation, as are Inst{qi, Sj Sk R ql}, ve Inst{qi, Sj Sk N ql}. See below.

Turing reduces his instruction set to three “canonical forms” – one for Left, Right, and No-movement. Si and Sk are symbols on the tape.

tape Final
m-config Symbol Operations m-config
qi Si PSk, L qm
qi Si PSk, R qm
qi Si PSk, N qm

For example, the operations in the first line are PSk = PRINT symbol Sk from the collection A, C, D, 0, 1, u, v, w, x, y, z, :, then move tape LEFT.

These he further abbreviated as:(N1) qi Sj Sk L qm(N2) qi Sj Sk R qm(N3) qi Sj Sk N qm

In Proof #3 he calls the first of these “Inst{qi Sj Sk L ql}”, and he shows how to write the entire machine S.D as the logical conjunction (logical OR): this string is called “Des(M)”, as in “Description-of-M”.i.e. if the machine prints 0 then 1's and 0's on alternate squares to the right ad infinitum it might have the table (a similar example appears on page 119):

q1, blank, P0, R, q2
q2, blank, P-blank, R, q3
q3, blank, P1, R, q4
q4, blank, P-blank, R, q1

(This has been reduced to canonical form with the “p-blank” instructions so it differs a bit from Turing's example.)If put them into the “ Inst( ) form” the instructions will be the following (remembering: S0 is blank, S1 = 0, S2 = 1):

Inst {q1 S0 S1 R q2}
Inst {q2 S0 S0 R q3}
Inst {q3 S0 S2 R q4}
Inst {q4 S0 S0 R q1}

The reduction to the Standard Description (S.D) will be:

; D A D D C R D A A ; D A A D D R D A A A ; D A A A D D C C R D A A A A ; D A A A A D D R D A ;

This agrees with his example in the book (there will be a blank between each letter and number). Universal machine U uses the alternate blank squares as places to put "pointers".

Referanslar

  • Turing, A.M. (1936), "On Computable Numbers, with an Application to the Entscheidungsproblem", Londra Matematik Derneği Bildirileri, 2 (published 1937), 42 (1), pp. 230–65, doi:10.1112/plms/s2-42.1.230 (ve Turing, A.M. (1938), "On Computable Numbers, with an Application to the Entscheidungsproblem: A correction", Londra Matematik Derneği Bildirileri, 2 (published 1937), 43 (6), pp. 544–6, doi:10.1112/plms/s2-43.6.544). (Çevrimiçi sürüm.) This is the epochal paper where Turing defines Turing makineleri, shows that the Entscheidungsproblem is unsolvable.
  • Hans Reichenbach (1947), Elements of Symbolic Logic, Dover Publications, Inc., New York.
  • Martin Davis (1965), The Undecidable, Basic Papers on Undecidable Propositions, Unsolvable Problems and Computable Functions, Raven Press, New York. The two papers of Post referenced above are included in this volume. Other papers include those by Gödel, Church, Rosser, and Kleene.
  • Andrew Hodges (1983), Alan Turing: Enigma, Simon ve Schuster, New York. Cf. Chapter "The Spirit of Truth" for a history leading to, and a discussion of, his proof.
  • Torkel Franzén (2005), Gödel'in Teoremi: Kullanımı ve Kötüye Kullanılmasına İlişkin Eksik Bir Kılavuz. A.K. Peters.