Difference between revisions of "Template:MELD features/Appendix C"

From Public Domain Knowledge Bank
Jump to: navigation, search
(Appendix C: BNF Grammar for MELD)
 
(One intermediate revision by the same user not shown)
Line 1: Line 1:
<noinclude> [[MELD features]] </noinclude>
+
Do you mean: [[MELD features/Appendix C]] ?
= Appendix C: BNF Grammar for MELD =
+
Or the top level page: [[MELD features]] ?
 
 
This BNF can be used to check for syntactic well-formedness of a MELD formula, and -- coupled with the 650 formulas above in Appendix A, -- to check a MELD formula for semantic well-formedness as well.
 
 
 
Assume the following Terminals (token-level non-terminals)
 
<pre>
 
<Character>
 
<String>
 
<Number>
 
<Symbol>
 
<Variable>
 
 
 
Assume the following MELD data object:
 
 
 
<Constant>
 
 
 
The empty expansion is:
 
 
 
<epsilon>
 
 
 
 
 
;;;;;;;;;;;;;;;;;;;;;;;;
 
;; Syntactic Constraints
 
;;;;;;;;;;;;;;;;;;;;;;;;
 
 
 
<Formula> ::=          #$True
 
        |              #$False
 
        |              <Variable>
 
        |              <Literal>
 
        |              <NotForm>
 
        |              <AndForm>
 
        |              <OrForm>
 
        |              <XorForm>
 
        |              <ImpForm>
 
        |              <EquivForm>
 
        |              <UnivForm>
 
        |              <ExistForm>
 
        |              <ExistExactForm> 
 
        |              <ExistUBoundForm> 
 
        |              <ExistLBoundForm> 
 
 
 
<Formula-Seq> ::=      <Formula> <Formula-Seq>
 
        |              . <Variable>
 
        |              <epsilon>
 
 
 
<NotForm> ::=          ( #$not <Formula> )
 
 
 
<AndForm> ::=          ( #$and <Formula-Seq> )
 
 
 
<OrForm> ::=            ( #$or <Formula-Seq> )
 
 
 
<XorForm> ::=          ( #$xor <Formula> <Formula> )
 
 
 
<ImpForm> ::=          ( #$implies <Formula> <Formula> )
 
 
 
<EquivForm> ::=        ( #$equivalent <Formula> <Formula> )
 
 
 
<UnivForm> ::=          ( #$forAll <Variable> <Formula> )
 
 
 
<ExistForm> ::=        ( #$thereExists <Variable> <Formula> )
 
 
 
<ExistExactForm> ::=    ( #$thereExistExactly <1stOrderTerm> <Variable> <Formula> )
 
 
 
<ExistUBoundForm> ::=  ( #$thereExistAtMost  <1stOrderTerm> <Variable>  <Formula> )
 
 
 
<ExistLBoundForm> ::=  ( #$thereExistAtLeast <1stOrderTerm> <Variable>  <Formula> )
 
 
 
<Literal> ::=          <AtomicFormula>
 
        |              ( #$not <AtomicFormula> )
 
       
 
<AtomicFormula> ::=    ( <Predicate> <Argument-Seq> )
 
 
 
<Argument-Seq> ::=      <2ndOrderTerm> <Argument-Seq>
 
        |              . <Variable>
 
        |              <epsilon>
 
 
 
<Predicate> ::=        <Rep1stOrderTerm>
 
 
 
<FunctionExp> ::=      ( <Function> <Argument-Seq> )
 
 
 
<Function> ::=          <Rep1stOrderTerm>
 
 
 
<2ndOrderTerm> ::=      <1stOrderTerm>
 
        |              <Formula>
 
 
 
<1stOrderTerm> ::=      <Rep1stOrderTerm>
 
        |              <PrimitiveTerm>
 
 
 
<Rep1stOrderTerm> ::=  <Constant>
 
        |              <FunctionExp>
 
        |              <Variable>
 
 
 
<PrimitiveTerm> ::=    <Character>
 
        |              <String>
 
        |              <Number>
 
        |              <Symbol>
 
        |              <Variable>
 
 
 
;;;;;;;;;;;;;;;;;;;;;;;
 
;; Semantic Constraints
 
;;;;;;;;;;;;;;;;;;;;;;;
 
 
 
For <ExistExactForm> :               
 
 
 
1st arg must denote a positive integer
 
                                     
 
For <ExistUBoundForm> :               
 
 
 
1st arg must denote a positive integer
 
                                     
 
 
 
For <ExistLBoundForm> :               
 
 
 
1st arg must denote a positive integer
 
 
 
For <Function> :
 
 
 
when <Function> is ground
 
  (#$isa <Function> #$NonPredicateFunction) must be true
 
 
 
For <Predicate> :
 
when <Predicate> is ground
 
(#$isa <Predicate> #$Predicate) must be true
 
 
 
 
 
Relation Arity Constraints:
 
 
For <FunctionExp> :
 
when <Function> is ground
 
either
 
  (#$isa <Function> #$VariableArityRelation)
 
or
 
  (#$arity <Function> <N>)
 
  and
 
  <N> is a non-negative integer
 
  and
 
  if <Argument-Seq> is terminated by . <Variable>
 
      the number of <2ndOrderTerm>s in <Argument-Seq>
 
      must be less than or equal to <N>
 
  else the number of <2ndOrderTerm>s in <Argument-Seq>
 
        must be equal to <N>
 
 
 
For <AtomicFormula> :
 
 
when <Predicate> is ground
 
either
 
  (#$isa <Predicate> #$VariableArityRelation)
 
 
or
 
  (#$arity <Predicate> <N>)
 
  and
 
  <N> is a non-negative integer
 
  and
 
  if <Argument-Seq> is terminated by . <Variable>
 
      the number of <2ndOrderTerm>s in <Argument-Seq>
 
      must be less than or equal to <N>
 
  else the number of <2ndOrderTerm>s in <Argument-Seq>
 
      must be equal to <N>               
 
 
 
Relation Argument Constraints:
 
 
 
For <FunctionExp> :
 
 
 
each term in <Argument-Seq> must satisfy all applicable arg constraints
 
(e.g., #$arg1Isa, #$interArgIsa2-1, ...)
 
 
 
or <AtomicFormula> :
 
 
 
each term in <Argument-Seq> must satisfy all applicable arg constraints
 
(e.g., #$arg1Isa, #$interArgIsa2-1, ...)
 
</pre>
 

Latest revision as of 18:30, 30 September 2019

Do you mean: MELD features/Appendix C ? Or the top level page: MELD features ?