Dcg interpreter counting words

Description

A DCG interpreter that counts words

Source: The Art of Prolog

Download

Program source code: dcg_interpreter_counting_words.pl

Listing

/*
        parse(Start,Tokens,N) :-
            The sequence of tokens Tokens, represented as a difference-list,
            can be reached by applying the grammar rules defined by -->/2,
            starting from Start, and N tokens are found.
*/
 
:-  op( 800, xfx, -->).
:- op(40,xfx,\).
 
        parse(A,Tokens,N) :-
            nonterminal(A), A --> B, parse(B,Tokens,N).
        parse((A,B),Tokens\Xs,N) :-
            parse(A,Tokens\Tokens1,NA), parse(B,Tokens1\Xs,NB),
	    N is NA+NB.
 
        parse(A,Tokens,N) :-  terminals(A), connect(A,Tokens), length(A,N).
        parse({A},Xs\Xs,0) :-  A.
 
	terminals(Xs) :- list(Xs).
 
	list([]).
	list([X|Xs]) :- list(Xs).
 
        connect([ ],Xs\Xs).
        connect([W|Ws],[W|Xs]\Ys) :-  connect(Ws,Xs\Ys).
 
     length([X|Xs],N) :- length(Xs,N1), N is N1+1.
     length([],0).
 
%      Program 19.5:  A DCG interpreter that counts words

Comments

pl/prolog/pllib/dcg_interpreter_counting_words.txt · ostatnio zmienione: 2019/06/27 15:50 (edycja zewnętrzna)
www.chimeric.de Valid CSS Driven by DokuWiki do yourself a favour and use a real browser - get firefox!! Recent changes RSS feed Valid XHTML 1.0