- From: Boley, Harold <Harold.Boley@nrc-cnrc.gc.ca>
- Date: Tue, 16 May 2006 12:27:13 -0400
- To: <public-rif-wg@w3.org>
Hassan and all, Thanks for coming back to the Phase 1 Expressive Discriminators: http://www.w3.org/2005/rules/wg/wiki/Rulesystem_Arrangement_Framework > It suffers from using preconceived notions that do not > necessarily fit all rule-based languages (e.g., it assumes that rules > use functional Herbrand terms to represents objects - for a language > like IRL, this make no sense -, The feature/record/object-centered terms are there: Syn: Syntactic Discriminators 5. Slotted (Keyed, Role-Named) vs. Positional Arguments o Allowing n-ary atoms with a set of n 'attribute=value' pairs as in RDF/OWL properties, F-logic methods, and object-oriented > there is no mention of such things as > negation, nor of collections or aggregates, etc., ...). These are Phase *1* Expressive Discriminators. Only the charter's Phase *2* lists extensions for negation etc.: http://www.w3.org/2005/rules/wg/charter > ===== SES: SYNTACTIC-ENTAILING-SEMANTIC DISCRIMINATORS ===== > > SES.1. HOMOGENEOUS (BODY HAS SINGLE EXPRESSIVENESS CLASS) VS. HYBRID (BODY > HAS TWO EXPRESSIVENESS CLASSES) RULES > > ??? This is the option to split the body into 'resolution' goals and 'constraint' (e.g., solved by DL engines) goals. > SES.7. LABELED (ANCHORED, OIDED) VS. UNLABELED CLAUSES > > ??? This is the option to give names (e.g., webized) to facts+rules for various kinds of reference, as may be used for editing, interoperation, and, perhaps (see below), expressiveness. > SES.7.1. LABELS ALLOWED VS. NOT ALLOWED AS ARGUMENTS OF USER PREDICATES > > ??? This is the basic option to use names as arguments. > SES.7.2. LABELS ALLOWED VS. NOT ALLOWED AS ARGUMENTS OF PRIORITY-GIVING > SYSTEM PREDICATE 'OVERRIDES' (CF. SCLP) > > ??? This is the option to express priorities between clauses via their names, usually facts over clause names such as in overrides(clause1,clause2). If 'overrides' is not a USER PREDICATE but a SYSTEM PREDICATE, this will not presuppose 7.1. > 1. inference control > PRAG.1.2. INCREMENTAL VS. EXHAUSTIVE > > ??? This is one-solution-at-a-time (for finite and infinite models) vs. all-solutions-at-once (for finite models). PRAG.2. COMPLEXITY ??? These are the layered computational complexity classes, mostly for query answereing. > ===== PRAG: PRAGMATIC DISCRIMINATORS ===== . . . > PRAG.3.2. TEST CASES > > ??? Does the system include a library of test cases, also for benchmarking? > PRAG.3.3. MAPPINGS > > ??? Does the system have pre-defined mappings between various of it own sublanguages? -- Harold ------------------------------------------------------------------------------ CLASSIFYING LIFE AND IRL AS RULE SYSTEMS ===== SYN: SYNTACTIC DISCRIMINATORS ===== SYN.1. RESTRICTED VS. UNRESTRICTED USE OF LOGIC VARIABLES SYN.1.1. SINGLE OCCURRENCE VS. MULTIPLE OCCURRENCE (IMPLICIT VARIABLE EQUALITY) [IRL] IRL uses three sorts of variables: (1) object handles; (2) local names; and, (3) global names - (1) and (2) have scope limited to a rule; (3) are visible by the whole ruleset. Only object handles are bound by pattern matching and may not occur multiply in a rule's pattern, but can occur multiply in a rule's condition and body. All three kinds of variables can be destructively assigned to in a rule's body. For example, the IRL rule "raise-rate" below states that if an account has an interest rate greater than 1% but less than 2%, then that account's interest rate is raised to 2%. rule raise_rate { when { ?a: Account(?r: rate; ?r > 1; ?r < 2); } then { modify (?a) { ?r = 2; } } } In this rule the pattern to match is "?a: Account(?r: rate)". The variables ?a and ?r are object handles that get bound by pattern matching. The rule's condition (a Boolean expression evaluated after matching has bound its handles) is "?r > 1; ?r < 2", and the rule's body is "modify (?a) { ?r = 2; }". In both the condition and body Java-like global variables and local variables may also be used as they are in Java. Object handles may be viewed as logical variables, but only insofar as they are used as such for object pattern matching, the operation that binds them to their values. In conditions and actions, these handles behave like ordinary programming language variables (i.e., for JRules, like Java variables). [LIFE] LIFE uses logical variables (LVs) as in Prolog, but are typed (or more exactly have sorts - types or values). An unsorted occurrence is implicitly sorted with the most general sort \top (written "@") - this generalized the notion of "unbound" in Prolog. LIFE LV's are used a object tags. They may appear multiply (even with different sorts - the final sort being the intersection). The scope of a variable is that of the clause it appears in. "Binding" a variable in LIFE amounts to unifying or matching the object it tags with another one (namely, a function or predicate formal argument). LIFE also supports global variables (GVs). GVs have the scope of a module. LIFE supports non-monotonic variable assignment for both LVs and GVs in the form of a backtrackable destructive assigment. Finally, LIFE has a notion of global persistent variables that may be modified by non-backtrackable assigment. These have the scope of a module. SYN.1.2. RANGE-RESTRICTED RULES (NO HEAD-ONLY VARIABLES) VS. NON-RANGE-RESTRICTED RULES [IRL] In IRL, the range of variables are specified as types. Types of IRL are the same as in Java. [LIFE] In LIFE the range of variables are specified as sorts (types or values). For example, to express that "john likes all humans", in Prolog, one may write: likes(john,X) :- human(X). This would also work in LIFE; however, a more natural way is to write: likes(john,human). where "human" is a type in a taxonomy of classes including all human objects. Note that no variable is needed (single occurrences variables are redundant and can be erased). SYN.1.3. (FURTHER RESTRICTIONS FROM STATIC ANALYSIS RESEARCH) [Not sure I understand this criterion -hak] SYN.2. PREDICATE VARIABLES PERMITTED VS. NOT PERMITTED * SECOND-ORDER SYNTACTIC SUGAR ALLOWING VARIABLES IN PREDICATE POSITIONS OF QUERIES OR RULE BODIES AND POSSIBLY RULE HEADS (FURTHER GENERALIZED TO FUNCTION AND EVEN ATOM POSITIONS IN [HTTP://WWW.W3.ORG/SUBMISSION/SWSF-SWSL/#SWSL-RULES-HILOG]) [IRL] In IRL, rules do not denote predicates nor functions. They have names but these names are for documentation purposes and not used to "call" rules. Rules are activated ("fire") by data-driven pattern matching. Hence, rules are not bindable to variables. Java-style reflection is used whenever rules are used as objects. [LIFE] LIFE has both relational rules (Horn clauses over objects) and functional rules (rewrite rules on objects). Functions are fully higher-order (not only 2nd, but any order). Predicates are first-order. However, everything in LIFE is an object, including logical atoms and clauses. As a result, a variable may appear where a predicate is expected. In fact, predicates may also be "computed" as the result of functional expressions. For example, if the function 'foo' is defined thus: foo(bar,X) -> do_this(X). foo(buz,X) -> do_that(X). then one can write the Horn-clause: bah(X,Y) :- foo(X,Y). such that the query bah(bar,boo) gives the same as do_this(boo). A form of "higher-orderness" may also be achieved with LIFE's cyclic terms which allows anything to self-refer - including clauses and predicates. For example, the following rule prints itself out: C:(self(X) :- write(C)). To wit, in WildLife: > self(1)? _A: (self(1) :- write(_A)) *** Yes Finally, LIFE supports all traditional Prolog-style meta-programming ('listing', 'clause', 'assert', 'retract', etc...) and replaces the so-called "univ" term destructor '=..' with other operators (the function 'root_sort' returns the constructor of a term, and the function 'features' returns its list of attributes). SYN.3. MONOTONIC LLOYD-TOPOR EXTENSIONS ALLOWED VS. NOT ALLOWED * SYNTACTIC SUGAR FOR EXTENDING HORN LOGIC WITH DISJUNCTION IN RULE BODIES AS WELL AS CONJUNCTION AND CLASSICAL IMPLICATION IN RULE HEADS [HTTP://WWW.W3.ORG/SUBMISSION/SWSF-SWSL/#SWSL-RULES-MON-LT] [IRL] IRL's rules are production rules, not inference rules. Such issues are irrelevant for it. [LIFE] All these extensions being purely syntactic transformations, with LIFE's term-expansion facility (which generalizes Prolog's Definite Clause Grammars and Functional Monads), it is a simple matter of implementing these transformations as syntactic monads. (This is what LIFE's "accumulators" were designed to do.) SYN.4. EXPLICIT VS. IMPLICIT RULE SCOPE * ALLOWING FORMULAS AND/OR NAMES DENOTING WHAT HAS BEEN CALLED MODULES, CONTEXTS, RULESETS, OR MODELS [HTTP://WWW.ISI.EDU/~ARGOS/MATTHEW/TRIPLE_BY_EXAMPLE.HTML] [IRL] No. (IRL uses Java-like packages.) [LIFE] No. (LIFE uses Modula-like modules.) SYN.4.1. SLOTTED (KEYED, ROLE-NAMED) VS. POSITIONAL ARGUMENTS * ALLOWING N-ARY ATOMS WITH A SET OF N 'ATTRIBUTE=VALUE' PAIRS AS IN RDF/OWL PROPERTIES, F-LOGIC METHODS, AND OBJECT-ORIENTED SYSTEMS [HTTP://WWW.RULEML.ORG/INDOO] [IRL] IRL uses Java-like values and objects. Pattern-matching works on object structures. [LIFE] LIFE supports Order-Sorted Feature (OSF) terms - also known as psi-terms - which generalize algebraic terms (i.e., Prolog terms) with keyword-labelled as well as positional subterms. A psi-term is a rooted labelled graph. I may contain cycles. SYN.5. WEBIZED VS. NON-WEBIZED NAMES * ALLOWING URIS AS OIDS FOR CONSTANTS, FUNCTIONS, SLOTS, PREDICATES, CLASSES, AND/OR LABELS [HTTP://WWW.W3.ORG/2000/10/SWAP/PRIMER.HTML] [IRL] There is no support for URIs or web-aware naming. [LIFE] There is no support for URIs or web-aware naming. ===== SES: SYNTACTIC-ENTAILING-SEMANTIC DISCRIMINATORS ===== SES.1. HOMOGENEOUS (BODY HAS SINGLE EXPRESSIVENESS CLASS) VS. HYBRID (BODY HAS TWO EXPRESSIVENESS CLASSES) RULES ??? SES.2. FACT-ONLY (DATABASE TABLES) VS. RULE-ONLY VS. FACT-AND-RULE BASES [IRL] IRL supports production rules. Facts are objects in the working memory. IRL also supports Decision Tables. [LIFE] LIFE supports both facts and rules as in Prolog, as well as persistent objects. SES.2.1. VARIABLE-FUL (NON-GROUND) VS. VARIABLE-FREE (GROUND) FACTS (ALSO UNDER "VARIABLE-FUL VS. ... CLAUSES") [IRL] IRL facts are ground only. [LIFE] LIFE facts may be ground or non-ground. The notion of "ground" in LIFE is somewhat irrelevant since values are sorts are minimal types (i.e., they have no subsorts). The notion of "extensional" sort is what corresponds to the conventional notion of "value". An extensional sort is one that denotes a singleton set. For examples, numbers, strings, lists, etc., are extensional. (NB: WildLife 1.02 does not enforce sort extensionality - i.e, X = 1 and Y = 1, does not imply that X = Y.) SES.3. FUNCTION-FUL (FO HORN LOGIC) VS. FUNCTION-FREE (FO DATALOG) [IRL] IRL's objects are attributed graphs as in Java, not Herbrand terms. What corresponds to a Prolog "functor" is a Java-style constructor. IRL uses Java-like interpreted functions in rule conditions and bodies. [LIFE] LIFE terms are psi-terms. What corresponds to a Prolog "functor" is the root sort. Prolog terms are special cases of psi-terms, so "uninterpreted functions" are simply sorts. SES.3.1. FUNCTION ARITY/ARITIES [IRL] Object constructors may be used with less attributes than their class definition prescribes. Missing attributes are implicitly there and may be referred to by using "dotted" projection on a constructed object's handle. [LIFE] WildLife 1.02 implements features as total functions (meaning that one can attach any feature to any object). Hence, Prolog-like terms in LIFE using a functor symbol as root sort doe not have fixed arities. In theory, however, partial features can also be accommodated so as to enforced fixed arity if needed. SES.3.2. FIXED VS. UNFIXED FUNCTION NESTING DEPTH [IRL] There is no limit to either object or function nesting depth. [LIFE] There is no limit to either object or function nesting depth. SES.3.3. UNINTERPRETED VS. INTERPRETED FUNCTIONS [IRL] Functions are interpreted. Object contructors are not. [LIFE] LIFE supports interpreted functions (i.e., those symbols that have a functional definition). All other constructions are non-interpreted as functions - they are objects or predicates. Example of a LIFE function definition: fact(0) -> 1. fact(N:int) -> N*fact(N-1). SES.4. VARIABLE-FUL (NON-GROUND) VS. VARIABLE-FREE (GROUND) CLAUSES SES.4.1. VARIABLE-FUL (NON-GROUND) VS. VARIABLE-FREE (GROUND) FACTS (ALSO UNDER "FACT-ONLY ... BASES") (see SES.2.1) SES.5. PREDICATE ARITY/ARITIES [IRL] ILR does not have relational predicates. Boolean expressions using built-in, user-defined, or library-defined, functions and methods are evaluated as done in Java. All these functions have fixed arities. [LIFE] Nothing has fixed arity in LIFE. However, interpreted functions may be "curryed" (i.e., called with less arguments than specified by their definitions - such calls yield functional abstractions as in lambda calculus). SES.6. NUMBER OF PREMISES IN RULES [IRL] The premise of a rule consists is possibly many object patterns and conditions (Boolean expressions) on their parts. [LIFE] A relational rule is Horn-like (i.e, of the form: A0 :- A1, ..., An, with n >= 0, where the Ai's are literals; i.e., psi-terms denoting relations). A function rule is a rewrite rule of the form A -> B, where A is a psi-term and B is of the form "B0 | B1, ..., Bn", with n>=0, where B1, ..., Bn are literals. (This is read, "B0 such that B1 and ... Bn"). SES.7. LABELED (ANCHORED, OIDED) VS. UNLABELED CLAUSES ??? SES.7.1. LABELS ALLOWED VS. NOT ALLOWED AS ARGUMENTS OF USER PREDICATES ??? SES.7.2. LABELS ALLOWED VS. NOT ALLOWED AS ARGUMENTS OF PRIORITY-GIVING SYSTEM PREDICATE 'OVERRIDES' (CF. SCLP) ??? SES.8. CERTAIN VS. UNCERTAIN CLAUSES AND ATOMS [IRL] IRL does not support uncertainty (neither fuzzy nor stochastic). [LIFE] LIFE does not support uncertainty (neither fuzzy nor stochastic). ===== SEM: SEMANTIC DISCRIMINATORS ===== SEM.1. TERMINATING (ALL QUERIES TERMINATE) VS. NON-TERMINATING (AT LEAST ONE QUERY DOES NOT TERMINATE) RULEBASES [IRL] It is very easy to write a non-terminating IRL program. [LIFE] It is very easy to write a non-terminating LIFE program. SEM.2. FINITE-MODEL VS. INFINITE-MODEL RULEBASES (CF. DECIDABILITY) [IRL] IRL is Turing-complete (one can emulate a TM quite easily) and therefore is undecidable. [LIFE] LIFE is Turing-complete (one can emulate a TM quite easily) and therefore is undecidable. SEM.3. MODALITY/INTENTIONALITY (BEYOND FOL) [IRL] IRL supports event-driven and time-dependent rules (using so-called "chronicles"). [LIFE] There are no modalities in LIFE. ===== PRAG: PRAGMATIC DISCRIMINATORS ===== PRAG.1. INFERENCE CONTROL PRAG.1.1. FORWARD CHAINING VS. BACKWARD CHAINING VS. BIDIRECTIONAL CHAINING [IRL] IRL uses forward-chaining and supports at least two evaluation modes: (1) "normal" RETE-style mode (rules are fired according to specified priorities, refraction, and recency), (2) "sequential" mode (rules are applied in the order specified). [LIFE] LIFE uses backward-chaining for relations and forward-chaining for functions. Rules are tried in the order they are specified. PRAG.1.2. INCREMENTAL VS. EXHAUSTIVE ??? PRAG.2. COMPLEXITY ??? PRAG.3. INTEROPERABILITY [IRL] IRL does not interoperate with other rule systems. [LIFE] Most Edinburgh-style Prolog programs will run under LIFE as expected (up to defining in LIFE a few additional predicates for Prolog built-ins that may not exist in LIFE). The contrary is generally not true. PRAG.3.1. ANNOTATIONS (INCLUDING CONTROLLED ENGLISH) [IRL] Annotations are limited to comments. [LIFE] Annotations are limited to comments. PRAG.3.2. TEST CASES ??? PRAG.3.3. MAPPINGS ??? PRAG.3.3.1. WITHIN EXPRESSIVE EQUIVALENCE CLASSES ("CLUSTERS") PRAG.3.3.2. BETWEEN EXPRESSIVE EQUIVALENCE CLASSES (IMPERFECT OR "LOSSY") PRAG.3.4. (FURTHER INTEROPERABILITY DISCRIMINATORS SHOULD GO HERE) ------------------------------------------------------------------------------------- -- Hassan Aït-Kaci ILOG, Inc. - Product Division R&D tel/fax: +1 (604) 930-5603 - email: hak @ ilog . com
Received on Tuesday, 16 May 2006 16:27:31 UTC