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.”