Lazy lists in Prolog?

后端 未结 6 1678
情深已故
情深已故 2020-11-28 11:45

Is it possible to have lazy lists in Prolog? Something like the following:

ones([1 | Y]) :- ones(Y).

Although this obviously doesn\'t work

6条回答
  •  一个人的身影
    2020-11-28 12:31

    Markus Triska placed here in public domain some code worth to study:

    /* - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
       Prolog stream/lazy list demonstration
    
       Written 2005 by Markus Triska (triska@gmx.at)
       Public domain code.
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - */
    

    The title of the document (prost, for Prolog streams) maybe make the document a bit difficult to find, but make sense. Quoting from the above:

    Here, "stream" is used in the sense of "sequence", "delayed list", "lazy list" etc. as in Structure and Interpretation of Computer Programs, not in the sense of a Prolog input/output stream.

提交回复
热议问题