This paper discusses a language and associated environment for building rule-based programs. The language and environment are encapsulated in a system we call ORBS (Oregon Rule Based System). In tune with this conference, our focus will be on the interplay between language and environment design. However, we will broaden this somewhat to include design constraints placed by our program development model 1 as well. Instead of attempting a complete design rationalization of ORBS, we will concentrate on design decisions that highlight the coupling between language, environment, and development model. ORBS falls in the class of rule-based systems that often is categorized as forward-chaining or data-driven. Other systems in this category include OPS5 [9], YAPS [2], and all of the Hearsay family [5, 11, 15]. What is often taken as the inverse of this set are the backward-chaining or goal-directed languages such as EMYCIN [17]. Arguments for and against the forward and backward approaches have been made many times elsewhere (see [12] for examples of each), and we will not address the issue further in this paper. 2 While we believe that many of the arguments we make for the design of ORBS are applicable to rule-based systems in general, any reference to the term rule-based should be taken in light of the classification above.
[1]
James W. Goodwin,et al.
Why Programming Environments Need Dynamic Data Types
,
1981,
IEEE Transactions on Software Engineering.
[2]
William van Melle,et al.
A Domain-Independent Production-Rule System for Consultation Programs
,
1979,
IJCAI.
[3]
Barbara Hayes-Roth.
BB1: an architecture for blackboard systems that control, explain, and learn about their own behavior
,
1984
.
[4]
Frederick Hayes-Roth,et al.
Building expert systems
,
1983,
Advanced book program.
[5]
Stephen Fickas,et al.
The Design and an Example Use of Hearsay-III
,
1981,
IJCAI.
[6]
Janice Sue Aikins,et al.
Prototypes and production rules : a knowledge representation for computer consultations
,
1980
.