RSS    

   Реферат: Программирование на языке CLIPS

Обратите внимание, что поля claim и reason имеют квалификатор multifield, поскольку они могут содержать несколько элементов данных (более подробно об этом рассказано в Руководстве пользователя).

Однако недостаточно только представить в программе высказывания персонажей – нам понадобиться также выявить суть содержащихся в них утверждений. Далее, приняв определенное предположение о правдивости или лживости персонажа, которому принадлежит высказывание, можно построить гипотезу об истинности или лживости этого утверждения. С каждым таким утверждением свяжем уникальный числовой идентификатор.

;; Утверждение, смысл которого, например,

;; состоит в следующем,

;; Т А . . . .  означает, что А правдолюбец;

;; F А . . . . означает, что А лжец.

;; Утверждение может иметь под собой

;; основание (reason) – обычно это тэг

;; высказывания (объекта statement) или тэг

;; другого утверждения (объекта claim).

;; Утверждение также характеризуется признаком scope,

;; который может принимать значение «истина» или «ложь».

(deftemplate claim

           (multifield content (type SYMBOL))

           (multifield reason (type INTEGER) (default 0))

           (field scope  (type SYMBOL))

)

Например, раскрыв содержимое приведенного выше высказывания в предположении, что А говорит правду, получим следующие утверждение (объект claim):

(claim (content F A) (reason 1) (scope truth)).

Таким образом, объект claim наследует содержимое от объекта statement. Последний становится обоснованием (reason) данного утверждения. Поле scope объекта claim принимает значение предположения о правдивости или лживости этого высказывания.

Еще нам потребуется представление в программе того мира (world), в котором мы в настоящее время находимся. Объекты world порождаются в момент, когда мы формируем определенные предположения. Нужно иметь возможность различать разные множества предположений и идентифицировать их в программе в тот момент, когда процесс размышлений приводит нас к противоречию. Например, противоречие между высказываниями Т(А) и F(A) отсутствует, если они истинны в разных мирах, т.е. при разных предположениях. Если у вас есть сомнения на сей счет, вернитесь вновь к примерам в самом начале раздела А.4.

Миры будем представлять в программе следующим образом:

;; Объект world представляет контекст,

;; сформированный определенными предположениями

;; о правдивости или лживости персонажей.

;; Объект имеет уникальный идентификатор в поле tag,

;; а смысл допущения – истинность или лживость –

;; фиксируется в поле scope.

(deftemplate world

          (field tag (type INTEGER) (default 1))

          (field scope (type SYMBOL) (default truth))

)

Обратите внимание на то, что при указанных в шаблоне значениях по умолчанию мы можем начинать каждый процесс вычислений с объекта world, имеющего в поле значение 1, причем этот «мир» можно заселить высказываниями персонажей, которых мы предположительно считаем правдолюбцами. Таким образом можно инициализировать базу фактов the-facts для задачи Р0 следующим образом:

;; Утверждение, что А лжец.

(deffacts the-facts

          (world)

          (statement (speaker A)  (claim F A))

)

Если этот оператор deffacts будет включен в тот же файл, что и объявления шаблонов (а также правила, о которых речь пойдет ниже), то после загрузки этого файла в среду CLIPS нам понадобится для запуска программы дать только команду reset.

А.4.3. Разработка правил

В этом разделе мы рассмотрим набор правил, который помогает справиться с вырожденной формулировкой Р0 задачи о лжецах и правдолюбцах. Первые два правила, unwrap-true и unwrap-false, извлекают содержимое высказывания в предположении, что персонаж, которому принадлежит высказывание, является соответственно правдолюбцем или лжецом, и на этом основании формируют объект claim.

;; Извлечение содержимого высказывания.

(defrule unwrap-true

         (world (tag ?N)  (scope truth))

         (statement (speaker ?X)  (claim $?Y)  (tag ?N))

=>

         (assert (claim (content T ?X) (reason ?N)

                         (scope truth)))

         (assert (claim (content $?Y) (reason ?M)

                         (scope truth)))

)

(defrule unwrap-false

         (world (tag ?N)  (scope falsity))

         (statement (speaker ?X)  (claim $?Y)  (tag ?N))

=>

         (assert (claim (content F  ?X)  (reason ?N)

                (scope falsity)))

         (assert (claim (content NOT $?Y)  (reason ?N)

                 (scope falsity))

)

В каждом из приведенных правил первый оператор в условной части делает предположение соответственно о правдивости или лживости персонажа, а второй оператор в заключительной части правила распространяет предположение на формируемые утверждения – объекты claim.

Далее нам понадобятся правила, которые введут отрицания в выражения. Поскольку –Т(А) эквивалентно F(A),а –F(A) эквивалентно Т(А), то правила, выполняющие соответствующие преобразования, написать довольно просто. Анализ результатов применения этих правил значительно упростит выявление противоречий, следующих из определенного предположения.

;; Правила отрицания

(defrule not1

        ?F <- (claim (content NOT T ?P))

=>

        (modify ?F (content F ?P))

)

(defrule not2

        ?F <- (claim (conteny NOT F ?P))

=>

        (modify ?F (content T ?P))

)

;; Выявление противоречия между предположением о

;; правдивости и следующими из него фактами.

(defrule contra-truth

         (declare (salience 10))

         ?W <- (world (tag ?N) (scope truth))

         ?S  <- (statement (speaker ?Y) (tag ?N))

         ?P  <- (claim (content T ?X) (reason ?N) (scope truth))

         ?Q <- (claim (content F ?X)  (reason ?N) (scope truth))

=>

         (printout t crlf

                  “Statement is inconsistent if “ ?Y “ is a knight.”

;; “Высказывание противоречиво, если “ ?Y “ правдолюбец.”

     t crlf)

     (retract ?Q)

     (retract ?P)

     (modify ?W (scope falsity))

)

Если предположить, что исходное высказывание было правдивым, то в дальнейшем обнаруживается противоречивая пара утверждений, которые затем удаляются из рабочей памяти, а значение «правдивости» предположения в объекте world изменяется на falsity (лживость). Если же после этого также будет обнаружено противоречие, то мы приходим к выводу о глобальной несовместимости условий задачи, т.е. в данной постановке мы имеем дело с логическим парадоксом.

;; Выявление противоречия между предположениями о

;; лживости и следующими из него фактами.

(defrule contra-falsity

        (declare (salience 10))

        ?W <- (world (tag ?N) (scope falsity))

        ?S   <- (statement (speaker ?Y) (tag ?N))

        ?P   <- (claim (content F ?X) (reason ?N) (scope falsity))

        ?Q  <- (claim (content T ?X) (reason ?N) (scope falsity))

=>

 (printout t crlf

  “Statement is inconsistent if “ ?Y “ is a knave.”

;; “Высказывание противоречиво, если “ ?Y “ лжец.”

     t crlf)

     (modify ?W (scope contra))

)

Правило sweep обеспечивает проверку, все ли следствия из неверного предположения удалены из памяти.

;; Удалить из базы фактов все утверждения,

;; которые следуют из предположения о правдивости.

(defrule sweep

      (declare (salience 20))

      (world (tag ?N) (scope falsity))

      ?F <- (claim (reason ?N) (scope truth))

=>

      (retract ?F)

)

Обратите внимание на то, что правила contra-truth, contra-falsity и sweep имеют более высокий приоритет (значение параметра salience), чем другие правила. Этим обеспечивается как можно более ранее обнаружение противоречия, а следовательно, и удаление из базы фактов утверждений, сделанных на основе предположения, приведшего к противоречию.

Если теперь запустить на выполнение программу, представив ей исходный набор фактов, соответствующих условию задачи Р0, то программа обнаружит, что оба контекста противоречивы. Другими словами, независимо от того, предполагаем ли мы, что А говорит правду или лжет, программа обнаружит противоречие в контексте world. Трассировка программы в этом случае представлена в листинге А.1. Строки, выведенные курсивом, - сообщения основной программы, а прочие – сообщения программы трассировки. Для удобства строки, указывающие на активизацию правил, представлены полужирным шрифтом.

Листинг А.1. Трассировка решения задачи Р0

CLIPS> (reset)

= => f-0  (initial-fact)

= => f-1  (world (tag 1) (scope truth))

= => f-2  (statement (speaker A) (claim F A) (reason 0) (tag 1))

CLIPS> (run)

FIRE 1 unwrap-true: f-1,f-2

Assumption:

          A is a knight, so (T A) is true.

= => f-3  (claim (content F A) (reason 1) (scope truth))

= => f-4  (claim (content T A) (reason 1) (scope truth))

FIRE 2 contra-truth: f-1, f-2, f-4, f-3

Statement is inconsistent if A is a knight.

<= = f-3  (claim (content F A) (reason 1) (scope truth))

<= = f-4  (claim (content T A) (reason 1) (scope truth))

<= = f-1  (world (tag 1) (scope truth))

= => f-5  (world (tag 1) (scope falsity))

FIRE 3 unwrap-false: f-5, f-2

Assumption

A is a knave, so (T A) is false.

Страницы: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14


Новости


Быстрый поиск

Группа вКонтакте: новости

Пока нет

Новости в Twitter и Facebook

                   

Новости

© 2010.