Pemrograman Fungsional - Kalkulus Lambda

Kalkulus Lambda adalah kerangka kerja yang dikembangkan oleh Gereja Alonzo pada tahun 1930-an untuk mempelajari komputasi dengan fungsi.

  • Function creation - Gereja memperkenalkan notasinya λx.Euntuk menunjukkan fungsi di mana 'x' adalah argumen formal dan 'E' adalah badan fungsional. Fungsi ini bisa tanpa nama dan argumen tunggal.

  • Function application - Gereja menggunakan notasi itu E1.E2 untuk menunjukkan penerapan fungsi E1 untuk argumen sebenarnya E2. Dan semua fungsi dalam satu argumen.

Sintaks Kalkulus Lambda

Kalkulus Lamdba mencakup tiga jenis ekspresi, yaitu,

E :: = x (variabel)

| E 1 E 2 (aplikasi fungsi)

| λx.E (pembuatan fungsi)

Dimana λx.E disebut abstraksi Lambda dan E dikenal sebagai λ-ekspresi.

Mengevaluasi Kalkulus Lambda

Kalkulus lambda murni tidak memiliki fungsi bawaan. Mari kita evaluasi ekspresi berikut -

(+ (* 5 6) (* 8 3))

Di sini, kita tidak dapat memulai dengan '+' karena hanya beroperasi pada angka. Ada dua ekspresi yang dapat direduksi: (* 5 6) dan (* 8 3).

Kita bisa mengurangi salah satunya dulu. Misalnya -

(+ (* 5 6) (* 8 3)) 
(+ 30 (* 8 3)) 
(+ 30 24) 
= 54

Aturan pengurangan β

Kami membutuhkan aturan pengurangan untuk menangani λs

(λx . * 2 x) 4 
(* 2 4) 
= 8

Ini disebut reduksi β.

Parameter formal dapat digunakan beberapa kali -

(λx . + x x) 4 
(+ 4 4) 
= 8

Jika ada beberapa istilah, kami dapat menanganinya sebagai berikut -

(λx . (λx . + (− x 1)) x 3) 9

Batin x milik batin λ dan x luar milik yang terluar.

(λx . + (− x 1)) 9 3 
+ (− 9 1) 3 
+ 8 3 
= 11

Variabel Bebas dan Terikat

Dalam ekspresi, setiap kemunculan variabel bisa "bebas" (ke λ) atau "terikat" (ke λ).

reduksi β dari (λx . E) y menggantikan setiap x yang terjadi gratis di E dengan y. Sebagai Contoh -

Pengurangan Alfa

Reduksi alfa sangat sederhana dan dapat dilakukan tanpa mengubah arti ekspresi lambda.

λx . (λx . x) (+ 1 x) ↔ α λx . (λy . y) (+ 1 x)

Misalnya -

(λx . (λx . + (− x 1)) x 3) 9 
(λx . (λy . + (− y 1)) x 3) 9 
(λy . + (− y 1)) 9 3 
+ (− 9 1) 3 
+ 8 3 
11

Teorema Church-Rosser

Teorema Church-Rosser menyatakan sebagai berikut -

  • Jika E1 ↔ E2, maka ada E sehingga E1 → E dan E2 → E. “Reduksi dengan cara apapun pada akhirnya dapat menghasilkan hasil yang sama.”

  • Jika E1 → E2, dan E2 adalah bentuk normal, maka terjadi reduksi orde normal dari E1 menjadi E2. “Reduksi orde normal akan selalu menghasilkan bentuk normal, jika ada.”