Mercurial > hg > dml-open-cliopatria
diff cpack/dml/lib/dlogic.pl @ 0:718306e29690 tip
commiting public release
author | Daniel Wolff |
---|---|
date | Tue, 09 Feb 2016 21:05:06 +0100 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/cpack/dml/lib/dlogic.pl Tue Feb 09 21:05:06 2016 +0100 @@ -0,0 +1,61 @@ +/* Part of DML (Digital Music Laboratory) + Copyright 2014-2015 Samer Abdallah, University of London + + This program is free software; you can redistribute it and/or + modify it under the terms of the GNU General Public License + as published by the Free Software Foundation; either version 2 + of the License, or (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public + License along with this library; if not, write to the Free Software + Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA +*/ + +:- module( dlogic, [ ext/2, lambda/3, unary/2 ]). + +:- use_module(library(semweb/rdf_db)). +:- use_module(library(semweb/rdfs)). +:- use_module(library(sandbox)). +:- use_module(library(rdfutils)). + +% :- meta_predicate unary(:,-). +:- meta_predicate lambda(-,0,-). +:- rdf_meta ext(t,o). + +:- op(400,xfx,~). + +ext((C1,C2),X) :- !, ext(C1,X), ext(C2,X). +ext(C1;C2, X) :- !, ext(C1,X); ext(C2,X). +ext(inv(P) is Q, X) :- !, rdf_has(V,P,X), call(Q,V). +ext(P is Q, X) :- !, rdf_has(X,P,V), call(Q,V). +ext(q(P,Q), X) :- !, rdf(X,P,literal(Q,_)). +ext(NS:Class,X) :- !, rdf_global_id(NS:Class,C), rdfs_individual_of(X,C). +ext(Class,X) :- atomic(Class), rdfs_individual_of(X,Class). + +lambda(X,Goal,Y) :- + copy_term(X-Goal,Y-Goal1), + call(Goal1). + + +unary((Binary -> Unary), X) :- !, binary(Binary,X,Y), unary(Unary,Y). +unary(\Pred,X) :- !, call(Pred,X). +unary((U1,U2),X) :- !, unary(U1,X), unary(U2,X). +unary((U1;U2),X) :- !, unary(U1,X); unary(U2,X). +unary(a(Class),X) :- !, rdf_global_id(Class,C), rdfs_individual_of(X,C). +unary(P~Q,X) :- !, rdf(X,P,literal(Q,_)). + +binary(p(P),X,Y) :- !, rdf_global_id(P,P1), rdf(X,P1,Y). +binary(ip(P),X,Y) :- !, rdf_global_id(P,P1), rdf(Y,P1,X). +binary(P~Q,X,Y) :- !, rdf_global_id(P,P1), rdf(X,P1,literal(Q,Y)). +binary(\Pred,X,Y) :- !, call(Pred,X,Y). +binary(text,X,Y) :- !, literal_text(X,Y). +binary(num,X,Y) :- !, literal_number(X,Y). + + +sandbox:safe_meta(dlogic:lambda(_,Goal,_),[Goal]). +