SECD makinesi - SECD machine

SECD makinesi oldukça etkili (Görmek: # Landin'in katkısı ) sanal makine ve soyut makine hedef olması amaçlanmıştır fonksiyonel programlama dili derleyiciler. Harfler Stack Eçevre Control, Dump - makinenin dahili kayıtları. Stack, Control ve Dump kayıtları (bazı gerçekleştirmeler) yığınlar ve Çevre, bir ilişkilendirilebilir dizi.

Makine değerlendirmek için özel olarak tasarlanmış ilk makineydi lambda hesabı ifade. Başlangıçta tarafından tanımlanmıştır Peter J. Landin "İfadelerin Mekanik Değerlendirmesi"[1] Landin tarafından yayınlanan açıklama oldukça soyuttu ve birçok uygulama seçeneğini açık bıraktı (bir operasyonel anlambilim ). Bu nedenle, SECD makinesi genellikle daha ayrıntılı bir biçimde sunulur, örneğin Peter Henderson 's Lispkit Lisp Derleyici, 1980'den beri dağıtılır. O zamandan beri diğer birkaç deneysel derleyicinin hedefi olarak kullanılmaktadır.

1989'da araştırmacılar Calgary Üniversitesi makinenin donanım uygulaması üzerinde çalıştı.[2]

Landin'in katkısı

D. A. Turner (2012) [3] Şunu belirtiyor Algol 60 Üzerine Gözden Geçirilmiş Rapor (Naur 1963), tanımlayıcılarda sistematik bir değişiklikle değişken yakalamayı önleyen bir kopyalama kuralı tarafından bir prosedür çağrısı belirtir. Bu yöntem Algol 60 uygulamasında çalışır, ancak işlevlerin birinci sınıf vatandaşlar olduğu işlevsel bir programlama dilinde, bir çağrı yığınındaki bir serbest değişken hatalı olarak referans gösterilebilir.

Turner, Landin'in bunu SECD makinesiyle çözdüğünü, burada bir fonksiyonun bir kapatma bunun yerine yığın içinde.[3]

Gayri resmi açıklama

Bir ifadenin değerlendirilmesi başladığında, ifade kontrolün tek öğesi olarak yüklenir C. Çevre E, yığın S ve dökmek D boş başlayın.

Değerlendirilmesi sırasında C dönüştürülür ters Lehçe notasyonu (RPN) ile ap (için uygulamak ) tek operatör olmak. Örneğin, ifade F (G X) (tek bir liste öğesi) listeye değiştirilir X: G: ap: F: ap.

Değerlendirilmesi C diğer RPN ifadelerine benzer şekilde ilerler. İçindeki ilk öğe C bir değerdir, yığına aktarılır S. Daha doğrusu, öğe bir tanımlayıcıysa, yığına aktarılan değer, geçerli ortamda bu tanımlayıcı için bağlayıcı olacaktır. E. Öğe bir soyutlamaysa, bir kapatma serbest değişkenlerinin bağlarını korumak için oluşturulmuştur ( E) ve istifin üzerine itilen bu kapaktır.

Öğe ise ap, iki değer yığından çıkarılır ve uygulama yapılır (ilk olarak ikinciye uygulanır). Uygulamanın sonucu bir değer ise, yığına itilir.

Ancak, uygulama bir değere yönelik bir soyutlamaysa, kendisi bir uygulama (bir değerden ziyade) olabilen bir lambda hesap ifadesi ile sonuçlanacaktır ve bu nedenle yığına aktarılamaz. Bu durumda, güncel içerik S, E, ve C çöplüğe itildi D (bu üçlülerin bir yığınıdır), S boş olarak yeniden başlatıldı ve C ile uygulama sonucuna yeniden başlatılır E Bu ifadenin serbest değişkenleri için ortamı içeren, uygulamadan kaynaklanan bağlanma ile artırılmış. Değerlendirme daha sonra yukarıdaki gibi devam eder.

Tamamlanan değerlendirme ile gösterilir C boş olmak, bu durumda sonuç yığında olacaktır S. Tarihinde kaydedilen son değerlendirme durumu D daha sonra açılır ve tamamlanan değerlendirmenin sonucu, geri yüklenen yığın içeriğine aktarılır. D. Geri yüklenen durumun değerlendirilmesi daha sonra yukarıdaki gibi devam eder.

Eğer C ve D ikisi de boş, genel değerlendirme yığındaki sonuçla tamamlandı S.

Kayıtlar ve hafıza

SECD makinesi yığın tabanlı. Fonksiyonlar argümanlarını yığından alır. Yerleşik talimatların argümanları, talimat akışında hemen ardından kodlanır.

Tüm dahili veri yapıları gibi, yığın da bir listedir. S listeyi gösteren kayıt baş veya başlangıç. Liste yapısı nedeniyle, yığının sürekli bir bellek bloğu olması gerekmez, bu nedenle tek bir boş bellek hücresi olduğu sürece yığın alanı kullanılabilir. Tüm hücreler kullanılmış olsa bile, çöp toplama ek boş bellek sağlayabilir. Açıktır ki, SECD yapısının belirli uygulamaları yığını bir kanonik yığın yapısı olarak uygulayabilir, böylece yığın boyutuna kesin bir sınır koyulması koşuluyla sanal makinenin genel verimliliğini artırabilir.

C değerlendirilecek kod veya talimat listesinin başındaki noktaları kaydedin. Talimat yerine getirildikten sonra, C listedeki bir sonraki talimatı işaret eder — bir talimat işaretçisi (veya program sayıcı ), geleneksel makinelerde, sonraki talimatların her zaman yürütme sırasında belirtilmesi ve geleneksel makinelerde olduğu gibi varsayılan olarak sonraki bellek konumlarında bulunmaması dışında.

Mevcut değişken ortamı, E liste listesini gösteren kayıt. Her bir liste bir ortam düzeyini temsil eder: mevcut işlevin parametreleri listenin başındadır, geçerli işlevde serbest olan, ancak çevreleyen bir işlevle bağlanan değişkenler, diğer öğelerdedir. E.

Kimin başında çöplük D kayıt noktaları, örneğin işlev çağrıları sırasında diğer kayıtların değerleri için geçici depolama olarak kullanılır. Diğer makinelerin dönüş istifine benzetilebilir.

SECD makinesinin bellek organizasyonu, çoğu işlevsel dil tarafından kullanılan modele benzer tercümanlar: her biri bir atom (basit bir değer, örneğin 13) veya boş veya boş olmayan bir listeyi temsil eder. İkinci durumda, hücre diğer hücrelere iki işaretçi tutar, biri birinci öğeyi temsil eder, diğeri ise birinci öğe haricinde listeyi temsil eder. İki işaretçi geleneksel olarak adlandırılır araba ve cdr sırasıyla - ancak daha modern terimler baş ve kuyruk bunun yerine sıklıkla kullanılır. Bir hücrenin tutabileceği farklı değer türleri, bir etiket. Genellikle farklı atom türleri (tamsayılar, dizgiler vb.) Da ayırt edilir.

Yani, sayıları içeren bir liste 1, 2, ve 3, genellikle şu şekilde yazılır (1 2 3)aşağıdaki gibi temsil edilebilir:

Adres Etiketi İçeriği (tamsayılar için değer, listeler için araba ve cdr) 9 [tamsayı | 2] 8 [tamsayı | 3] 7 [liste | 8 | 0] 6 [liste | 9 | 7] ... 2 [liste | 1 | 6] 1 [tam sayı | 1] 0 [sıfır]

Hafıza hücreleri 3'ten 5'e kadar olan hücreler, hafızaya rastgele dağıtılabilen listemize ait değildir. Hücre 2 listenin başıdır, ilk öğenin değerini tutan hücre 1'e ve yalnızca içeren listeye işaret eder. 2 ve 3 (6. hücreden başlar). 6. hücre, 2'yi tutan bir hücreye ve 7 numaralı hücreye işaret eder; bu, yalnızca 3. Bunu, değeri içeren 8. hücreyi işaret ederek yapar 3ve boş bir listeyi gösteriyor (sıfır) cdr olarak. SECD makinesinde, 0 hücresi her zaman dolaylı olarak boş listeyi temsil eder, bu nedenle boş bir listeyi işaret etmek için özel bir etiket değerine gerek yoktur (sadece 0 hücresine işaret edebilecek ihtiyaç duyulan her şey).

Bir liste hücresindeki cdr'nin başka bir listeyi göstermesi gerektiği ilkesi sadece bir kuraldır. Hem araba hem de cdr atomları gösteriyorsa, bu genellikle şöyle yazılan bir çift verir: (1 . 2)

Talimatlar

  • sıfır yığına sıfır işaretçi iter
  • ldc yığına sabit bir argüman iter
  • ld bir değişkenin değerini yığına iter. Değişken, bir çift olan bağımsız değişken ile gösterilir. Çiftin arabası seviyeyi, cdr konumunu belirtir. Yani (1 . 3) mevcut fonksiyonun (seviye 1) üçüncü parametresini verir.
  • sel iki liste argümanı bekler ve yığından bir değer çıkarır. İlk liste, atılan değer sıfır değilse, ikinci liste ise çalıştırılır. Bu liste işaretçilerinden biri yapılmadan önce yeni C, aşağıdaki talimata bir işaretçi çöplükte kaydedilir.
  • katılmak dökümden bir liste referansı açar ve bunu yeni değer yapar C. Bu talimat, her iki alternatifin sonunda yer alır. sel.
  • ldf bir işlevi temsil eden bir liste argümanını alır. Bir kapama (işlevi ve mevcut ortamı içeren bir çift) oluşturur ve bunu yığının üzerine iter.
  • ap yığından bir kapanış ve parametre değerleri listesi açar. Kapatma, parametrelere, ortamını mevcut ortam olarak kurarak, parametre listesini onun önüne iterek, yığını temizleyerek ve ayarlayarak uygulanır. C kapanış fonksiyon göstericisine. Önceki değerleri S, Eve sonraki değeri C çöplükte kaydedilir.
  • ret yığından bir dönüş değeri çıkarır, geri yükler S, E, ve C dökümden ve dönüş değerini şimdiki yığına iter.
  • dum ortam listesinin önüne bir "kukla", boş bir liste iter.
  • rap gibi çalışır , yalnızca sahte bir ortam oluşumunu mevcut ortamla değiştirir, böylece yinelemeli işlevleri mümkün kılar

Araba, cdr, liste oluşturma, tamsayı toplama, G / Ç vb. Gibi temel işlevler için bir dizi ek talimat mevcuttur. Hepsi yığından gerekli parametreleri alır.

Ayrıca bakınız

Referanslar

  1. ^ Landin, P. J. (Ocak 1964). "İfadelerin Mekanik Değerlendirmesi". Bilgisayar. J. 6 (4): 308–320. doi:10.1093 / comjnl / 6.4.308.
  2. ^ Tasarım üzerine bir makale, SECD: TASARIM SORUNLARI kullanılabilir.
  3. ^ a b D. A. Turner "Fonksiyonel Programlama Dillerinin Bazı Tarihi" davetli bir derste TFP12, St Andrews University, 12 Haziran 2012. Algol 60 ile ilgili bölüme bakın.

daha fazla okuma

Dış bağlantılar