Gödel (dasturlash tili) - Gödel (programming language)

Gödel
Paradigmadeklarativ, mantiq
LoyihalashtirilganJon Lloyd va Patrisiya Xill
TuzuvchiJon Lloyd va Patrisiya Xill
Birinchi paydo bo'ldi1992
Barqaror chiqish
1.5 / 1995 yil 11-avgust (1995-08-11)
Matnni yozishkuchli
OSUnixga o'xshash
LitsenziyaFaqatgina notijorat tadqiqot / ta'lim maqsadlarida foydalanish
Lahjalar
Gödel umumiy (parametrlangan) modullar bilan

Gödel a deklarativ, umumiy maqsad dasturlash tili ga rioya qilgan mantiq dasturlash paradigmasi. Bu qattiq yozilgan til, asoslangan tizim turi juda xilma-xil mantiq bilan parametrik polimorfizm. U mantiqchining nomi bilan atalgan Kurt Gödel.

Xususiyatlari

Gödel modul tizimiga ega va u qo'llab-quvvatlaydi o'zboshimchalik bilan aniqlik tamsayılar, o'zboshimchalik bilan aniqlik ratsionalligi va shuningdek suzuvchi nuqta raqamlari. Bu hal qilishi mumkin cheklovlar sonlarning cheklangan domenlari va chiziqli ratsional cheklovlar ustidan. Bu ishlov berishni qo'llab-quvvatlaydi cheklangan to'plamlar. Bundan tashqari, moslashuvchan hisoblash qoidasi va bir vaqtning o'zida mantiqiy dasturlash tillarini umumlashtiradigan Azizillo operatori mavjud.

Gödelniki meta-mantiqiy ob'ektlar tahlil qiladigan meta-dasturlarni qo'llab-quvvatlaydi, transformatsiya, boshqa vazifalar qatorida kompilyatsiya, tekshirish va disk raskadrovka.

Namuna kodi

Quyidagi Gödel moduli ikkita sonning eng katta umumiy bo'luvchisi (GCD) tavsifidir. Bu Gödelning deklarativ xususiyatini namoyish qilish uchun mo'ljallangan, ayniqsa samarali emas CommonDivisor predikat agar shunday bo'lsa, deydi men va j nolga teng emas d ning umumiy bo'luvchisi men va j agar u o'rtasida bo'lsa 1 va kichikroq men va j va ikkalasini ham ajratadi men va j aniq Gcd predikat buni aytadi d ning eng katta umumiy bo'luvchisi men va j agar u umumiy bo'luvchi bo'lsa men va jva yo'q e bu ham umumiy bo'luvchidir men va j va kattaroqdir d.

MODUL GCD.IMPORT Butun sonlar. Gcd-ni taxmin qilish: Integer * Integer * Integer.Gcd (i, j, d) <- CommonDivisor (i, j, d) & ~ SOME [e] (CommonDivisor (i, j, e) & e> d). CommonDivisor-ni taxmin qilish: Integer * Integer * Integer.CommonDivisor (i, j, d) <- IF (i = 0  / j = 0) THEN d = Maks (Abs (i), Abs (j)) ELSE 1 = 

Tashqi havolalar