Prolog: Difference between revisions
m →OS/2 |
|||
(22 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
[[Image:GottlobFrege.jpg|[http://plato.stanford.edu/entries/frege/ Gottlob Frege] (1848 ~ 1925)<br>Friedrich Ludwig Gottlob Frege invented predicate logic on which Prolog is based|thumb|right]] | [[Image:GottlobFrege.jpg|[http://plato.stanford.edu/entries/frege/ Gottlob Frege] (1848 ~ 1925)<br>Friedrich Ludwig Gottlob Frege invented predicate logic on which Prolog is based|thumb|right]] | ||
Declarative logic programming language developed in France in the latter half of the | Declarative logic programming language developed in France in the latter half of the 1960s and early 1970s, name is a shortening of "PROgrammation en | ||
LOGique" or "Programming in Logic". Unique syntax gives the impression that it is difficult to learn but in actuality it is not more of an effort to learn it any of the classic languages, but programmers used to procedural languages sometimes difficulty getting their heads around the different programming paradigms Prolog has to offer than rank beginner do. | LOGique" or "Programming in Logic". Unique syntax gives the impression that it is difficult to learn but in actuality it is not more of an effort to learn it any of the classic languages, but programmers used to procedural languages sometimes difficulty getting their heads around the different programming paradigms Prolog has to offer than rank beginner do. | ||
Derivatives of Prolog include primarily constraint logic programming languages such as Prolog IV and ECLiPSE but also hybrids such as the strongly typed Mercury and [[Visual Prolog]] and even more alien systems such as Erlang. | Derivatives of Prolog include primarily constraint logic programming languages such as Prolog IV and ECLiPSE but also hybrids such as the strongly typed Mercury and [[Visual Prolog]] and even more alien systems such as Erlang. | ||
== | ==History== | ||
[[Image:AlainColmerauer.jpg|right|thumb|[http://alain.colmerauer.free.fr/ Alain Colmerauer] is the co-inventor of Prolog and the man behind the development of Prolog II, II+, III & IV]] | |||
Invented in Marseilles, France in 1972 by Alain Colmerauer and Philippe Rousse, the system is a descendant of a natural language machine translation system called '''Q-systems''' that Colmerauer started developing in 1968, but prior and parallel to that he alongside Rousse and others connected to the birth of Prolog such as Jean Trudel and Robert Pasero had participated in the "Traduction Automatique de l’Université de Montréal" project in Canada. Initially implemented on an [[IBM]] System/360 using Wirth's [[ALGOL W]] and PL/360. | |||
==Implementations== | |||
===OS/2=== | |||
<div style="column-count:2;-moz-column-count:2;-webkit-column-count:2"> | <div style="column-count:2;-moz-column-count:2;-webkit-column-count:2"> | ||
*[[Arity Prolog]] | Commercial: | ||
*[[Az-Prolog]] | *[[Arity Prolog]] | ||
*[[IBM PROLOG for OS/2]] - 16 bit only | *[[Az-Prolog]] | ||
*[[IBM SAA AD/Cycle Prolog/2]] | *[[IBM PROLOG for OS/2]] - 16-bit only | ||
*[[PDC Prolog]] | *[[IBM SAA AD/Cycle Prolog/2]] | ||
*[[PMPro Prolog]] | *ORISAbase, ORISAentry, ORISApro (ORISA Software GmbH) | ||
*[[Prolog II+]] | *[[PDC Prolog]] | ||
*[[Quintus Prolog]] | *[[PMPro Prolog]] | ||
*[[SICStus Prolog]] | *[[Prolog II+]] | ||
*[[ | *[[Quintus Prolog]] | ||
* | *[[SICStus Prolog]] | ||
*[[ | *VMV Prolog (Automata Design Associates) | ||
*[[Visual Prolog]] | |||
*XPRO (Rational Vision) | |||
Open Source: | |||
*[[SWI-Prolog]] | |||
</div> | </div> | ||
;Prolog libraries | |||
* [ | * [http://prolog-commons.org/PrologCommons.html/PrologCommons.html The Prolog Commons] - Not all library functions are germane to OS/2 - Open source | ||
==== | ===DOS=== | ||
<div style="column-count:2;-moz-column-count:2;-webkit-column-count:2"> | <div style="column-count:2;-moz-column-count:2;-webkit-column-count:2"> | ||
* [[ALS Prolog]] | ''Open Source'' | ||
*[[ALS Prolog]] | |||
* [[Aquarius Prolog]] | *[[Aquarius Prolog]] | ||
*Beta-Prolog | |||
*BinProlog | |||
*Beta-Prolog | *[https://github.com/Johnicholas/Hello-Github/tree/master/prolog-in-hundreds-of-loc/Boizumault Boizumault Prolog] | ||
*BinProlog | *[[cu-Prolog]] | ||
* [https://github.com/Johnicholas/Hello-Github/tree/master/prolog-in-hundreds-of-loc/Boizumault Boizumault Prolog] - | *Stony Brook Prolog - Aka SB-Prolog | ||
* | ''Commercial'' | ||
* | *Amzi! Prolog+Logic Server | ||
*[[ | *[[Arity Prolog]] | ||
*LPA Prolog | *[[Az-Prolog]] | ||
*LPA [[micro-PROLOG]] | *ESL Prolog-2 | ||
*Logicware MPROLOG | *Cogent Prolog Compiler | ||
*MR Prolog | *IF/Prolog | ||
*[[PDC Prolog]] | *LPA Prolog | ||
*Prolog II | *LPA [[micro-PROLOG]] | ||
*Prolog III | *Logicware MPROLOG | ||
*Chalcedony Prolog V/Prolog V-Plus | *MR Prolog | ||
*Prolog-86+ | *[[PDC Prolog]] | ||
*Prolog II | |||
*[[Quintus Prolog]] | *Prolog III | ||
*[[SICStus Prolog]] | *Chalcedony Prolog V/Prolog V-Plus | ||
* | *Prolog-86+ | ||
*[[Visual Prolog|Turbo Prolog]] | *[[Quintus Prolog]] | ||
*VML Prolog | *[[SICStus Prolog]] | ||
*SNI Prolog | |||
*[[Visual Prolog|Turbo Prolog]] | |||
*VML Prolog | |||
''Freeware'' | |||
*PD Prolog (A.D.A. PD Prolog) | |||
</div> | </div> | ||
== | ===Win-OS/2=== | ||
* [[ALS Prolog]] - | *[[ALS Prolog]] - former commercial/now open source | ||
* | *Amzi! Logic Explorer - Freeware | ||
* | *Amzi! Prolog+Logic Server - Commercial | ||
* [[Arity Prolog]] - Commercial | *[[Arity Prolog]] - Commercial | ||
* | *IF/Prolog - Commercial - Discontinued - Contraint ver. | ||
* | *LPA Prolog - Commercial - Versions up to 4.1 run with [[Win32s]] | ||
* | *Prolog IV - Commercial | ||
* [[Visual Prolog]] - Commercial | *[[Visual Prolog]] - Commercial | ||
== | ===Java=== | ||
<div style="column-count:2;-moz-column-count:2;-webkit-column-count:2"> | <div style="column-count:2;-moz-column-count:2;-webkit-column-count:2"> | ||
* [https://web.archive.org/web/20011006071211/http://www.students.cs.ruu.nl/people/smotterl/prolog/index.htm CKI-Prolog] - Old but works on Java 1.x on vintage hardware | Commercial: | ||
* DGKS Prolog | * [http://www.jekejeke.ch Jekejeke Prolog] | ||
* [https://www.gnu.org/software/gnuprologjava/ GNU Prolog for Java] | * [http://www.jiprolog.com/ JIProlog] | ||
* [https://web.archive.org/web/19990427194619/http://www.bird-land.com/java/prolog/index.html JavaLog] - Old but works on Java 1.x on vintage hardware | Open Source: | ||
* [https://web.archive.org/web/20011006071211/http://www.students.cs.ruu.nl/people/smotterl/prolog/index.htm CKI-Prolog] - Old but works on Java 1.x on vintage hardware | |||
* [https://code.google.com/p/jinniprolog/ Jinni Prolog] | * DGKS Prolog | ||
* [https://www.gnu.org/software/gnuprologjava/ GNU Prolog for Java] | |||
* [http://sourceforge.net/projects/jlogic/ jLog] | * [https://web.archive.org/web/19990427194619/http://www.bird-land.com/java/prolog/index.html JavaLog] - Old but works on Java 1.x on vintage hardware | ||
* [https://java.net/projects/jTrolog jTrolog] | * [https://code.google.com/p/jinniprolog/ Jinni Prolog] | ||
* [https://code.google.com/p/kernel-prolog/ Kernel Prolog] - Subset | * [http://sourceforge.net/projects/jlogic/ jLog] | ||
* [https://code.google.com/p/mandarax/ Mandarax] - Prolog variant, not fully compatible | * [https://java.net/projects/jTrolog jTrolog] | ||
* | * [https://code.google.com/p/kernel-prolog/ Kernel Prolog] - Subset | ||
* [https://prova.ws/ Prova] - Prolog variant, not fully compatible | * [https://code.google.com/p/mandarax/ Mandarax] - Prolog variant, not fully compatible | ||
* [https://code.google.com/p/styla/ Styla] - Requires [[Scala]] | * Prolog Café - Interpreter and translator | ||
* [http://alice.unibo.it/xwiki/bin/view/Tuprolog/ tuProlog] | * [https://prova.ws/ Prova] - Prolog variant, not fully compatible | ||
* [http://waitaki.otago.ac.nz/~michael/wp/ W-Prolog] | * [https://code.google.com/p/styla/ Styla] - Requires [[Scala]] | ||
* [http://alice.unibo.it/xwiki/bin/view/Tuprolog/ tuProlog] | |||
* [http://waitaki.otago.ac.nz/~michael/wp/ W-Prolog] | |||
</div> | </div> | ||
== | ;Utilities | ||
* [http://ioctl.org/logic/prolog1 Prolog in JavaScript] - Note sub-set, split into a few pages - Open Source | * [https://github.com/espakm/prolog4j Prolog4J] - Allows Java programs to use native Prolog engines - Open Source | ||
* [http://yieldprolog.sourceforge.net/ Yield Prolog] - Sub-set - Open Source | |||
===JavaScript=== | |||
* [http://ioctl.org/logic/prolog1 Prolog in JavaScript] - Note sub-set, split into a few pages - Open Source | |||
* [http://yieldprolog.sourceforge.net/ Yield Prolog] - Sub-set - Open Source | |||
==Publications== | ==Publications== | ||
* | *J.A. Campbell: ''Implementations of Prolog'' - Halsted Press 1984, ISBN 0-85312-675-5 | ||
*Patrice Boizumault: [http://press.princeton.edu/titles/5264.html The Implementation of Prolog]- | *Feliks Kluźniak; Stanisław Szpakowicz: ''Prolog for Programmers'' - Academic Press 1987, ISBN 0-12-416521-4 [http://www.eecs.uottawa.ca/~szpak/pub/P4P/Prolog_for_Programmers_neat.pdf] | ||
* Fernando C. N. Pereira | *Leon Sterling; Ehud Shapiro: ''The Art of Prolog'' - MIT Press 1994, ISBN 0-262-19338-8 | ||
; | *Michael Spivey: ''An Introduction to Logic Programming through Prolog'' - Prentice-Hall 1996, ISBN 0-13-536047-1 | ||
*Patrice Boizumault: [http://press.princeton.edu/titles/5264.html The Implementation of Prolog]- Translated by Ara M. Djamboulian and Jamal Fattouh - 1993/2014, ISBN 0-691-60939-X | |||
* Fernando C. N. Pereira; Stuart M. Shieber: [http://www.mtome.com/Publications/PNLA/prolog-digital.pdf Prolog and Natural-Language Analysis] | |||
*Michael A. Covington; Donald Nute; André Vellino: ''Prolog Programming in Depth'' (Second edition) - Prentice-Hall 1997, ISBN 0-13-138645-X | |||
;Papers | |||
* Krzysztof R. Apt, Maurizio Gabbrielli and Dino Pedreschi [http://oai.cwi.nl/oai/asset/1397/1397A.pdf A closer look at declarative interpretations*] | * Krzysztof R. Apt, Maurizio Gabbrielli and Dino Pedreschi [http://oai.cwi.nl/oai/asset/1397/1397A.pdf A closer look at declarative interpretations*] | ||
* [https://www.metalevel.at/tist/ Thinking in states] - Parsers & compilers | * [https://www.metalevel.at/tist/ Thinking in states] - Parsers & compilers | ||
* David H. D. Warren: [https://www.sri.com/sites/default/files/uploads/publications/pdf/656.pdf Applied Logic - Its use and implementation as a programming tool] | * David H. D. Warren: [https://www.sri.com/sites/default/files/uploads/publications/pdf/656.pdf Applied Logic - Its use and implementation as a programming tool] | ||
==Links== | ==Links== | ||
* [http://alain.colmerauer.free.fr/ Alain Colmerauer's homepage] - Has a cache of historical papers | * [http://alain.colmerauer.free.fr/ Alain Colmerauer's homepage] - Has a cache of historical papers related to Prolog | ||
* [https://github.com/Johnicholas/Hello-Github/tree/master/prolog-in-hundreds-of-loc/Boizumault Boizumault Prolog Archive on Github] - Contains the example Prolog implementations from his book (above) | * [https://github.com/Johnicholas/Hello-Github/tree/master/prolog-in-hundreds-of-loc/Boizumault Boizumault Prolog Archive on Github] - Contains the example Prolog implementations from his book (above) | ||
* [https://dtai.cs.kuleuven.be/ppcbook/ The first 10 Prolog Programming Contests] | * [https://dtai.cs.kuleuven.be/ppcbook/ The first 10 Prolog Programming Contests] | ||
* [https://dtai.cs.kuleuven.be/projects/ALP/newsletter/may05/nav/complang/nettalk.html Documenting large Prolog programs] | * [https://dtai.cs.kuleuven.be/projects/ALP/newsletter/may05/nav/complang/nettalk.html Documenting large Prolog programs] | ||
* ''Peter Skye'': [http://www.scoug.com/reports/ws98_bourassa.html Logic Programming In Native OS/2] | |||
* | * [http://www.learnprolognow.org/ Learn Prolog Now!] - Tutorial | ||
* USENET: [news:comp.lang.prolog comp.lang.prolog] | |||
* [http:// | |||
[[Category:Programming Languages]] [[Category:Prolog]] | [[Category:Programming Languages]][[Category:Prolog]] |
Latest revision as of 01:28, 9 August 2024

Friedrich Ludwig Gottlob Frege invented predicate logic on which Prolog is based
Declarative logic programming language developed in France in the latter half of the 1960s and early 1970s, name is a shortening of "PROgrammation en LOGique" or "Programming in Logic". Unique syntax gives the impression that it is difficult to learn but in actuality it is not more of an effort to learn it any of the classic languages, but programmers used to procedural languages sometimes difficulty getting their heads around the different programming paradigms Prolog has to offer than rank beginner do.
Derivatives of Prolog include primarily constraint logic programming languages such as Prolog IV and ECLiPSE but also hybrids such as the strongly typed Mercury and Visual Prolog and even more alien systems such as Erlang.
History

Invented in Marseilles, France in 1972 by Alain Colmerauer and Philippe Rousse, the system is a descendant of a natural language machine translation system called Q-systems that Colmerauer started developing in 1968, but prior and parallel to that he alongside Rousse and others connected to the birth of Prolog such as Jean Trudel and Robert Pasero had participated in the "Traduction Automatique de l’Université de Montréal" project in Canada. Initially implemented on an IBM System/360 using Wirth's ALGOL W and PL/360.
Implementations
OS/2
Commercial:
- Arity Prolog
- Az-Prolog
- IBM PROLOG for OS/2 - 16-bit only
- IBM SAA AD/Cycle Prolog/2
- ORISAbase, ORISAentry, ORISApro (ORISA Software GmbH)
- PDC Prolog
- PMPro Prolog
- Prolog II+
- Quintus Prolog
- SICStus Prolog
- VMV Prolog (Automata Design Associates)
- Visual Prolog
- XPRO (Rational Vision)
Open Source:
- Prolog libraries
- The Prolog Commons - Not all library functions are germane to OS/2 - Open source
DOS
Open Source
- ALS Prolog
- Aquarius Prolog
- Beta-Prolog
- BinProlog
- Boizumault Prolog
- cu-Prolog
- Stony Brook Prolog - Aka SB-Prolog
Commercial
- Amzi! Prolog+Logic Server
- Arity Prolog
- Az-Prolog
- ESL Prolog-2
- Cogent Prolog Compiler
- IF/Prolog
- LPA Prolog
- LPA micro-PROLOG
- Logicware MPROLOG
- MR Prolog
- PDC Prolog
- Prolog II
- Prolog III
- Chalcedony Prolog V/Prolog V-Plus
- Prolog-86+
- Quintus Prolog
- SICStus Prolog
- SNI Prolog
- Turbo Prolog
- VML Prolog
Freeware
- PD Prolog (A.D.A. PD Prolog)
Win-OS/2
- ALS Prolog - former commercial/now open source
- Amzi! Logic Explorer - Freeware
- Amzi! Prolog+Logic Server - Commercial
- Arity Prolog - Commercial
- IF/Prolog - Commercial - Discontinued - Contraint ver.
- LPA Prolog - Commercial - Versions up to 4.1 run with Win32s
- Prolog IV - Commercial
- Visual Prolog - Commercial
Java
Commercial:
Open Source:
- CKI-Prolog - Old but works on Java 1.x on vintage hardware
- DGKS Prolog
- GNU Prolog for Java
- JavaLog - Old but works on Java 1.x on vintage hardware
- Jinni Prolog
- jLog
- jTrolog
- Kernel Prolog - Subset
- Mandarax - Prolog variant, not fully compatible
- Prolog Café - Interpreter and translator
- Prova - Prolog variant, not fully compatible
- Styla - Requires Scala
- tuProlog
- W-Prolog
- Utilities
- Prolog4J - Allows Java programs to use native Prolog engines - Open Source
JavaScript
- Prolog in JavaScript - Note sub-set, split into a few pages - Open Source
- Yield Prolog - Sub-set - Open Source
Publications
- J.A. Campbell: Implementations of Prolog - Halsted Press 1984, ISBN 0-85312-675-5
- Feliks Kluźniak; Stanisław Szpakowicz: Prolog for Programmers - Academic Press 1987, ISBN 0-12-416521-4 [1]
- Leon Sterling; Ehud Shapiro: The Art of Prolog - MIT Press 1994, ISBN 0-262-19338-8
- Michael Spivey: An Introduction to Logic Programming through Prolog - Prentice-Hall 1996, ISBN 0-13-536047-1
- Patrice Boizumault: The Implementation of Prolog- Translated by Ara M. Djamboulian and Jamal Fattouh - 1993/2014, ISBN 0-691-60939-X
- Fernando C. N. Pereira; Stuart M. Shieber: Prolog and Natural-Language Analysis
- Michael A. Covington; Donald Nute; André Vellino: Prolog Programming in Depth (Second edition) - Prentice-Hall 1997, ISBN 0-13-138645-X
- Papers
- Krzysztof R. Apt, Maurizio Gabbrielli and Dino Pedreschi A closer look at declarative interpretations*
- Thinking in states - Parsers & compilers
- David H. D. Warren: Applied Logic - Its use and implementation as a programming tool
Links
- Alain Colmerauer's homepage - Has a cache of historical papers related to Prolog
- Boizumault Prolog Archive on Github - Contains the example Prolog implementations from his book (above)
- The first 10 Prolog Programming Contests
- Documenting large Prolog programs
- Peter Skye: Logic Programming In Native OS/2
- Learn Prolog Now! - Tutorial
- USENET: comp.lang.prolog