ECLiPSe

Source: Wikipedia, the free encyclopedia.
ECLiPSe Constraint Logic Programming System
Cisco Systems
Initial release1992; 33 years ago (1992)
Stable release
7.0 / January 22, 2018; 7 years ago (2018-01-22)
Mozilla Public (MPL)
Websiteeclipseclp.org

ECLiPSe is a software system for the development and deployment of

mathematical programming, and search techniques.[1] It contains constraint solver libraries, a high-level modeling and control language (a superset of Prolog
), interfaces to third-party solvers, an integrated development environment and interfaces for embedding into host environments.

ECLiPSe was developed until 1995 at the European Computer‐Industry Research Centre (ECRC) in

open source software under an equivalent of the Mozilla Public License, and is now hosted on SourceForge
.

Language

The ECLiPSe language[2] is largely backward-compatible with Prolog and supports different dialects, including ISO Prolog. Due to being declarative, it can be used both as a modelling language to describe problems, and as a general purpose programming language.

Beyond the basic Prolog data types, the following are available:

are also supported and especially useful in constraint modelling.

A

logical iteration construct[3] eliminates the need for most simple recursion
patterns.

ECLiPSe provides comprehensive facilities[2] to implement data-driven control behaviour. These include declarative delay-clauses as well as primitives for meta-programmed control like explicit goal suspension, flexible triggering facilities and execution priorities. Together with the attributed variable data type, this is the key to many extensions to the basic logic programming language, including all constraint-based functionality. The system calls user-definable event handlers when it encounters attributed variables in certain contexts, e.g. unification.

The

module system
controls the visibility of predicates, non-logical stores, source transformations and syntax settings. Module interfaces can be extended and restricted, and modules written in different language dialects can be mixed within one application.

Programs may contain structured comments from which reference documentation can be generated.

Libraries

ECLiPSe provides several libraries of constraint solvers which can be used in application programs:

Arithmetic constraints over finite domains, finite set constraints, generalized propagation, interval reasoning over non-linear constraints, interfaces to external

constraint handling rules
(CHR) and more.

Other libraries implement search methods like

branch-and-bound
, repair-based search, limited discrepancy search.

ECLiPSe interfaces to external solvers, in particular the COIN-OR, CPLEX, Gurobi, and Xpress-MP linear and mixed-integer programming solvers,[4] and the Gecode solver library.

Compatibility libraries for ISO Prolog[5] and other Prolog dialects (C-Prolog, Quintus, SICStus, SWI-Prolog) enable the reuse of libraries written in those dialects.

Other utility libraries, including a number of popular public domain ones, are included in the distribution.

System architecture

The system includes an incremental compiler which translates source code into virtual machine code. The compiler optimizes index selection, unification order, inlining of control constructs and can take mode information into account.

The runtime system implements the

virtual machine, automatic memory management with garbage collection of stacks and dictionary, event handling and data-driven execution. Versions of ECLiPSe implement OR-parallelism
.

ECLiPSe components can be integrated into software via a low-level C or C++ interface, or via high-level interfaces to Java and Tcl.

See also

References

  1. ^ "ECLiPSe Web Site". eclipseclp.org.
  2. ^
    S2CID 11827081
    .
  3. ISBN 978-3-540-45619-3.{{cite book}}: CS1 maint: location (link
    )
  4. ISBN 978-3-540-32050-0.{{cite book}}: CS1 maint: location (link
    )
  5. ^ "ECLiPSe ISO conformity declaration". eclipseclp.org.