Prolog - Prolog

Prolog
ParadigmaMantiqiy dasturlash
LoyihalashtirilganAlen Kolmerauer, Robert Kovalski
Birinchi paydo bo'ldi1972
Barqaror chiqish
1-qism: Umumiy yadro-1-nashr (1995 yil iyun); 25 yil oldin (1995-06))
2-qism: Modullar-nashr 1 (2000 yil iyun); 20 yil oldin (2000-06))
Fayl nomi kengaytmalari.pl, .pro, .P
Veb-sayt1-qism: www.iso.org/ standart/21413.html
2-qism: www.iso.org/ standart/20775.html
Mayor amalga oshirish
B-Prolog, Ciao, ECLiPSe, GNU Prolog, Jekejeke Prolog, Poplog Prolog, P #, Quintus Prolog, SICStus, qulupnay, SWI-Prolog, Tau Prolog, tuProlog, WIN-PROLOG, XSB, YAP.
Lahjalar
ISO Prolog, Edinburgh Prolog
Ta'sirlangan
Rejalashtiruvchi
Ta'sirlangan
CHR, Klojure, Ma'lumotlar katalogi, Erlang, KL0, KL1, Merkuriy, Oz, Strand, Visual Prolog, XSB

Prolog a mantiqiy dasturlash bilan bog'liq til sun'iy intellekt va hisoblash lingvistikasi.[1][2][3]

Prologning ildizi bor birinchi darajali mantiq, a rasmiy mantiq va boshqalarnikidan farqli o'laroq dasturlash tillari, Prolog asosan a sifatida mo'ljallangan deklarativ dasturlash til: dastur mantig'i so'zlar bilan ifodalanadi munosabatlar, faktlar sifatida ifodalangan va qoidalar. A hisoblash a ishga tushirish bilan boshlanadi so'rov bu munosabatlar ustidan.[4]

Til 1972 yilda Frantsiyaning Marsel shahrida ishlab chiqilgan va amalga oshirilgan Alen Kolmerauer asosida Filipp Russel bilan Robert Kovalski protsessual talqini Shoxning gaplari.[5][6]

Prolog birinchi mantiqiy dasturlash tillaridan biri edi[7] va bugungi kunda eng mashhur til bo'lib qolmoqda, bunda bir nechta bepul va tijorat dasturlari mavjud. Til uchun ishlatilgan isbotlovchi teorema,[8] ekspert tizimlari,[9] muddatli qayta yozish,[10] tipdagi tizimlar,[11] va avtomatlashtirilgan rejalashtirish,[12] shuningdek uning dastlabki mo'ljallangan foydalanish sohasi, tabiiy tilni qayta ishlash.[13][14] Zamonaviy Prolog muhiti yaratilishini qo'llab-quvvatlaydi grafik foydalanuvchi interfeyslari, shuningdek, ma'muriy va tarmoq dasturlari.

Prolog qidirish kabi qoidalarga asoslangan mantiqiy so'rovlardan foyda keltiradigan aniq vazifalar uchun juda mos keladi ma'lumotlar bazalari, ovozli boshqaruv tizimlar va shablonlarni to'ldirish.

Sintaksis va semantik

Prolog-da dastur mantig'i munosabatlar nuqtai nazaridan ifodalanadi va hisoblash ishga tushirish orqali boshlanadi so'rov bu munosabatlar ustidan. Aloqalar va so'rovlar Prolog-ning yagona ma'lumot turi yordamida tuziladi muddat.[4] Aloqalar tomonidan belgilanadi bandlar. So'rovni hisobga olgan holda Prolog dvigateli a ni topishga harakat qiladi qaror rad etish inkor qilingan so'rovning. Agar inkor qilingan so'rovni rad etish mumkin bo'lsa, ya'ni inkor qilingan so'rovdan iborat bandlar va singleton to'plamining birlashishini yolg'onga aylantiradigan barcha erkin o'zgaruvchilar uchun bir zum topilsa, demak, topilgan instantiya qo'llanilgan holda asl so'rov mantiqiy natija dasturning. Bu Prologni (va boshqa mantiqiy dasturlash tillarini) ma'lumotlar bazasi uchun ayniqsa foydali qiladi, ramziy matematika va tilni tahlil qilish dasturlari. Chunki Prolog nopoklikka yo'l qo'yadi predikatlar, tekshirish haqiqat qiymati ba'zi bir maxsus predikatlar qasddan bo'lishi mumkin yon ta'sir, masalan, qiymatni ekranga bosib chiqarish. Shu sababli dasturchiga ma'lum miqdordagi an'anaviy foydalanishga ruxsat beriladi majburiy dasturlash mantiqiy paradigma noqulay bo'lganida. Unda "sof Prolog" deb nomlangan mutlaqo mantiqiy kichik to'plam, shuningdek, bir qator ekstralogik xususiyatlar mavjud.

Ma'lumot turlari

Prologning singlisi ma'lumotlar turi bo'ladi muddat. Shartlar ham atomlar, raqamlar, o'zgaruvchilar yoki qo'shma atamalar.

  • An atom xos ma'nosi bo'lmagan umumiy maqsadli ism. Bunga atomlarning misollari kiradi x, qizil, "Tako"va "ba'zi atomlar".
  • Raqamlar bolishi mumkin suzadi yoki butun sonlar. ISO standartiga mos Prolog tizimlari Prolog bayrog'ini "chegaralangan" holda tekshirishi mumkin. Asosiy Prolog tizimlarining aksariyati o'zboshimchalik bilan uzunlikdagi butun sonlarni qo'llab-quvvatlaydi.
  • O'zgaruvchilar harflar, raqamlar va pastki chiziq belgilaridan tashkil topgan va katta harf yoki pastki chiziq bilan boshlanadigan qator bilan belgilanadi. O'zgaruvchilar mantiqiy o'zgaruvchilarga chambarchas o'xshaydi, chunki ular ixtiyoriy atamalar uchun to'ldiruvchidir.
  • A aralash atama yana "atamalar" bo'lgan "funktsiya" va bir qator "argumentlar" deb nomlangan atomlardan iborat. Murakkab atamalar odatda funktsiya sifatida yoziladi, so'ngra qavs ichida vergul bilan ajratilgan argumentlar atamalari ro'yxati mavjud. Argumentlar soni atama deyiladi arity. Atomni birikma atama deb hisoblash mumkin arity nol. Murakkab atamaga misol person_friends (zelda, [tom, jim]).

Murakkab atamalarning alohida holatlari:

  • A Ro'yxat atamalarning buyurtma qilingan to'plamidir. U vergul bilan ajratilgan kvadrat qavslar yoki bo'sh ro'yxat bilan belgilanadi []. Masalan, [1,2,3] yoki [qizil, yashil, ko'k].
  • Iplar: Tirnoq bilan o'ralgan belgilar ketma-ketligi (raqamli) belgilar kodlari ro'yxatiga, belgilar ro'yxatiga (uzunligi 1 atomlari) yoki Prolog bayrog'ining qiymatiga qarab atomga teng. juft_quotes. Masalan, "bo'lish yoki bo'lmaslik".[15]

ISO Prolog beradi atom / 1, raqam / 1, tamsayı / 1va float / 1 uchun predikatlar turini tekshirish.[16]

Qoidalar va faktlar

Prolog dasturlari bandlar yordamida aniqlangan munosabatlarni tavsiflaydi. Pure Prolog bilan cheklangan Shoxning gaplari. Gapning ikki turi mavjud: faktlar va qoidalar. Qoidalar shaklga ega

Bosh :- Tana.

va "Badan rost bo'lsa, bosh to'g'ri" deb o'qiladi. Qoidalar tanasi predikatlarga chaqiriqlardan iborat bo'lib, ularni qoida deb atashadi maqsadlar. O'rnatilgan mantiqiy operator ,/2 (arity degani 2 operator ism bilan ,) bildiradi birikma maqsadlar va ;/2 bildiradi ajratish. Bog'lanish va ajratish faqat tanada paydo bo'lishi mumkin, qoida boshida emas.

Bo'sh tanasi bo'lgan gaplar chaqiriladi faktlar. Haqiqatning misoli:

mushuk(qalloblar).

bu qoidaga teng:

mushuk(qalloblar) :- to'g'ri.

O'rnatilgan predikat rost / 0 har doim ham to'g'ri.

Yuqoridagi haqiqatni hisobga olgan holda, quyidagilarni so'rash mumkin:

Crookshanks mushukmi?

 ?- mushuk(qalloblar). Ha

mushuklar qanday narsalar?

 ?- mushuk(X). X = qalloblar

Tanasi bo'lgan gaplar chaqiriladi qoidalar. Qoidaga misol:

hayvon(X) :- mushuk(X).

Agar biz o'sha qoidani qo'shsak va so'rasak hayvonlar qanday narsalar?

 ?- hayvon(X). X = qalloblar

Ko'plab qurilgan predikatlarning relyatsion xususiyati tufayli ular odatda bir necha yo'nalishda ishlatilishi mumkin. Masalan, uzunlik / 2 ro'yxatning uzunligini aniqlash uchun ishlatilishi mumkin (uzunlik (Ro'yxat, L), ro'yxat berilgan Ro'yxat) shuningdek berilgan uzunlikdagi ro'yxat skeletini yaratish uchun (uzunlik (X, 5)), shuningdek ikkala ro'yxat skeletlari va ularning uzunliklarini birgalikda yaratish uchun (uzunlik (X, L)). Xuddi shunday, ilova / 3 ikkala ro'yxatni qo'shish uchun ikkalasidan ham foydalanish mumkin (qo'shish (ListA, ListB, X) berilgan ro'yxatlar ListA va Ro'yxatB) shuningdek berilgan ro'yxatni qismlarga ajratish (ilova (X, Y, Ro'yxat), ro'yxat berilgan Ro'yxat). Shu sababli, kutubxonaning nisbatan kichik to'plami ko'plab Prolog dasturlari uchun etarli.

Umumiy maqsadli til sifatida Prolog shuningdek, odatdagi faoliyatni amalga oshirish uchun turli xil predikatlarni taqdim etadi kirish / chiqish, grafiklardan foydalangan holda va boshqa yo'llar bilan operatsion tizim bilan aloqa qilish. Ushbu predikatlar relyatsion ma'noga ega emas va ular faqat tizimda yuzaga keladigan yon ta'sirlari uchun foydalidir. Masalan, predikat yozish / 1 ekranda atamani aks ettiradi.

Ijro

Prolog dasturining bajarilishi foydalanuvchining so'rov deb nomlangan bitta maqsadni e'lon qilishi bilan boshlanadi. Mantiqan, Prolog dvigateli a ni topishga harakat qiladi qaror inkor qilingan so'rovni rad etish. Prolog tomonidan qo'llaniladigan rezolyutsiya usuli deyiladi SLD o'lchamlari. Agar inkor qilingan so'rovni rad etish mumkin bo'lsa, unda tegishli o'zgaruvchan birikmalar mavjud bo'lgan so'rov dasturning mantiqiy natijasidir. Bunday holda, barcha hosil bo'lgan o'zgaruvchan birikmalar foydalanuvchiga xabar qilinadi va so'rov muvaffaqiyatli bajarilgan deb aytiladi. Amaliy jihatdan Prologni bajarish strategiyasini boshqa tillardagi funktsiya chaqiruvlarini umumlashtirish deb hisoblash mumkin, bir farqi shundaki, bir nechta band boshlari berilgan qo'ng'iroqqa mos kelishi mumkin. Bunday holda, tizim tanlov nuqtasini yaratadi, birlashtiradi birinchi muqobilning bosh qismi bilan maqsad va shu birinchi muqobilning maqsadlari bilan davom etadi. Agar dasturni amalga oshirishda biron bir maqsad bajarilmasa, so'nggi tanlov nuqtasi yaratilganidan buyon qilingan barcha o'zgaruvchan birikmalar bekor qilinadi va bajarilish ushbu tanlov nuqtasining keyingi alternativasi bilan davom etadi. Ushbu ijro strategiyasi xronologik deb nomlanadi orqaga qaytish. Masalan:

ona_bola(trude, sally). ota_bola(tom, sally).ota_bola(tom, erika).ota_bola(Mayk, tom). qardosh(X, Y)      :- ota_bola(Z, X), ota_bola(Z, Y). ota_bola(X, Y) :- ota_bola(X, Y).ota_bola(X, Y) :- ona_bola(X, Y).

Buning natijasida quyidagi so'rov to'g'ri deb baholanadi:

 ?- qardosh(sally, erika). Ha

Bu quyidagicha olinadi: Dastlab, so'rov uchun faqat bitta bosh gap mos keladi qardosh (salli, erika) birinchisi, shuning uchun so'rovni isbotlash ushbu bandning tanasini mos keladigan o'zgaruvchan birikmalar bilan, ya'ni qo'shma bilan isbotlashga tengdir (parent_child (Z, sally), parent_child (Z, erica)). Keyingi isbotlangan maqsad bu bog'lanishning eng chap tomonidir, ya'ni. parent_child (Z, sally). Ikkita bandning boshlari ushbu maqsadga mos keladi. Tizim tanlov nuqtasini yaratadi va tanasi bo'lgan birinchi alternativani sinab ko'radi otasi (Z, salli). Ushbu maqsad fakt yordamida isbotlanishi mumkin ota_bola (tom, salli), shuning uchun majburiy Z = tom hosil bo'ladi va isbotlanadigan keyingi maqsad yuqoridagi birikmaning ikkinchi qismidir: ota-bola (tom, erika). Shunga qaramay, buni tegishli fakt bilan isbotlash mumkin. Barcha maqsadlarni isbotlash mumkin bo'lganligi sababli, so'rov muvaffaqiyatli bo'ladi. So'rov hech qanday o'zgaruvchini o'z ichiga olmaganligi sababli, foydalanuvchiga hech qanday bog'lanish haqida xabar berilmaydi. O'zgaruvchilar bilan so'rov, masalan:

?- ota_bola(Ota, Bola).

backtracking bo'yicha barcha to'g'ri javoblarni sanab chiqadi.

Yuqorida aytib o'tilganidek, kod bilan so'rovga e'tibor bering ? - aka-uka (salli, salli). ham muvaffaqiyatga erishadi. Agar xohlasangiz, tegishli cheklovlarni tavsiflash uchun qo'shimcha maqsadlar qo'yiladi.

Looplar va rekursiya

Takroriy algoritmlarni rekursiv predikatlar yordamida amalga oshirish mumkin.[17]

Salbiy

Ichki Prolog predikati \+/1 beradi inkor etishmovchilik sifatida bunga imkon beradi monotonik emas mulohaza yuritish. Maqsad + noqonuniy (X) qoida bo'yicha

qonuniy(X) :- \+ noqonuniy(X).

quyidagicha baholanadi: Prolog isbotlashga urinadi noqonuniy (X). Agar ushbu maqsad uchun dalil topilsa, asl maqsad (ya'ni, + noqonuniy (X)) bajarilmaydi. Agar dalil topilmasa, asl maqsad muvaffaqiyatli bo'ladi. Shuning uchun \+/1 prefiks operatori so'rovdan beri "isbotlanmaydigan" operator deb nomlanadi ? - + Maqsad. agar maqsad isbotlanmasa muvaffaqiyatli bo'ladi. Bunday inkor tovush agar uning argumenti bo'lsa "zamin" (ya'ni o'zgaruvchini o'z ichiga olmaydi). Agar argument o'zgaruvchiga ega bo'lsa va isbotlash protsedurasi to'liq bo'lsa, mustahkamlik yo'qoladi. Xususan, so'rov ? - qonuniy (X). endi qonuniy bo'lgan barcha narsalarni sanab o'tishda foydalanib bo'lmaydi.

Prologda dasturlash

Prolog-da yuklash kodi deb nomlanadi konsalting. Prolog so'rovlarini Prolog so'roviga kiritish orqali interaktiv tarzda ishlatilishi mumkin ?-. Agar echim bo'lmasa, Prolog yozadi yo'q. Agar echim bo'lsa, u bosilib chiqadi. Agar so'rov uchun bir nechta echim bo'lsa, ularni yarim nuqta kiritish orqali so'rash mumkin ;. Kod samaradorligini, o'qish qobiliyatini va saqlanishini yaxshilash uchun dasturlashning yaxshi amaliyoti bo'yicha ko'rsatmalar mavjud.[18]

Prologda yozilgan dasturlarning bir nechtasini kuzatib boring.

Salom Dunyo

So'rovga misol:

?- yozmoq('Salom Dunyo!'), nl.Salom Dunyo!to'g'ri.?-

Kompilyatorni optimallashtirish

Har qanday hisoblash deklarativ tarzda davlat o'tishlarining ketma-ketligi sifatida ifodalanishi mumkin. Masalan, an optimallashtiruvchi kompilyator uchta optimallashtirish o'tish bilan dastlabki dastur va uning optimallashtirilgan shakli o'rtasidagi munosabatlar sifatida amalga oshirilishi mumkin:

dastur_optimized(Prog0, Prog) :-    optimallashtirish_pass_1(Prog0, Prog1),    optimallashtirish_pass_2(Prog1, Prog2),    optimallashtirish_pass_3(Prog2, Prog).

yoki unga teng ravishda foydalanish DCG yozuv:

dastur_optimized --> optimallashtirish_pass_1, optimallashtirish_pass_2, optimallashtirish_pass_3.

Quicksort

The tezkor saralash algoritmi, ro'yxatni uning saralangan versiyasiga tegishli:

bo'lim([], _, [], []).bo'lim([X|Xs], Pivot, Smalls, Katta) :-    (   X @< Pivot ->        Smalls = [X|Dam oling],        bo'lim(Xs, Pivot, Dam oling, Katta)    ;   Katta = [X|Dam oling],        bo'lim(Xs, Pivot, Smalls, Dam oling)    ). tezkor([])     --> [].tezkor([X|Xs]) -->    { bo'lim(Xs, X, Kichikroq, Kattaroq) },    tezkor(Kichikroq), [X], tezkor(Kattaroq).

Dizayn naqshlari

A dizayn namunasi da tez-tez uchraydigan muammoning umumiy qayta ishlatilishi mumkin bo'lgan echimidir dasturiy ta'minot dizayni. Prolog-da dizayn naqshlari turli xil nomlar ostida: skeletlari va texnikasi,[19][20] kliklar,[21] dastur sxemalari,[22] va mantiqiy tavsif sxemalari.[23]Dizayn naqshlariga alternativa yuqori darajadagi dasturlash.[24]

Yuqori darajadagi dasturlash

Yuqori darajadagi predikat - bu bir yoki bir nechta predikatlarni argument sifatida qabul qiladigan predikat. Garchi yuqori darajadagi dasturlarni qo'llab-quvvatlash Prologni birinchi darajali mantiq doirasidan tashqariga chiqarib tashlasa-da, bu predikatlar bo'yicha miqdorni aniqlashga imkon bermaydi,[25] ISO Prolog-da endi ba'zi bir o'rnatilgan yuqori darajadagi predikatlar mavjud qo'ng'iroq qilish / 1, qo'ng'iroq qilish / 2, qo'ng'iroq qilish / 3, findall / 3, setof / 3va bagof / 3.[26] Bundan tashqari, o'zboshimchalik bilan Prolog maqsadlarini tuzish va ish vaqtida baholash mumkin bo'lganligi sababli, yuqori darajadagi predikatlarni yozish oson xaritalar ro'yxati / 2, bu berilgan ro'yxatning har bir a'zosiga o'zboshimchalik bilan predikatni qo'llaydi va pastki ro'yxat / 3, bu ma'lum bir predikatni qondiradigan elementlarni filtrlaydigan, shuningdek, bunga imkon beradi qichqiriq.[24]

Yechimlarni vaqtincha namoyish qilishdan (orqaga qaytishdagi javoblarni almashtirish) fazoviy tasvirga (atamalarga) o'tkazish uchun Prologda berilgan so'rovning barcha javob almashtirishlarini ro'yxatdagi barcha yig'ish predikatlari mavjud. Buning uchun ishlatilishi mumkin ro'yxatni tushunish. Masalan, mukammal raqamlar ularning bo'linuvchilari yig'indisiga teng:

 mukammal(N) :-     o'rtasida(1, inf, N), U bu N // 2,     findall(D., (o'rtasida(1,U,D.), N mod D. =:= 0), Ds),     sumlist(Ds, N).

Bu mukammal raqamlarni sanash uchun, shuningdek raqamning mukammalligini tekshirish uchun ishlatilishi mumkin.

Yana bir misol, predikat xaritalar ro'yxati predikatni qo'llaydi P juft ro'yxatdagi barcha tegishli pozitsiyalarga:

xaritalar ro'yxati(_, [], []).xaritalar ro'yxati(P, [X|Xs], [Y|Ys]) :-   qo'ng'iroq qiling(P, X, Y),   xaritalar ro'yxati(P, Xs, Ys).

Qachon P bu hamma uchun predikatdir X, P (X, Y) birlashtiradi Y yagona noyob qiymatga ega, xaritalar ro'yxati (P, Xs, Ys) ni qo'llashga teng xarita funktsiyasi funktsional dasturlash kabi Ys = xarita (Funktsiya, Xs).

Prolog-da yuqori darajadagi dasturlash uslubi kashshof bo'lgan Salom va λProlog.

Modullar

Uchun keng miqyosda dasturlash, Prolog a beradi modul tizimi. Modul tizimi ISO tomonidan standartlashtirilgan.[27] Biroq, barcha Prolog kompilyatorlari modullarni qo'llab-quvvatlamaydilar va asosiy Prolog kompilyatorlarining modul tizimlari o'rtasida moslik muammolari mavjud.[28] Binobarin, bitta Prolog kompilyatorida yozilgan modullar boshqalarda ishlashga majbur bo'lmaydi.

Ayrilash

Deb nomlangan maxsus yozuv mavjud aniq band grammatikalari (DCG). Orqali aniqlangan qoida -->/2 o'rniga :-/2 protsessor tomonidan kengaytirilgan (kengaytirish_term / 2, boshqa tillardagi makrolarga o'xshash ob'ekt) bir nechta to'g'ridan-to'g'ri qayta yozish qoidalariga muvofiq, natijada oddiy Prolog bandlari mavjud. Eng muhimi, qayta yozish predikatni ikkita qo'shimcha dalil bilan jihozlaydi, bu esa atrofdagi holatni yashirin ravishda ishlatish uchun ishlatilishi mumkin,[tushuntirish kerak ] o'xshash monadalar boshqa tillarda. DCG'lar ko'pincha tahlilchilar yoki ro'yxat generatorlarini yozish uchun ishlatiladi, chunki ular shuningdek, farqlar ro'yxatlari uchun qulay interfeysni taqdim etadi.

Meta-tarjimonlar va aks ettirish

Prolog - bu homoikonik til va ko'plab imkoniyatlarni taqdim etadi aks ettirish. Uning yashirin bajarilish strategiyasi qisqacha yozishga imkon beradi meta-dairesel baholovchi (shuningdek, deyiladi meta-tarjimon) sof Prolog kodi uchun:

hal qilish(to'g'ri).hal qilish((Subgoal1,Subgoal2)) :-     hal qilish(Subgoal1),    hal qilish(Subgoal2).hal qilish(Bosh) :-     band(Bosh, Tana),    hal qilish(Tana).

qayerda to'g'ri bo'sh birikmani anglatadi va band (bosh, tan) formaning ma'lumotlar bazasidagi bandlar bilan birlashadi Bosh: - tanasi.

Prolog dasturlari o'zlari Prolog atamalarining ketma-ketligi bo'lgani uchun (:-/2 infix operator ) o'rnatilgan mexanizmlar yordamida osongina o'qiladigan va tekshiriladigan (masalan o'qing / 1), domenni o'ziga xos xususiyatlariga ega Prologni ko'paytiradigan moslashtirilgan tarjimonlarni yozish mumkin. Masalan, Sterling va Shapiro noaniqlik bilan mulohaza yuritadigan meta-tarjimonni taqdim etadilar, bu erda ozgina o'zgartirishlar bilan takrorlangan:[29]:330

hal qilish(to'g'ri, 1) :- !.hal qilish((Subgoal1,Subgoal2), Aniqlik) :-    !,    hal qilish(Subgoal1, Ishonchlilik1),    hal qilish(Subgoal2, Ishonchlilik2),    Aniqlik bu min(Ishonchlilik1, Ishonchlilik2).hal qilish(Maqsad, 1) :-    qurilgan(Maqsad), !,     Maqsad.hal qilish(Bosh, Aniqlik) :-    clause_cf(Bosh, Tana, Ishonchlilik1),    hal qilish(Tana, Ishonchlilik2),    Aniqlik bu Ishonchlilik1 * Ishonchlilik2.

Ushbu tarjimon shaklning o'rnatilgan Prolog jadvalidan foydalanadi[29]:327

qurilgan(A bu B).qurilgan(o'qing(X)).% va boshqalar.

kabi ifodalangan bandlar clause_cf (bosh, tan, aniqlik). Ularni hisobga olgan holda, uni shunday nomlash mumkin hal qilish (Maqsad, ishonch) qatl qilmoq Maqsad va natijada aniqlik o'lchovini olish.

Turing to'liqligi

Pure Prolog birinchi darajali pastki qismga asoslangan mantiq, Shoxning gaplari, bu Turing to'liq. Prologning to'liqligi uni Turing mashinasini simulyatsiya qilish uchun ishlatilishi mumkin:

burilish(Lenta0, Tasma) :-    ijro etish(q0, [], Ls, Lenta0, Rs),    teskari(Ls, Ls1),    qo'shib qo'ying(Ls1, Rs, Tasma). ijro etish(qf, Ls, Ls, Rs, Rs) :- !.ijro etish(Q0, Ls0, Ls, Rs0, Rs) :-    belgi(Rs0, Sym, RsRest),    bir marta(qoida(Q0, Sym, 1-savol, NewSym, Amal)),    harakat(Amal, Ls0, Ls1, [NewSym|RsRest], Rs1),    ijro etish(1-savol, Ls1, Ls, Rs1, Rs). belgi([], b, []).belgi([Sym|Rs], Sym, Rs). harakat(chap, Ls0, Ls, Rs0, Rs) :- chap(Ls0, Ls, Rs0, Rs).harakat(qolish, Ls, Ls, Rs, Rs).harakat(to'g'ri, Ls0, [Sym|Ls0], [Sym|Rs], Rs). chap([], [], Rs0, [b|Rs0]).chap([L|Ls], Ls, Rs, [L|Rs]).

Turing mashinasining oddiy namunasi quyidagi faktlar bilan ko'rsatilgan:

qoida(q0, 1, q0, 1, to'g'ri).qoida(q0, b, qf, 1, qolish).

Ushbu mashina birlamchi kodlashda raqamlardan biriga ko'paytmani bajaradi: U har qanday sonli "1" katakchalarni aylanib chiqadi va oxirida qo'shimcha "1" qo'shadi. Misol so'rovi va natija:

?- burilish([1,1,1], Ts).Ts = [1, 1, 1, 1] ;

Bu har qanday hisob-kitobni qanday qilib deklarativ tarzda davlat o'tishlari ketma-ketligi sifatida ifodalash mumkinligini, Prologda ketma-ket qiziqish holatlari o'rtasidagi munosabat sifatida qanday amalga oshirilishini ko'rsatadi.

Amalga oshirish

ISO Prolog

The ISO Prolog standarti ikki qismdan iborat. ISO / IEC 13211-1,[26][30] 1995 yilda nashr etilgan bo'lib, Prolog-ning asosiy elementlarini ko'plab tatbiq etishda mavjud amaliyotni standartlashtirishga qaratilgan. Tilning ilgari noaniq bo'lgan va ko'chma dasturlarga olib keladigan jihatlarini aniqlab berdi. Uchta dastur mavjud: Cor.1: 2007,[31] Kor.2: 2012 yil,[32] va Cor.3: 2017.[33] ISO / IEC 13211-2,[26] 2000 yilda nashr etilgan bo'lib, standartlarga modullarni qo'llab-quvvatlaydi. Standart tomonidan qo'llab-quvvatlanadi ISO / IEC JTC1 /SC22 / WG17[34] ishchi guruh. ANSI X3J17 standart bo'yicha AQSh texnik maslahat guruhidir.[35]

Jamlama

Samaradorlik uchun Prolog kodi odatda registrga asoslangan ta'sir ko'rsatadigan mavhum mashina kodida tuziladi Uorren mavhum mashinasi (WAM) ko'rsatmalar to'plami.[36] Ba'zi dasturlarda ishlaydi mavhum talqin kompilyatsiya vaqtida predikatlarning turi va rejimi haqida ma'lumot olish yoki yuqori ishlash uchun real mashina kodiga kompilyatsiya qilish.[37] Prolog kodini amalga oshirishning samarali usullarini yaratish mantiqiy dasturlash jamoatchiligida faol izlanishlar sohasidir va ba'zi bir bajarilishlarda turli xil ijro etilish usullari qo'llaniladi. Bunga quyidagilar kiradi bandni ikkilantirish va stekka asoslangan virtual mashinalar.[iqtibos kerak ]

Quyruq rekursiyasi

Prolog tizimlari odatda taniqli optimallash usulini qo'llaydi quyruq qo'ng'irog'ini optimallashtirish (TCO) namoyish etuvchi predmetlar uchun quyruq rekursiyasi yoki umuman olganda quyruq qo'ng'iroqlari: Qo'ng'iroqni quyruq holatida bajarishdan oldin bandning stek ramkasi tashlanadi. Shu sababli, deterministik quyruq-rekursiv predikatlar, boshqa tillardagi ko'chadanlar singari doimiy stak maydoni bilan bajariladi.

Muddat indeksatsiyasi

So'rovda atama bilan birlashtirilmaydigan gaplarni topish, gaplar sonida chiziqli. Muddat indeksatsiyasi foydalanadi ma'lumotlar tuzilishi bu imkon beradi pastki chiziqli vaqt qidiruv.[38] Indekslash faqat dastur ishiga ta'sir qiladi, bu semantikaga ta'sir qilmaydi. Ko'pgina Prologlar faqat birinchi davrda indeksatsiyadan foydalanadilar, chunki barcha shartlar bo'yicha indeksatsiya qimmatga tushadi, ammo unga asoslangan texnikalar maydonda kodlangan so'zlar yoki joylashtirilgan kod so'zlar to'liq so'rov va bosh bo'ylab tezkor indekslashni ta'minlash.[39][40]

Hashing

Kabi ba'zi Prolog tizimlari WIN-PROLOG va SWI-Prolog, endi katta ma'lumotlar to'plamlarini yanada samarali ishlashiga yordam beradigan xashlashni amalga oshirmoqdalar. Kabi yirik korpuslar bilan ishlashda bu juda katta ishlash yutuqlarini keltirib chiqaradi WordNet.

Tabletka

Ba'zi Prolog tizimlari, (B-Prolog, XSB, SWI-Prolog, YAP va Ciao ), amalga oshirish yod olish deb nomlangan usul jadvalga kiritish, bu foydalanuvchini oraliq natijalarni qo'lda saqlashdan ozod qiladi. Tabletka - bu makon-vaqt almashinuvi; oraliq natijalarni saqlash uchun ko'proq xotira yordamida bajarish vaqtini qisqartirish mumkin:[41][42]

So'rovlarni baholashda yuzaga kelgan subgoallar jadvalda va ushbu subgoallarga javoblar bilan birga saqlanadi. Agar subgoal qayta duch kelsa, baholash dastur bandlariga qarshi rezolyutsiyani qayta bajarish o'rniga jadvaldagi ma'lumotlarni qayta ishlatadi.[43]

Tabletka turli yo'nalishlarda uzaytirilishi mumkin. SLG piksellar sonini yoki chiziqli jadvallar orqali rekursiv predikatlarni qo'llab-quvvatlashi mumkin. Ko'p tishli Prolog tizimida jadvallarni tuzish natijalari shpalga yopiq bo'lishi yoki barcha qatorlar o'rtasida bo'lishishi mumkin. Va asta-sekin jadvalda jadvallar o'zgarishlarga ta'sir qilishi mumkin.

Texnik vositalarda amalga oshirish

Davomida Beshinchi avlod kompyuter tizimlari loyihasi, maxsus arxitektura bilan tezroq bajarilishini ta'minlash maqsadida Prolog-ni apparatda tatbiq etishga urinishlar bo'lgan.[44][45][46] Bundan tashqari, Prolog bir qator xususiyatlarga ega, ular parallel bajarilish orqali tezlashtirishga imkon beradi.[47] Cheklangan Prolog dasturlarini a-ga kompilyatsiya qilish uchun yaqinda yondashuv maydonda programlanadigan eshiklar qatori.[48] Shu bilan birga, umumiy maqsadlar uchun mo'ljallangan apparatlardagi tez sur'atlar ko'proq ixtisoslashgan arxitekturalarni doimiy ravishda bosib o'tdi.

Cheklovlar

Prolog tadqiqot va ta'lim sohasida keng qo'llanilishiga qaramay, Prolog va boshqa mantiqiy dasturlash tillari umuman kompyuter sanoatiga sezilarli ta'sir ko'rsatmadi.[49] Ko'pgina dasturlar sanoat standartlari bo'yicha kichik bo'lib, ularning soni 100000 satrdan oshadi.[49][50] Katta miqyosda dasturlash murakkab deb hisoblanadi, chunki hamma Prolog kompilyatorlari modullarni qo'llab-quvvatlamaydi va asosiy Prolog kompilyatorlarining modul tizimlari o'rtasida moslik muammolari mavjud.[28] Ilovalar bo'yicha Prolog kodining ko'chirilishi ham muammo bo'lib kelgan, ammo 2007 yildan beri rivojlanayotganlar quyidagilarni anglatadi: "Edinburg / Quintus tomonidan ishlab chiqarilgan Prolog dasturlarining portativligi, ko'chma haqiqiy dasturlarni saqlashga imkon beradigan darajada yaxshi".[51]

Prolog-da ishlab chiqilgan dasturiy ta'minot an'anaviy dasturlash tillari bilan taqqoslaganda yuqori mahsuldorlikka ega bo'lganligi uchun tanqid qilindi. Xususan, Prologning deterministik bo'lmagan baholash strategiyasi, deterministik hisob-kitoblarni dasturlashda yoki hatto "ahamiyatsiz bo'lmagan determinizm" dan foydalanishda ham muammoli bo'lishi mumkin (bu erda barcha imkoniyatlardan orqaga qaytish o'rniga bitta tanlov amalga oshiriladi). Prolog-ning asosiy diqqatga sazovor joylaridan birini, "orqaga va oldinga" dasturlarni ishga tushirish qobiliyatini yo'q qilish orqali kerakli ishlashga erishish uchun kesmalar va boshqa til konstruktsiyalaridan foydalanish kerak bo'lishi mumkin.[52]

Prolog faqat deklarativ emas: chunki o'xshash tuzilmalar tufayli kesuvchi operator, uni tushunish uchun Prolog dasturining protsessual o'qilishi kerak.[53] Prolog dasturidagi bandlarning tartibi muhim, chunki tilni bajarish strategiyasi unga bog'liqdir.[54] Kabi boshqa mantiqiy dasturlash tillari Ma'lumotlar katalogi, haqiqatan ham deklarativ, ammo tilni cheklaydi. Natijada, ko'plab amaliy Prolog dasturlari shunchaki deklarativ mantiqiy dasturlar sifatida emas, balki Prologning chuqurlikdagi birinchi qidirish tartibiga mos ravishda yozilgan.[52]

Kengaytmalar

Mantiqiy dasturlash imkoniyatlarini ko'p yo'nalishlarda kengaytirish uchun Prolog-dan turli xil dasturlar ishlab chiqilgan. Bunga quyidagilar kiradi turlari, rejimlar, cheklash mantiqiy dasturlash (CLP), ob'ektga asoslangan mantiqiy dasturlash (OOLP), bir vaqtda, chiziqli mantiq (LLP), funktsional va yuqori darajadagi mantiq dasturlash qobiliyatlari, shuningdek, bilan birgalikda ishlash bilimlar bazalari:

Turlari

Prolog - bu qo'llanilmagan til. Turlarni joriy etishga urinishlar 1980 yillarga to'g'ri keladi,[55][56] va 2008 yildan boshlab Prologni turlari bilan kengaytirishga urinishlar mavjud.[57] Ma'lumot nafaqat foydali bo'ladi turdagi xavfsizlik shuningdek, Prolog dasturlari haqida fikr yuritish uchun.[58]

Rejimlar

Tartibni aniqlovchiTafsir
+novar kirish paytida
-var kirish paytida
?Ko'rsatilmagan

Prolog sintaksisida predikatning qaysi argumentlari kirish, qaysi biri chiqish ekanligi aniqlanmagan.[59] Biroq, bu ma'lumot muhim ahamiyatga ega va uni sharhlarga kiritish tavsiya etiladi.[60] Prolog dasturlari haqida fikr yuritishda rejimlar qimmatli ma'lumotlarni taqdim etadi[58] va ijro etishni tezlashtirish uchun ham foydalanish mumkin.[61]

Cheklovlar

Cheklovli mantiqiy dasturlash dan tushunchalarni kiritish uchun Prolog-ni kengaytiradi qoniqish cheklash.[62][63] Cheklov mantiqiy dasturi, quyidagi bandlarning asosiy qismidagi cheklovlarga imkon beradi: A (X, Y): - X + Y> 0. Bu keng ko'lamli mos keladi kombinatorial optimallashtirish muammolar[64] va shuning uchun avtomatlashtirilgan vaqt jadvalini tuzish va kabi sanoat sharoitidagi dasturlar uchun foydalidir ishlab chiqarishni rejalashtirish. Ko'pgina Prolog tizimlari cheklangan domenlar uchun kamida bitta cheklov echuvchisi va ko'pincha ratsional raqamlar kabi boshqa domenlar uchun echimlar bilan ta'minlanadi.

Ob'ektga yo'naltirish

Flora-2 bu narsalarga asoslangan bilimlarni namoyish etish va fikrlash tizimidir F-mantiq va o'z ichiga oladi Salom, Tranzaksiya mantig'i va mag'lub bo'ladigan mulohaza.

Logtalk ko'pgina Prolog dasturlarini orqa kompilyator sifatida ishlatishi mumkin bo'lgan ob'ektga yo'naltirilgan mantiqiy dasturlash tili. Ko'p paradigma tili sifatida u prototiplar va sinflarni qo'llab-quvvatlashni o'z ichiga oladi.

Oblog Edinburg universiteti EdCAAD xodimi Margaret MakDugal tomonidan Prolog-ga kichik, ko'chma, ob'ektga yo'naltirilgan kengaytma.

Objlog ob'ektlar va CNRS, Marsel, Frantsiyadan Prolog II-ni birlashtirgan ramkaga asoslangan til edi.

Prolog ++ tomonidan ishlab chiqilgan Mantiqiy dasturlash bo'yicha assotsiatsiyalar va birinchi bo'lib 1989 yilda MS-DOS kompyuterlari uchun chiqarilgan. Boshqa platformalarni qo'llab-quvvatlash qo'shildi va 1995 yilda ikkinchi versiyasi chiqdi. Kris Mossning "Prolog ++" haqidagi kitobi Addison-Uesli tomonidan 1994 yilda nashr etilgan.

Grafika

A ta'minlaydigan prolog tizimlari grafik kutubxona bor SWI-Prolog,[65] Visual Prolog, WIN-PROLOG va B-Prolog.

Muvofiqlik

Prolog-MPI ochiq manba hisoblanadi SWI-Prolog orqali tarqatilgan hisoblash uchun kengaytma Xabarni uzatish interfeysi.[66] Shuningdek, turli xil Prolog dasturlash tillari mavjud.[67]

Veb-dasturlash

Ba'zi Prolog dasturlari, xususan SWI-Prolog va Ciao, qo'llab-quvvatlaydi server tomoni veb-dasturlash veb-protokollarni qo'llab-quvvatlash bilan, HTML va XML.[68] Qo'llab-quvvatlash uchun kengaytmalar ham mavjud semantik veb kabi formatlar RDF va Boyqush.[69][70] Prolog shuningdek, a mijoz tomoni til.[71]

Adobe Flash

Sidr bepul va asosiy Prolog tarjimoni. 4 va undan yuqori versiyalaridan Sidar FCA (Flash Cedar App) qo'llab-quvvatlashiga ega. Bu orqali Prolog-da dasturlash uchun yangi platforma mavjud ActionScript.

Boshqalar

  • F-mantiq uchun Prolog-ni ramkalar / moslamalar bilan kengaytiradi bilimlarni namoyish etish.
  • Tranzaksiya mantig'i holatini o'zgartiruvchi yangilanish operatorlarining mantiqiy nazariyasi bilan Prologni kengaytiradi. U model-nazariy va protsessual semantikaga ega.
  • OW Prolog Prolog-ning grafikasi va interfeysi yo'qligiga javob berish uchun yaratilgan.

Boshqa tillarga interfeyslar

Prolog va boshqa tillar o'rtasida ko'prik o'rnatadigan ramkalar mavjud:

  • The LPA Intelligence Server LPA Prolog-ni C, C #, C ++, Java, VB, Delphi, .Net, Lua, Python va boshqa tillarga joylashtirish imkonini beradi. LPA Prolog taqdim etadigan maxsus mag'lubiyatga oid ma'lumotlar turidan foydalanadi
  • Logic Server API Prolog-ni C, C ++, Java, VB, Delphi, .NET-da kengaytirish va joylashtirishga imkon beradi va .dll yoki .so-ga qo'ng'iroq qila oladigan har qanday til / muhit. Amzi uchun amalga oshiriladi! Prolog Amzi! Prolog + Logic Server ammo API spetsifikatsiyasi har qanday dastur uchun mavjud bo'lishi mumkin.
  • JPL - bu ikki yo'nalishli Java Prolog ko'prigi, u sukut bo'yicha SWI-Prolog bilan ta'minlanadi, bu esa Java va Prologga bir-birlariga qo'ng'iroq qilishga imkon beradi (rekursiv). Ma'lumki, yaxshi paralellik yordami mavjud va u faol rivojlanmoqda.
  • InterProlog, o'rtasida dasturlash kutubxonasi ko'prigi Java va Prolog, ikkala til o'rtasida ikki yo'nalishli predikat / usulni chaqirishni amalga oshiradi. Java moslamalarini Prolog shartlariga va aksincha xaritaga solish mumkin. Rivojlanishiga imkon beradi GUI-lar Prolog qatlamida mantiqiy ishlov berishni qoldirishda Java-da va boshqa funktsiyalar. Qo'llab-quvvatlaydi XSB uchun qo'llab-quvvatlash bilan SWI-Prolog va YAP 2013 yilga rejalashtirilgan.
  • Prova Java, agent xabarlari va reaktsiya qoidalari bilan mahalliy sintaksis integratsiyasini ta'minlaydi. Prova o'zini o'rta dasturiy ta'minot uchun qoidalarga asoslangan skript (RBS) tizimi sifatida egallaydi. Til birlashishda yangi zamin ochadi majburiy va deklarativ dasturlash.
  • PROL Java uchun o'rnatilgan Prolog mexanizmi. U kichik IDE va ​​bir nechta kutubxonalarni o'z ichiga oladi.
  • Java uchun GNU Prolog Java kutubxonasi (gnu.prolog) sifatida ISO Prolog dasturini amalga oshirishdir.
  • Ciao C, C ++, Java va relyatsion ma'lumotlar bazalariga interfeyslarni taqdim etadi.
  • C # -Prolog (C) da boshqariladigan (boshqariladigan) Prolog tarjimoni. Osonlik bilan C # dasturlariga qo'shilishi mumkin. Xususiyatlari: ishonchli va juda tezkor tarjimon, buyruq qatori interfeysi, Windows interfeysi, o'rnatilgan DCG, XML-predikatlar, SQL-predikatlar, kengaytiriladigan. To'liq manba kodi mavjud, shu jumladan maxsus maqsadli kengaytmalarni qo'shish uchun ishlatilishi mumkin bo'lgan ajralish generatori.
  • Jekejeke Prolog API Prolog va Java yoki Android o'rtasida bir-biriga bog'langan chaqiruv va qo'ng'iroqlarni bir-biriga bog'lab qo'ygan holda, shaxsiy bilim bazasini yaratish imkoniyati mavjud. U ISO Prolog tarjimonini mustaqil, applet, servlet, APK va boshqalarga joylashtirish uchun ishlatilishi mumkin.
  • PHP uchun Uorrenning abstrakt mashinasi PHP 5.3 da Prolog kompilyatori va tarjimoni. Mustaqil ravishda yoki tarjima qilingan Symfony2.1 doirasida ishlatilishi mumkin bo'lgan kutubxona Stefan Buettcherniki bu erda joylashgan Java-da ishlash stefan.buettcher.org/ CS/ wam/indeks.html]
  • tuProlog Bu minimal darajadagi yadro atrofida ataylab ishlab chiqilgan tarqatilgan dasturlar va infratuzilmalar uchun engil vaznli Prolog tizimidir yoki predikatlar kutubxonalarini yuklash / tushirish orqali statik yoki dinamik ravishda tuzilgan bo'lishi kerak. tuProlog tabiiy ravishda ko'p paradigma dasturlashni qo'llab-quvvatlaydi, bu Prolog va asosiy ob'ektga yo'naltirilgan tillar - ya'ni Java, tuProlog Java versiyasi va har qanday .NET-ga asoslangan til (C #, F # ..) o'rtasida tuProlog uchun toza, uzluksiz integratsiya modelini taqdim etadi. NET versiyasi.[72]

Tarix

Ism Prolog tomonidan tanlangan Filipp Russel uchun qisqartma sifatida programlama en logique (Frantsuz uchun dasturlash mantiq ). U 1972 yil atrofida yaratilgan Alen Kolmerauer asosida Filipp Russel bilan Robert Kovalski protsessual talqini Shoxning gaplari. Bu qisman mantiqning deklarativ bilimlarni namoyish qilish tili sifatida foydalanishni 1960-yillarning oxiri va 70-yillarning boshlarida Shimoliy Amerikada ommalashgan bilimlarning protsessual namoyishi bilan yarashtirish istagi bilan bog'liq edi. Ga binoan Robert Kovalski, birinchi Prolog tizimi 1972 yilda Kolmerauer va Filipp Russel tomonidan ishlab chiqilgan.[5] Prologning birinchi tadbiri Fortarda Jerar Battani va Anri Meloni tomonidan yozilgan tarjimon edi. Devid H. D. Uorren ushbu tarjimonni Edinburgga olib bordi va u erda eng zamonaviy dasturlar tomonidan qo'llaniladigan "Edinburgh Prolog" sintaksisini belgilaydigan muqobil oldingi dastur amalga oshirildi. Uorren, shuningdek, Fernando Pereyra bilan hamkorlikda nufuzli DEC-10 Prolog-ni yaratib, Prolog uchun birinchi kompilyatorni yaratdi. Keyinchalik Uorren DEC-10 Prolog-ni yaratish uchun g'oyalarni umumlashtirdi Uorren mavhum mashinasi.

Evropaning sun'iy intellekt tadqiqotchilari Prologga, amerikaliklar ma'qullashdi Lisp, xabarlarga ko'ra, tillarning mohiyati bo'yicha ko'plab millatchilik munozaralariga sabab bo'lgan.[73] Prologning zamonaviy rivojlanishining aksariyati Beshinchi avlod kompyuter tizimlari loyihasi (FGCS), bu Prolog nomli variantini ishlab chiqdi Kernel tili birinchi uchun operatsion tizim.

Pure Prolog dastlab a dan foydalanish bilan cheklangan edi qaror bilan teorema prover Shoxning gaplari shakl:

H: - B1, ..., Bn.

Teorema-proverni qo'llash quyidagi bandlarni protsedura sifatida ko'rib chiqadi:

H ni ko'rsatish / hal qilish, B ni ko'rsatish / hal qilish1 va ... va Bn.

Tez orada Pure Prolog kengaytirildi, shu bilan birga inkor etishmovchilik sifatida, unda shaklning salbiy shartlari yo'q (Bmen) B ga tegishli ijobiy shartlarni echishga urinish va muvaffaqiyatsizlik bilan ko'rsatiladimen.

Dastlabki guruh tomonidan Prolog-ning keyingi kengaytmalari taqdim etildi cheklash mantiqiy dasturlash amalga oshirish qobiliyatlari.

Sanoatda foydalanish

Prolog ishlatilgan Vatson. Watson IBM-ning DeepQA dasturi va Apache-dan foydalanadi UIMA (Tuzilmagan Axborotni boshqarish arxitekturasi) ramkasi. Tizim turli xil tillarda, jumladan Java, C ++ va Prolog-da yozilgan va SUSE Linux Enterprise Server 11 ta operatsion tizim Apache Hadoop taqsimlangan hisoblashlarni ta'minlash uchun asos. Prolog uchun ishlatiladi naqshlarni moslashtirish tabiiy tilni tahlil qilish daraxtlari ustida. Ishlab chiquvchilar quyidagilarni ta'kidladilar: "Biz tilni talab qildik, unda biz tahlil qilish daraxtlari va boshqa izohlarga (masalan, ob'ektni tanib olish natijalari) naqsh solishtirish qoidalarini qulay tarzda ifoda eta olamiz va ushbu qoidalarni juda samarali bajaradigan texnologiya. Biz Prologni topdik soddaligi va ifodaliligi tufayli til uchun ideal tanlov edi ".[14] Prolog past kodli ishlab chiqish platformasida qo'llanilmoqda GeneXus, bu AI atrofida joylashgan.[74]

Shuningdek qarang

Aloqador tillar

  • The Gödel Til - bu kuchli tarzda yozilgan dastur bir vaqtda cheklash mantiqiy dasturlash. U SICStus Prolog-da qurilgan.
  • Visual Prolog, ilgari PDC Prolog va Turbo Prolog deb nomlangan, a qattiq yozilgan ob'ektga yo'naltirilgan Prolog shevasi, bu standart Prologdan juda farq qiladi. Turbo Prolog sifatida u Borland tomonidan sotilgan, ammo hozirda uni dastlab uni ishlab chiqargan Daniyaning PDC firmasi (Prolog Development Center) ishlab chiqqan va sotgan.
  • Ma'lumotlar katalogi bu Prologning kichik to'plamidir. Bu tabaqalanishi mumkin bo'lgan munosabatlar bilan cheklanadi va murakkab atamalarga yo'l qo'ymaydi. Prologdan farqli o'laroq, ma'lumotlar katalogi yo'q Turing to'liq.
  • Merkuriy statik, polimorfik tipdagi tizim bilan bir qatorda rejim va determinizm tizimiga ega dasturiy ta'minot muhandisligiga yo'naltirilgan Prologning bir bo'lagi.
  • GraphTalk - bu qo'shimcha ob'ektga yo'naltirilgan xususiyatlarga ega bo'lgan Uorrenning mavhum mashinasini ishlab chiqarish.
  • Ba'zi jihatdan[qaysi? ] Prolog - bu pastki qism Rejalashtiruvchi. Plannerdagi g'oyalar keyinchalik Ilmiy jamoat metaforasi.
  • AgentSpeak dasturlash agenti xatti-harakatlari uchun Prologning bir variantidir ko'p agentli tizimlar.
  • Erlang hayotni Prolog-ga asoslangan dastur bilan boshladi va Prolog-ning unifikatsiyalashga asoslangan sintaksisining katta qismini saqlab qoldi.
  • Pilog ustiga qurilgan deklarativ tildir PicoLisp, bu Prolog semantikasiga ega, ammo Lisp sintaksisidan foydalanadi.

Adabiyotlar

  1. ^ Clocksin, Uilyam F.; Mellish, Kristofer S. (2003). Prologda dasturlash. Berlin; Nyu-York: Springer-Verlag. ISBN  978-3-540-00678-7.
  2. ^ Bratko, Ivan (2012). Sun'iy aql uchun prolog dasturlash (4-nashr). Xarlou, Angliya; Nyu-York: Addison Uesli. ISBN  978-0-321-41746-6.
  3. ^ Kovington, Maykl A. (1994). Prolog dasturchilari uchun tabiiy tilni qayta ishlash. Englewood Cliffs, NJ: Prentice Hall. ISBN  978-0-13-629213-5.
  4. ^ a b Lloyd, J. V. (1984). Mantiqiy dasturlash asoslari. Berlin: Springer-Verlag. ISBN  978-3-540-13299-8.
  5. ^ a b Kovalski, R. A. (1988). "Mantiqiy dasturlashning dastlabki yillari" (PDF). ACM aloqalari. 31: 38. doi:10.1145/35043.35046. S2CID  12259230.
  6. ^ Kolmerauer, A .; Roussel, P. (1993). "Prologning tug'ilishi" (PDF). ACM SIGPLAN xabarnomalari. 28 (3): 37. doi:10.1145/155360.155362.
  7. ^ Qarang Mantiqiy dasturlash § Tarix.
  8. ^ Stickel, M. E. (1988). "Prolog texnologiyasi teoremasini tasdiqlovchi: kengaytirilgan prolog kompilyatori tomonidan amalga oshirilishi". Avtomatlashtirilgan fikrlash jurnali. 4 (4): 353–380. CiteSeerX  10.1.1.47.3057. doi:10.1007 / BF00297245. S2CID  14621218.
  9. ^ Merritt, Dennis (1989). Prolog-da ekspert tizimlarini yaratish. Berlin: Springer-Verlag. ISBN  978-0-387-97016-5.
  10. ^ Felty, Emi. "Yuqori darajadagi muddatli qayta yozishni amalga oshirishda mantiqiy dasturiy yondashuv." Mantiqiy dasturlashning kengaytmalari (1992): 135-161.
  11. ^ Kent D. Li (2015 yil 19-yanvar). Dasturlash tillari asoslari. Springer. 298– betlar. ISBN  978-3-319-13314-0.
  12. ^ Ute Shmid (2003 yil 21-avgust). Funktsional dasturlarning induktiv sintezi: universal rejalashtirish, cheklangan dasturlarni katlama va analogli fikrlash orqali sxemalarni abstraktsiya qilish. Springer Science & Business Media. ISBN  978-3-540-40174-2.
  13. ^ Fernando C. N. Pereyra; Styuart M. Shiber (2005). Prolog va tabiiy til tahlili. Mikrotome.
  14. ^ a b Adam Lally; Pol Fodor (2011 yil 31 mart). "IBM Watson tizimida tabiiy tilni prolog yordamida qayta ishlash". Mantiqiy dasturlash assotsiatsiyasi. Shuningdek qarang Watson (kompyuter).
  15. ^ ISO / IEC 13211-1: 1995 Prolog, 6.3.7 Shartlar - ikki marta kotirovka qilingan ro'yxat belgisi. Xalqaro standartlashtirish tashkiloti, Jeneva.
  16. ^ Termin turini tasdiqlang - SWI-Prolog
  17. ^ Carlsson, Mats (2014 yil 27-may). SICStus Prolog foydalanuvchi qo'llanmasi 4.3: Asosiy ma'lumotnoma. BoD - Talab bo'yicha kitoblar. ISBN  9783735737441 - Google Books orqali.
  18. ^ Kovington, Maykl A.; Bagnara, Roberto; O'Kif, Richard A.; Wielemaker, Jan; Narx, Simon (2011). "Prolog uchun kodlash bo'yicha ko'rsatmalar". Mantiqiy dasturlash nazariyasi va amaliyoti. 12 (6): 889–927. arXiv:0911.2899. doi:10.1017 / S1471068411000391. S2CID  438363.
  19. ^ Kirschenbaum, M .; Sterling, L.S. (1993). "Skeletlarga texnikani qo'llash". Mantiqiy dasturlarni yaratish, (Ed. J.M.J. Jacquet): 27–140. CiteSeerX  10.1.1.56.7278.
  20. ^ Sterling, Leon (2002). "Prolog dasturlash uchun naqshlar". Hisoblash mantig'i: Mantiqiy dasturlash va undan tashqarida. Kompyuter fanidan ma'ruza eslatmalari / Sun'iy intellektdagi ma'ruza matnlari. 2407. 17-26 betlar. doi:10.1007/3-540-45628-7_15. ISBN  978-3-540-43959-2.
  21. ^ D. Barker-Plummer. Prolog-da klik dasturlash. M. Bruynooghe-da, muharrir, Proc. Mantiqdagi meta-dasturlash bo'yicha ikkinchi seminar, 247-256 betlar. Komp. Ilmiy ishlar., Katholieke universiteti. Leyven, 1990 yil.
  22. ^ Gegg-harrison, T. S. (1995). Prolog-da mantiqiy dastur sxemalarini namoyish etish. Mantiqiy dasturlash bo'yicha o'n ikkinchi xalqaro konferentsiya. 467-481 betlar.
  23. ^ Devil, Iv (1990). Mantiqiy dasturlash: tizimli dastur ishlab chiqish. Uokingem, Angliya: Addison-Uesli. ISBN  978-0-201-17576-9.
  24. ^ a b Naish, Li (1996). Prolog-da yuqori darajadagi mantiqiy dasturlash (Hisobot). Department of Computer Science, University of Melbourne. CiteSeerX  10.1.1.35.4505.
  25. ^ "With regard to Prolog variables, variables only in the head are implicitly universally quantified, and those only in the body are implicitly existentially quantified". Olingan 2013-05-04.
  26. ^ a b v ISO/IEC 13211: Information technology — Programming languages — Prolog. Xalqaro standartlashtirish tashkiloti, Jeneva.
  27. ^ ISO/IEC 13211-2: Modules.
  28. ^ a b Moura, Paulo (August 2004), "Logtalk", Mantiqiy dasturlash assotsiatsiyasi, 17 (3)
  29. ^ a b Shapiro, Ehud Y.; Sterling, Leon (1994). The Art of Prolog: Advanced Programming Techniques. Kembrij, Massachusets: MIT Press. ISBN  978-0-262-19338-2.
  30. ^ A. Ed-Dbali; Deransart, Pierre; L. Cervoni (1996). Prolog: the standard: reference manual. Berlin: Springer. ISBN  978-3-540-59304-1.
  31. ^ "ISO/IEC 13211-1:1995/Cor 1:2007 -".
  32. ^ "ISO/IEC 13211-1:1995/Cor 2:2012 -".
  33. ^ "ISO/IEC 13211-1:1995/Cor 3:2017 -".
  34. ^ "ISO/IEC JTC1 SC22 WG17".[doimiy o'lik havola ]
  35. ^ "X3J17 and the Prolog Standard". Arxivlandi asl nusxasi 2009-08-23. Olingan 2009-10-02.
  36. ^ David H. D. Warren. "An abstract Prolog instruction set". Technical Note 309, Xalqaro SRI, Menlo Park, CA, October 1983.
  37. ^ Van Roy, P.; Despain, A. M. (1992). "High-performance logic programming with the Aquarius Prolog compiler". Kompyuter. 25: 54–68. doi:10.1109/2.108055. S2CID  16447071.
  38. ^ Graf, Peter (1995). Muddat indeksatsiyasi. Springer. ISBN  978-3-540-61040-3.
  39. ^ Wise, Michael J.; Powers, David M. W. (1986). Indexing Prolog Clauses via Superimposed Code Words and Field Encoded Words. International Symposium on Logic Programming. pp. 203–210.
  40. ^ Colomb, Robert M. (1991). "Enhancing unification in PROLOG through clause indexing". The Journal of Logic Programming. 10: 23–44. doi:10.1016/0743-1066(91)90004-9.
  41. ^ Swift, T. (1999). "Tabling for non‐monotonic programming". Annals of Mathematics and Artificial Intelligence. 25 (3/4): 201–240. doi:10.1023/A:1018990308362. S2CID  16695800.
  42. ^ Zhou, Neng-Fa; Sato, Taisuke (2003). "Efficient Fixpoint Computation in Linear Tabling" (PDF). Proceedings of the 5th ACM SIGPLAN International Conference on Principles and Practice of Declarative Programming: 275–283.
  43. ^ Swift, T.; Warren, D. S. (2011). "XSB: Extending Prolog with Tabled Logic Programming". Theory and Practice of Logic Programming. 12 (1–2): 157–187. arXiv:1012.5123. doi:10.1017/S1471068411000500. S2CID  6153112.
  44. ^ Abe, S.; Bandoh, T.; Yamaguchi, S .; Kurosawa, K.; Kiriyama, K. (1987). "High performance integrated Prolog processor IPP". Proceedings of the 14th annual international symposium on Computer architecture - ISCA '87. p. 100. doi:10.1145/30350.30362. ISBN  978-0818607769. S2CID  10283148.
  45. ^ Robinson, Ian (1986). A Prolog processor based on a pattern matching memory device. Third International Conference on Logic Programming. Kompyuter fanidan ma'ruza matnlari. 225. Springer. 172–179 betlar. doi:10.1007/3-540-16492-8_73. ISBN  978-3-540-16492-0.
  46. ^ Taki, K.; Nakajima, K .; Nakashima, X .; Ikeda, M. (1987). "Performance and architectural evaluation of the PSI machine". ACM SIGPLAN xabarnomalari. 22 (10): 128. doi:10.1145/36205.36195.
  47. ^ Gupta, G.; Pontelli, E.; Ali, K. A. M.; Carlsson, M.; Hermenegildo, M. V. (2001). "Parallel execution of prolog programs: a survey". Dasturlash tillari va tizimlari bo'yicha ACM operatsiyalari. 23 (4): 472. doi:10.1145/504083.504085. S2CID  2978041.
  48. ^ "Statically Allocated Systems".
  49. ^ a b Logic programming for the real world. Zoltan Somogyi, Fergus Henderson, Thomas Conway, Richard O'Keefe. Proceedings of the ILPS'95 Postconference Workshop on Visions for the Future of Logic Programming.
  50. ^ "FAQ: Prolog Resource Guide 1/2 [Monthly posting] Section - [1-8] The Prolog 1000 Database".
  51. ^ Jan Vielemaker va Vitor Santos Kosta: Prolog dasturlarining ko'chirilishi: nazariya va amaliy tadqiqotlar. CICLOPS-WLPE Workshop 2010 yil.
  52. ^ a b Kiselyov, Oleg; Kameyama, Yukiyoshi (2014). Re-thinking Prolog. Proc. 31st meeting of the Japan Society for Software Science and Technology.
  53. ^ Franzen, Torkel (1994), "Declarative vs procedural", Mantiqiy dasturlash assotsiatsiyasi, 7 (3)
  54. ^ Dantsin, Evgeny; Eiter, Thomas; Gottlob, Georg; Voronkov, Andrei (2001). "Complexity and Expressive Power of Logic Programming". ACM hisoblash tadqiqotlari. 33 (3): 374–425. CiteSeerX  10.1.1.616.6372. doi:10.1145/502807.502810. S2CID  518049.
  55. ^ Mycroft, A.; O'Keefe, R. A. (1984). "A polymorphic type system for prolog". Sun'iy intellekt. 23 (3): 295. doi:10.1016/0004-3702(84)90017-1.
  56. ^ Pfenning, Frank (1992). Types in logic programming. Kembrij, Massachusets: MIT Press. ISBN  978-0-262-16131-2.
  57. ^ Schrijvers, Tom; Santos Kosta, Vitor; Wielemaker, Jan; Demoen, Bart (2008). "Towards Typed Prolog". In Maria Garcia de la Banda; Enrico Pontelli (eds.). Logic programming : 24th international conference, ICLP 2008, Udine, Italy, December 9-13, 2008 : proceedings. Kompyuter fanidan ma'ruza matnlari. 5366. 693-697 betlar. doi:10.1007/978-3-540-89982-2_59. ISBN  9783540899822.
  58. ^ a b Apt, K. R.; Marchiori, E. (1994). "Reasoning about Prolog programs: From modes through types to assertions". Hisoblashning rasmiy jihatlari. 6 (S1): 743. CiteSeerX  10.1.1.57.395. doi:10.1007/BF01213601. S2CID  12235465.
  59. ^ O'Keefe, Richard A. (1990). The craft of Prolog. Kembrij, Massachusets: MIT Press. ISBN  978-0-262-15039-2.
  60. ^ Michael Covington; Roberto Bagnara; va boshq. (2010). "Coding guidelines for Prolog". arXiv:0911.2899 [cs.PL ].
  61. ^ Roy, P.; Demoen, B .; Willems, Y. D. (1987). "Improving the execution speed of compiled Prolog with modes, clause selection, and determinism". Tapsoft '87. Kompyuter fanidan ma'ruza matnlari. 250. pp.111. doi:10.1007/BFb0014976. ISBN  978-3-540-17611-4.
  62. ^ Jaffar, J. (1994). "Constraint logic programming: a survey". The Journal of Logic Programming. 19–20: 503–581. doi:10.1016/0743-1066(94)90033-7.
  63. ^ Colmerauer, Alain (1987). "Opening the Prolog III Universe". Bayt. Avgust.
  64. ^ Wallace, M. (2002). "Constraint Logic Programming". Computational Logic: Logic Programming and Beyond. Kompyuter fanidan ma'ruza matnlari. 2407. 512-556 betlar. doi:10.1007/3-540-45628-7_19. ISBN  978-3540456285.
  65. ^ "XPCE graphics library".
  66. ^ "prolog-mpi". Apps.lumii.lv. Olingan 2010-09-16.
  67. ^ Ehud Shapiro. Bir vaqtning o'zida mantiqiy dasturlash tillari oilasi ACM hisoblash tadqiqotlari. 1989 yil sentyabr.
  68. ^ Vilemaker, J .; Xuang, Z.; Van Der Meij, L. (2008). "SWI-Prolog and the web" (PDF). Theory and Practice of Logic Programming. 8 (3): 363. doi:10.1017 / S1471068407003237. S2CID  5404048.
  69. ^ Jan Wielemaker and Michiel Hildebrand and Jacco van Ossenbruggen (2007), S. Heymans; A. Polleres; E. Ruckhaus; D. Pearse; G. Gupta (eds.), "Using {Prolog} as the fundament for applications on the semantic web" (PDF), Proceedings of the 2nd Workshop on Applications of Logic Programming and to the Web, Semantic Web and Semantic Web Services, CEUR Workshop Proceedings, Porto, Portugal: CEUR-WS.org, 287, pp. 84–98
  70. ^ Processing OWL2 Ontologies using Thea: An Application of Logic Programming. Vangelis Vassiliadis, Jan Wielemaker and Chris Mungall. Proceedings of the 5th International Workshop on OWL: Experiences and Directions (OWLED 2009), Chantilly, VA, United States, October 23–24, 2009
  71. ^ Loke, S. W.; Davison, A. (2001). "Secure Prolog-based mobile code". Theory and Practice of Logic Programming. 1 (3): 321. arXiv:cs/0406012. CiteSeerX  10.1.1.58.6610. doi:10.1017/S1471068401001211. S2CID  11754347.
  72. ^ "Arxivlangan nusxa". Arxivlandi asl nusxasi on 2019-03-17. Olingan 2019-06-08.CS1 maint: nom sifatida arxivlangan nusxa (havola)
  73. ^ Pountain, Dick (October 1984). "POP and SNAP". BAYT. p. 381. Olingan 23 oktyabr 2013.
  74. ^ "Wikipedia GeneXus Page".

Qo'shimcha o'qish

  • Blekbern, Patrik; Bos, Yoxan; Striegnitz, Kristina (2006). Learn Prolog Now!. ISBN  978-1-904987-17-8.
  • Ivan Bratko, Prolog Programming for Artificial Intelligence, 4th ed., 2012, ISBN  978-0-321-41746-6. Book supplements and source code[doimiy o'lik havola ]
  • William F. Clocksin, Christopher S. Mellish: Programming in Prolog: Using the ISO Standard. Springer, 5th ed., 2003, ISBN  978-3-540-00678-7. (This edition is updated for ISO Prolog. Previous editions described Edinburgh Prolog.)
  • William F. Clocksin: Clause and Effect. Prolog Programming for the Working Programmer. Springer, 2003, ISBN  978-3-540-62971-9.
  • Michael A. Covington, Donald Nute, Andre Vellino, Prolog Programming in Depth, 1996, ISBN  0-13-138645-X.
  • Michael A. Covington, Natural Language Processing for Prolog Programmers, 1994, ISBN  978-0-13-629213-5
  • M. S. Dawe and C.M.Dawe, Prolog for Computer Sciences, Springer Verlag 1992.
  • ISO/IEC 13211: Information technology — Programming languages — Prolog. Xalqaro standartlashtirish tashkiloti, Jeneva.
  • Feliks Kluźniak and Stanisław Szpakowicz (with a contribution by Janusz S. Bień). Prolog for Programmers. Academic Press Inc. (London), 1985, 1987 (available under a Creative Commons license at saytlar.google.com/ sayt/prologforprogrammers/[doimiy o'lik havola ]). ISBN  0-12-416521-4.
  • Richard O'Kif, The Craft of Prolog, ISBN  0-262-15039-5.
  • Robert Smith, John Gibson, Aaron Sloman: 'POPLOG's two-level virtual machine support for interactive languages', in Research Directions in Cognitive Science Volume 5: Artificial Intelligence, Eds D. Sliman and N. Bernsen, Lawrence Erlbaum Associates, pp 203–231, 1992.
  • Leon Sterling va Ehud Shapiro, The Art of Prolog: Advanced Programming Techniques, 1994, ISBN  0-262-19338-8.
  • David H D Warren, Luis M. Pereira and Fernando Pereira, Prolog - the language and its implementation compared with Lisp. ACM SIGART Bulletin archive, Issue 64. Proceedings of the 1977 symposium on Artificial intelligence and programming languages, pp 109–115.