(define-class <class-name> (<var>) [<docstring>] {:def | :iff-def} <sent-with-arg-vars> [:constraints <sent-with-arg-vars>] [:equivalent <sent-with-arg-vars>] [:sufficient <sent-with-arg-vars>] [:default-constraints <sent-with-arg-vars>] [:axiom-def <sent-without-arg-vars>] [:axiom-constraints <sent-without-arg-vars>] [:axiom-defaults (<sent-without-arg-vars>*)] [:theory <theory-name>] [:implementation <target-system-name>] [:class-slots (<slot-spec>*)] [:instance-slots (<extended-slot-spec>*)] [:default-slot-values (<slot-spec>*)] [:issues <issue-tree>])
Defines an OntoLingua class. See also CREATE-CLASS, which is the functional form.
<class-name> should be a symbol which names the class being defined. Ontolingua will convert this symbol into a format which is appropriate for the selected target representation system during translation (e.g., if one were translating into CycL, the symbol would be converted into a string which would obey the CycL conventions for case and word delimiters.)
<var> is a symbol begining with a ? that stands for instances of the class being defined. For example, in
(define-class father (?father) ...)
the symbol ?father is the <var> instance variable.
Within the sentences in the body of the class definition, the instance variable is treated as a variable bound to instances of the class.
Note: sequence-variables (indicated by a '@' prefix in KIF and Epikit) are not guaranteed to be supported in all target representation systems. This means that "portable" OntoLingua relations always have a fixed arity.
<docstring> when provided, should be a string which describes the class being defined. It will be stored as the Lisp documentation (of type OL:ONTO-CLASS) for the symbol which names the class. If a docstring is provided, it must immediately follow the argument list.
The remaining keyword arguments may occur in any order, and are described below:
:AXIOM-CONSTRAINTS - The associated value should be a KIF sentence which is a standalone sentence not related to the variables in the argument list. It is the same as the :AXIOM-DEF sentence except it is not definitional -- relevant to the form being defined, but not part of its definition.
Logically, this sentence neither implies nor is implied by the relation holding for a given binding of the variable(s) <var> ; it is a standalone sentence. It should mention the relation being defined, however.
A list of sentences may be supplied instead of a single sentence; Ontolingua will automatically construct a conjunction of all the supplied :AXIOM-CONSTRAINTS sentences in this case.
:AXIOM-DEF - The value of this keyword should be KIF sentence; it will be asserted along with the definition. Logically, this sentence neither implies nor is implied by membership in the class being defined; it is a standalone sentences. It should mention the class being defined, however. If this axiom happens to mention the variable VAR, then this variable is treated like any other unquantified KIF variable: it is assumed to be universally quantified. Thus, it is confusing to use VAR in the :AXIOM-DEF sentence.- The value should be a KIF sentence with no free variables. In particular, the sentence does not implicitly constrain the variables in the argument list (that is what :def and :iff-def are for). The :AXIOM-DEF sentence is considered to be definitional. That is, it is part of the definition as are :DEF and :IFF-DEF sentences. Non-definition axioms should be specified with the :AXIOM-CONSTRAINTS keyword.
A list of sentences may be supplied instead of a single sentence; Ontolingua will automatically construct a conjunction of all the supplied :AXIOM-DEF sentences in this case.
:AXIOM-DEFAULTS - the value of this keyword should be a list of KIF sentences which are not related to VAR. They should mention the class being defined, however. Each of these sentences is taken to hold until and unless a contradictory sentence is asserted.
:CONSTRAINTS - The associated value should be a KIF sentence that specifies necessary constraints on the relation that are not meant as part of the definition of the relation. The :CONSTRAINTS sentence is taken to be true for any bindings of the <var> arguments for which the relation holds; it "follows" from the definition. One can also think of constraints as (monotonically) inherited facts about sets of instances for which the relation holds.
:CONSTRAINTS sentences are logically equivalent to :DEF sentences, and take the same form (i.e., sentences with terms that include free variables from the <var> arguments list.) The purpose of the distinction between definitional and nondefinitional constraints is to support terminological reasoning apart from other kinds of deductive inference. The :CONSTRAINTS sentence is an assertion used in nonterminological inference, such as inheritence of sentences used to ensure consistency.
A list of sentences may be supplied instead of a single sentence; Ontolingua will automatically construct a conjunction of all the supplied :CONSTRAINTS sentences in this case.
:DEF - The value of this keyword argument should be a KIF sentence that "defines" the class; that is, a KIF sentence using the argument symbol as a free variable that holds over all instances of the class. The purpose of the :DEF sentence is to specify constraints on consistent use of the class; it should reflect the textual definition given in the docstring. Some implementations make special use of sentences labeled as definitions.
Logically, the :DEF sentence is implied by membership in the class, and membership in a class is specfied by something satisfying a unary precicate. That is, the :DEF sentence is a necessary condition for class membership. For example,
(define-class human (?human) "The human animal." :def (animal ?human))
is logically equivalent to
(=> (human ?human) (animal ?human))
It also is way of saying that human is a subclass of animal (human is subsumed by animal).
:DEFAULT-CONSTRAINTS - The value of this keyword argument should be a list of KIF sentences that specify what "follows by default" from membership in the class. The precise operational semantics of nonmonotonic inference will depend on the target representation system. The intended use of :DEFAULT-CONSTRAINTS is to specify "default inheritance" of facts about instances of the class. The :DEFAULT-CONSTRAINTS sentences have the the same form as the :DEF and :CONSTRAINTS sentences.
When it is asserted that an individual is an instances of the class, then each of the :DEFAULT-CONSTRAINTS sentences will hold ("by default") with the <var> argument bound to that individual, until and unless a sentence that contradicts that :DEFAULT-CONSTRAINTS sentence is asserted for that individual. For example:
(define-class american (?person) :default-constraints (owns-tv ?person))
specifies
(=> (american ?person) (<= (owns-tv ?person) (not (provable (not (owns-tv ?person))))))
:EQUIVALENT - The value of this keyword argument should be a list of KIF sentences that specify biconditional constraints on the relation that are not meant as part of the definition of the relation.
:EQUIVALENT constraints are logically equivalent to :IFF-DEF constraints. The purpose of the distinction between definitional and nondefinitional constraints is to support terminological reasoning apart from other types of deductive inference. The :EQUIVALENT sentences are assertions used in nonterminological inference.
:IFF-DEF - The value of this keyword argument should be a KIF sentence that "completely defines" the class. This is just like the :DEF keyword, except that the sentence specifies both necessary and sufficient conditions for membership in the class. For example:
(define-class female-person (?person) "female humans" :iff-def (and (human ?person) (= (gender ?person) female)))
specifies that
(<=> (female-person ?person) (and (human ?person) (gender ?person)))
and that this fact is the definition of (what it means to be) a female-person.It is not legal use both the :DEF and :IFF-DEF keywords in the same definition.
:IMPLEMENTATION - The value of this keyword argument should be a symbol (usually a keyword) which names the target representation system in which the definition should be defined. This is independent of the theory in which the defined is defined. If the :IMPLEMENTATION argument is not supplied, the current implementation is assumed (see IN-IMPLEMENTATION.)
:ISSUES - The value of this argument should be a Lisp "tree" of strings. The tree can be either a string, or a list of strings, or a list of (<label> <any-lisp-object>) pairs, where <label> is a string or symbol that names the type of the comment. For examples,
:issues ("This is a footnote about FOO." (:example (= (foo ?x) (inverse (bar ?x)))) ("Why not do it this way?
:SUFFICIENT - The value of this keyword arg should be a KIF sentence that specifies sufficient constraints for the relation to hold for a given binding of the <var> arguments. The :SUFFICIENT sentence thus specifies conditions under which the relation may be inferred; it may be used as a backward chaining deductive rule whose consequent is an instantiation of the relation.
A list of sentences may be supplied instead of a single sentence; Ontolingua will automatically construct a disjunction of all the supplied :SUFFICIENT sentences in this case.
:THEORY - The value of this keyword argument should be a symbol which names the theory in which the definition should be defined. If the :THEORY argument is not supplied, the current theory is assumed (see IN-THEORY.)
:DEFAULT-SLOT-VALUES, :INSTANCE-SLOTS, and :CLASS-SLOTS - These keyword arguments are discussed below, under "Alternate Slot Syntax."
SECOND ORDER SENTENCES
Within the :AXIOM-DEF there may be sentences that specify properties of the class being defined, denoted by CLASS-NAME, rather than properties of instances of the class, denoted by the <var> variable. Such sentences use the names of relations as arguments to special "second order" relations.
In the following example, human is defined as a subclass-of animal, which was previously stated in a first-order style above.
(define-class human (?human) "The human animal." :axiom-def (subclass-of human animal))Alternate Slot Syntax
Ontolingua supports additional syntax for writing some definition sentences in a frame/slot style instead of the predicate calculus style of KIF. This additional syntax is supported via three additional definition keywords, whose associated values are lists of sentences in the following format, called a SLOT-VALUE-SPEC:
(slot-name slot-value1 slot-value2 ...)
SLOT-NAME is the name of a binary relation. The first argument to this binary-relation (the frame) is made implicit by the keyword with which the sentence is associated, and each SLOT-VALUE is a second argument to the relation.
During the translation process, Ontolingua will transform such a sentence into the equivalent KIF sentences
(slot-name frame slot-value-1) (slot-name frame slot-value-2)
These resulting sentences will be added to the :AXIOM-DEF, :CONSTRAINTS, :AXIOM-CONSTRAINTS, or :DEFAULT-CONSTRAINTS sentences depending on the keyword with which the original slot-syntax sentences are associated.
The three keywords supported in this manner are as follows:
:CLASS-SLOTS - The associated value should be a list of SLOT-VALUE-SPECs whose frames are taken to be the relation being defined. Thus, the relations corresponding to the slot names are second-order relations (see "Second Order Sentences" above.) Sentences translated from :CLASS-SLOTS are added to the :AXIOM-DEF sentence.
:INSTANCE-SLOTS - This keyword is only valid in the definition of unary relations (or equivalently, classes.) The associated value should be a list of SLOT-VALUE-SPECs sentences whose frames are taken to be individuals for which the unary relation holds. Sentences translated from :INSTANCE-SLOTS are added to the :CONSTRAINTS sentence.
An extended slot syntax is supported for this keyword which allows values for "facets" of slots to be provided. Within the SLOT-VALUE-SPECS any of the slot-values may be a list of the form:
(facet facet-value1 facet-value2 ...)
Ontolingua will transform these into the equivalent KIF sentences:
(facet relation slot facet-value1) (facet relation slot facet-value2)
:DEFAULT-SLOT-VALUES - This keyword is only valid in the definition of unary relations (or equivalently, classes.) The associated value should be a list SLOT-VALUE-SPECs sentences whose frames are taken to be individuals for which the unary relation holds. Sentences translated form :DEFAULT-SLOT-VALUES are added to the :DEFAULT-CONSTRAINTS sentences, and will therefore hold for each instance of the class until and unless a contrary assertion is made about that instance.