0
次のルールから2つのテスト条件要素を削除し、その可読性を向上させたいと思います。CLIPS句相互依存
(defrule compare-things
(logical ?thing0 <- (object (is-a TYPED_THING)
(type-results $? ?t0 $?)))
(logical ?thing1 <- (object (is-a TYPED_THING)
(type-results $? ?t1 $?)))
(thing-comparable ?type)
?type0 <- (object (is-a TYPING)
(qualified-type ?type ?model ?mode ?comp0))
?type1 <- (object (is-a TYPING)
(qualified-type ?type ?model ?mode ?comp1))
; This test exists to restrict the number of rule firings
(test (> (str-compare (instance-name ?thing0) (instance-name ?thing1)) 0))
; Ideally, the following two tests can be removed
(test (= (str-compare (instance-name ?type0) (instance-name ?t0)) 0))
(test (= (str-compare (instance-name ?type1) (instance-name ?t1)) 0))
=>
(make-instance of COMPARISON
(compares ?thing0 ?thing1)
(score nil)
)
(printout t "comparing: " (instance-name ?thing0) (instance-name ?thing1) crlf)
)
マルチスロットフィールドは?t0
と?t1
は?type0
と?type1
同じインスタンスに対応する値。私は(直感的に最初の試みである)?t0
と?t1
?type0
とし、?type1
を交換した場合、ルールのロード中に、私は次のエラーが表示されます
Defining defrule: compare-things
[ANALYSIS2] Pattern-address ?type0 used in CE #4 was previously bound within a pattern CE.
[ANALYSIS2] Pattern-address ?type1 used in CE #5 was previously bound within a pattern CE.
ERROR:
(defrule MAIN::compare-things
(logical
?thing0 <- (object (is-a TYPED_THING)
(type-results $? ?type0 $?)))
(logical
?thing1 <- (object (is-a TYPED_THING)
(type-results $? ?type1 $?)))
(thing-comparable ?type)
?type0 <- (object (is-a TYPING)
(qualified-type ?type ?model ?mode ?comp0))
?type1 <- (object (is-a TYPING)
(qualified-type ?type ?model ?mode ?comp1))
(test (> (str-compare (instance-name ?thing0) (instance-name ?thing1)) 0))
=>
(make-instance of COMPARISON
(compares ?thing0 ?thing1)
(score nil))
(printout t "comparing: " (instance-name ?thing0) (instance-name ?thing1) crlf))
FALSE
次のデータが開発中のルールを刺激するために使用されています 次の出力を生成しなければならない
(defclass TYPING (is-a USER)
(role concrete)
(multislot qualified-type (access initialize-only)
(type STRING)
(cardinality 4 4))
(slot score (access initialize-only)
(type FLOAT))
)
(defclass TYPED_THING (is-a USER)
(slot id (access initialize-only)
(type INTEGER))
(multislot type-results (access initialize-only)
(type INSTANCE)) ; of TYPING
)
(defclass COMPARISON (is-a USER)
(multislot compares (access initialize-only)
(type INSTANCE) ; of TYPED_THING
(cardinality 2 2))
(slot score (access read-write)
(type FLOAT))
)
; These facts tag top-level types that are comparable
(deffacts KNOWN_COMPARABLE_TYPES
(thing-comparable "cat-a")
(thing-comparable "cat-c")
)
(definstances KNOWN_THINGS
(thing0 of TYPED_THING
(id 0)
(type-results (make-instance of TYPING (qualified-type "cat-a" "x0" "y0" "z0")(score 0.9))
(make-instance of TYPING (qualified-type "cat-b" "x0" "y0" "z0")(score 0.9))))
(thing1 of TYPED_THING
(id 1)
(type-results (make-instance of TYPING (qualified-type "cat-a" "x0" "y0" "z1")(score 0.9))
(make-instance of TYPING (qualified-type "cat-a" "x1" "y1" "z0")(score 0.9))))
(thing2 of TYPED_THING
(id 2)
(type-results (make-instance of TYPING (qualified-type "cat-b" "x0" "y0" "z1")(score 0.9))))
)
(それが現在そうであるよう):
CLIPS> (reset)
CLIPS> (run)
comparing: [thing1][thing0]
これはまさに私が探していたものです。私はインスタンス上の 'name'スロットを認識していませんでした。 –