John F.
Sowa
Conceptual Graphs for a Data Base Interface
Abstract: A data base system that supports natural language queries is not really natural if it requires the user to know how the data
are represented. This paper defines a formalism, called conceptual graphs, that can describe data according to the user’s view and ac-
cess data according to thesystem’s view. In addition, the graphs can representfunctional dependencies in the data base and support in-
ferences and computations that are not explicit in the initial query.
Introduction
Historically, data base systems evolved as generalized been shown by the TORUS system at the University of
access methods. Theyaddressedthenarrow issue of Toronto [2], which uses a representation similar to the
enabling independent programs to cooperate in access- one developed here. The second point has been investi-
ing the same data. As a result, most data base systems gated in a growing body of research in computational
emphasize the questions of how data may be stored or linguistics and artificial intelligence; for a survey of that
accessed, but they ignore the questions of what the data work, see the article by Heidorn [3] and the collections
base means to the people who use it or how it relates to of papers edited by Schank and Colby [4] or Bobrow
the overall operations of a business enterprise. When a and Collins [ 5 ] . The third point is the principal topic of
business converts from a manual system to a computer- thispaper: Besides representing logical relations in a
ized system, the computer cannot adapt itself to the users’ conceptual graph, the system must use the graphs toper-
view of the world, and the people have to learn strange form inferences that answer theoriginal question.
conventions to access theirfamiliar data. Since relational databaseshave asimpler logical
Before a computer can adaptitself to a person’s world structure than network or hierarchical systems, they are
view, that view must be described in a formalism that an important first step toward simplifying the user’s in-
thecomputercanprocess.Theconceptual graphs de- terface. Relations are a good interface for a professional
fined in this paper provide a formal notation that serves programmer, and they can also be used by nonprogram-
asan intermediary betweenthe human andthecom- mers who are familiar with the data base conventions.
puter: the graphs describe themeaning of data according Several query languages, such as SEQUEL [6], SQUARE
to the user’s view, but they are also associated with pro- [7], and Query-by-Example [8], have been designed for
cedures that can access the data according to the ma- nonprogrammerswho have beentrained in using the
chine view. When a person asks a question in ordinary data base. But casual users and even programmers who
English orother naturallanguage, the system would had not learned the conventions would require a consid-
translate the question intoa conceptual graph. Then the erable period of training before they could ask a ques-
system could search for other graphs that describe the tion.
data base and arerelevant to theoriginal question. When Figure 1 shows a sample relation in a form that might
it finds such graphs, it can use them to access the data be presented to a user of a relational query language.
and compute the answer. The name of the relation is HIRE, and its domains are
Conceptualgraphsare notintended as ameans of named EMPLOYEE, MANAGER, and DATE. Under
storing data but as a means of describing data and the the domain headings are the n-tuples for which the rela-
interrelationships. As a method of formal description, tion is true. A person familiar with the real world system
they havethree principal advantages:First, they can could probably guess that the three domains represent
support a direct mapping onto a relational data base as an employee, the manager who originally hired the em-
defined by Codd [ 11 ; second, theycanbeused as a ployee, and the date the employee was hired. But there
semantic basis for natural language; and third, they can is no information in the relation that excludes other in-
Support automaticinferencestocompute relationships terpretations, such as, for each manger, the date he first
336 that
are
not explicitly mentioned. The first point has became a manger and the first employee he hired. For a
I
JOHN F. SOWA IBM J . RES. DEVELOP.
complex data base with dozens of relations, few users MANAGER
cancorrectly guessthe meaning of every domain in
Mary Smith John Brown 9/1/10
every relation.
The meaning of a relation is called its intension, and
I Tom Jones
Mary Smith 8/8/75
the set of all the n-tuples stored in the data baseis called Figure 1 The HIRE relation.
its extension. The question of representing extensions,
accessing them, and modifying them is the familiar one
that all data base systems address. The question of rep-
resenting intensions,however,tendsto be
ignored,
p z q pzq 1 - 1-
largely because adequate formalisms and techniques for Figure 2 Examples of concepts.
handling them have not been available. For a data base
system, the three principal kinds of intensional informa-
tion are the functional dependencies, the domain roles,
supported by the underlying data base system; what the
and the constraints on domain values. In a data base re-
data mean should be described by an intensional formal-
lation, functional dependencies indicate which domains
ism at theinterface to the data.
are permissible keys and which domains are dependent
To meet these requirements, conceptual graphs are a
upon the keys; for therelation in Fig. I , EMPLOYEE is
network of concepts and conceptual relations that de-
the key domain,andthe domains MANAGERand
scribe the domain roles. Certain conceptual graphs, the
DATE are determined when EMPLOYEE is specified.
conceptual schemata and working graphs, have a super-
The domain roles indicate how the domains are related;
imposed network of functional dependenciesthatare
for Fig. 1 , the MANGER of each n-tuple performs an
mapped to the data base. To answer a user's question,
act, HIRE, the EMPLOYEE is the one who is hired,
the system assembles a working graphthathasthe
and the D A T E is when the particular act occurred. The
appropriate domain roles together with functional depen-
constraints indicate permissible values; for Fig. 1, they
denciesthatdeterminethe answer. Thenext several
would specify the expected form of a name or date, the
sections of this paper define these structures formally,
requirement that no date of hire may precede the date
present an algorithm for computing the working graphs,
the company was founded, and the constraint that no
and give an example of how the system would process a
person may hire himself.
typical question.
Besides representing intensions, the system must use
them to provide a more natural interface and to check
Conceptual graphs
the plausibility of new information that is being added.
In the theoryof conceptual graphs, thebasic primitive is
This paper defines conceptual graphs as an intensional
called a concept. It is represented by a box containing a
formalism and shows how they might be used to meet
sort label, which identifies the type of concept. For read-
the following requirements:
ability, sort labels are written as English words in upper
Familiar conventions A person who knows the forms case letters, but they could just as well be numbers or
and procedures of abusiness enterprise shouldbe computer addresses.
able to ask questions aboutit without having to learn Formally, a concept is an undefined primitive. Infor-
the peculiarities of the computer system. mally, it is a symbol that could represent anything that
Automatic inference Thesystem shouldinferrela- anyone might ever think of-an entity, action, or proper-
tions that are not storedexplicitly in the data base. ty in the real world, an abstraction, fantasy, or mathe-
NaturalnessThe intensionalformalismshouldbe matical function.Someconceptsareshown in Fig. 2.
close enough to the semantics of natural language to For those aspectsof the world recorded in the data base,
support convenientdialogue and prompting facilities. at least one concept is defined for every data base do-
Semuntic integrity The domain constraints should help main. Some concepts are more general than others: the
to keep the data base an accurate reflection of the sort label PERSON marks a more general concept than
real world. EMPLOYEE, and EMPLOYEE is more general than
MANAGER. To represent the levels of generality, the
Thesearerequirements for the user's interface;the
sort labels are ordered.
physical implementation must also satisfy other criteria,
such as speed and reliability. By separating the concep- Definition There is a set S whose members are called
tual graphs that describe the meaning of data from the sortlabels, with a partialordering 5 defined upon S.
system that stores and accesses data, the two problems The function sort maps concepts into sort labels.If a
can be addressed independently. Efficient storage alloca- and b are concepts for which sort ( a ) 5 sort ( b ) , then
tion or means of recovery after a system crash must be a is said to be a subsort of 6. 337
JULY 1 916 (:ONCEPTUAL GRAPHS
+”++”+
Figure 3 Examples of conceptual relations
subsorts: LION, TIGER, and JAGUAR are all com-
mon subsorts of F E L I N E and WILD-ANIMAL. Not
all pairs of concepts have common subsorts: NUMBER
and EMPLOYEE have nocommon subsort [ 9 ] .
Connectionsbetweenconceptsarerepresented by
conceptual relations, which are written as labeled circles
having one or more links. The links are numbered con-
BOY WALK
secutively, starting with 1; for the special case of dyadic
conceptual relations, an arrowhead pointing towards the
circle indicates link 1, and an arrowhead pointing away
IDEA SLEEP indicates link 2.
The examples in Fig. 3 show some common concep-
(b)
tual relations. The relations A G N T and P T N T have
Figure 4 The conceptual graph ( a ) is well-formedwhile the been adaptedfromcase grammar [ 101: AGNT(or
graph at ( b ) is ill-formed. A G E N T ) links a concept representing an animate entity
to a concept of an action that the entity is performing;
PTNT (or PATIENT) links an action to an entity that
is being acted upon. Besides linguistic cases, conceptual
HIRE PERSON relationscan represent mathematical or computational
notions: RES (or RESULT) links a concept represent-
ing a function to a concept representing the result of the
DATE HIRE EMPLOYEE with
function.
As sort labels,
choice
the of labels for
conceptual relations hasno formal significance in the
Figure 5 Two well-formed conceptual graphs theory, but a readable set should be chosen for a given
application [ 1 1 1.
Definition A conceptualgraph is a finite, connected,
undirected, bipartite graph with nodes of one type called
Since a concept is not a set, one concept cannot be a
concepts and nodes of the other type called conceptuul
subset of another concept. Yet subsorts and subsets are
relations. Aconceptualgraph may consist of a single
closelyrelated: If u is a subsort of b, as the concept
concept,but it cannothaveconceptual relationswith
EMPLOYEE is a subsort of theconceptPERSON,
then the set of all things to which a applies is a subset of unattached links.
the things to which b applies. Since a concept is an in- Intheoperations defined uponconceptualgraphs,
tensional symbol,notanextensionalset of things, the links may be attachedordetached from concepts, but
principle of extensionality does nothold: Twoconceptstheyare permanentlybound to conceptualrelations.
with different sort labels are distinct, even if theyrepre-Only dyadic conceptual relations are used in the exam-
sentexactlythesame things in the data base. Even if ples in this paper,butthe definitions andtheorems allow
everyperson mentioned in thedatabasehappensto bearbitrarily many links.
an employee, the meaning of employee includesaddi-
Definition A conceptual relation has a certain number of
tional relationships beyond those that are true for per-
links, which may be attached to concepts. If a concep-
sons in general.Following are some examples of the
tual relation has n links forsome integer n 3 1 , it is
ordering of sort labels:
called n-udic, and its links are numbered 1 , . . ., n.
MANAGER < EMPLOYEE < PERSON
Formation rules
< ANIMAL < ENTITY
Not all combinations of concepts and conceptual rela-
H I R E < ACT < EVENT, DATE < TIME
tions are meaningful; the data basedesigner must have a
Ordering symbols other than 5 are defined in the ob- way of declaring certain combinationswell-formedand
vious way; i.e., x < y if and only if x 5 y and x # y . other combinations ill-formed. Figure 4 (a) shows a well-
formed conceptual graph, which represents the phrase
Dejinition The concept c is called a common subsort of
“boy walking.” The graph in Fig. 4 ( b ) is an ill-formed
the concepts a and b if sort ( c ) 5 sort ( a ) and sort ( c )
combination, taken fromChomsky’s famous example
5 sort ( b ) .
“Colorless green ideassleep furiously.”
FIXED-BINARY is common a subsort of F I X E D Well-formed conceptualgraphsare like well-formed
338 andBINARY.Twoconcepts may have many commonformulas in symbolic logic or grammatical sentences in
IOHN F. SOWA I B M J. RES. DEVELOP.
English. They are not necessarily true or even plausible,
HIRE PERSON
butthey ruleoutsome nonsensicalcombinations. To
distinguish the well-formed conceptual graphs, there are /\
formationrules thatgenerate all of the well-formed
graphs but none of the ill-formed ones. The data base
designer must prime the system with a starting set of
conceptual graphs, which are all well-formed by defini- Figure 6 A join of the graphs in Fig. 5
tion. Every other well-formed graph is generated by re-
peated applications of four basic rules.
Assumption The system has a collection of conceptual
graphs that are defined as well-formed. Every graph con-
sisting of a single concept is well-formed. All other well-
formed conceptualgraphsare obtainedbyrepeated
application of the following rules:
1. Copy An exact copy of any well-formed conceptual
graph is well-formed. Figure 7 A restriction of the graph in Fig. 6.
2. Detach All connected graphs that remain when any
conceptual relation is removedfrom a well-formed
conceptual graph are also well-formed.
3. Restrict If a is a concept in a well-formed conceptual
graph u, then for any sort label s 5 sort ( a ) ,the graph
obtained by substituting s for the sort label of a is
well-formed.
4. Join Let a be a concept in a well-formed conceptual
graph u and b be a concept in a well-formed concep-
tual graph w , where u and w may be the same graph. Figure 8 A join of two concepts in the same graph.
Then if sort ( a ) = sort ( b ), u and w may be joined to
form a well-formed conceptual graph u by deleting a
from u and attaching to b all the links of conceptual
relations in u that had previously been attached to a.
T o illustrate the formation rules, Fig. 5 presents two
conceptual graphs that are assumed to be well-formed.
The first graph may be read as “A manager hiring a cer-
tain person,”andthe second as“An employee being
hired at a certain date.”
Since both graphs in Fig. 5 have a concept with sort Figure 9 Finalgraph obtained by detachment.
label HIRE, they may be joined by deleting one of the
concepts with label H I R E and attaching the two dan-
gling links tothe corresponding concept in theother
graph. This operation produces thegraph in Fig. 6. With an appropriate set of starting graphs, the forma-
Since two conceptscan only bejoined when they have tion rules generategraphsthat may be considered
identical sort labels, the sort label PERSON in Fig. 6 “grammatically correct.” But grammar rulesare not
would have to be restricted to EMPLOYEE, as in Fig. rules of inference: formation rules generate syntactically
7 , before it could be joined to the other concept labeled well-formed combinations; inference
rules
generate
EMPLOYEE. combinations that are trueif the assumptions are true. In
Since Fig. 7 now has two concepts with identical sort defining the rules of a formal system, a logician has vari-
labels, they may be joined by deleting one of them and ous options for assigning a construct either to the forma-
attaching thedangling link to the otherone. tionrules ortothe rules of inference. Sorted logic
According to the detachrule, one of the two copiesof [ 12, 131 differs from the standard predicate calculus by
PTNT in Fig. 8 may be removed to form the graph in incorporating sorts into the formation rules; as a result,
Fig. 9. This graph may be read “A manager hiring an it often has simplerformulas and shorter proofs. The
employee ata certain date.” sort labels on concepts make the formation rules more 339
JULY 1976 CONCEPTUAL GRAPHS
Derived formation rules
PHYSICAL-BEING
The basic formation rules operate on one concept at a
time; derivedformationrules aresequences of basic
operationsthatdo acomplexderivation in onestep.
ANIMAL There are two reasons for having the derived rules: the-
oretically, they can simplify the definitions and shorten
the proofs; and practically, the combined operations can
Figure 10 Samplestartinggraphs.
eliminateintermediate computationsand improve sys-
temperformance. The first derived rule is projection,
which extracts a subgraph from a conceptual graph and
COLOR SLEEP
then restricts some of the concepts in it. Another de-
rived rule is the joinof two graphs on a common projec-
Figure 11 Graph derived from Fig. IO. tion, which allows the graphs in Fig. 5 to form the graph
in Fig. 9 in a single step. A special case of this rule is
complex, but they sharply reduce the number of alterna- maximal join, where the common projection is as large
tives to be considered in performing inferences. as possible; maximal joins are importantin the algorithm
T o show how the formation rules impose constraints for answering a data base query.
on a derivation, take the two graphsin Fig. 10 as a start-
ing set.SinceANIMAL < PHYSICAL-BEING, the Definition A well-formed conceptual graph u is a projec-
sort label PHYSICAL-BEING in the first graph can be tion of a well-formed conceptual graph w if u can be de-
restricted toANIMAL.Thepthetwographscanbe rived from w by zero or more applications of detachment
joined on ANIMAL to form the graph in Fig. 1 1 . and zero or more applications of restriction, but no ap-
plication of join.
This graph can be further restricted toform graphs for
the sentences “A brown beaver sleeps” or “A purple Eachdetachmentreducesthesize of the resulting
cow sleeps.” But since IDEA is not a subsort of ANI- graph by at least one conceptual relation. It may also
MAL nor of PHYSICAL-BEING, there is no way of cause the graph to become disconnected, and thereby
deriving “A green idea sleeps.” The formation rules thus create several well-formed conceptual graphs, each with
eliminatenonsensicalthings like green ideas, but they fewer concepts and conceptual relations than the origi-
allow conceivable, nonexistent things like purple cows. nal. Each restriction leaves the number of concepts and
The rules for handling subsorts impose the same kinds relations unchanged, but it makes the graph more spe-
of constraints as the semantic markers used by Katz and cialized. None of the formation rules allow a restriction
Fodor [ 141. The partial ordering of subsorts, however, tobeundonetoreturn to the original, more general
is moregeneral than semantic markers: besidesbinary graph.
distinctions, a partialordering may include arbitrary
trees and lattices. Theorem If u is a connected subgraph of a well-formed
The rules presented so far place no restrictions upon conceptual graph w , then u is a projection of w that can
the starting set of well-formed conceptual graphs: any be derived from w solely by the rule of detachment.
combination of symbols that anyone might ever think of
Proof Apply the rule of detachment to each conceptual
could be represented as a conceptual graph. In setting
relation of w that is not in u. All the graphs that remain
up a query facility, the data basedesigner would select a
are, by definition, projections of w. Since u is connected
set of concepts for all the domains in the data base, aux-
and none of its conceptual relations were detached, u
iliary concepts for real world characteristics related to
mustbe wholly contained within one of those projec-
thosedomains,andotherconceptsfor functions that
tions. That projection cannotcontain any conceptual
might be applied tovalues in the domains. Since few
relation not in u since all of them were detached. Fur-
data base designers aretrained linguists, a practical sys-
thermore, it cannot contain any concept not in u since
tem would have to be primed with a basic set of con-
each such conceptwould have to be attached atoconcept
cepts for commonEnglish words, a set of conceptual
of u by some conceptual relation not in u. Therefore, that
relations for linguistic cases and mathematical relations,
projection must be u.
and a set of tools and questionnaires for automating the
task of defining conceptual graphs. Much work remains If two isomorphic graphsweredrawn carefully on
to be done before the definition of a language can be transparent plastic sheets, one graph could be overlaid
reduced to filling out a questionnaire, but the purpose of on the other with a perfect match: all concepts, concep-
this paper is to present a formalism that may help to sys- tual relations, and links would line up exactly. The next
340 theorem
that
shows
job.
tematize
that a projection of a graph
be can over-
JOHN F. SOWA IBM J. RES. DEVELOP.
laid on some subgraph of the original; the matching con- Proof Since a projective origin of u in w is a connected
ceptual relations would be identical, but some or all of subgraph of w, it must bea well-formed conceptual
theconcepts in the original would correspondto sub- graph that is derivablefrom w solely by detachment.
sorts in the projection. Then to derive u, restrict each concept of the projective
origin to the concept in u to which it is mapped by the
Theorem If u is a projection of w, then there is an iso-
isomorphism.
+
morphism that maps u onto a connected subgraph w'
+
of w : if u is any concept of u, then a is a subsort of ( a ); Dejinition If u and w are well-formed conceptual graphs,
if r is any conceptual relation of u, then Y = + ( r ); and u is a projection of u, and u is a projection of w, then u is
if the ith link of r is attached to ai, then the ith link of called a common projection of u and w .
4 ( r ) is attached to C#J(ui).
Theorem If u is a common projection of u and w, then
Proof Since u may be derived from w, there must be a the projective origin of u in u is isomorphic to the projec-
finite sequence of applications of detachmentand re- tive origin of u in w.
striction, A', A', . . ., leading from w to v. Construct
two series of well-formed conceptual graphs u l , u2, . . ., Proof Twographsthatare isomorphic to u must be
and wl, w2, . . ., and a series of isomorphisms between isomorphic to each other.
them +',4 '; . .. Let u1 = w1= w , and let 6' be the identity
If two graphs have a common concept, the join rule
mappingfrom u1 to w'. Then if the ith rule Ai was
allows them to be combined by merging the two com-
detachment, perform that rule on both ui and w i to derive
mon concepts. That simple join on a common concept
vi+' and wi+', and let +"' = 4'. Or if Ai restricts some
can be extended to a join on a common projection. If
concept a to one of its subsorts b, then apply A' to ui
two graphs u and w have a common projection u , then
to derive vi+', let wi+l = w', and let 4"' ( b ) = + ' ( a ) ,
the projective origins of u in u and in w are subgraphs of
but let 4'" have the same value as +' for all other con-
u and w that are isomorphic. Therefore, u and w can be
cepts and conceptual relations in vi+'. At each stage ih
overlaid with the two projective origins matched up ex-
the derivation, +'*' will be an isomorphism from vi+' to
i+l actly. Each concept in the two subgraphs can then be
11% satisfying the conditions of the theorem if the con-
restricted to thecommon subsort in their common
ditions held for i. Since they hold for 1, they must, by
projection u.
induction, hold for all i. The conditions must therefore
hold for the last members of the series, which are u, w ' , Theorem If u is a common projection of u and W , then u
and 4. and w may be joined on the common projection u to
form a well-formed conceptual graph by the following
This theorem implies that a projectim of a conceptual
steps:
graph can be overlaid on some subgraph of the original.
That subgraph is called a projective origin of the projec- 1. Let u' be a projective origin of u in u, and let w' be a
tion. A given projection may have more than one possible projective origin of u in w.
projective origin. Suppose, for example, that the concept 2. Restrict each concept of U' and w' to the sort label of
c was a common subsort of several different concepts in the corresponding conceptof u.
a graph u ; then the conceptc by itself would be a projec- 3. Detach all conceptual relations of u'.
tion of u, and every concept in u of which c was a sub- 4. Join each concept of u' to the corresponding concept
sort would be a projective origin of c. of w'.
Dejinition If u is a projection of w ,then a subgraph of w The concepts and conceptual relations in the resulting
that is isomorphic to u under the conditions of the pre- graph are the union of all those in u , those in u - u ' , and
ceding theorem is called a projective origin of u in w.
those in w - w'.
The definition of projection would allow the detach-
Proof To prove that the resulting conceptual graph is
ments and restrictions to be applied in any order. The
well-formed, it is necessary to show that the same graph
next theorem shows that the same projection could be
couldbeobtained from u and w byapplying only the
derived in a standard order that first applies all detach-
basic formation rules. First, the acts of restricting con-
ments and then applies all restrictions.
cepts in u' and w' to their corresponding concepts in u
Theorem If u is a projection of w , then u can be derived are legal because each concept in a projection is a sub-
from u' by first detaching conceptual relations to form a sort of the corresponding conceptin any of its projective
projective origin of u in w and then performing a series origins. Second, the act of detaching all the conceptual
of restrictionsonconcepts of the projective origin to relations of u' at once produces the same collection of
derive u. well-formed graphs obtained by detaching them one at a 341
JULY 1976 CONCEPTUAL GRAPHS
sponds to a in a projective origin of u in u, and the con-
HIRE EMPLOYEE cept c that corresponds to a in a projective origin of u
in w.
pr"yGy7
Figure 12 A maximal common projection of graphs in Fig. 5 . A kernel of a common projection is important because
a basic algorithm for computing common projections is
to start with a kernel and then build it up into larger
graphs byadding otherconceptsandconceptual rela-
PERSON tions.
Dejinition Let u be a common projection of u and w with
a kernel k = ( u , 6, c ) . Then u is called a maximal com-
mon projection with respect to the kernel k if there is no
graph t with the following properties: t is acommon
Figure 13 A maximal join with a different kernel. projection of u and w with thesame kernel k, u is a
projection o f t , and u is not identical to t .
Dejinition Let u be a maximal common projection of u
time. Finally, the acts of joining the concepts from u' and w with respect to the kernel k = ( a , 6, c ) . Then a
and w' are legal because they have been restrictedto maximul join of u and w with respect to k is a graph ob-
identical subsorts. The derivation is therfore equivalent tained by joining u and w on the common projection u
to a sequence of detachments, restrictions, and simple under the condition that the concept b in u is joined to
joins. the concept c in w.
The first set of restrictions had the effect of replacing u'
Figure 12 is a maximal common projection of the
and w' with copies of u. Since no detachments were per-
graphs in Fig. 5 with respect to akernelconsisting of
formed on any conceptual relations of w , the resulting
the three concepts labeled HIRE: one in each of the
graph before the joins must have been the union of u
graphs of Fig. 5 and the one in Fig. 12. By a maximal
with MJ - w'. Since the original graph u was connected,
join on this graph, Fig. 9 could be derived from Fig. 5 in
every conceptand conceptual relationof u - u' must have
one step.
been connected to some concept of u' by conceptual re-
A single conceptMANAGER would alsoform a
lations not in u'. Therefore,the final series of joins
maximal commonprojection of thesametwographs,
would result in combining the concepts and conceptual
with the kernelcontaining the concept labeled MAN-
relations of u - u' with those of the union of u with w - w'.
AGER in the first graph of Fig. 5 and EMPLOYEE in
When two graphs are drawn on transparent sheets, a
the secondgraph. Figure 13 showsthecorresponding
joinon acommonprojectioncouldbeillustrated by
maximal join; this join cannot be extended as far as the
covering part of one graph with part of the other graph.
two concepts H I R E becausetheconceptual relations
Overlapping conceptual relations have to match exactly,
AGNT and PTNTare different. Thederived graph
but overlapping concepts are restricted to common sub-
may be read as "A manager who hired a person was
sorts.
hired at a certain date." As this exampleshows,two
Dejinition If u and w are joined ona common projection graphs may have several different maximal joins.
u , then all conceptsand conceptualrelations in the
projective origin of u in u and the projective origin of u Values and quantifiers
in w are said to be covered by the join. In particular, if The concepts described so far are generic concepts that
the projective origin of u in u includes all of u, then the may represent anything of a given sort. To describe ac-
entire graph u is said to be coveredby the join. tual information about particular entities or eventsin the
data base, concepts must be associated with particular
The notion of covering is important for answering a
instances. A concept behaves like a variable in the pred-
data base query. The user's original question is trans-
icate calculus: the sort label is analogous to a subscript
lated into a query graph, and the system generates an
in sorted logic or a data type in a programming language;
answer graph whose join with the query graph covers it
it determines the kind of entities, events, or properties
completely. The next three definitions introduce maxi-
that the conceptmay represent. The concept NUMBER,
mal joins, which are used in deriving the answergraph.
for example, may represent any number; to specify a par-
Dejinition If u is a common projection of u and w ,then a ticular number, it must be assigned a value. Figure 14
kernel of the common projection consists of three con- shows concepts with values specified by placing either a
342 cepts:anyconcept a in u , theconcept b thatcorre- literal or a propernameafterthesort label.
JOHN F. SOWA IBM J. RES, DEVELOP,
A concept may be indefinite, constant, or quantified.
An indefinite concept has justa sort label inside the box,
pG&Gq F I V
a constant concept has a specified value, and a quanti- Figure 14 Concepts with specified values.
fied concept hasa logical quantifier. Since valuesand
quantifiers are mutually exclusive, they are both written
in the same position in the box. The symbol V represents
a universal quantifier and 3 an existential quantifier.
Besidesrepresentingquantifiers, conceptual graphs
/’
NUMBER:3 -__
--.
\
‘\ \
must indicate their scope. For each existential quantifier
//’ \
that depends on one or more universal quantifiers, dot- //
\
\
/ \
ted lines may be drawn from the universal quantifiers to \
the existential. Figure 15, forexample,representsthe
proposition
Figure 15 Quantified concepts with lines indicating scope.
(VX) ) ( z = difference (x, y ) 1.
( ~ y(32)
Notethatthe variablenamesx, y , and z have disap-
peared from Fig. 15. The purpose of named variables in
Dejinition A functionaldependency in a conceptual
logic is to indicate repeated uses of the same variable by
graph is a set of function links from one or more con-
repeated occurrences of its name. In conceptual graphs,
cepts called sources to a concept called the target of the
however, avariable appears as a box, and all uses of
functional dependency. Associated with each functional
that variable are linked to the same box. By eliminating
dependency is an access procedure. Whenever all the
named variables, the graphs eliminate accidental varia-
sources of afunctional dependencyhavevalues,the
tions caused by different choices of names and avoid the
access procedure can computea value for the target.
need to rename variables in substitutions.
In theordinary predicate calculus,functionaldepen-
Dotted linesshowing thescope of quantifierscan
dencies are seldom stated explicitly. In a system for ac-
express finer distinctions than thestandardpredicate
cessing data bases and other computational facilities, a
calculus. For example, considera predicate P ( x , y, z, w)
statement that one variable depends on another is not as
with x and y universally quantified, z existentially quanti-
useful asanaccessprocedurethat can computethe
fied depending only on x, and w existentially quantified
dependency upon request. Thetechnique of combining a
depending only on y. Both of the following formulas in
logical notation with procedures that evaluate functions
standard logic introduce irrelevant dependencies of u’ on
has great generality: Woods [17] developed such a tech-
xorzony:
nique for his question answering system, Winograd
[ 181 suggested a method that he called procedural at-
tachment in his discussion of frame systems, and Weyh-
rauch and Thomas [ 191 used a similar method of seman-
The dotted lines overlaid on a conceptual graph repre- tic attachment in their proof checking system.
sent only those dependencies that are logically neces- Plural nouns normally havesets of entitiesastheir
sary [ 151. values. For the question “What employees werehired
The ordinary existential quantifier 3 states that there by Jones?”theexpectedanswer would be a set. To
exists one or more entities that meet the given condi- answer such questions, concepts may have sets as val-
tions. For the graph in Fig. 15, the result of the function ues, and a new symbol, E-set, is introduced to represent
is unique; therefore, the unique existential quantifier E’ “Thereexists a set of sort. . . .” This quantifier is
may be used to state that there exists exactly one value weaker than the ordinaryexistential because it allows
of z for each pair of x and y . In general, a function of n empty sets as values of the concept. Since E’ defines an
arguments is determined whenever theunique existential ordinaryfunction, it cansupport functionalcomposi-
E’ depends on n universal quantifiers. Since the dotted tions; E-set, however, cannot support the same composi-
lines then define a function,they are called functional tionsbecause it would create fallacies suchasthe
dependencies [ 161. The basic conceptual graph repre- connection trap [201.
sents the domain roles, and the functional dependencies Another refinement thatincreasestheexpressive
are a separate graph structure overlaid ontop of the power of the notation is the possibility of introducing
original graph; the two structures represent complemen- compound sort labels, which are themselves conceptual
tary information, and eachis necessary for a full descrip- graphs,Forthenonrestrictivephrase “All elephants,
tion of the data baserelations. which have trunks,” the quantifier “all” applies only to 343
JULY 1976 CONCEPTUAL GRAPHS
k"""
To data base sort, uulue, and quant, definitions and theorems can re-
+ MANAGER:El fer to the components of a concept without mentioning
the way they happen to be drawn on paper or represent-
ed in computer storage. Although diagrams are impor-
tant for helping people to visualize conceptual graphs,
I
the formalism should not depend on some artist's draft-
t ing techniques.
HIRE
\ I
X""""""""" Conceptual schema
To data base A conceptual schema is a conceptual graph that has cer-
tain combinations of quantifiers andfunctionaldepen-
Figure 16 Conceptual schema for the HIRE relation.
dencies. It is a mediator between the conceptual graphs
and the other facilities in the computer system: its un-
derlying structure is a conceptualgraph,butitsfunc-
the sort ELEPHANT; but in the restrictive phrase "All tional dependencies form a superimposed structure that
elephants that perform in circuses" the quantifier applies provides a direct mapping to the data base. To answer a
to the sort ELEPHANT-THAT-PERFORM-IN-CIR- user's question, the system would find or construct a
CUS. Although a sorted logic could use roundabout schema having functional dependencies that would com-
paraphrases toavoid adding new sort lables, Altham and pute the desired answer. The computed values may be
Tennant [2 1] developed a notation for sort expressions simple scalars if the target of a functional dependency
that reflects thestructure of the original English sen- is quantified with E', or they may be sets if it is quanti-
tence. For this example, the compound sort expression fied with E-set. The ordinary existential quantifier 3 is
would itself include an existential quantifier on CIR- not used in a schema because it does not define a unique
CUS. function.
Altham and Tennant's approach could be adapted to
Dejinition A conceptual schema is a well-formed con-
conceptual graphs by making the set of sort labels open-
ceptual graph having one or more functional dependen-
ended and accepting graphs that meet certain conditions
cies. If the concept c is a source of one or more func-
as new labels. Formalizing thatapproach,however,
tional dependencies, but not a target of any dependency,
would require considerable discussion that is beyond the
then quant(c) = V. If c is a target of one functional de-
scope of this paper. Values and quantifiers on concepts
pendency and a source of one or more functional depen-
are defined formally by introducing two selector func-
dencies, then quant(c) = E'. If c is a target but not a
tions, value and quant, which apply to a concept and re-
source, then quant(c) is either E' or E-set. No concept
turn whatever value or quantifier is written inside the
may be the targetof two or more functional dependencies.
box.
All other concepts in the schema are indefinite and are
Assumption The two functions value and quant may be called selectors.
applied to any concept e. If both ualue(c) and quant(c)
For a relational data base, the relations are described
are undefined, then c is indefinite. If ualue(c) is defined,
by conceptual schemata. If a relation is in Codd's third
then c is constant. If quant(c) is defined, then c is
normal form [221, it has a key consisting of one or more
quantified. These two functions obey the following rules:
domains, all other domains are functionally dependent
No concept is both constant and quantified: for all e , upon the key, and there are no transitive dependencies.
either uafue(c)or quant(c) is undefined. For such a relation, the conceptual schema would have a
quantified concept for each domain as well as selector
Whenever quant (c) is defined, its value is one of the
conceptsand conceptualrelations thatdescribethe
four symbols {V, 3, E', E-set}.
domain roles. In the relation HIRE, for example,the
There is a function permissible, which defines a set of key domain EMPLOYEE is universally quantified, the
permissible values for a concept with a given sort la- conceptsforthe nonkeydomains MANAGER and
bel: if c is any constant concept, then uulue(c) must DATE have the quantifier E', and the selector concept
be in the set permissible (sort(c) ) . HIRE is indefinite (Fig. 16). Attached to the two func-
tional dependencies are the access paths for some data
If s and t are sort labels for which s 5 t , then permissi-
base relation.
b l e ( ~is) a subset of permissible(t).
Many relations and functions have more than one set
Note that theformal definitions are independent of the of key domains. For such relations, the system needs a
344 box and circlenotation. By using theselector functions separate schema for every possible set of keys. Differ-
JOHN F. SOWA 1BM J . RES. DEVELOP.
""""""""""""""~
ence is a function with three possiblekeys: in normal /'
use, the two arguments are keys that determine the re-
sult, but with either argument and the result, the other
argument is determined. In order to compute any of the
three values, given the other two, the system would need
three schemata: besides Fig. 15, it would eed a schema
P
that showed argument 1 functionally dependent on result I
and argument 2 , and another schema that showed argu-
ment 2 functionally dependent on result and argument 1 . Figure 17 Conceptual schemata for the STOCK relation.
The system would select the appropriate schema for a
given problem, depending on which values were speci-
fied and which were to be determined. Since the algo-
rithms for a function and its inverse are usually quite possible assumptionand also theleast interesting. In
different, each of thethreeschemata would haveto most practical applications, a relation has a key of less
specify a different procedure. than n domains and the nonkey domains have unique
The conceptual schema for difference illustrates the values for each combination of values for the key do-
use of schemata for representing functions that access a mains. When a target concept has the unique existential
procedure instead of a stored file. The greater-than rela- E', targets and sources may be joined to form intricate
tion,for example, has infinitely many entries,but it paths of functional dependencies to answercomplex
could be evaluated by a simple procedure; its conceptual questions. The selector conceptsin a schema are like the
schema would look like a data base schema, but its func- knobs and indentations on the piecesof a jigsaw puzzle:
tion links would beattachedto a procedure [23]. As they determine the ways in which a schema may be joined
this example illustrates,a conceptual schema can pre- tootherschemata.Intheextremecase,the analogy
sent the same interface to the user for either a computed with a jigsaw puzzle is complete; the schematafit togeth-
or a stored relation. er in only one way to answer a fixed number of possible
For some data base relations, all domains are part of questions. In the general case, there is an endlessvariety
the key. The STOCK relation, for example, is a many- of combinations;theselectors match concepts in the
to-manyrelation betweenpartsandthe supplierwho user's question to determine the selection of schemata
stock them; each supplier may stock multiple parts, and required to answerit.
each part may be in the stock of multiple suppliers. This Inthe SPARc/DBMS approach [24], thetermcon-
relation has two domains, both domains are part of the ceptual schema refers to a complete description of all
key, and there are no other domainsfunctionally depen- the logical relations in the entire data base; it is a de-
dent on the key. T o place universal quantifiers on both scription of the user's view at a conceptual level rather
domains in the schema would be inaccurate because it than a description of the system's view of thedata
would imply that all suppliers stock all parts. Instead, asstored.Since a conceptualschemaas defined in
two schemata, as in Fig. 17, are needed: one says that this paperdescribes onlya part of thedatabase,it
for eachsupplier there exists a set of parts, and the other would correspondto a conceptualsubschema in the
says that for each part there existsa set of suppliers. SPARc/DBMS terms.Exceptfor thisdifference in ter-
The quantifier E-set includes the possibility that the minology, the s P A R c / DBMS approach is compatible
set may be empty. Some suppliers, for example,may not with the theory developed in this paper. In fact, the for-
stock any parts at the presenttime. Whenever a domain malism forconceptualgraphs and schemata may be
Y is functionally dependent on domain X , e.g$ X + Y , considered as a proposed description language for
the inverse function f" determines a set of values in s P A R c / D B M s , which as yet has not developed a formal
X (possibly empty) for each value in Y . For the HIRE notation.
relation, D A T E is functionally dependent on EM- As in the s P A R c / D B M s approach,thefirststep in
PLOYEE; therefore, for all dates, there exists a possi- defining a data base is to develop a formalized model of
bly empty set of employees hired onthatdate.Since an enterprise, with a list of all the entities and relation-
this fact is implied by the schema in Fig. 16, the system ships to be represented. For eachrelation to be stored in
could either have a separate schema for the inverse, or it the data base, the data base designer would define one or
could have a mechanism for deriving an inverse schema more conceptual schemata to represent the roles of the
when necessary. entities and the functional dependencies between them.
Any relation over n domains can be characterized by H e would then map the access procedures to internal
a conceptual schema having n - 1 source concepts anda paths in the data base, and he would specify a domain in
target concept quantified with E-set. This is the weakest some relation for each quantified concept. If a schema 345
JULY 1976 CONCEPTUAL GRAPHS
had n quantified concepts, the mapping would specify n valuestrue,false,possible, unlikely, etc. MODE is a
different domains in the data base, possibly in different dyadic relation that links SITUATION, whose value is
relations. The formationrules forconceptualgraphs a conceptual graph, to TRUTH-VALUE, whose value
could then be used to form the schemataof derived rela- states whether the graph is true or false. Then all Boo-
tions: an equal-join of twodatabase relations would lean connectives are represented as concepts of func-
correspond to a join of their schemata, and a projection tions that take truth values as arguments and produce
of a relation would correspondto aprojection of its truth values as results; for any formula in the proposi-
schema. tional calculus, each Boolean connective would corre-
spond to a concept of a Boolean function, and each pro-
Boolean connectives positional symbol would correspond to a concept with
The world. according to Wittgenstein, is all that is the sort label SITUATION. With this construction, formu-
case [ 2 5 ] . For a particular aspect of the world, a data las in symbolic logic can be mapped directly into con-
base is all that is known to be the case. Wittgenstein’s ceptual graphs. Thisapproachshowsthat conceptual
view of the world as a “totality of facts,” an enormous graphs are at least as general as standard logic,but it
conjunction of elementary propositions,is a position that does not take advantage of the special properties of the
he modified in his later philosophy, but his early position graphs.
is an apt characterization of a data base: a data base is a The direct approach is based on the hypothesis that
large conjunction of propositions, all asserted to be true. conceptual graphs are isomorphic to thementalstruc-
The main advantage of relational data bases is that the tures underlying human thinking; it uses psychological
propositions arestored in a simple logical form. The and linguistic evidence to formulate the rules and com-
data base is organized as a conjunction of relations, each puter simulations to test their efficiency. This approach,
represented by a list of n-tuples for which it is known to which is discussed in a forthcoming book [ 2 7 ] ,assumes
be true; the structure is further simplified by storing the that the Boolean connectives may be represented stati-
relations in third normal form. Furthermore, the proposi- cally, as in the abstract approach, but that their primary
tions in a data base are positive; data bases seldom if role is to indicate operations for combining conceptual
evercontain negated predicatesand relations. Other graphs; the system has a current working graph, and the
Boolean connectives, such as disjunctions, are also ab- Boolean connectives specify operations on thatgraph:
sent in the data as stored, although they may be used in
a databasequery. Conditionals areneverpresent in Conjunction Join a new graph to the working graph.
stored data and are rarely used in queries, but they are
NegationDetachthe negatedsubgraph fromthe
common in stating constraints. working graph; an isolated negation would have noth-
Theseobservations imply thatthe Boolean connec-
ing to detach andwould require the creation of an arti-
tives have clearlydistinct uses in a data base system. ficial working graph.
Reaction-timeexperimentsshowthat peoplealso find
some connectives more difficult to process than others: Disjunction Create an extra copy of the current work-
disjunctions normally take more time than conjunctions; ing graph,andjoineachalternativetoone of the
negative statements take longer to interpret thanpositive copies.
statements if they are presented in isolation, but they are
Implication If some subgraph of the working graph is
just as easy to process aspositive statements if they are
a projection of the antecedent, then join the conse-
negating a presupposition that underlies the current dis-
quent to theworking graph.
cussion [ 2 6 ] . The apparent symmetry in thestandard
notation for symbolic logic is misleading because it sug- Since the topic of this paper is not psychology, but data
gests that conceptual graphsshould represent them all in bases, furtherelaboration and justification for theserules
a parallel form. In fact, conjunction is the only one that is left to the forthcoming book. Two observations, how-
is easy to represent- simply by joining graphs. To repre- ever, are worth making: first, the procedural aspect of
sent all Boolean connectives in a conceptual graph, there these rules may make them useful in a computer simula-
are two basic approaches, which may be called abstract tion; and second, they are compatible with the abstract
and direct. approach, since the working graph could be made up of
The abstract approach treats Boolean connectives as concepts of situations, truth
values, and
Boolean
functions of truth values, as in symbolic logic. It intro- connectives. People could therefore learn to do symbolic
duces two new sort labels, SITUATION and TRUTH- logic, but they would have to perform multiple “direct”
VALUE, and a conceptual relation MODE. A concept steps for each “abstract”operation.
labeled SITUATION may haveconceptualgraphsas For answering data base queries, the system could use
346 values,
and
one labeled TRUTH-VALUE may have both direct operations forcombining graphs and abstract
JOHN F. SOWA JULY 1976
representationsfor Boolean connectives. If theuser’s infer what relations anddomainsare involved. Many
query contained Boolean connectives, they would initial- natural language systems can answer this type of ques-
ly be translated into the abstract style. But to determine tion because the required domains are in a single data
what data base relations should be accessed, the system base relation; the REQUEST system described by Plath
would rely upon operations for directly combining con- [28] and Petrick [29] supports a natural syntax for such
ceptual schemata. Since the abstract approach does not questions. Queries that apply a function to the data are
illustrate the novel features of conceptual graphs,the also easy to handle if the user’s question specifies the
remainder of this paper concentrates on techniques us- function by an appropriate keyword, such as “average”
ing direct operations. or “total.” Queries that combine data from two or more
relations can be handled if the system designer antici-
Answering a query
pates the form of the question by providing a macro or
Since the logical structure of a data base has sucha sim- procedure for answering it. Butconceptual graphs are
pleform, a special algorithm for answering data base designed for the more general problem of having the sys-
queries can be more efficient than a general procedure tem determine for itself what relations and domains are
for proving theorems.Whereas atheorem proverde- necessary to answera given question.
duces a general theorem, a data base system starts with If the user’s question is incomplete or ambiguous, the
facts aboutparticular entities and determineswhich enti- system may prompt him for further information; and it
ties satisfy a given relation. A typical query may have may refusetoacceptwordsorconstructionsthatit
the logical form, doesn’t understand. But in no case should the system
require the user to specify the stored relations and ac-
Find all pairs (x,y ) , for which R ( x , y , a , b, c ) is true. cess paths in the data base. Determining the required
relations is not a problem of syntax, but semantics. The
In this example, R is a relation, x and y are variables REQUEST system, for example, has a sophisticated syn-
whose values are to be determined, and a, b, and c are tax that can translate a usable subset of English into a
constants specified in the query. If R happens to be one formal notation, such as a conceptual graph or a rela-
of the basic relations around which the data baseis orga- tional query language. Heidorn’s naturallanguage pro-
nized, thelogical problem of answering this query is triv- cessor [30] would also be adequate; his internal prob-
ial, although the programming effort may be significant lem descriptions are similar in structure to conceptual
for nonrelational data bases. A major difficulty for data graphs, and his prompting technique could support a dia-
basequerysystemsoccurs when R is not one of the logue for handling complex queries. The inference prob-
basic relations but must be determined by some combi- lem arises after the natural language statement has been
nation of relations. translated into a formal notation: merely converting the
Most query languages avoid the difficulty by requiring syntax cannot addinformation; if the user did not speci-
the user to learn the files or relations in the data base fy the relations, the translated formwill not specify them
and then to state his query in terms of them. Even the either.
sophisticated systems based on relational databases, For the TORUS system [ 21, the designer must solve
such as SEQUEL, SQUARE, or Query-by-Example, require
the inference problem in advance by creating a prede-
the user to name each relation explicitly. If the query
fined network of concepts with all possible combinations
requires data from two or more relations, the sequence
that anyone might ever ask about. When the user types
of operations forcombining them can quickly exceed the
in a question, the system translates it into a query graph
abilities of anonprogrammer. Menus and on-linehelp
and attempts to match it to some part of the predefined
facilities can remind the user of the available relations
network. Associated with various parts of the network
and give him a refreshercourseon how to combine
are links to appropriate data base relations. Which rela-
them. Help facilities, however, do not make the learning
tions are required to answer a given question is deter-
problem go away; they just providea piecemeal tutorial
mined by the parts of the network that match the query
instead of a complete user’s guide.
graph.
For systems with a natural language interface, the in- For a data base with a small number of domains that
ference problem cannot be avoided. The following state-
can only be related in a fixed number of combinations,
ment, for example, is not natural English:
the predefined network is adequate. But in the general
In relation HIRE, find EMPLOYEE where MAN- case, the numberof combinations may be infinite; some-
AGER is Jones. one might ask the question “Who was the person who
hired the person who hired Jones?” where a single rela-
People never talk like that to other people. They would tion may be iterated arbitrarily many times. If the sys-
say, “Who did Jones hire?” and expect the listener to tem can join conceptual schemata as needed,it can gen- 347
IBM J. RES. DEVELOP CONCEPTUAL GRAPHS
3. The entire querygraph q is covered by a join with the
answer graph w .
4. For every concept in q that has a value, the corre-
Figure 18 A sample query graph. sponding concept in w has the samevalue.
5. For every concept in q that had a question mark, the
corresponding conceptin w has a value.
erate only those combinations required for the question
Point 1 would be satisfied if the system generates w by
at hand; otherwise, it would have to store an enormous
using the basic formation rules or the derived rules such
number of combinations, most of which would never be
as projection and maximal join. Point 2 guarantees that
used. Another weakness of the giant network is the lack
the system is sound; i.e., it will not generate incorrect
of modularity: if the data base designer wanted to add,
answers. Point 3 implies that w includes all of the do-
delete, orredefine a data base relation, he would have to
main roles and relationships of the query graph, although
change every part of the network from which that rela-
some of the concepts may be further restricted; for ex-
tion could be accessed; in an incremental approach,
ample, PERSON in the query graph may be restricted to
however, he might only have to change one schema that
EMPLOYEE or MANAGER as a result of joins with
was mapped to that relation.Athird weakness of the
various conceptualschemata. Point 4 insuresthatthe
predefined network is that it places the burden on the
answer is talking about the same entities that the user
data base designer to foresee all possible combinations
asked about. And point 5 states that w must include an
at the time he is defining the network; an incremental
answer to the question. If the original question was in-
approach would allow him to enter simple schemata and
complete or ambiguous, then it would not have a unique
let the system form the combinations. Questions of rela-
answer. In that case, the system should prompt the user
tive efficiency depend on the implementation: whether it
for further information; it should not require him to re-
is faster to search through a large graph or to copy and
state the entire question, butonly to add values or condi-
join small graphs; whether a single large graph requires
tions that are necessary to complete it.
more 1 / 0 transfersthan several small graphs;and
whether search techniques can more easily find a path
Algorithms for generating an answer graph
through a large graph or find multiple small graphs.
Before considering a general algorithm, we should look
With conceptual graphs, either the single network or
at a special case where the answer graph is easy to find.
the collection of schemata couldbeused. The recom-
Suppose someone asked the question “Who hired Lee?”.
mended approach,however, is tojoinschemataas
The query graph for this example is Fig. 18.
needed to answer a given query. For efficiency, some
The conceptual schema in Fig. 16 almost meets the
combinations that are frequently used together could be
criteria for an answer graph: a maximal join with the
included in a single schema. The value of the concept
schema for H I R E would cover the entire query graph.
AGE, for example, may be computed by finding a date
The schema does not satisfy criterion 4 or 5 , however,
of birth in the data base andcalling a procedure that sub-
because it does not have values for the concepts in the
tractstwodates;therefore,theschemathat defines
query graph having a value or a “?”. To determine val-
A G E could include access links for both the data base
ues, Fig. 18 may be joined with Fig. 16 to produce Fig.
relation andtheprocedure. Efficiency, of course, is
19. The question mark from the query graph is carried
meaninglessunless the system can answer the original
over, and the value “Lee” replaces the universal quanti-
questionandguaranteethattheanswer is correct; it
fier. ( I t thestandardpredicate calculus, a universally
must start with the query graph and determine which
quantifiedvariablemayalwaysbereplaced by acon-
schemata to join and which data base accesses to make
stant; but in a sorted logic, the replacement is permissi-
in order to compute the answer.
ble only if the sorts match. The corresponding rule for
When the user types in a question, the input analyzer
conceptual graphs implies that the systemmust check
should translate it intoa well-formed conceptual graph q
whetherLee is an employeebeforerestricting PER-
(the systems described by Heidorn or Petrick could be
S0N:Lee to EMPL0YEE:Lee in order to perform the
adaptedtodothetranslation).Everyconcept in the
join.)
graph q whose value is to be determined would be
When the target of a function is flagged with a ques-
flagged with a question mark. To determine values for
tion mark and all of its sources have values, thena value
the flagged concepts,thesystem should generatean
for the target can be computed by the access procedure.
answer graph w that meets thefollowing criteria:
Since the concept MANAGER:E’? is functionally de-
1. w is a well-formed conceptual graph. pendentonEMPLOYEE:Lee,the value for MAN-
348 2. w is true if thedatabase is correct. AGER canbeobtainedfrom the data base. Then the
JOHN F. SOWA I B M J . RES. DEVELOP.
manager’s name would be substituted for the quantifier,
and the resulting graph would satisfy all the criteria for
an answer. In a more complex case, the target of a func-
tional dependency may be flagged with a question mark,
but one or more sources may not yet have values; in that
case,questionmarks could be propagatedbackwards
t
HIRE DATE:E’
along the functionlinks to flag thesourceconcepts ?
whose values are requested. If the question marks even-
tually stop on concepts with values, then the access pro-
Figure 19 First step towards the answer graph.
cedurescan be called andtheresultsreturnedtothe
original questionmark, which came from the user’s
query.
The criticalproblem arises whenaquestion mark a potentially infinite number of questions. For example,
stops on a concept that has neither a value nor a func- “Who was the person who hired the person who hired
tion link leading to it; then there is no procedure to exe- the personwho hired Jones?” couldbe answered be-
cute or place to propagate another question mark. Such cause every schemajoined would cover part of the origi-
a state is similar to an original query graph. Figure 18, nal query graph. If the system runs out of schemata to
for example, had a question mark on a concept but no join to the graphand it still has unanswered question
function links. For Fig. 18, the answer was obtained by marks, it could use the concepts left with question marks
joining the query graph to a conceptual schema so that as the starting points for prompting the user for further
the question mark was joined to a target concept. This information. By asking for help when it runs into a dead
technique could be generalized to form algorithm A: end, the system could extend the query graph and even-
tually generate any answerderivable from the data base.
Start with the concepts on the query graph that are
The additionalrestriction for algorithmBkeeps it
flagged with question marks; join conceptual schemata
from looping, but it does not guarantee correct answers.
to the graph so that the Ragged concepts are covered
The next three definitions characterize the permissible
by targetconcepts; propagate thequestion marks
conditions for joining schemata, the schematic universe
backwards along the function links; evaluateany func-
that includes all possible schemata that may be derived
tional dependencies whose sources all havevalues;
byrepeated joins, and theset of all correctanswer
and repeat until the original question is answered.
graphs. Every answer graph may be generated by deter-
This algorithm sounds plausible, but will it always termi- mining values for the quantified concepts of some sche-
nate with a result, and will the result be the correct an- ma in the schematic universe. For the TORUS system, the
swer to theoriginal question? analog of the schematic universe is its single large con-
Unfortunately, algorithm A may not always terminate, ceptual network. For this theory, however, the schemat-
and it can generate incorrectresults. If the original ques- ic universe would never be generated in its entirety; in-
tion was incomplete, the algorithm makes no provision stead, schemata would be joined as needed to answer a
for generating prompts: instead, it keeps joiningsche- given query.
mata andpropagating question marks without ever having
DeJinition A schematic j o i n is a join either of two con-
enough values to answer them. Although every function
ceptualgraphs or of oneconceptual graph with itself
may generatecorrect results, there could be multiple
under the following conditions:
paths of function links in the data base, and the algo-
rithm might stumble upon a path that answered a ques- The join must be maximal.
tion different from the one the user asked; the user may
The result inherits all function links; the sources and
have asked for the quantity of widgets on hand, and the
target of each functional dependency in the resulting
algorithm could generate the quantity ordered.
graph are the concepts covered by the source and tar-
To keep the system from looping endlessly on unsolv-
get concepts in the original graph.
able problems,algorithm B imposes another condition
on algorithm A: every join of a new schema to the de- When an indefinite concept is joined to a quantified
veloping answer graph must cover at least one concept concept, the resulting concept has the samequantifier.
of the original query graph. This restriction keeps the
When the quantifier E’ is joined to the quantifier V,
graphs from growing too large, with branches far remote
the result has quantifier E’.
fromtheconcepts of the original query. By avoiding
remote joins,algorithm B may be unable to answer some When the quantifier V is joined to the quantifier V, the
complex queries automatically, but it could still answer result has quantifier V. 349
JULY 1976 CONCEPTUAL GRAPHS
All other joins of quantifiers (E' to E', E' to E-set, E- with the source concept of another copy of the same
set to E-set, and E-set to V) are prohibited; if this re- schema would producetheschemafor f ( f ( x ) ) . The
striction prevents a join from being maximal, then the join of the target o f f with the source concept of the
prospective schematic join is rejected. same copy would produce the schema for x = f ( x ) . A
join of the two source concepts for g would produce the
Theorem The graph that results froma schematic join of
schema for I:( x , x ) . And a join of a schema forf with a
oneortwoconceptualschemata is also a conceptual
schema for g in all possible combinations would produce
schema.
schematafor x ( f ( x ) , Y), g ( x , f ( y ) ) , and f ( g ( x , Y))
Proof This result follows from the observation that the when the target of one functional dependency is joined
properties defined for a conceptualschemaare pre- to a source of another; but it would also produce the com-
served by the conditions for a schematic join. binations { f ( x ) , g(x, y ) } and {g(x, y ) , f ( y ) } when the
sources are joined. Note that joining two copies of the
One reason for requiring the joins to be maximal is to
schema for f could not produce { f ( x ) , f ( x ) } because a
force the paths of selector concepts to coalesce when-
maximal join would cause the twoidentical function con-
ever possible; otherwise,redundantorspuriouspaths
cepts as well as the twotarget concepts to beoverlaid on
could be generated that the data base designer had not
top of each other; theprohibition against joining two ex-
intended. Since universal quantifiers are the sources of
istentials would then cause the joinbetorejected.
function links, the effect of joining two universals is to
When all universally quantified concepts in a schema
specify the same argument for two different functions or
are assigned values from the data base, then the access
for two arguments of the same function. Joining E' to V
procedures can compute values for the other quantified
specifies the result of one function as an input argument
concepts. By systematicallygeneratingvalues for all
of another. Joining two existential quantifiers is prohib-
schemata in the schematic universe, the set of all possi-
ited because two different
functional dependencies
ble answer graphs may be enumerated. If a closed cycle
would then have the same target concept, which might
of functionlinks has been created by some schematic
beassignedtwoinconsistentvalues. Therequirement
join, then the resulting schema can never obtain values
for maximal joins together with the prohibition against
for targets in the cycle and cannot lead to an answer
joining two existentialquantifiers preventsthesame
graph. A conflict may arise when a target concept has
schema from being joined more than once in exactly the
been restricted for some join; thena value computed for
same position; this restriction prevents the system from
the target may not belong to the subsort to which the
getting into a loop when it is generating an answer graph.
concept has been restricted; any graph with such a con-
The rule against joining E-set with a universal quantifier
flict is rejected [ 3 11.
prohibits sets as inputs to functions; further extensions
to the theory could allow sets as inputs, but these will Definition An answer graph is a conceptual graph ob-
not be considered in this paper. tained by assigning values to the quantified concepts of
some schema s according to thefollowing rules:
Dejinition The schemutic universe determined by a set S
of conceptual schemata is the set of all schemata ob- For each concept c in s where quant ( c ) = V, assign a
tained by the following operations: value in the setpermissible (sort ( c )) .
All schemata in S are in the schematic universe. When all source concepts of a functional dependency
Foreachschema s in theschematicuniverse, if a have values and the target does not have a value, then
schematic join of s with itself is possible,then the use the access procedure to compute a value for the
schema that results from that join is in the schematic target. Repeat as long as there is a dependency whose
universe. sources have values and target does not.
For each pair of schemata (s, t ) in the schematic uni- If some target concept remains without a value, then
verse, if a schematic join of s and t is possible, then reject the graph.
the schema that results from that join is in the sche- If some target concept c has been assignedavalue
matic universe.
that is not in the setpermissible (sort ( c )) , then reject
Since the schemata in S define functions, the schemat- the graph.
ic universe represents all possible functions that may be
Otherwise, accept thegraph as an answergraph.
derived by composition of the functions in S . As exam-
ples, let f ( x ) and g ( x , y ) be functions defined by sche- Theanswergraphsare all well-formed conceptual
mata (cf. Fig. 15 for a diagram of such a schema). Then graphsbecause they are simply schemata with values
350 a schematic join of the target concept of theschemaforf assigned. The questionof whether the answer graphs are
JOHN F. SOWA IBM J. RES. DEVELOP.
all true depends on the adequacy of the original set of If w is a working graph for q, antd s is a schema in S ,
conceptual schemata. Each answer graph is a statement then the result of a schematic join either of w with it-
of some relationshipsbetween entities recorded in the self or of w with s is also a working graph for q, pro-
data base; if the stored data were correct and if each of vided that no concept that has a value is joined to a
the original schemata correctly stated functional depen- concept with a quantifier E' or E-set, no concept that
dencies, then their joins would also state a correct func- has a value is restricted to a subsort for which the val-
tional dependency. Possible errors could arise because ue is not permitted, and all values and question marks
some combination of schemata might cause the selector in w are copied over to the corresponding conceptsof
concepts (the indefinite concepts such as H I R E in Fig. the resulting graph(some universalquantifiers may
16) toform unexpected pathsthatare not true.The therefore be replaced with values).
selector concepts are necessary to distinguish different
If w is a working graph for q and the target of some
domain roles and to select the correct schemata for an-
functional dependency f in w has a question mark,
swering a given query. In order to avoid undesired com-
then the graph obtained by adding question marks to
binations,however, the number of selectors shouldbe
every source off that does not have a value is also a
kept to the minimum necessaryto distinguish thedo-
working graph for q .
main roles. An important topic for further study is a set
of guidelines to help data base designersdefine schemata If w is a working graph for q, all sources of some func-
that avoid such combinations. tional dependency f in w have values, and the target of
If the data base hasa set of conceptual schemata that f does not have a value, then the graph obtained by
rule outincorrect combinations,then thesystemcan evaluating the access procedure for f , replacing the
answer a user's question simply by picking the correct quantifier on the target concept with the value,and
answer graph. Unfortunately, there are too many possi- erasing the question mark on the target (if present) is
ble answer graphs tolet the system generate them one at also a working graph for 4.
a time and check them against the query graph. There-
fore, the system must be more selective and join only The working graphs are steps along the way towards
those schemata that have a good chance of leading to a answering a query. The following theorem shows that
satisfactory answer graph. The next four definitions de- when all the quantified concepts of a working graph have
scribe an algorithm that avoids incorrect combinations been given values, the resulting values are the same as
and uses a set of preference rules as a heuristic guide for those obtained from some answer graph. The theorem is
speeding up the search. generalenough to includealgorithms that permit joins
arbitrarily remote from the original query graph as well
Dejinition A querygraph is a well-formed conceptual as algorithms that require each join to cover at least one
graph with the following properties: it contains no quan- concept of the query graph.
tifier or function link, one or more of its concepts have
Theorem Let S be a set of conceptual schemata, q be a
values, one or more concepts have a question mark, and
query graph, and w be a working graph for q. If no con-
no concept has both a value and a question mark.
cepts in w have quantifiers or questionmarksand if
everyconceptandconceptual relation of q has been
The query graph is generated by the input analyzer covered by a join with some schema from S, then the
from theuser's original question.Theinputanalyzer values in w for the concepts of q having question marks
must have astarting set of well-formed conceptual arethesame as those obtained by joining q tosome
graphs that are compatible with the data base schemata: answer graph that covers it completely.
every starting graph used by the input analyzer must be
coverable by a join with some schema in the schematic Proof Let sl, sz, ' . ., by the sequence of schemata that
universe. This is a necessary condition for deriving an- were joined to q in deriving w. Observe that the criteria
swerablequerygraphs.It is not a sufficient condition for joininga schema to a working graph are stronger
because the user can always ask a question with incom- than the criteria fora schematic join; therefore, the sche-
pleteinformation; but, in that case, the system should mata sl, s2, . . . may bejoined by schematic joins to
prompt him for the missing information. each other in the same order and position that they were
joined in forming w. The result of these joins is a schema
Dejinition For a set of conceptual schemata S and a s that is isomorphic to w and contains the samecomposi-
query graph q, a working graph for q is any conceptual tion of function links used to derive w. Since w has no
graph that may be obtained by the following operations: quantifiers left, the query graph q must have had values
to assign to each universal quantifier of s, and the results
The querygraph q is a working graph for q. of evaluating the access proceduresmust have generated 351
JULY 1976 CONCEPTUAL GRAPHS
values for every existentially quantified concept. There- The preference rules are simply guidelines for choos-
fore, assign the valuesfrom q to the universalquanti- ing between alternative joins. If they require too much
fiers of s, and evaluate all access procedures to deter- computationfor aparticularimplementation, thenthe
mine values for the existentials; the result is an answer rules may be modified or replaced without fear of gener-
graph w’, which is isomorphic to w, has the same values ating incorrectanswers.One way of speedingup the
for corresponding concepts, but may have different sort search for preferred joins is to index the schemata ac-
labels because of the different order of performing re- cording to the concepts they contain: one index for the
strictions. Since the values generated for w satisfied all selectorconcepts of a schema, another for the target
the question marks of q, the same values of w’ must also concepts, and another for the source concepts. Then,
satisfy them. Therefore, a join of q to the answer graph instead of computing preference scores for all possible
w’ would cover q and assign the same values as w to the joins,thesystem could pick aquestionmark in the
question marksof q. query graph, look in the index for a target concept that
had a common subsort, and choosea join with that sche-
This theorem means that any algorithmobeying the
ma if its preference score was abovea given threshold.
conditions for deriving a working graph will generate a
correct answer to a query provided that the set of sche- Dejinition Let S be a set of schemata and q be a query
mata do not permit incorrect answer graphs. The next graph.Thenthe following procedurefor generating
definition states preference rules for choosing between working graphs for q is called algorithm C:
variouspossibleschematic joins. The preference rules w:= q ;
have no effect upon the correctness or incorrectness of while (there is a preferred joinj with W )
the answers generated; they are heuristic rules for en-
do begin
couraging joins that have a good chance of answering
w: = result of performing j with w;
the question while avoiding paths that are remote from
while (there is a source concept a in w
the original question.Thepreferencerules lead to
& a does not have a value
graphs with high ‘Isemantic density” as in the technique
& a does not have a question mark
of preference semantics that Wilks [32] developed for
& the target of a has a question mark)
analyzing natural language.
do place a question mark on a ;
Dejinition Let S be a set of schemata, q be a query while (there is a target concept b in w
graph, and w be a working graph for q. Then if j is any & b has a question mark
schematic join either of w with itself or of w with some & all sources of b have values)
schema in S, the preference score for the joinj with w is do get a value for b from its access procedure;
the sum of the points determined by the following condi- if (there are no question marks left in w
tions: and all of q has been covered by some join)
then begin
Add a point for each concept in w that is covered by j . print answer;
stop
Add an additional point for each concept in q that is
end
covered by j . If this value is zero, then reject j .
end.
If a concept in w having a question mark is covered by
If there are any question marks left on w and no pre-
a target of a function link, then add a point; if it is
ferred joins to perform, then each universally quantified
covered by a source of a function link, then subtract a
concept having a question mark is called a prompting
point.
point.
If a concept in w that has a value is covered by a A prompting point is where the system begins when it
source of afunctionlink,thanadd a point; if it is asks a question to get further information. This method
covered by a target of a function link, then reject j . of prompting is similar to Heidorn’s technique in his
For each conceptand conceptual relation in q that has simulation system. Withoutprompting, algorithm C is not
not yet been covered by any join, add a point if it is able to generateall possible answer graphs because each
covered by j . preferred join must cover at least one concept of the
querygraph;questionsthatrequireremotesearches
If every possible join has been rejected, then there is cannot be answered automatically. Furthermore, algo-
no preferred join. Otherwise, the one or more schematic rithm C does no backtracking; in cases where the set of
joinswith the highest preferencescoreare preferred schemata permit many possible combinations, the algo-
352 joins. rithm might try one combination that would preclude
JOHN F. SOWA IBM J . RES. DEVELOP.
others. If there are no question marks left on theworking
graph but not all of the query graph has been coveredby
some join, then either the original query contained ir-
relevant information or the system has found an alterna- I
tive path through the data base that answers a question AGE: ? TIME
different from the one the user asked. In such cases, too,
it would require help to get out of its predicament. Figure 20 Query graph for “What was Lee’s age whenhired?”
A system based on algorithm C would do what it was
told explicitly and whatever wasobviously implied by
what it was told. Whenever it could not find an obvious from another relation, and then call a function to sub-
solution to a problem, it would come back and ask for tract the two dates. A system having conceptual graphs
furtherinstructions. A systemthatsearchedone level for its user interface, however, could accept the question
deep would relieve the user of the need to specify much as stated in English and determine for itself what rela-
tedious detail, and it could still answer arbitrarily com- tions and procedures to access.
plex questions withsomeprompting.Although one Assumethatthe input analyzercantranslatethe
could relax the preference rules to let the system search user’s question into the query graph shown in Fig. 20.
deeper,further searching would increasethesystem The concept PERSON has the value Lee, and the value
overhead without substantially improving its usefulness. of A G E is to be determined. The conceptual relation
As the example in the next section shows, algorithm C CHRC has been borrowed from the TORUS system; it
can generate sophisticatedinferences without a great may be read “is a characteristic of.” To determine which
deal of searching. relation to insert between PERSONand AGE, the input
By computing an answer graph, the system can deter- analyzer would follow the rule that the preposition “of”
mine the state of some entitiesin the data basein answer or the possessive case marker ‘“s” indicates an unspeci-
to a specific question. If the user had asked a question fied relation betweentwonouns;theanalyzer would
containing Boolean connectives, the system would have search through its starting set of conceptual graphs and
to generate separate answers for each part of the ques- find CHRC as the defaultrelation between A G E and
tion andthen combinethemaccording to the type of PERSON.The conceptualrelation A T is used for
connective. If instead of asking about a specific entity moments of time; the relation LOC is used for spatial
such as PERSON:Lee, the question had been about all locations. The input analyzer will translatephrases of
persons having a certainattribute, then the system the form ‘‘X when y” into a graph were x and y are shown
should not compute an answer graphwith specific values to occur at the same time. Since“hired” is apassive
for the concepts; instead, it should generate a schema participle, PERS0N:Lee is linked asthe patient of
that could berepeatedlyevaluatedforeveryperson. HIRE; for the question “What was Lee’s age when hir-
Any method, such as algorithm C, that can be used to ing?” PERS0N:Lee would be the agent of HIRE.
generate specific answer graphs can also be used to de- Since the question mark on A G E cannot be propagat-
termine a schema simply by erasing the values on the ed anywhere, the system must find some schema to join
answer graph and saving the functional dependencies. A to the query graph. It naturally starts with the concept
schema with its access procedures is a specialized pro- AGE, which has the question mark, and searches for a
gram for answering query graphs of a particular shape; schema in which A G E is functionally dependenton
once the schema has been found, it can be evaluated for something that is computable. Figure 21 shows such a
every element of a set. With extensionsfor Boolean schema, which gives the definition of AGE. Associated
connectives and repeated evaluations over sets, concep- with this schema are access links to a data base relation
tual graphs could form the basis of a general data base for a person’s date of birth and an access procedure that
query facility. computes the difference of two dates.
The definition of AGE is in second normal form, but
Example not third normal form because there is a transitive de-
Suppose a computer user typed in the question “What pendency of A G E upon D A T E andthenupon PER-
was Lee’s age when hired?” If the system had a relation SON. The BIRTH relation in the data base, however,
for all employees and their ages at time of hire, it could may be stored in third normal form if convenient. This
immediately find the answer. In most systems, however, example illustrates the point that a schema may present
that question would not be asked often enough to justify a view of the data base different from the one that is ac-
space for everybody’s age when hired. To get an answer tually stored. Acomplex schemacansometimes im-
tothat simple question, the user would haveto find prove efficiency byreducing the number of steps in a
Lee’s date of birth from one relation, find his date of hire data base inference. 353
JULY 1976 CONCEPTUAL GRAPHS
Fig. 16 for the data base relation H I R E meets these cri-
DATE: V
/
teria, and a join with Fig. 16 is now the preferred join;
/
its preference score would be I 1. The schema in Fig. 2 1
could not be joined again to the working graph in the
same position as before, because a maximal join would
9 ,P
I cause two existential quantifiers to be joined, and such
\ I
BIRTH \ I DIFFERENCE joins are prohibited by the rules for a schematic join.
\
\
\ ‘\ When the schematic join of Figs. 16 and 23 is performed,
PERS0N:Lee is restricted toEMPL0YEE:Lee.The
t ‘\
L
\\ t
system must therefore check the data base to determine
whether Lee is an employee; if he is, the system can de-
DATE:E’ rive Fig. 24.
When the schema for H I R E is joined to the graph,the
question mark on DATE is propagatedback toEM-
Figure 21 Schema for defining AGE.
PL0YEE:Lee. Since the source of the functionalde-
pendency has avalue, the system can access the data
base to find Lee’s date of hire. Now both arguments of
PERSON AGE DATE
D I F F E R E N C E have values, and the access procedure
cancompute Lee’sage. Note that the HIRE schema
contains information about the manager, which is irrele-
Figure 22 Maximal common projection of Figs. 20 and 21 vant to the current question; since it is not needed, it
would not be evaluated. A good property of this tech-
nique is that schemata can be arbitrarily complex, and
Since DATE < TIME, Fig. 22 is a maximal common the system will simply ignore the unneeded information.
projection of the query graph with the schema in Fig. 21 Once the answer has been generated, the functional
having as a kernel the three concepts AGE. To compute dependencies in Fig. 24 are no longer needed. But if the
the preference score for the join onthis common projec- user wanted to know the agewhen hired for Smith,
tion, the system would add 3 points for the three con- Jones,andothers, then thesystem should savethe
ceptscovered by thejoin, 3 morepoints because all dependencies.Theconceptsandconceptual relations
three concepts are in the query graph, 1 point because a define the meaning of the domains and their interrela-
concept witha question mark is covered by atarget tionships; the functional dependencies are a data flow
concept, 1 point because a concept withavalue is graph for computing the actual values. If the same func-
covered by a source,and 5 extra points because five tion is to beevaluatedrepeatedly, thesystem could
concepts andconceptualrelations of thequery graph erase the current set of values and compute new values
that had not previously been covered are coveredby this using the same functional dependency graph. Foroptim-
join; thetotalpreference score is 13. A join with the ized execution, the system could even compile the func-
schema for HIRE (Fig. 16) would have a score of 12; it tional dependencies into COBOL or pL/I.
is almost as good, but the join with Fig. 21 is the pre-
ferred join. Towards a natural interface
The schematic join of Fig. 21 with the query graph is As a computer interface, English has beenmuch ma-
the workinggraph in Fig. 2 3 . In forming the join, the ligned for its supposed wordiness. Part of the blame for
universalquantifier onPERSON is replacedwith the the bad reputation must be borne by “English-like’’ lan-
value Lee, and the universally quantified concept D A T E guages, such as COBOL, which often do little but pad a
replaces the indefinite conceptTIME.Thequestion formalnotationwith English prepositions. Onequery
marks are propagated from targets to sources of func- language, for example, has the following notation:
tional dependencies, according to algorithm C.
SKILFILE JOBCODE EQ ‘ENG’
When the question mark reaches PERSON:Lee, the
SKILCODE EQ ‘GERMAN’
systemcan use theaccess links to find Lee’s date of
LOC EQ ‘NY’
birth from the data base. This value will satisfy one ar-
LIST EMPLOYEE MANNBR DEPT SVCYRS.
gument of DIFFERENCE. The other argument, how-
ever, has a question mark that cannot be propagated fur- The language has a macro facility that can provide an
ther. The system must find a schema in which the con- English-like interface. When the necessary macros have
cept DATE is functionally dependent on some concept beendefined, thesystem can translatethe following
354 thathas aknown (or computable) value. Theschema in English sentence into the above notation:
JOHN F. SOWA IBM J. RES. DEVELOP.
From the skills inventory get me the name, man number,
department, and years in service of the engineers with
knowledge of German located in the New York area.
For a practical system, such a half-hearted approach to
English is useless. Whereas macros generally reduce the
amount of typing,thismacro is 74% longerthan the
formalnotation. Furthermore,thephrase“Fromthe
skills inventory” may be easierto read than “SKIL-
\
\
t
\
FILE,” but it is no easier to remember. The macro lan- \
\
guage requires every phrase to be defined by a unique \
rule; “years in service” is translated to “SVCYRS” by
one rule, but “years of service” would require a separate
rule. A more natural interface should accept the follow-
ing request:
Forengineers in NewYorkwho know German, list
L
name, man no., dept., service years. Figure 23 Working graph.
This sentence is shorter than the formal notation and is
easier to read than the English-like macro. It is also eas-
ier for the user to learn because it omits the file name ””+ MANAGER:E‘
“SKILFILE” and does not use theodd abbreviations
“MANNBR” or “SVCYRS.” Because it omits the file /
/’
/
name, it cannot be translated to the formal notation by a
change of syntax; instead, the system must use semantic
mechanisms like theconceptualschema, which deter-
mine system dependencies as a result of processing the /””-””””””””””
7
English sentence.
Although theabove examplerequired fewer key-
strokes for the English syntax than for the formal nota-
tion, the primary advantage of natural language is not in
syntax but in semantics. Duringa conversation,the
most importantsemanticfeaturesappear in dialogue,
inference, and metalanguage:
Dialogue Natural languages are used in adialogue
where both parties contribute to the conversation and
ask questions to clarify or expand an incomplete mes-
sage.
Inference Mostsentences canbe short andsimple
becausethe listener is expectedto fill in the“ob- Figure 24 Finalworking graph.
vious” gaps. A complete theorem proving system is
not necessary to understand English, but a technique
for inferring the obvious is essential. guage. Prompting methodshavealready been men-
tioned, and many of Heidorn’s dialogues can be adapted
Metalanguage English is its own metalanguage. It can
to conceptual graphs with little more than a change of
be used either to talk about a subject or to talk about
notation. For help facilities, the same conceptual sche-
what can besaid about the subject; it can therefore
mata used to access the data base couldbetranslated
support prompting and help facilities in the same lan-
into English sentencestoanswer auser’s questions
guage used for queries and programming.
about command and data formats. By using thesame
These three features of natural language are the areas schematafor accessing dataandfor generating mes-
where conceptual graphs can make the biggest contribu- sages,thesystem would guaranteethatthe diagnostic
tion. Inference was emphasized in this paper, but con- and help facilities would always be consistent with the
ceptual graphs can also help in dialogues and metalan- implementation. 355
JULY 1976 CONCEPTUAL GRAPHS
Codd [33] emphasized the importance of anatural be used directly by the data base designer for represent-
language interface for thecasual user. Yet even the most ing and analyzing relationships between various domains
experienced system programmerswrite comments in in the data base; displays and plotters could present the
their native language because they find it more under- graphs for a two-dimensional view of the data base. The
standable and expressive than a programming language. designer could see the graphs on a display, but the end
The same properties that make English good for queries user would not be aware of them. Instead, conceptual
also make it good for programming: the abilities to sup- graphs could support an interface that would let the user
port a dialogue for problemdefinition, to take care of talk about familiar data in a familiar terminology without
machine dependent details without the user’s assistance, the need for special query languagesand computer-
and to answer questions about formats and conventions. oriented conventions.
A program to be executed in batch mode, where perfor-
mance is critical, should not go through an interpretive Acknowledgment
naturallanguageinterface for every data base access; The ideas in this paper have evolved over a long period
instead, the programmer could use that interface while of time and have benefited from suggestions by numer-
writing the program and then have the system compile ous friendsandcolleagues. I especiallythank J. M.
the accesses into a standard language for optimized exe- Cadiou, A. K. Chandra, E. F. Codd, R. L. Griffith, G. E.
cution. Heidorn, H. D. Mills, C. P. Wang, and M. Wilson from
Suppose a programmer asked “Give me a COBOL pro- IBM, L. G. Creary, professor of philosophy atCase
cedure to compute a person’s age when hired.” For this Western Reserve University, and the tinknown referees
case, the system would not derive an answer graph from who forced me to make this a better paper.
the data base. Instead, it would derive a general schema This paper contains some material from a forthcoming
for computing age when hired foranyperson.Every book entitled Conceptual Structures: Informution Pro-
schema in the schematic universe is a general function. cessing in Mind and Machine to bepublished by the
For a one-shot query, the system uses the schema only Addison-Wesley Publishing Co. as one volume in the
once; but for automatic programming, the system could IBM Systems Programming Series.
compute a schema as though it were answering a query
and then translate the schema into a program. Instead of
References and notes
immediately executing the calls upon access procedures,
1. E. F. Codd, “A Relational Model of Data for Large Shared
the system could compile them into COBOL statements, Data Banks,” Commun. ACM 13, 377 (1970).
which the programmer could insert into a program for 2. N. Roussopoulos and J. Mylopoulos, “Using Semantic
batch execution. The programmer could use the query Networks for Data Base Management,” Proceedings of the
InternationalConference on Very Large Datu Bases,
facility as a programming assistant that would handle the ACM, New York, 1975, p. 144.
machine dependent details of data base accesses. 3. C . E. Heidorn, “Automatic Programming through Natural
For a system of distributed computers,conceptual Language Dialogue,” IBM J . Res. Dev~4op.20, 302 (1976,
this issue).
graphs can support a clean separation between the mes- 4. Comp//tcr Modc.1~ of Thought d n d Lunguuge, edited by
sage handling and thedatabaseaccesses.Instead of R. C. Schank and K. M. Colby, W. H. Freeman and Com-
calling the access procedures for each value requested pany, San Francisco, 1973.
5. Representation and Understanding:Studies in Cognitive
for some target concept, algorithm C could be modified Science, edited by D. C. Bobrow and A. Collins, Academic
to make all of the accesses at the end of the derivation. Press, New York, 1975.
If the data base processor is in a different computer from 6. M. M. Astrahan and D. D. Charnberlin,“Implementation
of a Structured English Query Language,” Cornmun.
the input analyzer, all of the prompting and interaction A C M 18, 580 (1975).
could be handled by a local computer, and only a list of 7. R. F. Boyce, D. D. Chamberlin, W. F. King, and M. M.
specific accesses would need to be sent to the data base Hammer, “Specifying Queriesas Relational Expressions:
The SQUARE Data Sublanguage,” Cornmun. ACM 18,
processor. This separation would be especially useful if 621 (1975 j .
the data base had a relatively small number of relations, 8. M. M. Zloof, “Query by Example,” A F l P S Con$ Proc.,
but a very large number of entries in each relation:a N u t . Comput. Conj:, 1975 p. 43 I .
9. Note that an employee number is not a common subsort of
computer that did message handling would only need a EMPLOYEE and NUMBER. Instead, it is a subsort of
few schemata that could be stored on an ordinary disk, NUMBERthatbears a particularrelationship toEM-
but the data base processor would require a mass stor- PLOYEE.
10. C. J . Fillmore, “The Case for Case,” Univc~rsalsin Linguis-
age facility. tic Theory, edited by E. Bach and R. T. Harms, Holt,Rine-
Conceptual graphs are precise enough to support logi- hart and Winston, New York, p. 1.
cal inferences and data base accesses, yet they are rich 1 1 . In themore complete theory, presented in aforthcoming
book [27], there is only one primitive conceptual relation,
enough and flexible enough to serve as a semantic basis named LINK. All others are defined by the process of rela-
356 for natural language. As a formal notation,thegraphscan tional abstraction, which is essentially the lambda calculus
JOHN F. SOWA I B M J. RES. DEVELOP.
generalized to graphs. This paper, however, presents a re- 24. Interim Report, A N S I / X 3 / S P A R C , Study Group on Data
stricted version of the formalism, in which the conceptual Base ManagementSystems, reprinted in F D T , ACM-
relations are fixed in advance. SIGMOD 7, 1975.
12. A. Schmidt, “Uber deduktive Theorien mit mehreren Sor- 25. L. Wittgenstein, Tractatus Logico-Philosophicus, Routledge
ten von Grunddingen,” Mrrth. Ann. 115, 485 (1938). and Kegan Paul, London.
13. H. Wang, “The Logic of Many-Sorted Theories,” J . of 26. P. C . Wason and P. N. Johnson-Laird, Psychology of Rea-
Symbolic Logic 17, 105 (1952). soning, B. T. Batsford, London, 1972.
14. J. J. Katz and J. A. Fodor, “The Structure of a Semantic 27. J. F. Sowa, Conceptual Structures: Information Processing
Theory,” Language 39, I 70 ( 1963). in Mind and Machine, Addison-Wesley, Reading, Mass., to
15. For a study of the increased expressive power introduced be published.
by such a notation, see W. J . Walker, “Finite Partially Or- 28. W. J. Plath, “REQUEST: A Natural-Language Question-
dered Quantification,” J . Symbolic Logic 35, 535 ( 1970). Answering System,” I B M J . Res. Develop. 20, 326 (1976,
16. A standard technique in methods of theorem proving is to this issue).
replaceexistentialquantifiers with Skolem functions,cf. 29. S. R. Petrick, “On Natural Language Based Computer Sys-
J. A. Robinson, “A Machine-Oriented Logic Based on the tems,” IBM J . Res. Develop. 20, 3 14 ( 1976, this issue).
ResolutionPrinciple,” J . Assoc. Comput.Much. 12, 23 30. G. E. Heidorn, “English as a Very HighLevelLanguage
( 1965). As ageneral method of representingquantifiers, for Simulation Programming,” Proceedings of the Sympo-
however, this technique fails because the resulting formula sium on Very High Level Languages, SIGPLAN Notices
is no longer equivalent to the original. When an existential 9, (April 1974), p. 91.
quantifier specifies a unique entity, however, then the lines 31. Readerswhoare familiar withtheresolutionprinciple
of scope determine auniquefunction, and the functional should notethe parallels betweenschematicjoinsand
form is equivalent to the quantifier notation. Robinson’s unification algorithm [ 161. Both techniques in-
17. W. A. Woods, “Procedural Semantics for a Question-An- volve universally quantified functionalcompositions and the
swering Machine,” AFIPS Con$Proc.,Fall .It. Comput. set of all possible answer graphsis theanalog of the Herbrand
Conf., 1968 p. 457. universe.AlgorithmC may be interpreted as a heuristic
18. T. Winograd, “Frame Representations and the Declarative- method for finding an element of the Herbrand universe
Procedural Controversy,” Representation and Understand- that answers the user’s question.
ing: Studies in Cognitive Science, edited by D. G. Bobrow 32. Y. Wilks, “An Intelligent Analyzer and Understander of
and A. Collins, Academic Press, New York, 1975. English,” Commun. A C M 18, 264 ( 1975).
19. R. W. Weyhrauch andA. J. Thomas,“FOL: aProof 33. E. F. Codd, “Seven Steps to Rendezvous with the Casual
Checker for First-Order Logic,” Memo AIM-235, Stanford User,” Data Base Munagement, edited by J. W. Klimbie
Artificial Intelligence Laboratory, NTIS #AD/ A-006 898, and K. L. Koffeman, North-Holland Publishing Co., Am-
1974. sterdam, (1974) p. 179.
20. See Codd [ I ] , p. 385, for a discussion of the connection
trap.
21. J. E. J. Altham and N . W. Tennant, “SortalQuantifica-
tion,” Formal Semantics of Natural Language, edited by
E. L. Keenan,Cambridge University Press, p. 46. Received April 2, 1975; revised Februury 23, 1976
22. E. F. Codd, “Further Normalization of the Data Base Re-
lational Model,” Data Base Systems, edited by R. Rustin,
Prentice-Hall, Englewood Cliffs, N.J., 1972, p. 33.
23. A greater-than join of two data baserelations could be repre-
sented by joining their schemata with the schema for the Theuuthor is locatedatthe I B M SystemsReseurch
greater-than relation. Institute, 219 E . 42nd Street, N e w York, N Y 1001 7.
357
JULY 1976 CONCEPTUAL GRAPHS