Choice points and Redo's in Prolog

后端 未结 2 1612
再見小時候
再見小時候 2021-01-12 19:47

After asking a question here about when exactly a Redo is called in Prolog with new variables, or when it is attempted with the same, I thought I figured it out

2条回答
  •  悲哀的现实
    2021-01-12 20:27

    It has to do with Indexing.

    From SWI-Prolog Glossary of Terms

    Indexing is a technique used to quickly select candidate clauses of a predicate for a specific goal. In most Prolog systems, indexing is done (only) on the first argument of the head. If this argument is instantiated to an atom, integer, float or compound term with functor, hashing is used to quickly select all clauses where the first argument may unify with the first argument of the goal. SWI-Prolog supports just-in-time and multi-argument indexing. See section 2.18.

    This is one of those cases where the concept and implementation diverge.

    Think of it like this, if you were to write the logic engine for Prolog and then the users wanted it to work faster you would add enhancements that made it faster, but in so doing, the way it works would not be the same as the conceptual model.

    Now that the engine has enhancements you should really have a switch that turns off those enhancements when debugging so that you see what is really happening.

    From Prolog Programming in Depth by
    Michael A. Covington
    Donald Nute
    Andr´e Vellino

    Sec. 4.14. Indexing pg. 111

    When a Prolog system executes a query, it doesn’t have to search the entire knowledge base for a matching clause. All Prologs use INDEXING (a hashing function or lookup table) to go directly to the right predicate. For example, with FAMILY.PL, a query to mother/2 does not search the clauses for father/2.

    Most modern Prologs use indexing to go further than that. They index, not only on the predicate and arity, but also on the principal functor of the first argument. For example, if you have the knowledge base

    a(b).  
    a(c).  
    
    d(e).
    d(f).  
    

    then the query ‘?- d(f).’ not only won’t search the clauses for a/1, it also won’t look at d(e). It goes straight to d(f), which is the only clause whose predicate, arity, and first argument match those in the query.

    Question in comment

    Is there some kind of 'vanilla' or 'standard' Prolog environment for beginners where those kinds of enhancements are limited, in order to see more clearly how all the small details work and interact?

    Meta-interpreters

    From: A Couple of Meta-interpreters in Prolog

    An interpreter for a language similar or identical to its own implementation language is called meta-interpreter (MI).

    Learning about Prolog MIs are an excellent way to understand how Prolog works and also learn about MIs which are extremely useful, e.g.

    Use of Prolog for developing a new programming language

    Implementation in another language

    Another way to see how unification works is to use the unification algorithm with backtracking implemented in another language and then use that to enhance the code outputting information you want to see. There is a miniProlog written in OCaml, but I don't suspect that many people know OCaml.

    A lot of the more extensive books on Artificial Intelligence implement it.

    "Paradigms of Artificial Intelligence Programming" by Perter Norvig (Lisp)

    "Artificial Intelligence Structures and Strategies for Complex Problem Solving" by George F Luger (Pseudo Code)

    Prolog implementations can be found on GitHub. smallProlog is very basic and done in C.

    And for the theory of unification there is the classic in

    "Handbook of automated reasoning" Chapter 8

    Unification theory by Franz Baader and Wayne Snyder

    Derivation trees

    See: Prolog derivation trees, choices, and unification

提交回复
热议问题